From b958386689e63a48446e574326eb31ad924783a3 Mon Sep 17 00:00:00 2001 From: Abdelkarim Habouch <37211852+karimhabush@users.noreply.github.com> Date: Sat, 13 May 2023 22:28:30 +0100 Subject: [PATCH] Add Edge browser support using EdgeChromiumDriverManager (#3058) Co-authored-by: Nicholas Tindle Co-authored-by: k-boikov <64261260+k-boikov@users.noreply.github.com> --- .env.template | 2 +- autogpt/commands/web_selenium.py | 7 +++++++ 2 files changed, 8 insertions(+), 1 deletion(-) diff --git a/.env.template b/.env.template index a32bf936eece..aba612fd7a4d 100644 --- a/.env.template +++ b/.env.template @@ -192,7 +192,7 @@ OPENAI_API_KEY=your-openai-api-key ### BROWSER ## HEADLESS_BROWSER - Whether to run the browser in headless mode (default: True) ## USE_WEB_BROWSER - Sets the web-browser driver to use with selenium (default: chrome). -## Note: set this to either 'chrome', 'firefox', or 'safari' depending on your current browser +## Note: set this to either 'chrome', 'firefox', 'safari' or 'edge' depending on your current browser # HEADLESS_BROWSER=True # USE_WEB_BROWSER=chrome ## BROWSE_CHUNK_MAX_LENGTH - When browsing website, define the length of chunks to summarize (in number of tokens, excluding the response. 75 % of FAST_TOKEN_LIMIT is usually wise ) diff --git a/autogpt/commands/web_selenium.py b/autogpt/commands/web_selenium.py index 8cec23238d9e..4f5ad30ea598 100644 --- a/autogpt/commands/web_selenium.py +++ b/autogpt/commands/web_selenium.py @@ -10,6 +10,7 @@ from selenium.common.exceptions import WebDriverException from selenium.webdriver.chrome.options import Options as ChromeOptions from selenium.webdriver.common.by import By +from selenium.webdriver.edge.options import Options as EdgeOptions from selenium.webdriver.firefox.options import Options as FirefoxOptions from selenium.webdriver.remote.webdriver import WebDriver from selenium.webdriver.safari.options import Options as SafariOptions @@ -17,6 +18,7 @@ from selenium.webdriver.support.wait import WebDriverWait from webdriver_manager.chrome import ChromeDriverManager from webdriver_manager.firefox import GeckoDriverManager +from webdriver_manager.microsoft import EdgeChromiumDriverManager import autogpt.processing.text as summary from autogpt.commands.command import command @@ -78,6 +80,7 @@ def scrape_text_with_selenium(url: str) -> tuple[WebDriver, str]: "chrome": ChromeOptions, "safari": SafariOptions, "firefox": FirefoxOptions, + "edge": EdgeOptions, } options = options_available[CFG.selenium_web_browser]() @@ -96,6 +99,10 @@ def scrape_text_with_selenium(url: str) -> tuple[WebDriver, str]: # Requires a bit more setup on the users end # See https://developer.apple.com/documentation/webkit/testing_with_webdriver_in_safari driver = webdriver.Safari(options=options) + elif CFG.selenium_web_browser == "edge": + driver = webdriver.Edge( + executable_path=EdgeChromiumDriverManager().install(), options=options + ) else: if platform == "linux" or platform == "linux2": options.add_argument("--disable-dev-shm-usage")