[{"data":1,"prerenderedAt":-1},["ShallowReactive",2],{"project-74951":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":25,"hasPages":23,"topics":26,"createdAt":10,"pushedAt":10,"updatedAt":27,"readmeContent":28,"aiSummary":29,"trendingCount":16,"starSnapshotCount":16,"syncStatus":15,"lastSyncTime":30,"discoverSource":31},74951,"open-seo","every-app\u002Fopen-seo","every-app","Open source alternative to Semrush and Ahrefs","https:\u002F\u002Fopenseo.so",null,"TypeScript",2169,267,16,2,0,18,53,518,54,109.28,"MIT License",false,"main",true,[],"2026-06-12 04:01:16","# OpenSEO\n\nOpenSEO is an SEO tool for _the people_. If tools like Semrush or Ahrefs are too expensive or bloated, OpenSEO is a pay-as-you-go alternative that you actually control.\n\nEasy to self-host and extend, but we have a managed version too:\n\n[openseo.so](https:\u002F\u002Fopenseo.so)\n\n![OpenSEO demo (placeholder)](https:\u002F\u002Fgithub.com\u002Fuser-attachments\u002Fassets\u002F6a928771-66ff-486b-b131-a54a3943985f)\n\n## Table of Contents\n\n- [Why Use This](#why-use-this)\n- [Main SEO Workflows](#main-seo-workflows)\n- [Roadmap](#roadmap)\n- [Community](#community)\n- [Pricing \u002F Costs (Free + API costs)](#pricing--costs)\n- [DataForSEO API Key Setup](#dataforseo-api-key-setup)\n- [Self-hosting](#self-hosting)\n  - [Cloudflare Self-Hosting](#cloudflare-self-hosting)\n  - [Docker Self Hosting](#docker-self-hosting)\n- [Local Development](#local-development)\n- [Contributing](#contributing)\n- [SEO API Cost Reference](#seo-api-cost-reference)\n\n## Why Use This\n\n- Open source and self-hostable.\n- No subscriptions.\n  - Pay only for what you use.\n- Fork and vibe code your own features.\n- Focused workflows instead of a bloated, complex SEO suite.\n\n## Main SEO Workflows\n\n- Keyword research\n  - Find topics worth targeting, estimate demand, and prioritize what to write next.\n- Rank tracking\n  - Monitor keyword positions across desktop and mobile over time, with SERP feature detection.\n- Domain insights\n  - Understand where your domain is gaining or losing visibility so you can focus on the pages that move revenue.\n- Backlinks\n  - See who links to your site, which pages attract links, and where links are newly won or lost.\n- Site Audits\n  - Catch technical issues early so your site is easier for search engines to crawl and rank.\n\n## Roadmap\n\nTop priorities:\n\n- AI SEO, GEO, LLM Visibility\n- MCP for Claude\n- Making the best agentic workflows for SEO\n\nIf something important is missing, please join the [Discord](https:\u002F\u002Fdiscord.gg\u002Fc9uGs3cFXr) or email me at ben@openseo.so and request it.\n\n## Community\n\nEmail me: ben@openseo.so\nJoin Discord to chat: [Discord](https:\u002F\u002Fdiscord.gg\u002Fc9uGs3cFXr)\n\nFollow along for updates:\n\n- Sign up for the mailing list on our website: [openseo.so](https:\u002F\u002Fopenseo.so)\n- Follow on X: https:\u002F\u002Fx.com\u002Fbensenescu\n\n## Pricing \u002F Costs\n\nOpenSEO is totally free to use. It works by using DataForSEO's APIs, which is a paid third-party service unaffiliated with OpenSEO.\n\nThere are two separate things:\n\n1. OpenSEO app cost: $0, you host it yourself.\n2. DataForSEO API: pay-as-you-go based on usage.\n\nFor cost estimates, see [DataForSEO API Cost Reference](#seo-api-cost-reference).\n\n## DataForSEO API Key Setup\n\nOpenSEO uses DataForSEO to fetch SEO data. You need an API key to connect OpenSEO to the service.\n\nBacklinks requires one more step beyond the API key: you also need DataForSEO Backlinks enabled on your account (trial or paid subscription), then confirm access from the Backlinks page in OpenSEO.\n\n1. Go to [DataForSEO API Access](https:\u002F\u002Fapp.dataforseo.com\u002Fapi-access).\n2. Request API credentials by email (`API key by email` or `API password by email`).\n3. Use your DataForSEO login + API password, then base64 encode `login:password`:\n\n```sh\nprintf '%s' 'YOUR_LOGIN:YOUR_PASSWORD' | base64\n```\n\n4. Set this as `DATAFORSEO_API_KEY` in your environment file:\n\n- Docker self-hosting: `.env`\n- Cloudflare: Set it in the workers UI\n- Local development: `.env.local`\n\n## Self-hosting\n\nOpenSEO supports two self-hosting paths:\n\n- Docker for your homelab or local use (Recommended).\n- Cloudflare for use across multiple devices or for your team.\n\n_Docker_\n\nDocker is recommended for getting started. It's super easy to get up and running once you install Docker.\n\n_Cloudflare_\n\nIf you love OpenSEO and want to use it across multiple devices or with your team, you can host it on Cloudflare which we'll be a SaaS-like experience. Also, this will have automatic database backups and other nice convenience features. It's just a bit more effort to get started if you're unfamiliar with Cloudflare.\n\n## Docker Self Hosting\n\nPrerequisites:\n\n- Install Docker: https:\u002F\u002Fwww.docker.com\u002Fproducts\u002Fdocker-desktop\u002F\n\nQuickstart:\n\n1. `cp .env.example .env`\n2. Set `DATAFORSEO_API_KEY` in `.env`\n3. `docker compose up -d`\n4. Open `http:\u002F\u002Flocalhost:\u003CPORT>` (default `3001`)\n\nBy default, `compose.yaml` pulls the published image from GHCR:\n\n- `ghcr.io\u002Fevery-app\u002Fopen-seo:latest`\n\nTo update to the newest published image, pull first and then restart:\n\n```sh\ndocker compose pull\ndocker compose up -d\n```\n\nOr use a single command:\n\n```sh\ndocker compose up -d --pull always\n```\n\nUse a pinned version tag in `.env` if preferred:\n\n```sh\nOPEN_SEO_IMAGE=ghcr.io\u002Fevery-app\u002Fopen-seo:v1.2.3\n```\n\nFor more info, see [`docs\u002FSELF_HOSTING_DOCKER.md`](.\u002Fdocs\u002FSELF_HOSTING_DOCKER.md).\n\n## Cloudflare Self-Hosting\n\n### Deploy the Worker\n\nClicking this button opens a page to deploy OpenSEO in your Cloudflare account. If you do not have an account yet, it will take you to account creation first (OpenSEO works great on the free plan).\n\nReference these docs while deploying since the Cloudflare UI doesn't indicate what steps you need to take: [`docs\u002FSELF_HOSTING_CLOUDFLARE.md`](.\u002Fdocs\u002FSELF_HOSTING_CLOUDFLARE.md).\n\n[![Deploy to Cloudflare](https:\u002F\u002Fdeploy.workers.cloudflare.com\u002Fbutton)](https:\u002F\u002Fdeploy.workers.cloudflare.com\u002F?url=https:\u002F\u002Fgithub.com\u002Fevery-app\u002Fopen-seo)\n\n## Local Development\n\n### Prerequisites\n\n- Node.js 20+\n- [pnpm](https:\u002F\u002Fpnpm.io\u002F)\n- A DataForSEO account\u002FAPI credentials\n\n### Local Development Workflow\n\n```sh\npnpm install\n\n# Run once per fresh local DB\npnpm run db:migrate:local\n```\n\nConfigure .env.local:\n\n1. `cp .env.example .env.local`\n2. Add `DATAFORSEO_API_KEY` as a base64-encoded `login:password` value:\n\n   `printf '%s' 'YOUR_LOGIN:YOUR_PASSWORD' | base64`\n\nRun Locally:\n\n```sh\n# Option 1\npnpm run dev\n\n# Option 2 (Recommended)\n# This log file makes it easier for your coding agent to debug.\nmkdir .logs\ntouch .logs\u002Fdev-server.log\n\n# This command uses portless, which is great for worktrees. It also pipes logs to that fixed file, which is helpful for agent debugging output.\npnpm dev:agents\n```\n\n`pnpm dev:agents` runs through [portless](https:\u002F\u002Fgithub.com\u002Fvercel-labs\u002Fportless) at `http:\u002F\u002Fopen-seo.localhost:1355` by default.\n\nWhen using a git worktree, [portless](https:\u002F\u002Fgithub.com\u002Fvercel-labs\u002Fportless) prefixes the branch name, for example `http:\u002F\u002Ffeature-name.open-seo.localhost:1355`.\n\n### Database Commands\n\nGenerate migration:\n\n```sh\npnpm run db:generate\n```\n\nMigrate local DB:\n\n```sh\npnpm run db:migrate:local\n```\n\n### Auth modes\n\n- `AUTH_MODE=cloudflare_access` (default): validates Cloudflare Access JWTs (`cf-access-jwt-assertion`) using `TEAM_DOMAIN` + `POLICY_AUD`.\n- `AUTH_MODE=local_noauth`: local trusted mode, no auth check, injects `admin@localhost`.\n- `AUTH_MODE=hosted`: Better Auth-backed email\u002Fpassword mode. Requires Better Auth schema generation plus `BETTER_AUTH_SECRET` and `BETTER_AUTH_URL`.\n\nLocal scripts (`pnpm dev` and `pnpm dev:agents`) set `AUTH_MODE=local_noauth` automatically.\nUse `AUTH_MODE=cloudflare_access pnpm dev` when you specifically want to test Access validation locally.\n\nFor Cloudflare deployments, ensure Cloudflare Access is enabled on your Worker route\u002Fdomain and provide `TEAM_DOMAIN` + `POLICY_AUD` in environment variables.\n\n## Contributing\n\nContributions are very welcome.\n\n- Open an issue for bugs, UX friction, or feature requests.\n- Open a PR if you want to implement a feature directly.\n- Community-driven improvements are prioritized, and high-quality PRs are encouraged.\n\nIf you want to contribute but are unsure where to start, open an issue and describe what you want to build.\n\n## SEO API Cost Reference\n\nUse this section to estimate DataForSEO spend per request type. OpenSEO itself remains free; these are API usage costs only.\n\nAs of February 26, 2026, DataForSEO’s public docs\u002Fpricing pages say:\n\n- New accounts include **$1 free credit** to test the API.\n- The minimum top-up\u002Fpayment is **$50**.\n\nThat means you can try OpenSEO for free with the starter credit, then decide if\u002Fwhen to top up.\n\n### Pricing sources\n\n- DataForSEO SERP API pricing: https:\u002F\u002Fdataforseo.com\u002Fapis\u002Fserp-api\u002Fpricing\n- DataForSEO Labs pricing: https:\u002F\u002Fdataforseo.com\u002Fpricing\u002Fdataforseo-labs\u002Fdataforseo-google-api\n- DataForSEO Backlinks pricing: https:\u002F\u002Fdataforseo.com\u002Fpricing\u002Fbacklinks\u002Fbacklinks\n- DataForSEO Lighthouse API docs: https:\u002F\u002Fdocs.dataforseo.com\u002Fv3\u002Fon_page\u002Flighthouse\u002Foverview\u002F\n\n### 1) Rank tracking\n\nThere are in-app estimates for this since its dependent on the settings you select.\n\n$2\u002Fmonth example:\n\n- 50 keywords\n- 1 device (Mobile or Desktop)\n- Search 5 pages deep.\n\nSearching ten pages deep costs 8x more than one page. Tracking both devices costs 2x more.\n\n### 2) Site audit\n\n- $0.01 per 20 pages audited with Lighthouse\n\n### 3) Keyword research (`related` mode)\n\n- Current billed cost pattern (from account usage logs):\n  - `0.02 + (0.0001 x returned_keywords)` USD\n- Default app setting: `150` results per search (`$0.035` each).\n- Available result tiers:\n  - 150 results = `$0.035`\n  - 300 results = `$0.05`\n  - 500 results = `$0.07`\n\n### 4) Domain overview\n\n- Standard domain overview request (with top 200 ranked keywords): `$0.0401` per domain.\n- General formula if needed:\n  - `0.0201 + (0.0001 x ranked_keywords_returned)` USD\n\n### 5) Backlinks search\n\n> [!NOTE]\n> There is a 2 week free trial, but then DataForSEO requires a $100\u002Fmonth commitment for this API. You can access this data for just $10\u002Fmonth through [openseo.so](https:\u002F\u002Fopenseo.so). Soon, we'll let you use an OpenSEO API key so that you can call our API from your self hosted instance.\n\n- Backlinks search costs about `$0.06` for a domain or `$0.04` for a page.\n- Opening extra tabs like `Referring Domains` or `Top Pages` adds about `+$0.02` each.\n- Exact cost can vary slightly based on returned rows and DataForSEO pricing.\n\n### Planning examples\n\n- 100 keyword research requests at the default 150 results: `$3.50`\n- 100 keyword research requests at 500 results each: `$7.00`\n- 100 domain overviews (200 ranked keywords each): `$4.01`\n- 100 backlinks domain searches at current defaults before opening extra tabs: about `$6.34`\n- 100 backlinks page searches at current defaults before opening extra tabs: about `$4.30`\n- 100 fully explored backlinks domain searches: about `$10.94`\n- 100 fully explored backlinks page searches: about `$8.61`\n","OpenSEO 是一个开源的搜索引擎优化工具，旨在让用户以更灵活和经济的方式进行关键词研究和竞争对手分析。该项目使用 TypeScript 编写，核心功能包括关键词研究、排名跟踪、域名洞察、反向链接分析及网站审计等，帮助用户发现有价值的主题、监控关键词表现、了解自身网站在搜索引擎中的可见度变化，并及时发现可能影响搜索排名的技术问题。特别适合那些觉得市场上现有 SEO 工具过于昂贵或功能冗余的个人开发者及小型企业使用。此外，OpenSEO 支持自托管部署，也提供了基于 DataForSEO API 的按需付费模式，使得成本更加可控。","2026-06-11 03:51:41","high_star"]