[{"data":1,"prerenderedAt":-1},["ShallowReactive",2],{"project-2405":3},{"id":4,"name":5,"fullName":6,"owner":7,"repo":5,"description":8,"homepage":9,"htmlUrl":10,"language":11,"languages":10,"totalLinesOfCode":10,"stars":12,"forks":13,"watchers":14,"openIssues":15,"contributorsCount":16,"subscribersCount":16,"size":16,"stars1d":17,"stars7d":18,"stars30d":19,"stars90d":16,"forks30d":16,"starsTrendScore":20,"compositeScore":21,"rankGlobal":10,"rankLanguage":10,"license":22,"archived":23,"fork":23,"defaultBranch":24,"hasWiki":23,"hasPages":23,"topics":25,"createdAt":10,"pushedAt":10,"updatedAt":42,"readmeContent":43,"aiSummary":44,"trendingCount":16,"starSnapshotCount":16,"syncStatus":45,"lastSyncTime":46,"discoverSource":47},2405,"skyvern","Skyvern-AI\u002Fskyvern","Skyvern-AI","Automate browser based workflows with AI","https:\u002F\u002Fwww.skyvern.com",null,"Python",21889,2035,101,38,0,18,68,318,71,44.93,"GNU Affero General Public License v3.0",false,"main",[26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41],"ai","api","automation","browser","browser-automation","computer","gpt","llm","playwright","powerautomate","puppeteer","python","rpa","selenium","vision","workflow","2026-06-12 02:00:41","\u003C!-- DOCTOC SKIP -->\n\n\u003Ch1 align=\"center\">\n \u003Ca href=\"https:\u002F\u002Fwww.skyvern.com\">\n  \u003Cpicture>\n    \u003Csource media=\"(prefers-color-scheme: dark)\" srcset=\"fern\u002Fimages\u002Fskyvern_logo.png\"\u002F>\n    \u003Cimg height=\"120\" src=\"fern\u002Fimages\u002Fskyvern_logo_blackbg.png\"\u002F>\n  \u003C\u002Fpicture>\n \u003C\u002Fa>\n \u003Cbr \u002F>\n\u003C\u002Fh1>\n\u003Cp align=\"center\">\n🐉 Automate Browser-based workflows using LLMs and Computer Vision 🐉\n\u003C\u002Fp>\n\u003Cp align=\"center\">\n  \u003Ca href=\"https:\u002F\u002Fwww.skyvern.com\u002F\">\u003Cimg src=\"https:\u002F\u002Fimg.shields.io\u002Fbadge\u002FWebsite-blue?logo=googlechrome&logoColor=black\"\u002F>\u003C\u002Fa>\n  \u003Ca href=\"https:\u002F\u002Fwww.skyvern.com\u002Fdocs\u002F\">\u003Cimg src=\"https:\u002F\u002Fimg.shields.io\u002Fbadge\u002FDocs-yellow?logo=gitbook&logoColor=black\"\u002F>\u003C\u002Fa>\n  \u003Ca href=\"https:\u002F\u002Fdiscord.gg\u002FfG2XXEuQX3\">\u003Cimg src=\"https:\u002F\u002Fimg.shields.io\u002Fdiscord\u002F1212486326352617534?logo=discord&label=discord\"\u002F>\u003C\u002Fa>\n  \u003C!-- \u003Ca href=\"https:\u002F\u002Fpepy.tech\u002Fproject\u002Fskyvern\" target=\"_blank\">\u003Cimg src=\"https:\u002F\u002Fstatic.pepy.tech\u002Fbadge\u002Fskyvern\" alt=\"Total Downloads\"\u002F>\u003C\u002Fa> -->\n  \u003Ca href=\"https:\u002F\u002Fgithub.com\u002Fskyvern-ai\u002Fskyvern\">\u003Cimg src=\"https:\u002F\u002Fimg.shields.io\u002Fgithub\u002Fstars\u002Fskyvern-ai\u002Fskyvern\" \u002F>\u003C\u002Fa>\n  \u003Ca href=\"https:\u002F\u002Fgithub.com\u002FSkyvern-AI\u002Fskyvern\u002Fblob\u002Fmain\u002FLICENSE\">\u003Cimg src=\"https:\u002F\u002Fimg.shields.io\u002Fgithub\u002Flicense\u002Fskyvern-ai\u002Fskyvern\"\u002F>\u003C\u002Fa>\n  \u003Ca href=\"https:\u002F\u002Ftwitter.com\u002Fskyvernai\">\u003Cimg src=\"https:\u002F\u002Fimg.shields.io\u002Ftwitter\u002Ffollow\u002Fskyvernai?style=social\"\u002F>\u003C\u002Fa>\n  \u003Ca href=\"https:\u002F\u002Fwww.linkedin.com\u002Fcompany\u002F95726232\">\u003Cimg src=\"https:\u002F\u002Fimg.shields.io\u002Fbadge\u002FFollow%20 on%20LinkedIn-8A2BE2?logo=linkedin\"\u002F>\u003C\u002Fa>\n\u003C\u002Fp>\n\n[Skyvern](https:\u002F\u002Fwww.skyvern.com) automates browser-based workflows using LLMs and computer vision. It provides a Playwright-compatible SDK that adds AI functionality on top of playwright, as well as a no-code workflow builder to help both technical and non-technical users automate manual workflows on any website, replacing brittle or unreliable automation solutions.\n\n\u003Cp align=\"center\">\n  \u003Cimg src=\"fern\u002Fimages\u002Fgeico_shu_recording_cropped.gif\"\u002F>\n\u003C\u002Fp>\n\nTraditional approaches to browser automations required writing custom scripts for websites, often relying on DOM parsing and XPath-based interactions which would break whenever the website layouts changed.\n\nInstead of only relying on code-defined XPath interactions, Skyvern relies on Vision LLMs to learn and interact with the websites.\n\n# How it works\nSkyvern was inspired by the Task-Driven autonomous agent design popularized by [BabyAGI](https:\u002F\u002Fgithub.com\u002Fyoheinakajima\u002Fbabyagi) and [AutoGPT](https:\u002F\u002Fgithub.com\u002FSignificant-Gravitas\u002FAutoGPT) -- with one major bonus: we give Skyvern the ability to interact with websites using browser automation libraries like [Playwright](https:\u002F\u002Fplaywright.dev\u002F).\n\nSkyvern uses a swarm of agents to comprehend a website, and plan and execute its actions:\n\n\u003Cpicture>\n  \u003Csource media=\"(prefers-color-scheme: dark)\" srcset=\"fern\u002Fimages\u002Fskyvern_2_0_system_diagram.png\" \u002F>\n  \u003Cimg src=\"fern\u002Fimages\u002Fskyvern_2_0_system_diagram.png\" \u002F>\n\u003C\u002Fpicture>\n\nThis approach has a few advantages:\n\n1. Skyvern can operate on websites it's never seen before, as it's able to map visual elements to actions necessary to complete a workflow, without any customized code\n1. Skyvern is resistant to website layout changes, as there are no pre-determined XPaths or other selectors our system is looking for while trying to navigate\n1. Skyvern is able to take a single workflow and apply it to a large number of websites, as it's able to reason through the interactions necessary to complete the workflow\nA detailed technical report can be found [here](https:\u002F\u002Fwww.skyvern.com\u002Fblog\u002Fskyvern-2-0-state-of-the-art-web-navigation-with-85-8-on-webvoyager-eval\u002F).\n\n# Demo\n\u003C!-- Redo demo -->\nhttps:\u002F\u002Fgithub.com\u002Fuser-attachments\u002Fassets\u002F5cab4668-e8e2-4982-8551-aab05ff73a7f\n\n# Quickstart\n\n## Skyvern Cloud\n[Skyvern Cloud](https:\u002F\u002Fapp.skyvern.com) is a managed cloud version of Skyvern that allows you to run Skyvern without worrying about the infrastructure. It allows you to run multiple Skyvern instances in parallel and comes bundled with anti-bot detection mechanisms, proxy network, and CAPTCHA solvers.\n\nIf you'd like to try it out, navigate to [app.skyvern.com](https:\u002F\u002Fapp.skyvern.com) and create an account.\n\n## Run Locally (UI + Server)\n\nChoose your preferred setup method:\n\n> **Database default**: As of skyvern 1.0.31+, `skyvern run server` defaults to a SQLite database at `~\u002F.skyvern\u002Fdata.db` so it works out of the box with no Postgres setup. To use Postgres instead, set `DATABASE_STRING` in `.env` or pass `--database-string` to `skyvern quickstart`. Docker Compose always uses the bundled Postgres service.\n\n### Option A: pip install (Recommended)\n\nDependencies needed:\n- [Python 3.11.x](https:\u002F\u002Fwww.python.org\u002Fdownloads\u002F), works with 3.12, not ready yet for 3.13\n- [NodeJS & NPM](https:\u002F\u002Fnodejs.org\u002Fen\u002Fdownload\u002F)\n\nAdditionally, for Windows:\n- [Rust](https:\u002F\u002Frustup.rs\u002F)\n- VS Code with C++ dev tools and Windows SDK\n\n#### 1. Install Skyvern\n\n```bash\npip install skyvern\n```\n\n#### 2. Run Skyvern\n\n```bash\nskyvern quickstart\n```\n\n### Option B: Docker Compose\n\nUse this option if you want everything containerized (Postgres, API, UI) and don't want to install Python\u002FNode locally.\n\n1. Install [Docker Desktop](https:\u002F\u002Fwww.docker.com\u002Fproducts\u002Fdocker-desktop\u002F)\n2. Clone the repository:\n   ```bash\n   git clone https:\u002F\u002Fgithub.com\u002Fskyvern-ai\u002Fskyvern.git && cd skyvern\n   ```\n3. Configure your LLM provider in `.env` (the `quickstart --docker-compose` command below will create it from `.env.example` if missing):\n   ```bash\n   cp .env.example .env  # if not already created\n   # edit .env to add your LLM API key\n   ```\n4. Start everything:\n   ```bash\n   docker compose up -d\n   ```\n5. Open http:\u002F\u002Flocalhost:8080\n\n### Troubleshooting\n\n**`(sqlite3.OperationalError) table organizations already exists`** — You hit a known bug in `pip install skyvern==1.0.31`. Fix:\n\n```bash\nrm ~\u002F.skyvern\u002Fdata.db   # remove the leftover SQLite file\npip install --upgrade skyvern   # 1.0.32+ contains the fix\nskyvern quickstart\n```\n\nIf you are still on 1.0.31 and cannot upgrade, install via uv instead:\n\n```bash\nuv pip install skyvern\n```\n\n**`pip install skyvern` fails with ResolutionImpossible (litellm \u002F fastmcp)** — You hit a dependency-resolution conflict in 1.0.31. Either upgrade to 1.0.32+ or use uv: `uv pip install skyvern`.\n\n## SDK\n\n**Skyvern is a Playwright extension that adds AI-powered browser automation.** It gives you the full power of Playwright with additional AI capabilities—use natural language prompts to interact with elements, extract data, and automate complex multi-step workflows.\n\n**Installation:**\n- Python: `pip install skyvern` then run `skyvern quickstart` for local setup\n- TypeScript: `npm install @skyvern\u002Fclient`\n\n### AI-Powered Page Commands\n\nSkyvern adds four core AI commands directly on the page object:\n\n| Command | Description |\n|---------|-------------|\n| `page.act(prompt)` | Perform actions using natural language (e.g., \"Click the login button\") |\n| `page.extract(prompt, schema)` | Extract structured data from the page with optional JSON schema |\n| `page.validate(prompt)` | Validate page state, returns `bool` (e.g., \"Check if user is logged in\") |\n| `page.prompt(prompt, schema)` | Send arbitrary prompts to the LLM with optional response schema |\n\nAdditionally, `page.agent` provides higher-level workflow commands:\n\n| Command | Description |\n|---------|-------------|\n| `page.agent.run_task(prompt)` | Execute complex multi-step tasks |\n| `page.agent.login(credential_type, credential_id)` | Authenticate with stored credentials (Skyvern, Bitwarden, 1Password) |\n| `page.agent.download_files(prompt)` | Navigate and download files |\n| `page.agent.run_workflow(workflow_id)` | Execute pre-built workflows |\n\n### AI-Augmented Playwright Actions\n\nAll standard Playwright actions support an optional `prompt` parameter for AI-powered element location:\n\n| Action | Playwright | AI-Augmented |\n|--------|------------|--------------|\n| Click | `page.click(\"#btn\")` | `page.click(prompt=\"Click login button\")` |\n| Fill | `page.fill(\"#email\", \"a@b.com\")` | `page.fill(prompt=\"Email field\", value=\"a@b.com\")` |\n| Select | `page.select_option(\"#country\", \"US\")` | `page.select_option(prompt=\"Country dropdown\", value=\"US\")` |\n| Upload | `page.upload_file(\"#file\", \"doc.pdf\")` | `page.upload_file(prompt=\"Upload area\", files=\"doc.pdf\")` |\n\n**Three interaction modes:**\n```python\n# 1. Traditional Playwright - CSS\u002FXPath selectors\nawait page.click(\"#submit-button\")\n\n# 2. AI-powered - natural language\nawait page.click(prompt=\"Click the green Submit button\")\n\n# 3. AI fallback - tries selector first, falls back to AI if it fails\nawait page.click(\"#submit-btn\", prompt=\"Click the Submit button\")\n```\n\n### Core AI Commands - Examples\n\n```python\n# act - Perform actions using natural language\nawait page.act(\"Click the login button and wait for the dashboard to load\")\n\n# extract - Extract structured data with optional JSON schema\nresult = await page.extract(\"Get the product name and price\")\nresult = await page.extract(\n    prompt=\"Extract order details\",\n    schema={\"order_id\": \"string\", \"total\": \"number\", \"items\": \"array\"}\n)\n\n# validate - Check page state (returns bool)\nis_logged_in = await page.validate(\"Check if the user is logged in\")\n\n# prompt - Send arbitrary prompts to the LLM\nsummary = await page.prompt(\"Summarize what's on this page\")\n```\n\n### Quick Start Examples\n\n**Run via UI:**\n```bash\nskyvern run all\n```\nNavigate to http:\u002F\u002Flocalhost:8080 to run tasks through the web interface.\n\n**Python SDK:**\n```python\nfrom skyvern import Skyvern\n\n# Local mode\nskyvern = Skyvern.local()\n\n# Or connect to Skyvern Cloud\nskyvern = Skyvern(api_key=\"your-api-key\")\n\n# Launch browser and get page\nbrowser = await skyvern.launch_cloud_browser()\npage = await browser.get_working_page()\n\n# Mix Playwright with AI-powered actions\nawait page.goto(\"https:\u002F\u002Fexample.com\")\nawait page.click(\"#login-button\")  # Traditional Playwright\nawait page.agent.login(credential_type=\"skyvern\", credential_id=\"cred_123\")  # AI login\nawait page.click(prompt=\"Add first item to cart\")  # AI-augmented click\nawait page.agent.run_task(\"Complete checkout with: John Snow, 12345\")  # AI task\n```\n\n**TypeScript SDK:**\n```typescript\nimport { Skyvern } from \"@skyvern\u002Fclient\";\n\nconst skyvern = new Skyvern({ apiKey: \"your-api-key\" });\nconst browser = await skyvern.launchCloudBrowser();\nconst page = await browser.getWorkingPage();\n\n\u002F\u002F Mix Playwright with AI-powered actions\nawait page.goto(\"https:\u002F\u002Fexample.com\");\nawait page.click(\"#login-button\");  \u002F\u002F Traditional Playwright\nawait page.agent.login(\"skyvern\", { credentialId: \"cred_123\" });  \u002F\u002F AI login\nawait page.click({ prompt: \"Add first item to cart\" });  \u002F\u002F AI-augmented click\nawait page.agent.runTask(\"Complete checkout with: John Snow, 12345\");  \u002F\u002F AI task\n\nawait browser.close();\n```\n\n**Simple task execution:**\n```python\nfrom skyvern import Skyvern\n\nskyvern = Skyvern()\ntask = await skyvern.run_task(prompt=\"Find the top post on hackernews today\")\nprint(task)\n```\n\n## Advanced Usage\n\n### Control your own browser (Chrome)\n\nLet Skyvern control your existing Chrome browser — with all your cookies, logins, and extensions.\n\n#### Step 1: Enable remote debugging in Chrome\n\n1. Open Chrome and navigate to `chrome:\u002F\u002Finspect\u002F#remote-debugging`\n2. Click **Enable** to start the debugging server\n3. You should see: **Server running at: 127.0.0.1:9222**\n\n> [!TIP]\n> The `skyvern init browser` command can do this automatically — it opens `chrome:\u002F\u002Finspect\u002F#remote-debugging`, waits for you to enable it, and saves the config.\n\n#### Step 2: Connect Skyvern\n\n**Option A — Python Code:**\n```python\nfrom skyvern import Skyvern\n\nskyvern = Skyvern(\n    base_url=\"http:\u002F\u002Flocalhost:8000\",\n    api_key=\"YOUR_API_KEY\",\n    browser_address=\"http:\u002F\u002F127.0.0.1:9222\",\n)\ntask = await skyvern.run_task(\n    prompt=\"Find the top post on hackernews today\",\n)\n```\n\n**Option B — Skyvern Service:**\n\nAdd two variables to your .env file:\n```bash\nBROWSER_TYPE=cdp-connect\nBROWSER_REMOTE_DEBUGGING_URL=http:\u002F\u002F127.0.0.1:9222\n```\n\nRestart Skyvern service `skyvern run all` and run the task through UI or code\n\n### Connect Skyvern Cloud to your local browser\n\nLet Skyvern Cloud control a Chrome browser running on your machine — with all your existing cookies, logins, and extensions. Useful for automating sites where you're already logged in or behind a VPN.\n\n```bash\n# One command to start Chrome + create a tunnel to Skyvern Cloud\nskyvern browser serve --tunnel\n```\n\nThen use the tunnel URL in your task:\n\n```python\nfrom skyvern import Skyvern\n\nskyvern = Skyvern(api_key=\"your-api-key\")\ntask = await skyvern.run_task(\n    prompt=\"Download the latest invoice from my account\",\n    browser_address=\"https:\u002F\u002Fabc123.ngrok-free.dev\",\n)\n```\n\n> [!WARNING]\n> Always use `--api-key` when exposing your browser via a tunnel. Without it, anyone with the URL has full control of your browser. See the [security docs](https:\u002F\u002Fwww.skyvern.com\u002Fdocs\u002Foptimization\u002Fbrowser-tunneling#security).\n\nSee the [full documentation](https:\u002F\u002Fwww.skyvern.com\u002Fdocs\u002Foptimization\u002Fbrowser-tunneling) for all options, manual tunnel setup, and troubleshooting.\n\n### Get consistent output schema from your run\nYou can do this by adding the `data_extraction_schema` parameter:\n```python\nfrom skyvern import Skyvern\n\nskyvern = Skyvern()\ntask = await skyvern.run_task(\n    prompt=\"Find the top post on hackernews today\",\n    data_extraction_schema={\n        \"type\": \"object\",\n        \"properties\": {\n            \"title\": {\n                \"type\": \"string\",\n                \"description\": \"The title of the top post\"\n            },\n            \"url\": {\n                \"type\": \"string\",\n                \"description\": \"The URL of the top post\"\n            },\n            \"points\": {\n                \"type\": \"integer\",\n                \"description\": \"Number of points the post has received\"\n            }\n        }\n    }\n)\n```\n\n### Helpful commands to debug issues\n\n\n```bash\n# Launch the Skyvern Server Separately*\nskyvern run server\n\n# Launch the Skyvern UI\nskyvern run ui\n\n# Check status of the Skyvern service\nskyvern status\n\n# Stop the Skyvern service\nskyvern stop all\n\n# Stop the Skyvern UI\nskyvern stop ui\n\n# Stop the Skyvern Server Separately\nskyvern stop server\n```\n\n# Performance & Evaluation\n\nSkyvern has SOTA performance on the [WebBench benchmark](webbench.ai) with a 64.4% accuracy. The technical report + evaluation can be found [here](https:\u002F\u002Fwww.skyvern.com\u002Fblog\u002Fweb-bench-a-new-way-to-compare-ai-browser-agents\u002F)\n\n\u003Cp align=\"center\">\n  \u003Cimg src=\"fern\u002Fimages\u002Fperformance\u002Fwebbench_overall.png\"\u002F>\n\u003C\u002Fp>\n\n## Performance on WRITE tasks (eg filling out forms, logging in, downloading files, etc)\n\nSkyvern is the best performing agent on WRITE tasks (eg filling out forms, logging in, downloading files, etc), which is primarily used for RPA (Robotic Process Automation) adjacent tasks.\n\n\u003Cp align=\"center\">\n  \u003Cimg src=\"fern\u002Fimages\u002Fperformance\u002Fwebbench_write.png\"\u002F>\n\u003C\u002Fp>\n\n# Skyvern Features\n\n## Skyvern Tasks\nTasks are the fundamental building block inside Skyvern. Each task is a single request to Skyvern, instructing it to navigate through a website and accomplish a specific goal.\n\nTasks require you to specify a `url`, `prompt`, and can optionally include a `data schema` (if you want the output to conform to a specific schema) and `error codes` (if you want Skyvern to stop running in specific situations).\n\n\u003Cp align=\"center\">\n  \u003Cimg src=\"fern\u002Fimages\u002Fskyvern_2_0_screenshot.png\"\u002F>\n\u003C\u002Fp>\n\n\n## Skyvern Workflows\nWorkflows are a way to chain multiple tasks together to form a cohesive unit of work.\n\nFor example, if you wanted to download all invoices newer than January 1st, you could create a workflow that first navigated to the invoices page, then filtered down to only show invoices newer than January 1st, extracted a list of all eligible invoices, and iterated through each invoice to download it.\n\nAnother example is if you wanted to automate purchasing products from an e-commerce store, you could create a workflow that first navigated to the desired product, then added it to a cart. Second, it would navigate to the cart and validate the cart state. Finally, it would go through the checkout process to purchase the items.\n\nSupported workflow features include:\n1. Browser Task\n1. Browser Action\n1. Data Extraction\n1. Validation\n1. For Loops\n1. File parsing\n1. Sending emails\n1. Text Prompts\n1. HTTP Request Block\n1. Custom Code Block\n1. Uploading files to block storage\n1. (Coming soon) Conditionals\n\n\u003Cp align=\"center\">\n  \u003Cimg src=\"fern\u002Fimages\u002Fblock_example_v2.png\"\u002F>\n\u003C\u002Fp>\n\n## Livestreaming\nSkyvern allows you to livestream the viewport of the browser to your local machine so that you can see exactly what Skyvern is doing on the web. This is useful for debugging and understanding how Skyvern is interacting with a website, and intervening when necessary\n\n## Form Filling\nSkyvern is natively capable of filling out form inputs on websites. Passing in information via the `navigation_goal` will allow Skyvern to comprehend the information and fill out the form accordingly.\n\n## Data Extraction\nSkyvern is also capable of extracting data from a website.\n\nYou can also specify a `data_extraction_schema` directly within the main prompt to tell Skyvern exactly what data you'd like to extract from the website, in jsonc format. Skyvern's output will be structured in accordance to the supplied schema.\n\n## File Downloading\nSkyvern is also capable of downloading files from a website. All downloaded files are automatically uploaded to block storage (if configured), and you can access them via the UI.\n\n## Authentication\nSkyvern supports a number of different authentication methods to make it easier to automate tasks behind a login. If you'd like to try it out, please reach out to us [via email](mailto:founders@skyvern.com) or [discord](https:\u002F\u002Fdiscord.gg\u002FfG2XXEuQX3).\n\n\u003Cp align=\"center\">\n  \u003Cimg src=\"fern\u002Fimages\u002Fsecure_password_task_example.png\"\u002F>\n\u003C\u002Fp>\n\n\n### 🔐 2FA Support (TOTP)\nSkyvern supports a number of different 2FA methods to allow you to automate workflows that require 2FA.\n\nExamples include:\n1. QR-based 2FA (e.g. Google Authenticator, Authy)\n1. Email based 2FA\n1. SMS based 2FA\n\n🔐 Learn more about 2FA support [here](https:\u002F\u002Fwww.skyvern.com\u002Fdocs\u002Fcredentials\u002Ftotp).\n\n### Password Manager Integrations\nSkyvern currently supports the following password manager integrations:\n- [x] Bitwarden\n- [x] Custom Credential Service (HTTP API)\n- [ ] 1Password\n- [ ] LastPass\n\n\n## Model Context Protocol (MCP)\n\nSkyvern supports the Model Context Protocol (MCP) to allow you to use any LLM that supports MCP.\n\nSee the MCP documentation [here](https:\u002F\u002Fwww.skyvern.com\u002Fdocs\u002Fintegrations\u002Fmcp#mcp-server)\n\n## Zapier \u002F Make.com \u002F N8N Integration\nSkyvern supports Zapier, Make.com, and N8N to allow you to connect your Skyvern workflows to other apps.\n\n* [Zapier](https:\u002F\u002Fwww.skyvern.com\u002Fdocs\u002Fintegrations\u002Fzapier)\n* [Make.com](https:\u002F\u002Fwww.skyvern.com\u002Fdocs\u002Fintegrations\u002Fmake.com)\n* [N8N](https:\u002F\u002Fwww.skyvern.com\u002Fdocs\u002Fintegrations\u002Fn8n)\n\n🔐 Learn more about 2FA support [here](https:\u002F\u002Fwww.skyvern.com\u002Fdocs\u002Fcredentials\u002Ftotp).\n\n\n# Real-world examples of Skyvern\nWe love to see how Skyvern is being used in the wild. Here are some examples of how Skyvern is being used to automate workflows in the real world. Please open PRs to add your own examples!\n\n## Invoice Downloading on many different websites\n[Book a demo to see it live](https:\u002F\u002Fmeetings.hubspot.com\u002Fskyvern\u002Fdemo)\n\n\u003Cp align=\"center\">\n  \u003Cimg src=\"fern\u002Fimages\u002Finvoice_downloading.gif\"\u002F>\n\u003C\u002Fp>\n\n## Automate the job application process\n[💡 See it in action](https:\u002F\u002Fapp.skyvern.com\u002Ftasks\u002Fcreate\u002Fjob_application)\n\u003Cp align=\"center\">\n  \u003Cimg src=\"fern\u002Fimages\u002Fjob_application_demo.gif\"\u002F>\n\u003C\u002Fp>\n\n## Automate materials procurement for a manufacturing company\n[💡 See it in action](https:\u002F\u002Fapp.skyvern.com\u002Ftasks\u002Fcreate\u002Ffinditparts)\n\u003Cp align=\"center\">\n  \u003Cimg src=\"fern\u002Fimages\u002Ffinditparts_recording_crop.gif\"\u002F>\n\u003C\u002Fp>\n\n## Navigating to government websites to register accounts or fill out forms\n[💡 See it in action](https:\u002F\u002Fapp.skyvern.com\u002Ftasks\u002Fcreate\u002Fcalifornia_edd)\n\u003Cp align=\"center\">\n  \u003Cimg src=\"fern\u002Fimages\u002Fedd_services.gif\"\u002F>\n\u003C\u002Fp>\n\u003C!-- Add example of delaware entity lookups x2 -->\n\n## Filling out random contact us forms\n[💡 See it in action](https:\u002F\u002Fapp.skyvern.com\u002Ftasks\u002Fcreate\u002Fcontact_us_forms)\n\u003Cp align=\"center\">\n  \u003Cimg src=\"fern\u002Fimages\u002Fcontact_forms.gif\"\u002F>\n\u003C\u002Fp>\n\n\n## Retrieving insurance quotes from insurance providers in any language\n[💡 See it in action](https:\u002F\u002Fapp.skyvern.com\u002Ftasks\u002Fcreate\u002Fbci_seguros)\n\u003Cp align=\"center\">\n  \u003Cimg src=\"fern\u002Fimages\u002Fbci_seguros_recording.gif\"\u002F>\n\u003C\u002Fp>\n\n[💡 See it in action](https:\u002F\u002Fapp.skyvern.com\u002Ftasks\u002Fcreate\u002Fgeico)\n\n\u003Cp align=\"center\">\n  \u003Cimg src=\"fern\u002Fimages\u002Fgeico_shu_recording_cropped.gif\"\u002F>\n\u003C\u002Fp>\n\n# Contributor Setup\nMake sure to have [uv](https:\u002F\u002Fdocs.astral.sh\u002Fuv\u002Fgetting-started\u002Finstallation\u002F) installed.\n1. Run this to create your virtual environment (`.venv`)\n    ```bash\n    uv sync --group dev\n    ```\n2. Perform initial server configuration\n    ```bash\n    uv run skyvern quickstart\n    ```\n3. Navigate to `http:\u002F\u002Flocalhost:8080` in your browser to start using the UI\n   *The Skyvern CLI supports Windows, WSL, macOS, and Linux environments.*\n\n# Documentation\n\nMore extensive documentation can be found on our [📕 docs page](https:\u002F\u002Fwww.skyvern.com\u002Fdocs). Please let us know if something is unclear or missing by opening an issue or reaching out to us [via email](mailto:founders@skyvern.com) or [discord](https:\u002F\u002Fdiscord.gg\u002FfG2XXEuQX3).\n\n# Supported LLMs\n| Provider | Supported Models |\n| -------- | ------- |\n| OpenAI   | GPT-5.5, GPT-5.4, GPT-5, GPT-4.1, o3, o4-mini |\n| Anthropic | Claude 4.7 Opus, Claude 4.6 (Sonnet, Opus), Claude 4.5 (Haiku, Sonnet, Opus) |\n| Azure OpenAI | Any GPT models deployed to your Azure subscription |\n| AWS Bedrock | Claude 4.7, Claude 4.6 (Sonnet, Opus), Claude 4.5 (Sonnet, Opus) |\n| Gemini | Gemini 3.1 Pro, Gemini 3 Flash, Gemini 2.5 Pro\u002FFlash |\n| Ollama | Run any locally hosted model via [Ollama](https:\u002F\u002Fgithub.com\u002Follama\u002Follama) |\n| OpenRouter | Access models through [OpenRouter](https:\u002F\u002Fopenrouter.ai) |\n| OpenAI-compatible | Any custom API endpoint that follows OpenAI's API format (via [liteLLM](https:\u002F\u002Fdocs.litellm.ai\u002Fdocs\u002Fproviders\u002Fopenai_compatible)) |\n\nFor detailed LLM configuration including all available model keys, environment variables, and multi-model setups, see the [LLM Configuration docs](https:\u002F\u002Fwww.skyvern.com\u002Fdocs\u002Fself-hosted\u002Fllm-configuration).\n\n# Contributing\n\nWe welcome PRs and suggestions! Don't hesitate to open a PR\u002Fissue or to reach out to us [via email](mailto:founders@skyvern.com) or [discord](https:\u002F\u002Fdiscord.gg\u002FfG2XXEuQX3).\nPlease have a look at our [contribution guide](CONTRIBUTING.md) and\n[\"Help Wanted\" issues](https:\u002F\u002Fgithub.com\u002Fskyvern-ai\u002Fskyvern\u002Fissues?q=is%3Aopen+is%3Aissue+label%3A%22help+wanted%22) to get started!\n\nIf you want to chat with the skyvern repository to get a high level overview of how it is structured, how to build off it, and how to resolve usage questions, check out [Code Sage](https:\u002F\u002Fsage.storia.ai?utm_source=github&utm_medium=referral&utm_campaign=skyvern-readme).\n\n# Telemetry\n\nBy Default, Skyvern collects basic usage statistics to help us understand how Skyvern is being used. If you would like to opt-out of telemetry, please set the `SKYVERN_TELEMETRY` environment variable to `false`.\n\n# License\nSkyvern's open source repository is supported via a managed cloud. All of the core logic powering Skyvern is available in this open source repository licensed under the [AGPL-3.0 License](LICENSE), with the exception of anti-bot measures available in our managed cloud offering.\n\nIf you have any questions or concerns around licensing, please [contact us](mailto:support@skyvern.com) and we would be happy to help.\n\n# Star History\n\n[![Star History Chart](https:\u002F\u002Fapi.star-history.com\u002Fsvg?repos=Skyvern-AI\u002Fskyvern&type=Date)](https:\u002F\u002Fstar-history.com\u002F#Skyvern-AI\u002Fskyvern&Date)\n","Skyvern 是一个利用大语言模型（LLM）和计算机视觉技术实现基于浏览器工作流自动化的项目。其核心功能包括提供与 Playwright 兼容的 SDK，该 SDK 在 Playwright 之上增加了人工智能功能，并且配备了一个无代码工作流构建器，帮助技术和非技术用户都能轻松地在任何网站上自动化手动工作流程，从而替代易出错或不可靠的传统自动化方案。Skyvern 通过使用视觉 LLM 来学习并交互网站内容，而不是单纯依赖于易受网页布局变化影响的 XPath 交互方式，这使得它非常适合需要高度灵活性和适应性的场景，如动态变化频繁的网页数据抓取、表单填写等任务。",2,"2026-06-11 02:49:48","top_language"]