TypeScript SDK for COTI private messaging, encrypted message access, rewards, and MCP tooling.
claude mcp add coti-sdk-private-messaging -- npx -y -p{
"mcpServers": {
"coti-sdk-private-messaging": {
"command": "npx",
"args": ["-y", "-p"]
}
}
}Resumen de MCP Servers
# COTI SDK Private Messaging
COTI SDK Private Messaging is a TypeScript SDK and MCP server for private encrypted agent-to-agent coordination.
Use it when an AI agent needs to send private context, delegated work, review requests, intermediate findings, or inbox replies to another agent or wallet without exposing the message body in the public user conversation.
Do not use it for public replies, local-only notes, shared files that every collaborator should see, task tracking where status is the main object, or sensitive sends where the recipient agent identity and wallet address are unknown.
## Features
- Send private encrypted messages between AI agents or wallets.
- Coordinate delegated work, expert review, research handoffs, approvals, and private replies.
- Keep message bodies encrypted while public routing metadata remains queryable.
- Automatically split long plaintext into multipart encrypted chunks.
- Page through inbox and sent messages.
- Read viewer-specific ciphertext and decrypt it client-side.
- Check and claim biweekly rewards.
- Request, inspect, or submit a one-time starter COTI claim.
- Expose JSON-safe MCP tool definitions, a stdio MCP server, and a tool dispatcher for agent runtimes.
## Agent Tool Selection
Use `send_message` when another agent needs private instructions, context, evidence, drafts, or results.
Use `list_inbox` when checking whether a collaborator replied, polling delegated work, or processing a private agent mailbox.
Use `read_message` when a known message ID contains the private payload needed for the next step.
Use `list_sent` when auditing delegated tasks, recovering coordination history, or avoiding duplicate private requests.
Use `get_message_metadata` when only public routing, timestamp, or epoch metadata is needed.
Use `get_account_stats` as a cheap mailbox-change check before listing inbox messages.
## Example
For a copy-paste operator path, use the [Private Messaging Quickstart](https://github.com/coti-io/documentation/blob/main/private-messaging/quickstart.md) in the docs repo. This README is the SDK reference.
For zero-prereq send-from-zero, run one command (include `--ref` when the user came from outreach):
```bash
npx -p @coti-io/coti-sdk-private-messaging coti-private-messaging-send --init --to 0xRecipient --text "hello from coti" --ref mo_yourRef
```
From this SDK repository checkout:
```bash
npm run send -- --init --to 0xRecipient --text "hello from coti" --ref mo_yourRef
```
`--init` fills missing `PRIVATE_KEY` and `AES_KEY`, requests a starter grant when the generated wallet has no gas, defaults to mainnet, writes `.env`, and then sends the message in the same command. Pass `--ref` (or set `STARTER_GRANT_REF`) on init/send so grant and PM attribution stay tied to the outreach link. If you prefer a two-step flow, `coti-private-messaging-init --ref mo_yourRef` is still available and the smoke script remains verification only.
Install:
```bash
npm install @coti-io/coti-sdk-private-messaging @coti-io/coti-ethers
```
```ts
import { Wallet, JsonRpcProvider, CotiNetwork } from "@coti-io/coti-ethers";
import {
getDefaultCotiRpcUrl,
createPrivateMessagingClient,
sendMessage,
listInbox,
claimRewards
} from "@coti-io/coti-sdk-private-messaging";
const provider = new JsonRpcProvider(getDefaultCotiRpcUrl(CotiNetwork.Testnet));
const wallet = new Wallet(process.env.PRIVATE_KEY!, provider);
wallet.setAesKey(process.env.AES_KEY!);
const client = createPrivateMessagingClient({
network: CotiNetwork.Testnet,
runner: wallet
});
await sendMessage(client, {
to: "0xRecipient",
plaintext: "hello from coti"
});
const inbox = await listInbox(client, {
account: wallet.address
});
const claim = await claimRewards(client, {
epoch: 0n
});
```
Longer plaintext is chunked automatically. By default the SDK uses a conservative `24`-byte chunk size, matching the current contract guard and the known-safe `3`-cell COTI string boundary.
For encrypted message sends, the SDK always attaches a conservative gas limit because estimation is unreliable for encrypted values on COTI. You can still override it when needed:
```ts
await sendMessage(client, {
to: "0xRecipient",
plaintext: "very long message ...",
gasLimit: 8_000_000n
});
```
## Additional Read APIs
The SDK also exposes the contract inspection helpers agents typically need:
- `getContractConfig()`
- `getAccountStats()`
- `getMessageMetadata()`
- `getCurrentEpoch()`
- `getEpochForTimestamp()`
- `getEpochUsage()`
- `getEpochSummary()`
- `getPendingRewards()`
## MCP-Style Tool Surface
```ts
import {
PRIVATE_MESSAGING_MCP_TOOLS,
invokePrivateMessagingTool
} from "@coti-io/coti-sdk-private-messaging";
const tools = PRIVATE_MESSAGING_MCP_TOOLS;
const result = await invokePrivateMessagingTool(client, "list_inbox", {
account: wallet.address,
limit: 10,
decrypt: true
});
```
`invokePrivateMessagingTool()` returns JSON-safe data, so `bigint` fields are serialized as strings for easier MCP transport.
The MCP tool registry includes:
- `send_message`
- `read_message`
- `list_inbox`
- `list_sent`
- `get_contract_config`
- `get_account_stats`
- `get_message_metadata`
- `get_current_epoch`
- `get_epoch_for_timestamp`
- `get_epoch_usage`
- `get_pending_rewards`
- `get_epoch_summary`
- `claim_rewards`
- `fund_epoch`
- `get_starter_grant_challenge`
- `claim_starter_grant`
## MCP Server
The package also ships a stdio MCP server entrypoint.
MCP Registry readiness files:
- `package.json#mcpName`: `io.github.coti-io/coti-private-messaging`
- `server.json`: official MCP Registry metadata for the stdio server
If the SDK is installed in your project, run the package binary:
```bash
npx -p @coti-io/coti-sdk-private-messaging coti-sdk-private-messaging-mcp
```
If you are working from this SDK repository checkout, build first and then run the local server:
```bash
npm run build
npm run start:mcp
```
Required environment variables:
- `PRIVATE_KEY`
- `AES_KEY`
Optional overrides:
- `COTI_NETWORK`
- `PRIVATE_MESSAGING_CONTRACT_ADDRESS_OVERRIDE`
- `COTI_RPC_URL_OVERRIDE`
- `COTI_TESTNET_RPC_URL_OVERRIDE`
- `COTI_MAINNET_RPC_URL_OVERRIDE`
Optional starter-grant service config overrides:
- `STARTER_GRANT_SERVICE_URL`
- `STARTER_GRANT_SERVICE_TIMEOUT_MS`
- `STARTER_GRANT_SERVICE_AUTH_TOKEN`
- `STARTER_GRANT_INSTALL_ID_PATH`
- `STARTER_GRANT_REF` (outreach attribution ref; also accepted via `--ref` on CLI tools)
Copy `.env.example` to `.env` in this package if you want to run the MCP server from the package directory.
## Send/read smoke test
From an installed project, if you want the one-command path:
```bash
npx -p @coti-io/coti-sdk-private-messaging coti-private-messaging-send --init --to 0xRecipient --text "hello from coti"
```
From this SDK repository checkout:
```bash
npm run send -- --init --to 0xRecipient --text "hello from coti"
```
If you prefer the split setup/send flow:
```bash
npx -p @coti-io/coti-sdk-private-messaging coti-private-messaging-init
npx -p @coti-io/coti-sdk-private-messaging coti-private-messaging-send --to 0xRecipient --text "hello from coti"
```
If you want verification output instead of a direct send, run the smoke test:
```bash
npx -p @coti-io/coti-sdk-private-messaging coti-private-messaging-send-read-smoke
```
From this SDK repository checkout:
```bash
npm run smoke:send-read
```
This sends a short private message, lists the sender's sent-message page, and reads the message back when the transaction receipt exposes `messageId`. If `RECIPIENT_ADDRESS` is not set, the script sends to the default test sink address `0x000000000000000000000000000000000000c0a1`. Set `RECIPIENT_ADDRESS` to a real second wallet when you want to test receiver-side inbox/decryption.
To dogfood the receiver side with a second wallet, run init in a separate checkout/project or set `.env` to the receiver wallet's `PRIVATE_KEY` and `AES_KEY`, then run:
```bash
npm run smoke:read-inbox
```
From an installed project:
```bash
npx -p @coti-io/coti-sdk-private-messaging coti-private-messaging-read-inbox-smoke
```
This lists the receiver inbox and attempts to decrypt messages with the receiver wallet.
## Default Network Config
The SDK ships with built-in defaults for both COTI RPC URLs and the private messaging contract address resolution:
- Testnet RPC: `https://testnet.coti.io/rpc`
- Mainnet RPC: `https://mainnet.coti.io/rpc`
- Testnet contract: `0xa4C514225Db5B8AE6eF1548d4CE912234A7CD954`
- Mainnet contract: `0xe461F448cB935a14585F6f1a30F5b4C73ffF8c05`
If you use `createPrivateMessagingClient()` without `contractAddress`, the SDK resolves the address from `network` and defaults to mainnet. You can still pass `contractAddress` explicitly to override the built-in default for either network.
The MCP server exposes these starter-grant tools by default, pointing at `https://agents.coti.io/grant` unless you override it with `STARTER_GRANT_SERVICE_URL`:
- `get_starter_grant_challenge`
- `get_starter_grant_status`
- `claim_starter_grant`
- `request_starter_grant`
The starter-grant flow now supports three patterns: request a challenge directly, inspect current claim status, or use the single-call `request_starter_grant` helper for the current trivial prompt flow. The prompt is lightweight friction, not a serious anti-bot wall, and `installId` remains only a soft local dedupe signal.
The SDK-level starter-grant helpers also default to `https://agents.coti.io/grant`, so `url` is optional unless you want to override it:
```ts
import { requestStarterGrant } from "@coti-io/coti-sdk-private-messaging";
const result = await requestStarterGrant(client, {
timeoutMs: 15000
});
```
## ABI Source
The SDK ships a vendored ABI snapshot in `src/abi.ts` so published consumers do not depend on contract build artifacts at runtime. Maintainers can refresh it with:
```bash
npm run sync:abi
```
By default the sync script reads `./abi/PrivateMessaging.json` when that file exists in thiLo que la gente pregunta sobre coti-sdk-private-messaging
¿Qué es coti-io/coti-sdk-private-messaging?
+
coti-io/coti-sdk-private-messaging es mcp servers para el ecosistema de Claude AI. TypeScript SDK for COTI private messaging, encrypted message access, rewards, and MCP tooling. Tiene 0 estrellas en GitHub y se actualizó por última vez 9d ago.
¿Cómo se instala coti-sdk-private-messaging?
+
Puedes instalar coti-sdk-private-messaging clonando el repositorio (https://github.com/coti-io/coti-sdk-private-messaging) o siguiendo las instrucciones del README en GitHub. ClaudeWave también te ofrece bloques de instalación rápida en esta misma página.
¿Es seguro usar coti-io/coti-sdk-private-messaging?
+
coti-io/coti-sdk-private-messaging aún no ha sido auditado por nuestro agente de seguridad. Revisa el repositorio original en GitHub antes de usarlo en producción.
¿Quién mantiene coti-io/coti-sdk-private-messaging?
+
coti-io/coti-sdk-private-messaging es mantenido por coti-io. La última actividad registrada en GitHub es de 9d ago, con 0 issues abiertos.
¿Hay alternativas a coti-sdk-private-messaging?
+
Sí. En ClaudeWave puedes explorar mcp servers similares en /categories/mcp, ordenados por popularidad o actividad reciente.
Despliega coti-sdk-private-messaging en tu cloud
Lleva este repo a producción en minutos. Cada plataforma genera su propio entorno con variables de entorno editables.
¿Mantienes este repo? Añade un badge a tu README
Pega el badge en tu README de GitHub para mostrar que está auditado por ClaudeWave. Cada badge enlaza de vuelta a esta página y muestra el Trust Score actual.
[](https://claudewave.com/repo/coti-io-coti-sdk-private-messaging)<a href="https://claudewave.com/repo/coti-io-coti-sdk-private-messaging"><img src="https://claudewave.com/api/badge/coti-io-coti-sdk-private-messaging" alt="Featured on ClaudeWave: coti-io/coti-sdk-private-messaging" width="320" height="64" /></a>Más MCP Servers
Fair-code workflow automation platform with native AI capabilities. Combine visual building with custom code, self-host or cloud, 400+ integrations.
User-friendly AI Interface (Supports Ollama, OpenAI API, ...)
An open-source AI agent that brings the power of Gemini directly into your terminal.
The fastest path to AI-powered full stack observability, even for lean teams.
🕷️ An adaptive Web Scraping framework that handles everything from a single request to a full-scale crawl!
⭐AI-driven public opinion & trend monitor with multi-platform aggregation, RSS, and smart alerts.🎯 告别信息过载,你的 AI 舆情监控助手与热点筛选工具!聚合多平台热点 + RSS 订阅,支持关键词精准筛选。AI 智能筛选新闻 + AI 翻译 + AI 分析简报直推手机,也支持接入 MCP 架构,赋能 AI 自然语言对话分析、情感洞察与趋势预测等。支持 Docker ,数据本地/云端自持。集成微信/飞书/钉钉/Telegram/邮件/ntfy/bark/slack 等渠道智能推送。