{"id":46198841,"url":"https://github.com/yilee/agentlink","last_synced_at":"2026-04-04T15:01:57.854Z","repository":{"id":341719124,"uuid":"1171180047","full_name":"yilee/agentlink","owner":"yilee","description":"Access your local Claude Code agent from anywhere","archived":false,"fork":false,"pushed_at":"2026-03-31T11:27:20.000Z","size":11452,"stargazers_count":6,"open_issues_count":0,"forks_count":1,"subscribers_count":0,"default_branch":"master","last_synced_at":"2026-04-03T00:39:12.259Z","etag":null,"topics":["claude","claude-code","claude-ui"],"latest_commit_sha":null,"homepage":"https://msclaude.ai","language":"TypeScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/yilee.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"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-03-03T00:33:41.000Z","updated_at":"2026-04-02T12:43:04.000Z","dependencies_parsed_at":"2026-04-02T12:04:14.941Z","dependency_job_id":null,"html_url":"https://github.com/yilee/agentlink","commit_stats":null,"previous_names":["yilee/agentlink"],"tags_count":241,"template":false,"template_full_name":null,"purl":"pkg:github/yilee/agentlink","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/yilee%2Fagentlink","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/yilee%2Fagentlink/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/yilee%2Fagentlink/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/yilee%2Fagentlink/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/yilee","download_url":"https://codeload.github.com/yilee/agentlink/tar.gz/refs/heads/master","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/yilee%2Fagentlink/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":31403952,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-04-04T10:20:44.708Z","status":"ssl_error","status_checked_at":"2026-04-04T10:20:06.846Z","response_time":60,"last_error":"SSL_read: unexpected eof while reading","robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":false,"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":["claude","claude-code","claude-ui"],"created_at":"2026-03-03T04:19:17.997Z","updated_at":"2026-04-04T15:01:57.811Z","avatar_url":"https://github.com/yilee.png","language":"TypeScript","funding_links":[],"categories":[],"sub_categories":[],"readme":"# AgenticWorker\n\n[![CI](https://github.com/yilee/agentlink/actions/workflows/ci.yml/badge.svg)](https://github.com/yilee/agentlink/actions/workflows/ci.yml)\n[![npm server](https://img.shields.io/npm/v/@agent-link/server?label=server)](https://www.npmjs.com/package/@agent-link/server)\n[![npm agent](https://img.shields.io/npm/v/@agent-link/agent?label=agent)](https://www.npmjs.com/package/@agent-link/agent)\n[![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT)\n\nEnglish | [中文](./README.zh-CN.md)\n\nAccess your local Claude Code agent from anywhere — through a shareable web URL.\n\nAgenticWorker runs a lightweight agent on your dev machine, connects it to a cloud relay, and gives you a clean chat interface at `https://msclaude.ai/xxxx`. All code execution happens locally. The relay just forwards encrypted messages.\n\n```\nBrowser (any device)  ←→  Cloud Relay  ←→  Local Agent  ←→  Your Codebase\n```\n\n## Quick Start\n\n```bash\n# Install\nnpm install -g @agent-link/agent\n\n# Start (prints a session URL)\nagentlink-client start --daemon\n\n# Open the URL in any browser — done.\n```\n\n## Three Modes\n\n### Chat\nRemote pair-programming with Claude Code. Send prompts from any browser, get real-time streaming responses with tool calls, markdown, and code blocks rendered live.\n\n### Teams\nOrchestrate multiple Claude agents in parallel. A Lead agent plans and delegates tasks to subagents, then synthesizes results — with a live kanban dashboard tracking progress.\n\n### Loop\nSchedule recurring prompts with cron expressions. Automate code reviews, dependency checks, report generation, and other routine tasks that run on your local codebase.\n\n## Why AgenticWorker?\n\n- **Access from anywhere.** Phone, tablet, another machine — just open the URL.\n- **Everything runs locally.** Your files never leave your machine. The relay only sees encrypted messages.\n- **No setup on the browser side.** No extensions, no local server, no port forwarding. One URL.\n- **Session history.** Resume previous conversations. Your Claude session files are read directly.\n- **Real-time streaming.** Tool calls, markdown, code blocks — all rendered live as Claude works.\n- **Multi-agent Teams.** Spawn parallel Claude subagents from the browser. A Lead agent plans, delegates tasks, and synthesizes results — with a live kanban dashboard.\n- **End-to-end encryption.** All WebSocket traffic is encrypted with XSalsa20-Poly1305 (TweetNaCl).\n\n## How It Works\n\n1. `agentlink-client start` connects to the relay server via WebSocket.\n2. The server assigns a unique session URL (96-bit random ID).\n3. You open the URL in a browser. The browser connects to the same relay.\n4. Messages flow: browser → relay → agent → Claude CLI → agent → relay → browser.\n5. Claude runs with `--permission-mode bypassPermissions`, so it can work autonomously.\n6. All messages between relay↔agent and relay↔browser are encrypted with per-session keys.\n\n## Commands\n\n```bash\n# Agent\nagentlink-client start [--daemon] [--server URL] [--name NAME] [--dir PATH] [--password PWD]\nagentlink-client stop\nagentlink-client status\nagentlink-client config list|get|set\nagentlink-client service install|uninstall\nagentlink-client upgrade\n\n# Self-hosted relay server\nagentlink-server start [--daemon] [--port PORT]\nagentlink-server stop\nagentlink-server status\n```\n\n## Self-Hosting\n\nYou can run your own relay server instead of using the public one:\n\n```bash\nnpm install -g @agent-link/server\nagentlink-server start --daemon --port 3456\n\n# Then point agents to your server\nagentlink-client start --daemon --server ws://your-server:3456\n```\n\n## Requirements\n\n- Node.js 18+\n- Claude CLI installed and authenticated (`claude` command available)\n\n## Architecture\n\n| Component | Tech |\n|-----------|------|\n| Agent | TypeScript, Commander.js, `ws` |\n| Server | Express, `ws`, modular architecture (SessionManager, AuthManager, MessageRelay) |\n| Web UI | Vue 3 SFC + Vite, marked.js, highlight.js |\n| Encryption | TweetNaCl (XSalsa20-Poly1305 secretbox) |\n\n## Links\n\n- [npm: @agent-link/agent](https://www.npmjs.com/package/@agent-link/agent)\n- [npm: @agent-link/server](https://www.npmjs.com/package/@agent-link/server)\n- [GitHub](https://github.com/yilee/agentlink)\n\n## License\n\nMIT\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fyilee%2Fagentlink","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fyilee%2Fagentlink","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fyilee%2Fagentlink/lists"}