{"id":50592329,"url":"https://github.com/exzvor/ide99","last_synced_at":"2026-06-05T11:30:19.121Z","repository":{"id":358883307,"uuid":"1243379104","full_name":"exzvor/ide99","owner":"exzvor","description":"A local-first PostgreSQL IDE. Native desktop app for macOS, Linux and Windows — free and open source.","archived":false,"fork":false,"pushed_at":"2026-06-03T18:59:14.000Z","size":3952,"stargazers_count":10,"open_issues_count":0,"forks_count":0,"subscribers_count":0,"default_branch":"main","last_synced_at":"2026-06-03T20:17:15.803Z","etag":null,"topics":["database-client","database-gui","database-tools","datagrip-alternative","dbeaver-alternative","explain-analyzer","jsonb","mcp-server","pgvector","postgis","postgres","postgresql","postgresql-client","postgresql-gui","postgresql-ide","query-analyzer","rust","sql-editor","tauri","timescaledb"],"latest_commit_sha":null,"homepage":"https://ide99.io","language":"TypeScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"apache-2.0","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/exzvor.png","metadata":{"files":{"readme":"README.md","changelog":"CHANGELOG.md","contributing":"CONTRIBUTING.md","funding":null,"license":"LICENSE","code_of_conduct":"CODE_OF_CONDUCT.md","threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":"SECURITY.md","support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null,"notice":null,"maintainers":null,"copyright":null,"agents":null,"dco":null,"cla":null}},"created_at":"2026-05-19T09:35:38.000Z","updated_at":"2026-06-03T18:59:16.000Z","dependencies_parsed_at":null,"dependency_job_id":null,"html_url":"https://github.com/exzvor/ide99","commit_stats":null,"previous_names":["exzvor/ide99"],"tags_count":6,"template":false,"template_full_name":null,"purl":"pkg:github/exzvor/ide99","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/exzvor%2Fide99","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/exzvor%2Fide99/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/exzvor%2Fide99/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/exzvor%2Fide99/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/exzvor","download_url":"https://codeload.github.com/exzvor/ide99/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/exzvor%2Fide99/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":33939225,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-05-26T15:22:16.424Z","status":"online","status_checked_at":"2026-06-05T02:00:06.157Z","response_time":120,"last_error":null,"robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":true,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["database-client","database-gui","database-tools","datagrip-alternative","dbeaver-alternative","explain-analyzer","jsonb","mcp-server","pgvector","postgis","postgres","postgresql","postgresql-client","postgresql-gui","postgresql-ide","query-analyzer","rust","sql-editor","tauri","timescaledb"],"created_at":"2026-06-05T11:30:17.689Z","updated_at":"2026-06-05T11:30:19.110Z","avatar_url":"https://github.com/exzvor.png","language":"TypeScript","funding_links":[],"categories":[],"sub_categories":[],"readme":"\u003cdiv align=\"center\"\u003e\n\n# ide99\n\n**The fast, local-first PostgreSQL IDE.**\n28 MB native desktop app. EXPLAIN plan diff, JSONB tree editor, blocking chains, migrations, pgvector, MCP server for AI agents.\n\n[![Latest release](https://img.shields.io/github/v/release/exzvor/ide99?style=flat-square\u0026color=4f8cff)](https://github.com/exzvor/ide99/releases/latest)\n[![Downloads](https://img.shields.io/github/downloads/exzvor/ide99/total?style=flat-square\u0026color=4f8cff)](https://github.com/exzvor/ide99/releases)\n[![Stars](https://img.shields.io/github/stars/exzvor/ide99?style=flat-square\u0026color=4f8cff)](https://github.com/exzvor/ide99/stargazers)\n[![License](https://img.shields.io/badge/license-Apache%202.0-blue.svg?style=flat-square)](LICENSE)\n\n[Download](#install) · [Docs](https://ide99.io/docs/) · [Discussions](https://github.com/exzvor/ide99/discussions) · [Why ide99](#why-ide99)\n\n[ide99.io (English)](https://ide99.io) · [ide99.ru (Русский)](https://ide99.ru)\n\n\u003cbr/\u003e\n\n\u003cimg src=\".github/social-preview.png\" alt=\"ide99 — fast local-first PostgreSQL IDE with EXPLAIN plan visualizer\" width=\"900\" /\u003e\n\n\u003c/div\u003e\n\n---\n\n## Why ide99\n\nPostgreSQL IDEs are either heavy (DBeaver, DataGrip), dated (pgAdmin), or closed and paid. ide99 is a native ~28 MB desktop app built around the things Postgres developers do every day: explain slow queries, edit JSONB, untangle locks, ship migrations, work with pgvector — and let AI agents work with a real database safely.\n\n|  | ide99 | DBeaver CE | DataGrip | pgAdmin |\n|---|---|---|---|---|\n| Install size | **~28 MB** | ~600 MB | ~800 MB | ~250 MB |\n| Native (no JVM / Electron) | ✅ | ❌ | ❌ | ❌ |\n| EXPLAIN plan tree + diff | ✅ | ⚠️ | ⚠️ | ❌ |\n| JSONB tree editor | ✅ | ⚠️ | ⚠️ | ❌ |\n| Blocking chain DAG | ✅ | ❌ | ❌ | ❌ |\n| pgvector / PostGIS / TimescaleDB packs | ✅ | ⚠️ | ⚠️ | ❌ |\n| MCP server for AI agents | ✅ | ❌ | ❌ | ❌ |\n| Local-first, no cloud proxy | ✅ | ✅ | ✅ | ✅ |\n| Open source | ✅ Apache-2.0 | ✅ | ❌ | ✅ |\n| Price | **Free forever** | Free / Pro | $229 / yr | Free |\n\n---\n\n## Install\n\nPrebuilt binaries for macOS, Linux and Windows on the [latest release](https://github.com/exzvor/ide99/releases/latest).\n\n| OS | File | Notes |\n|---|---|---|\n| macOS Apple Silicon | `ide99_\u003cversion\u003e_aarch64.pkg` | Recommended on M1/M2/M3/M4 — postinstall script strips `com.apple.quarantine`, so no per-launch Gatekeeper warning |\n| macOS Apple Silicon (DMG) | `ide99_\u003cversion\u003e_aarch64.dmg` | Drag-to-Applications flow |\n| Windows 10/11 | `ide99_\u003cversion\u003e_x64-setup.exe` | NSIS installer |\n| Windows portable | `ide99_\u003cversion\u003e_x64-portable.zip` | Unzip and run — useful if SmartScreen blocks the installer download |\n| Linux (any) | `ide99_\u003cversion\u003e_amd64.AppImage` | `chmod +x` and run |\n| Debian / Ubuntu | `ide99_\u003cversion\u003e_amd64.deb` | |\n| Fedora / RHEL | `ide99-\u003cversion\u003e-1.x86_64.rpm` | |\n\nVerify any download with the SHA256 checksum on the release page.\n\n### Trust \u0026 signing status\n\nBuilds are currently unsigned; EV code-signing is on the roadmap. Until then:\n\n- **macOS** — install the `.pkg`; subsequent launches are clean. From the `.dmg`, right-click the app on first launch and pick *Open*.\n- **Windows** — SmartScreen may flag the installer. Click *More info → Run anyway*, or use the portable `.zip`.\n- **Linux** — AppImage / `.deb` / `.rpm` are unsigned but reproducible; verify SHA256.\n\nide99 is local-first: connections, credentials and query history live in `\u003cdata_dir\u003e/ide99/` on your machine. No cloud proxy, no telemetry by default. See [SECURITY.md](SECURITY.md) for the full threat model.\n\n### Package managers\n\nHomebrew, winget, scoop, AUR and Flathub channels are planned.\n\n---\n\n## Build from source\n\n```bash\ngit clone https://github.com/exzvor/ide99.git\ncd ide99\nnpm install\nnpm run tauri dev\n```\n\nRequires Node.js 20+ and Rust stable ([rustup](https://rustup.rs/)). Tauri prerequisites for your OS: [tauri.app/start/prerequisites](https://tauri.app/start/prerequisites/).\n\nProduction bundle:\n\n```bash\nnpm run tauri build\n```\n\nOutput lands in `src-tauri/target/release/bundle/` — `.dmg` / `.pkg` on macOS, `.deb` / `.AppImage` / `.rpm` on Linux, `.exe` on Windows.\n\nUseful scripts:\n\n```bash\nnpm run typecheck            # tsc --noEmit\nnpm run lint                 # biome check .\nnpm run test                 # vitest unit tests\ncd src-tauri \u0026\u0026 cargo test\ncd src-tauri \u0026\u0026 cargo clippy -- -D warnings\n```\n\n---\n\n## Connect an AI agent (MCP)\n\nide99 exposes a Model Context Protocol server so Claude Code, Cursor, Windsurf and Cline can read the active connection, the current query and the last result — and propose SQL or EXPLAIN analyses in context. The agent never sees your credentials.\n\nEnable: **Settings → AI / MCP → Enable MCP server**. The *Connect your agent* button generates the JSON snippet for `~/.claude/mcp_servers.json` or `~/.cursor/mcp.json`.\n\nOn first connect each client passes an in-IDE authorize flow with explicit scope (`Allow`, `Allow read-only`, `Allow with write access`, `Deny`). Write calls (`run_query_write`, `apply_migration`) additionally require a per-call confirm with SQL preview. Every call is appended to `\u003cdata_dir\u003e/mcp-audit.log`.\n\nFull guide: [ide99.io/docs](https://ide99.io/docs/).\n\n---\n\n## All features\n\n\u003cdetails\u003e\n\u003csummary\u003e\u003cstrong\u003eEditor \u0026 query\u003c/strong\u003e\u003c/summary\u003e\n\n- PostgreSQL-aware autocomplete (CTEs, window functions, JSONB operators, `pg_catalog`)\n- Monaco-based SQL editor with multi-cursor, snippets, format\n- Parameter binding and saved query history\n- Virtualised result grid — 50M+ rows at 60 fps\n- Multi-tab persistence across sessions\n\n\u003c/details\u003e\n\n\u003cdetails\u003e\n\u003csummary\u003e\u003cstrong\u003ePerformance \u0026 diagnostics\u003c/strong\u003e\u003c/summary\u003e\n\n- EXPLAIN visualiser with tree view and plan diff (embedded `pev2`)\n- Health Screen — bloat, slow queries, missing \u0026 unused indexes, one-click fixes\n- Live Ops dashboard — sessions, blocking chains (DAG)\n- `pg_stat_statements` integration\n\n\u003c/details\u003e\n\n\u003cdetails\u003e\n\u003csummary\u003e\u003cstrong\u003eSchema \u0026 migrations\u003c/strong\u003e\u003c/summary\u003e\n\n- ERD + Visual Schema Editor (bidirectional GUI ↔ SQL)\n- Object editors: tables, views, materialised views, functions, procedures\n- Native migrations with Squawk lint\n- Backup / Restore workflows\n\n\u003c/details\u003e\n\n\u003cdetails\u003e\n\u003csummary\u003e\u003cstrong\u003eExtension packs\u003c/strong\u003e\u003c/summary\u003e\n\n- pgvector — vector search, index tuning, recall analysis\n- PostGIS — spatial query helpers and map preview\n- TimescaleDB, pg_partman, pg_stat_statements, pg_repack\n\n\u003c/details\u003e\n\n\u003cdetails\u003e\n\u003csummary\u003e\u003cstrong\u003eAI \u0026 automation\u003c/strong\u003e\u003c/summary\u003e\n\n- MCP server with scoped permissions and audit log\n- JSONB tree editor with path autocomplete\n- Instant DB (free beta) — on-demand throwaway PostgreSQL instances for prototyping, migration dry-runs and extension probes\n\n\u003c/details\u003e\n\n---\n\n## Built on\n\n[Tauri 2.0](https://tauri.app) · [Rust](https://www.rust-lang.org) · [React 18](https://react.dev) · [TypeScript](https://www.typescriptlang.org) · [Monaco](https://microsoft.github.io/monaco-editor/) · [pev2](https://github.com/dalibo/pev2) · [tokio-postgres](https://github.com/sfackler/rust-postgres) · [Radix UI](https://www.radix-ui.com) · [Tailwind v4](https://tailwindcss.com) · [Zustand](https://github.com/pmndrs/zustand)\n\n---\n\n## Contributing \u0026 community\n\n- [Discussions](https://github.com/exzvor/ide99/discussions) — feature requests, EXPLAIN puzzles, MCP setups\n- [Issues](https://github.com/exzvor/ide99/issues) — bugs with concrete reproductions\n- [CONTRIBUTING.md](CONTRIBUTING.md) — dev setup, coding conventions, PR flow\n- [SECURITY.md](SECURITY.md) — responsible disclosure\n- [CODE_OF_CONDUCT.md](CODE_OF_CONDUCT.md)\n- [CHANGELOG.md](CHANGELOG.md)\n\nLocalised in English and Russian out of the box.\n\n---\n\n## License\n\n[Apache License 2.0](LICENSE) — free to use, modify and distribute, commercially and otherwise.\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fexzvor%2Fide99","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fexzvor%2Fide99","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fexzvor%2Fide99/lists"}