{"id":50556057,"url":"https://github.com/sunilp/aip-node","last_synced_at":"2026-06-04T07:02:51.159Z","repository":{"id":353865918,"uuid":"1220611357","full_name":"sunilp/aip-node","owner":"sunilp","description":"AIP TypeScript SDK: verifiable agent identity for MCP and A2A. Ed25519 tokens, delegation chains, capability enforcement.","archived":false,"fork":false,"pushed_at":"2026-04-25T06:20:25.000Z","size":83,"stargazers_count":0,"open_issues_count":0,"forks_count":0,"subscribers_count":0,"default_branch":"main","last_synced_at":"2026-04-26T01:10:19.257Z","etag":null,"topics":["a2a","agent-identity","ai-agents","ai-security","authentication","biscuit","delegation","ed25519","identity-protocol","jwt","mcp","model-context-protocol","typescript"],"latest_commit_sha":null,"homepage":"https://sunilprakash.com/aip/","language":"TypeScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"other","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/sunilp.png","metadata":{"files":{"readme":"README.md","changelog":"CHANGELOG.md","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-04-25T05:16:49.000Z","updated_at":"2026-04-25T06:25:41.000Z","dependencies_parsed_at":null,"dependency_job_id":null,"html_url":"https://github.com/sunilp/aip-node","commit_stats":null,"previous_names":["sunilp/aip-node"],"tags_count":null,"template":false,"template_full_name":null,"purl":"pkg:github/sunilp/aip-node","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/sunilp%2Faip-node","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/sunilp%2Faip-node/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/sunilp%2Faip-node/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/sunilp%2Faip-node/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/sunilp","download_url":"https://codeload.github.com/sunilp/aip-node/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/sunilp%2Faip-node/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":33893323,"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-04T02:00:06.755Z","response_time":64,"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":["a2a","agent-identity","ai-agents","ai-security","authentication","biscuit","delegation","ed25519","identity-protocol","jwt","mcp","model-context-protocol","typescript"],"created_at":"2026-06-04T07:02:50.192Z","updated_at":"2026-06-04T07:02:51.152Z","avatar_url":"https://github.com/sunilp.png","language":"TypeScript","funding_links":[],"categories":[],"sub_categories":[],"readme":"# AIP TypeScript SDK\n\nTypeScript implementation of the [Agent Identity Protocol (AIP)](https://github.com/sunilp/aip) for verifiable, delegable AI agent identity.\n\nFull spec implementation including features not yet available in the Python SDK: DNS-based identity resolution, completion blocks for provenance, HTTP binding, and A2A binding.\n\n## Packages\n\n| Package | Description |\n|---------|-------------|\n| [`@aip-sdk/core`](packages/core) | Ed25519 identity, key management, identity documents, DNS resolution, completion blocks |\n| [`@aip-sdk/token`](packages/token) | Compact (JWT+EdDSA) and chained (Biscuit+Datalog) tokens |\n| [`@aip-sdk/mcp`](packages/mcp) | MCP proxy middleware, audit, token verification, HTTP binding |\n| [`@aip-sdk/agents`](packages/agents) | Framework adapters (LangChain.js, Vercel AI SDK), A2A binding |\n\n## Quick Start\n\n```bash\nnpm install @aip-sdk/core @aip-sdk/token\n```\n\n```typescript\nimport { KeyPair } from \"@aip-sdk/core\";\nimport { CompactToken } from \"@aip-sdk/token\";\n\n// Generate identity\nconst keypair = await KeyPair.generate();\nconst aipId = `aip:key:ed25519:${keypair.publicKeyMultibase()}`;\n\n// Issue token\nconst token = await CompactToken.create(\n  {\n    iss: aipId,\n    sub: \"aip:key:ed25519:zAgent1\",\n    scope: [\"tool:search\"],\n    max_depth: 0,\n    iat: Math.floor(Date.now() / 1000),\n    exp: Math.floor(Date.now() / 1000) + 3600,\n  },\n  keypair\n);\n\n// Verify token\nconst verified = await CompactToken.verify(token, keypair.publicKeyBytes());\nconsole.log(\"Verified:\", verified.claims.scope);\n```\n\n## MCP Proxy\n\nProtect MCP servers with token verification:\n\n```typescript\nimport { AipProxy, ProxyConfig } from \"@aip-sdk/mcp\";\n\nconst config = new ProxyConfig({\n  upstream: \"http://localhost:3000\",\n  port: 8080,\n  trustKeys: [\"z6MkhaXgBZDvotDkL5LQ...\"],\n});\n\nconst proxy = new AipProxy(config);\nproxy.serveForever();\n```\n\n## Agent Framework Integration\n\n### LangChain.js\n\n```typescript\nimport { AIPLangChainPlugin } from \"@aip-sdk/agents\";\n\nconst plugin = new AIPLangChainPlugin();\nawait plugin.register(agentExecutor, \"search-agent\");\n\nconst headers = await plugin.getToolCallHeaders(\"search-agent\");\n// { \"X-AIP-Token\": \"eyJ...\" }\n```\n\n### Vercel AI SDK\n\n```typescript\nimport { AIPVercelAIPlugin } from \"@aip-sdk/agents\";\n\nconst plugin = new AIPVercelAIPlugin();\nawait plugin.register(\"assistant\", [\"search\", \"calculate\"]);\n\nconst headers = await plugin.getToolCallHeaders(\"assistant\");\n```\n\n## Protocol\n\n- Paper: [arXiv:2603.24775](https://arxiv.org/abs/2603.24775)\n- IETF: [draft-prakash-aip-00](https://datatracker.ietf.org/doc/draft-prakash-aip/)\n- Spec: [sunilprakash.com/aip/](https://sunilprakash.com/aip/)\n- Python SDK: [agent-identity-protocol on PyPI](https://pypi.org/project/agent-identity-protocol/)\n\n## License\n\nApache 2.0\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fsunilp%2Faip-node","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fsunilp%2Faip-node","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fsunilp%2Faip-node/lists"}