Skip to main content
ClaudeWave
coti-io avatar
coti-io

coti-sdk-private-messaging

Ver en GitHub

TypeScript SDK for COTI private messaging, encrypted message access, rewards, and MCP tooling.

MCP ServersRegistry oficial0 estrellas0 forksTypeScriptApache-2.0Actualizado 9d ago
Install in Claude Code / Claude Desktop
Method: NPX · -p
Claude Code CLI
claude mcp add coti-sdk-private-messaging -- npx -y -p
claude_desktop_config.json (Claude Desktop)
{
  "mcpServers": {
    "coti-sdk-private-messaging": {
      "command": "npx",
      "args": ["-y", "-p"]
    }
  }
}
1. Run the command above in your terminal (Claude Code), or paste the JSON config into claude_desktop_config.json (Claude Desktop).
2. Replace any <placeholder> values with your API keys or paths.
3. Restart Claude. The MCP server and its tools appear automatically.
Casos de uso

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 thi

Lo 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.

Featured on ClaudeWave: coti-io/coti-sdk-private-messaging
[![Featured on ClaudeWave](https://claudewave.com/api/badge/coti-io-coti-sdk-private-messaging)](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

Alternativas a coti-sdk-private-messaging