@tokenrip/cli 1.0.1 → 1.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (93) hide show
  1. package/README.md +248 -35
  2. package/dist/cjs/client.js +2 -1
  3. package/dist/cjs/client.js.map +1 -1
  4. package/dist/cjs/commands/auth.js +72 -25
  5. package/dist/cjs/commands/auth.js.map +1 -1
  6. package/dist/cjs/commands/config.js +12 -0
  7. package/dist/cjs/commands/config.js.map +1 -1
  8. package/dist/cjs/commands/contacts.js +36 -0
  9. package/dist/cjs/commands/contacts.js.map +1 -0
  10. package/dist/cjs/commands/inbox.js +36 -0
  11. package/dist/cjs/commands/inbox.js.map +1 -0
  12. package/dist/cjs/commands/msg.js +51 -0
  13. package/dist/cjs/commands/msg.js.map +1 -0
  14. package/dist/cjs/commands/operator-link.js +32 -0
  15. package/dist/cjs/commands/operator-link.js.map +1 -0
  16. package/dist/cjs/commands/share.js +33 -0
  17. package/dist/cjs/commands/share.js.map +1 -0
  18. package/dist/cjs/commands/thread-share.js +32 -0
  19. package/dist/cjs/commands/thread-share.js.map +1 -0
  20. package/dist/cjs/commands/thread.js +39 -0
  21. package/dist/cjs/commands/thread.js.map +1 -0
  22. package/dist/cjs/config.js +7 -3
  23. package/dist/cjs/config.js.map +1 -1
  24. package/dist/cjs/contacts.js +64 -0
  25. package/dist/cjs/contacts.js.map +1 -0
  26. package/dist/cjs/crypto.js +47 -0
  27. package/dist/cjs/crypto.js.map +1 -0
  28. package/dist/cjs/formatters.js +120 -1
  29. package/dist/cjs/formatters.js.map +1 -1
  30. package/dist/cjs/identity.js +25 -0
  31. package/dist/cjs/identity.js.map +1 -0
  32. package/dist/cjs/index.js +27 -1
  33. package/dist/cjs/index.js.map +1 -1
  34. package/dist/cjs/output.js +11 -11
  35. package/dist/cjs/output.js.map +1 -1
  36. package/dist/cjs/state.js +24 -0
  37. package/dist/cjs/state.js.map +1 -0
  38. package/dist/cli.js +180 -21
  39. package/dist/cli.js.map +1 -1
  40. package/dist/client.js +2 -1
  41. package/dist/client.js.map +1 -1
  42. package/dist/commands/auth.d.ts +5 -3
  43. package/dist/commands/auth.js +70 -25
  44. package/dist/commands/auth.js.map +1 -1
  45. package/dist/commands/config.d.ts +1 -0
  46. package/dist/commands/config.js +12 -1
  47. package/dist/commands/config.js.map +1 -1
  48. package/dist/commands/contacts.d.ts +7 -0
  49. package/dist/commands/contacts.js +30 -0
  50. package/dist/commands/contacts.js.map +1 -0
  51. package/dist/commands/inbox.d.ts +6 -0
  52. package/dist/commands/inbox.js +33 -0
  53. package/dist/commands/inbox.js.map +1 -0
  54. package/dist/commands/msg.d.ts +13 -0
  55. package/dist/commands/msg.js +47 -0
  56. package/dist/commands/msg.js.map +1 -0
  57. package/dist/commands/operator-link.d.ts +3 -0
  58. package/dist/commands/operator-link.js +29 -0
  59. package/dist/commands/operator-link.js.map +1 -0
  60. package/dist/commands/share.d.ts +6 -0
  61. package/dist/commands/share.js +29 -0
  62. package/dist/commands/share.js.map +1 -0
  63. package/dist/commands/thread-share.d.ts +4 -0
  64. package/dist/commands/thread-share.js +29 -0
  65. package/dist/commands/thread-share.js.map +1 -0
  66. package/dist/commands/thread.d.ts +8 -0
  67. package/dist/commands/thread.js +35 -0
  68. package/dist/commands/thread.js.map +1 -0
  69. package/dist/config.d.ts +1 -0
  70. package/dist/config.js +6 -3
  71. package/dist/config.js.map +1 -1
  72. package/dist/contacts.d.ts +16 -0
  73. package/dist/contacts.js +53 -0
  74. package/dist/contacts.js.map +1 -0
  75. package/dist/crypto.d.ts +16 -0
  76. package/dist/crypto.js +40 -0
  77. package/dist/crypto.js.map +1 -0
  78. package/dist/formatters.d.ts +7 -0
  79. package/dist/formatters.js +112 -0
  80. package/dist/formatters.js.map +1 -1
  81. package/dist/identity.d.ts +7 -0
  82. package/dist/identity.js +18 -0
  83. package/dist/identity.js.map +1 -0
  84. package/dist/index.d.ts +5 -0
  85. package/dist/index.js +4 -0
  86. package/dist/index.js.map +1 -1
  87. package/dist/output.d.ts +1 -1
  88. package/dist/output.js +10 -10
  89. package/dist/output.js.map +1 -1
  90. package/dist/state.d.ts +5 -0
  91. package/dist/state.js +17 -0
  92. package/dist/state.js.map +1 -0
  93. package/package.json +3 -1
@@ -0,0 +1,33 @@
1
+ import { requireAuthClient } from '../auth-client.js';
2
+ import { CliError } from '../errors.js';
3
+ import { outputSuccess } from '../output.js';
4
+ import { formatInbox } from '../formatters.js';
5
+ import { loadState, saveState } from '../state.js';
6
+ export async function inbox(options) {
7
+ const { client } = requireAuthClient();
8
+ const state = loadState();
9
+ // Determine "since" value: explicit flag > stored cursor > 24h ago
10
+ const sinceOverride = options.since;
11
+ const since = sinceOverride
12
+ ?? state.lastInboxPoll
13
+ ?? new Date(Date.now() - 86400000).toISOString();
14
+ const params = { since };
15
+ if (options.types)
16
+ params.types = options.types;
17
+ if (options.limit)
18
+ params.limit = options.limit;
19
+ try {
20
+ const { data } = await client.get('/v0/inbox', { params });
21
+ const result = data.data;
22
+ if (!sinceOverride) {
23
+ saveState({ ...state, lastInboxPoll: new Date().toISOString() });
24
+ }
25
+ outputSuccess(result, formatInbox);
26
+ }
27
+ catch (error) {
28
+ if (error instanceof CliError)
29
+ throw error;
30
+ throw new CliError('INBOX_FAILED', 'Failed to fetch inbox. Is the server running?');
31
+ }
32
+ }
33
+ //# sourceMappingURL=inbox.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"inbox.js","sourceRoot":"","sources":["../../src/commands/inbox.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,mBAAmB,CAAC;AACtD,OAAO,EAAE,QAAQ,EAAE,MAAM,cAAc,CAAC;AACxC,OAAO,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AAC7C,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EAAE,SAAS,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAEnD,MAAM,CAAC,KAAK,UAAU,KAAK,CAAC,OAK3B;IACC,MAAM,EAAE,MAAM,EAAE,GAAG,iBAAiB,EAAE,CAAC;IACvC,MAAM,KAAK,GAAG,SAAS,EAAE,CAAC;IAE1B,mEAAmE;IACnE,MAAM,aAAa,GAAG,OAAO,CAAC,KAAK,CAAC;IACpC,MAAM,KAAK,GAAG,aAAa;WACtB,KAAK,CAAC,aAAa;WACnB,IAAI,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,QAAQ,CAAC,CAAC,WAAW,EAAE,CAAC;IAEnD,MAAM,MAAM,GAA2B,EAAE,KAAK,EAAE,CAAC;IACjD,IAAI,OAAO,CAAC,KAAK;QAAE,MAAM,CAAC,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC;IAChD,IAAI,OAAO,CAAC,KAAK;QAAE,MAAM,CAAC,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC;IAEhD,IAAI,CAAC;QACH,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,MAAM,CAAC,GAAG,CAAC,WAAW,EAAE,EAAE,MAAM,EAAE,CAAC,CAAC;QAC3D,MAAM,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC;QAEzB,IAAI,CAAC,aAAa,EAAE,CAAC;YACnB,SAAS,CAAC,EAAE,GAAG,KAAK,EAAE,aAAa,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,EAAE,CAAC,CAAC;QACnE,CAAC;QAED,aAAa,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;IACrC,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,IAAI,KAAK,YAAY,QAAQ;YAAE,MAAM,KAAK,CAAC;QAC3C,MAAM,IAAI,QAAQ,CAAC,cAAc,EAAE,+CAA+C,CAAC,CAAC;IACtF,CAAC;AACH,CAAC"}
@@ -0,0 +1,13 @@
1
+ export declare function msgSend(body: string, options: {
2
+ to?: string;
3
+ thread?: string;
4
+ intent?: string;
5
+ type?: string;
6
+ data?: string;
7
+ inReplyTo?: string;
8
+ }): Promise<void>;
9
+ export declare function msgList(options: {
10
+ thread: string;
11
+ since?: string;
12
+ limit?: string;
13
+ }): Promise<void>;
@@ -0,0 +1,47 @@
1
+ import { requireAuthClient } from '../auth-client.js';
2
+ import { CliError } from '../errors.js';
3
+ import { outputSuccess } from '../output.js';
4
+ import { formatMessageSent, formatMessages } from '../formatters.js';
5
+ import { resolveRecipient } from '../contacts.js';
6
+ export async function msgSend(body, options) {
7
+ if (!options.to && !options.thread) {
8
+ throw new CliError('MISSING_OPTION', 'Provide --to <recipient> or --thread <id>');
9
+ }
10
+ if (options.to && options.thread) {
11
+ throw new CliError('CONFLICTING_OPTIONS', 'Use --to or --thread, not both');
12
+ }
13
+ const { client } = requireAuthClient();
14
+ const payload = { body };
15
+ if (options.intent)
16
+ payload.intent = options.intent;
17
+ if (options.type)
18
+ payload.type = options.type;
19
+ if (options.data)
20
+ payload.data = JSON.parse(options.data);
21
+ let endpoint;
22
+ if (options.to) {
23
+ payload.to = [resolveRecipient(options.to)];
24
+ endpoint = '/v0/messages';
25
+ }
26
+ else {
27
+ if (options.inReplyTo)
28
+ payload.in_reply_to = options.inReplyTo;
29
+ endpoint = `/v0/threads/${options.thread}/messages`;
30
+ }
31
+ const { data } = await client.post(endpoint, payload);
32
+ outputSuccess(data.data, formatMessageSent);
33
+ }
34
+ export async function msgList(options) {
35
+ if (!options.thread) {
36
+ throw new CliError('MISSING_OPTION', '--thread <id> is required');
37
+ }
38
+ const { client } = requireAuthClient();
39
+ const params = {};
40
+ if (options.since)
41
+ params.since_sequence = options.since;
42
+ if (options.limit)
43
+ params.limit = options.limit;
44
+ const { data } = await client.get(`/v0/threads/${options.thread}/messages`, { params });
45
+ outputSuccess(data.data, formatMessages);
46
+ }
47
+ //# sourceMappingURL=msg.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"msg.js","sourceRoot":"","sources":["../../src/commands/msg.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,mBAAmB,CAAC;AACtD,OAAO,EAAE,QAAQ,EAAE,MAAM,cAAc,CAAC;AACxC,OAAO,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AAC7C,OAAO,EAAE,iBAAiB,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AACrE,OAAO,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAElD,MAAM,CAAC,KAAK,UAAU,OAAO,CAC3B,IAAY,EACZ,OAOC;IAED,IAAI,CAAC,OAAO,CAAC,EAAE,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC;QACnC,MAAM,IAAI,QAAQ,CAAC,gBAAgB,EAAE,2CAA2C,CAAC,CAAC;IACpF,CAAC;IACD,IAAI,OAAO,CAAC,EAAE,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC;QACjC,MAAM,IAAI,QAAQ,CAAC,qBAAqB,EAAE,gCAAgC,CAAC,CAAC;IAC9E,CAAC;IAED,MAAM,EAAE,MAAM,EAAE,GAAG,iBAAiB,EAAE,CAAC;IAEvC,MAAM,OAAO,GAA4B,EAAE,IAAI,EAAE,CAAC;IAClD,IAAI,OAAO,CAAC,MAAM;QAAE,OAAO,CAAC,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IACpD,IAAI,OAAO,CAAC,IAAI;QAAE,OAAO,CAAC,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;IAC9C,IAAI,OAAO,CAAC,IAAI;QAAE,OAAO,CAAC,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IAE1D,IAAI,QAAgB,CAAC;IACrB,IAAI,OAAO,CAAC,EAAE,EAAE,CAAC;QACf,OAAO,CAAC,EAAE,GAAG,CAAC,gBAAgB,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,CAAC;QAC5C,QAAQ,GAAG,cAAc,CAAC;IAC5B,CAAC;SAAM,CAAC;QACN,IAAI,OAAO,CAAC,SAAS;YAAE,OAAO,CAAC,WAAW,GAAG,OAAO,CAAC,SAAS,CAAC;QAC/D,QAAQ,GAAG,eAAe,OAAO,CAAC,MAAM,WAAW,CAAC;IACtD,CAAC;IAED,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,MAAM,CAAC,IAAI,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;IACtD,aAAa,CAAC,IAAI,CAAC,IAAI,EAAE,iBAAiB,CAAC,CAAC;AAC9C,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,OAAO,CAAC,OAI7B;IACC,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC;QACpB,MAAM,IAAI,QAAQ,CAAC,gBAAgB,EAAE,2BAA2B,CAAC,CAAC;IACpE,CAAC;IAED,MAAM,EAAE,MAAM,EAAE,GAAG,iBAAiB,EAAE,CAAC;IACvC,MAAM,MAAM,GAA2B,EAAE,CAAC;IAC1C,IAAI,OAAO,CAAC,KAAK;QAAE,MAAM,CAAC,cAAc,GAAG,OAAO,CAAC,KAAK,CAAC;IACzD,IAAI,OAAO,CAAC,KAAK;QAAE,MAAM,CAAC,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC;IAEhD,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,MAAM,CAAC,GAAG,CAAC,eAAe,OAAO,CAAC,MAAM,WAAW,EAAE,EAAE,MAAM,EAAE,CAAC,CAAC;IACxF,aAAa,CAAC,IAAI,CAAC,IAA0C,EAAE,cAAc,CAAC,CAAC;AACjF,CAAC"}
@@ -0,0 +1,3 @@
1
+ export declare function operatorLink(options: {
2
+ expires?: string;
3
+ }): Promise<void>;
@@ -0,0 +1,29 @@
1
+ import { randomUUID } from 'node:crypto';
2
+ import { loadIdentity } from '../identity.js';
3
+ import { signPayload } from '../crypto.js';
4
+ import { getFrontendUrl } from '../config.js';
5
+ import { CliError } from '../errors.js';
6
+ import { outputSuccess } from '../output.js';
7
+ import { parseDuration } from './share.js';
8
+ export async function operatorLink(options) {
9
+ const identity = loadIdentity();
10
+ if (!identity) {
11
+ throw new CliError('NO_IDENTITY', 'No agent identity found. Run `tokenrip auth register` first.');
12
+ }
13
+ const exp = options.expires
14
+ ? parseDuration(options.expires)
15
+ : Math.floor(Date.now() / 1000) + 300; // default 5 minutes
16
+ const token = signPayload({ sub: 'operator-auth', iss: identity.agentId, exp, jti: randomUUID() }, identity.secretKey);
17
+ const frontendUrl = getFrontendUrl();
18
+ const url = `${frontendUrl}/operator/auth?token=${encodeURIComponent(token)}`;
19
+ outputSuccess({ url, token, agent_id: identity.agentId, expires_at: new Date(exp * 1000).toISOString() }, (data) => [
20
+ '',
21
+ `Operator link for ${data.agent_id}:`,
22
+ '',
23
+ ` ${data.url}`,
24
+ '',
25
+ `Expires: ${data.expires_at}`,
26
+ '',
27
+ ].join('\n'));
28
+ }
29
+ //# sourceMappingURL=operator-link.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"operator-link.js","sourceRoot":"","sources":["../../src/commands/operator-link.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AACzC,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAC9C,OAAO,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AAC3C,OAAO,EAAE,cAAc,EAAE,MAAM,cAAc,CAAC;AAC9C,OAAO,EAAE,QAAQ,EAAE,MAAM,cAAc,CAAC;AACxC,OAAO,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AAC7C,OAAO,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAE3C,MAAM,CAAC,KAAK,UAAU,YAAY,CAChC,OAA6B;IAE7B,MAAM,QAAQ,GAAG,YAAY,EAAE,CAAC;IAChC,IAAI,CAAC,QAAQ,EAAE,CAAC;QACd,MAAM,IAAI,QAAQ,CAAC,aAAa,EAAE,8DAA8D,CAAC,CAAC;IACpG,CAAC;IAED,MAAM,GAAG,GAAG,OAAO,CAAC,OAAO;QACzB,CAAC,CAAC,aAAa,CAAC,OAAO,CAAC,OAAO,CAAC;QAChC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC,GAAG,GAAG,CAAC,CAAC,oBAAoB;IAE7D,MAAM,KAAK,GAAG,WAAW,CACvB,EAAE,GAAG,EAAE,eAAe,EAAE,GAAG,EAAE,QAAQ,CAAC,OAAO,EAAE,GAAG,EAAE,GAAG,EAAE,UAAU,EAAE,EAAE,EACvE,QAAQ,CAAC,SAAS,CACnB,CAAC;IAEF,MAAM,WAAW,GAAG,cAAc,EAAE,CAAC;IACrC,MAAM,GAAG,GAAG,GAAG,WAAW,wBAAwB,kBAAkB,CAAC,KAAK,CAAC,EAAE,CAAC;IAE9E,aAAa,CACX,EAAE,GAAG,EAAE,KAAK,EAAE,QAAQ,EAAE,QAAQ,CAAC,OAAO,EAAE,UAAU,EAAE,IAAI,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,CAAC,WAAW,EAAE,EAAE,EAC1F,CAAC,IAAI,EAAE,EAAE,CAAC;QACR,EAAE;QACF,qBAAqB,IAAI,CAAC,QAAQ,GAAG;QACrC,EAAE;QACF,KAAK,IAAI,CAAC,GAAG,EAAE;QACf,EAAE;QACF,YAAY,IAAI,CAAC,UAAU,EAAE;QAC7B,EAAE;KACH,CAAC,IAAI,CAAC,IAAI,CAAC,CACb,CAAC;AACJ,CAAC"}
@@ -0,0 +1,6 @@
1
+ export declare function parseDuration(s: string): number;
2
+ export declare function share(assetId: string, options: {
3
+ commentOnly?: boolean;
4
+ expires?: string;
5
+ for?: string;
6
+ }): Promise<void>;
@@ -0,0 +1,29 @@
1
+ import { loadIdentity } from '../identity.js';
2
+ import { createCapabilityToken } from '../crypto.js';
3
+ import { getFrontendUrl } from '../config.js';
4
+ import { CliError } from '../errors.js';
5
+ import { outputSuccess } from '../output.js';
6
+ import { formatShareLink } from '../formatters.js';
7
+ export function parseDuration(s) {
8
+ const match = s.match(/^(\d+)(s|m|h|d)$/);
9
+ if (!match)
10
+ throw new CliError('INVALID_DURATION', `Invalid duration: ${s}. Use e.g. 1h, 7d, 30m`);
11
+ const n = parseInt(match[1], 10);
12
+ const unit = match[2];
13
+ const multipliers = { s: 1, m: 60, h: 3600, d: 86400 };
14
+ return Math.floor(Date.now() / 1000) + n * multipliers[unit];
15
+ }
16
+ export async function share(assetId, options) {
17
+ const identity = loadIdentity();
18
+ if (!identity) {
19
+ throw new CliError('NO_IDENTITY', 'No agent identity found. Run `tokenrip auth register` first.');
20
+ }
21
+ const perm = options.commentOnly ? ['comment'] : ['comment', 'version:create'];
22
+ const exp = options.expires ? parseDuration(options.expires) : undefined;
23
+ const aud = options.for || undefined;
24
+ const token = createCapabilityToken({ sub: `asset:${assetId}`, iss: identity.agentId, perm, exp, aud }, identity.secretKey);
25
+ const frontendUrl = getFrontendUrl();
26
+ const url = `${frontendUrl}/s/${assetId}?cap=${encodeURIComponent(token)}`;
27
+ outputSuccess({ url, token, assetId, perm, exp: exp ?? null, aud: aud ?? null }, formatShareLink);
28
+ }
29
+ //# sourceMappingURL=share.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"share.js","sourceRoot":"","sources":["../../src/commands/share.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAC9C,OAAO,EAAE,qBAAqB,EAAE,MAAM,cAAc,CAAC;AACrD,OAAO,EAAE,cAAc,EAAE,MAAM,cAAc,CAAC;AAC9C,OAAO,EAAE,QAAQ,EAAE,MAAM,cAAc,CAAC;AACxC,OAAO,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AAC7C,OAAO,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAC;AAEnD,MAAM,UAAU,aAAa,CAAC,CAAS;IACrC,MAAM,KAAK,GAAG,CAAC,CAAC,KAAK,CAAC,kBAAkB,CAAC,CAAC;IAC1C,IAAI,CAAC,KAAK;QAAE,MAAM,IAAI,QAAQ,CAAC,kBAAkB,EAAE,qBAAqB,CAAC,wBAAwB,CAAC,CAAC;IACnG,MAAM,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;IACjC,MAAM,IAAI,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;IACtB,MAAM,WAAW,GAA2B,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC;IAC/E,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,WAAW,CAAC,IAAI,CAAC,CAAC;AAC/D,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,KAAK,CACzB,OAAe,EACf,OAAkE;IAElE,MAAM,QAAQ,GAAG,YAAY,EAAE,CAAC;IAChC,IAAI,CAAC,QAAQ,EAAE,CAAC;QACd,MAAM,IAAI,QAAQ,CAAC,aAAa,EAAE,8DAA8D,CAAC,CAAC;IACpG,CAAC;IAED,MAAM,IAAI,GAAG,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,EAAE,gBAAgB,CAAC,CAAC;IAC/E,MAAM,GAAG,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,aAAa,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;IACzE,MAAM,GAAG,GAAG,OAAO,CAAC,GAAG,IAAI,SAAS,CAAC;IAErC,MAAM,KAAK,GAAG,qBAAqB,CACjC,EAAE,GAAG,EAAE,SAAS,OAAO,EAAE,EAAE,GAAG,EAAE,QAAQ,CAAC,OAAO,EAAE,IAAI,EAAE,GAAG,EAAE,GAAG,EAAE,EAClE,QAAQ,CAAC,SAAS,CACnB,CAAC;IAEF,MAAM,WAAW,GAAG,cAAc,EAAE,CAAC;IACrC,MAAM,GAAG,GAAG,GAAG,WAAW,MAAM,OAAO,QAAQ,kBAAkB,CAAC,KAAK,CAAC,EAAE,CAAC;IAE3E,aAAa,CAAC,EAAE,GAAG,EAAE,KAAK,EAAE,OAAO,EAAE,IAAI,EAAE,GAAG,EAAE,GAAG,IAAI,IAAI,EAAE,GAAG,EAAE,GAAG,IAAI,IAAI,EAAE,EAAE,eAAe,CAAC,CAAC;AACpG,CAAC"}
@@ -0,0 +1,4 @@
1
+ export declare function threadShare(threadId: string, options: {
2
+ expires?: string;
3
+ for?: string;
4
+ }): Promise<void>;
@@ -0,0 +1,29 @@
1
+ import { loadIdentity } from '../identity.js';
2
+ import { createCapabilityToken } from '../crypto.js';
3
+ import { getFrontendUrl } from '../config.js';
4
+ import { CliError } from '../errors.js';
5
+ import { outputSuccess } from '../output.js';
6
+ import { formatShareLink } from '../formatters.js';
7
+ function parseDuration(s) {
8
+ const match = s.match(/^(\d+)(s|m|h|d)$/);
9
+ if (!match)
10
+ throw new CliError('INVALID_DURATION', `Invalid duration: ${s}. Use e.g. 1h, 7d, 30m`);
11
+ const n = parseInt(match[1], 10);
12
+ const unit = match[2];
13
+ const multipliers = { s: 1, m: 60, h: 3600, d: 86400 };
14
+ return Math.floor(Date.now() / 1000) + n * multipliers[unit];
15
+ }
16
+ export async function threadShare(threadId, options) {
17
+ const identity = loadIdentity();
18
+ if (!identity) {
19
+ throw new CliError('NO_IDENTITY', 'No agent identity found. Run `tokenrip auth register` first.');
20
+ }
21
+ const perm = ['comment'];
22
+ const exp = options.expires ? parseDuration(options.expires) : undefined;
23
+ const aud = options.for || undefined;
24
+ const token = createCapabilityToken({ sub: `thread:${threadId}`, iss: identity.agentId, perm, exp, aud }, identity.secretKey);
25
+ const frontendUrl = getFrontendUrl();
26
+ const url = `${frontendUrl}/threads/${threadId}?cap=${encodeURIComponent(token)}`;
27
+ outputSuccess({ url, token, threadId, perm, exp: exp ?? null, aud: aud ?? null }, formatShareLink);
28
+ }
29
+ //# sourceMappingURL=thread-share.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"thread-share.js","sourceRoot":"","sources":["../../src/commands/thread-share.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAC9C,OAAO,EAAE,qBAAqB,EAAE,MAAM,cAAc,CAAC;AACrD,OAAO,EAAE,cAAc,EAAE,MAAM,cAAc,CAAC;AAC9C,OAAO,EAAE,QAAQ,EAAE,MAAM,cAAc,CAAC;AACxC,OAAO,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AAC7C,OAAO,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAC;AAEnD,SAAS,aAAa,CAAC,CAAS;IAC9B,MAAM,KAAK,GAAG,CAAC,CAAC,KAAK,CAAC,kBAAkB,CAAC,CAAC;IAC1C,IAAI,CAAC,KAAK;QAAE,MAAM,IAAI,QAAQ,CAAC,kBAAkB,EAAE,qBAAqB,CAAC,wBAAwB,CAAC,CAAC;IACnG,MAAM,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;IACjC,MAAM,IAAI,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;IACtB,MAAM,WAAW,GAA2B,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC;IAC/E,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,WAAW,CAAC,IAAI,CAAC,CAAC;AAC/D,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,WAAW,CAC/B,QAAgB,EAChB,OAA2C;IAE3C,MAAM,QAAQ,GAAG,YAAY,EAAE,CAAC;IAChC,IAAI,CAAC,QAAQ,EAAE,CAAC;QACd,MAAM,IAAI,QAAQ,CAAC,aAAa,EAAE,8DAA8D,CAAC,CAAC;IACpG,CAAC;IAED,MAAM,IAAI,GAAG,CAAC,SAAS,CAAC,CAAC;IACzB,MAAM,GAAG,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,aAAa,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;IACzE,MAAM,GAAG,GAAG,OAAO,CAAC,GAAG,IAAI,SAAS,CAAC;IAErC,MAAM,KAAK,GAAG,qBAAqB,CACjC,EAAE,GAAG,EAAE,UAAU,QAAQ,EAAE,EAAE,GAAG,EAAE,QAAQ,CAAC,OAAO,EAAE,IAAI,EAAE,GAAG,EAAE,GAAG,EAAE,EACpE,QAAQ,CAAC,SAAS,CACnB,CAAC;IAEF,MAAM,WAAW,GAAG,cAAc,EAAE,CAAC;IACrC,MAAM,GAAG,GAAG,GAAG,WAAW,YAAY,QAAQ,QAAQ,kBAAkB,CAAC,KAAK,CAAC,EAAE,CAAC;IAElF,aAAa,CAAC,EAAE,GAAG,EAAE,KAAK,EAAE,QAAQ,EAAE,IAAI,EAAE,GAAG,EAAE,GAAG,IAAI,IAAI,EAAE,GAAG,EAAE,GAAG,IAAI,IAAI,EAAE,EAAE,eAAe,CAAC,CAAC;AACrG,CAAC"}
@@ -0,0 +1,8 @@
1
+ export declare function threadCreate(options: {
2
+ participants?: string;
3
+ message?: string;
4
+ }): Promise<void>;
5
+ export declare function threadShare(threadId: string, options: {
6
+ expires?: string;
7
+ for?: string;
8
+ }): Promise<void>;
@@ -0,0 +1,35 @@
1
+ import { requireAuthClient } from '../auth-client.js';
2
+ import { loadIdentity } from '../identity.js';
3
+ import { createCapabilityToken } from '../crypto.js';
4
+ import { getFrontendUrl } from '../config.js';
5
+ import { CliError } from '../errors.js';
6
+ import { outputSuccess } from '../output.js';
7
+ import { formatThreadCreated, formatShareLink } from '../formatters.js';
8
+ import { resolveRecipients } from '../contacts.js';
9
+ import { parseDuration } from './share.js';
10
+ export async function threadCreate(options) {
11
+ const { client } = requireAuthClient();
12
+ const payload = {};
13
+ if (options.participants) {
14
+ payload.participants = resolveRecipients(options.participants.split(',').map((p) => p.trim()));
15
+ }
16
+ if (options.message) {
17
+ payload.message = { body: options.message };
18
+ }
19
+ const { data } = await client.post('/v0/threads', payload);
20
+ outputSuccess(data.data, formatThreadCreated);
21
+ }
22
+ export async function threadShare(threadId, options) {
23
+ const identity = loadIdentity();
24
+ if (!identity) {
25
+ throw new CliError('NO_IDENTITY', 'No agent identity found. Run `tokenrip auth register` first.');
26
+ }
27
+ const perm = ['comment'];
28
+ const exp = options.expires ? parseDuration(options.expires) : undefined;
29
+ const aud = options.for || undefined;
30
+ const token = createCapabilityToken({ sub: `thread:${threadId}`, iss: identity.agentId, perm, exp, aud }, identity.secretKey);
31
+ const frontendUrl = getFrontendUrl();
32
+ const url = `${frontendUrl}/threads/${threadId}?cap=${encodeURIComponent(token)}`;
33
+ outputSuccess({ url, token, threadId, perm, exp: exp ?? null, aud: aud ?? null }, formatShareLink);
34
+ }
35
+ //# sourceMappingURL=thread.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"thread.js","sourceRoot":"","sources":["../../src/commands/thread.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,mBAAmB,CAAC;AACtD,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAC9C,OAAO,EAAE,qBAAqB,EAAE,MAAM,cAAc,CAAC;AACrD,OAAO,EAAE,cAAc,EAAE,MAAM,cAAc,CAAC;AAC9C,OAAO,EAAE,QAAQ,EAAE,MAAM,cAAc,CAAC;AACxC,OAAO,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AAC7C,OAAO,EAAE,mBAAmB,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAC;AACxE,OAAO,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACnD,OAAO,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAE3C,MAAM,CAAC,KAAK,UAAU,YAAY,CAAC,OAGlC;IACC,MAAM,EAAE,MAAM,EAAE,GAAG,iBAAiB,EAAE,CAAC;IAEvC,MAAM,OAAO,GAA4B,EAAE,CAAC;IAE5C,IAAI,OAAO,CAAC,YAAY,EAAE,CAAC;QACzB,OAAO,CAAC,YAAY,GAAG,iBAAiB,CACtC,OAAO,CAAC,YAAY,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CACrD,CAAC;IACJ,CAAC;IAED,IAAI,OAAO,CAAC,OAAO,EAAE,CAAC;QACpB,OAAO,CAAC,OAAO,GAAG,EAAE,IAAI,EAAE,OAAO,CAAC,OAAO,EAAE,CAAC;IAC9C,CAAC;IAED,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,MAAM,CAAC,IAAI,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC;IAC3D,aAAa,CAAC,IAAI,CAAC,IAAI,EAAE,mBAAmB,CAAC,CAAC;AAChD,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,WAAW,CAC/B,QAAgB,EAChB,OAA2C;IAE3C,MAAM,QAAQ,GAAG,YAAY,EAAE,CAAC;IAChC,IAAI,CAAC,QAAQ,EAAE,CAAC;QACd,MAAM,IAAI,QAAQ,CAAC,aAAa,EAAE,8DAA8D,CAAC,CAAC;IACpG,CAAC;IAED,MAAM,IAAI,GAAG,CAAC,SAAS,CAAC,CAAC;IACzB,MAAM,GAAG,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,aAAa,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;IACzE,MAAM,GAAG,GAAG,OAAO,CAAC,GAAG,IAAI,SAAS,CAAC;IAErC,MAAM,KAAK,GAAG,qBAAqB,CACjC,EAAE,GAAG,EAAE,UAAU,QAAQ,EAAE,EAAE,GAAG,EAAE,QAAQ,CAAC,OAAO,EAAE,IAAI,EAAE,GAAG,EAAE,GAAG,EAAE,EACpE,QAAQ,CAAC,SAAS,CACnB,CAAC;IAEF,MAAM,WAAW,GAAG,cAAc,EAAE,CAAC;IACrC,MAAM,GAAG,GAAG,GAAG,WAAW,YAAY,QAAQ,QAAQ,kBAAkB,CAAC,KAAK,CAAC,EAAE,CAAC;IAElF,aAAa,CAAC,EAAE,GAAG,EAAE,KAAK,EAAE,QAAQ,EAAE,IAAI,EAAE,GAAG,EAAE,GAAG,IAAI,IAAI,EAAE,GAAG,EAAE,GAAG,IAAI,IAAI,EAAE,EAAE,eAAe,CAAC,CAAC;AACrG,CAAC"}
package/dist/config.d.ts CHANGED
@@ -8,3 +8,4 @@ export declare function loadConfig(): TokenripConfig;
8
8
  export declare function saveConfig(config: TokenripConfig): void;
9
9
  export declare function getApiUrl(config: TokenripConfig): string;
10
10
  export declare function getApiKey(config: TokenripConfig): string | undefined;
11
+ export declare function getFrontendUrl(): string;
package/dist/config.js CHANGED
@@ -1,7 +1,7 @@
1
1
  import fs from 'node:fs';
2
2
  import path from 'node:path';
3
3
  import os from 'node:os';
4
- export const CONFIG_DIR = path.join(os.homedir(), '.config', 'tokenrip');
4
+ export const CONFIG_DIR = process.env.TOKENRIP_CONFIG_DIR ?? path.join(os.homedir(), '.config', 'tokenrip');
5
5
  const CONFIG_FILE = path.join(CONFIG_DIR, 'config.json');
6
6
  function defaultConfig() {
7
7
  return { preferences: {} };
@@ -20,9 +20,12 @@ export function saveConfig(config) {
20
20
  fs.writeFileSync(CONFIG_FILE, JSON.stringify(config, null, 2), 'utf-8');
21
21
  }
22
22
  export function getApiUrl(config) {
23
- return config.apiUrl || process.env.TOKENRIP_API_URL || 'https://api.tokenrip.com';
23
+ return process.env.TOKENRIP_API_URL || config.apiUrl || 'https://api.tokenrip.com';
24
24
  }
25
25
  export function getApiKey(config) {
26
- return config.apiKey || process.env.TOKENRIP_API_KEY;
26
+ return process.env.TOKENRIP_API_KEY || config.apiKey;
27
+ }
28
+ export function getFrontendUrl() {
29
+ return process.env.TOKENRIP_FRONTEND_URL || 'https://tokenrip.com';
27
30
  }
28
31
  //# sourceMappingURL=config.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"config.js","sourceRoot":"","sources":["../src/config.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,SAAS,CAAC;AACzB,OAAO,IAAI,MAAM,WAAW,CAAC;AAC7B,OAAO,EAAE,MAAM,SAAS,CAAC;AAEzB,MAAM,CAAC,MAAM,UAAU,GAAG,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,OAAO,EAAE,EAAE,SAAS,EAAE,UAAU,CAAC,CAAC;AACzE,MAAM,WAAW,GAAG,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,aAAa,CAAC,CAAC;AAQzD,SAAS,aAAa;IACpB,OAAO,EAAE,WAAW,EAAE,EAAE,EAAE,CAAC;AAC7B,CAAC;AAED,MAAM,UAAU,UAAU;IACxB,IAAI,CAAC;QACH,MAAM,GAAG,GAAG,EAAE,CAAC,YAAY,CAAC,WAAW,EAAE,OAAO,CAAC,CAAC;QAClD,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,CAAmB,CAAC;IAC3C,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,aAAa,EAAE,CAAC;IACzB,CAAC;AACH,CAAC;AAED,MAAM,UAAU,UAAU,CAAC,MAAsB;IAC/C,EAAE,CAAC,SAAS,CAAC,UAAU,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;IAC9C,EAAE,CAAC,aAAa,CAAC,WAAW,EAAE,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC;AAC1E,CAAC;AAED,MAAM,UAAU,SAAS,CAAC,MAAsB;IAC9C,OAAO,MAAM,CAAC,MAAM,IAAI,OAAO,CAAC,GAAG,CAAC,gBAAgB,IAAI,0BAA0B,CAAC;AACrF,CAAC;AAED,MAAM,UAAU,SAAS,CAAC,MAAsB;IAC9C,OAAO,MAAM,CAAC,MAAM,IAAI,OAAO,CAAC,GAAG,CAAC,gBAAgB,CAAC;AACvD,CAAC"}
1
+ {"version":3,"file":"config.js","sourceRoot":"","sources":["../src/config.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,SAAS,CAAC;AACzB,OAAO,IAAI,MAAM,WAAW,CAAC;AAC7B,OAAO,EAAE,MAAM,SAAS,CAAC;AAEzB,MAAM,CAAC,MAAM,UAAU,GAAG,OAAO,CAAC,GAAG,CAAC,mBAAmB,IAAI,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,OAAO,EAAE,EAAE,SAAS,EAAE,UAAU,CAAC,CAAC;AAC5G,MAAM,WAAW,GAAG,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,aAAa,CAAC,CAAC;AAQzD,SAAS,aAAa;IACpB,OAAO,EAAE,WAAW,EAAE,EAAE,EAAE,CAAC;AAC7B,CAAC;AAED,MAAM,UAAU,UAAU;IACxB,IAAI,CAAC;QACH,MAAM,GAAG,GAAG,EAAE,CAAC,YAAY,CAAC,WAAW,EAAE,OAAO,CAAC,CAAC;QAClD,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,CAAmB,CAAC;IAC3C,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,aAAa,EAAE,CAAC;IACzB,CAAC;AACH,CAAC;AAED,MAAM,UAAU,UAAU,CAAC,MAAsB;IAC/C,EAAE,CAAC,SAAS,CAAC,UAAU,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;IAC9C,EAAE,CAAC,aAAa,CAAC,WAAW,EAAE,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC;AAC1E,CAAC;AAED,MAAM,UAAU,SAAS,CAAC,MAAsB;IAC9C,OAAO,OAAO,CAAC,GAAG,CAAC,gBAAgB,IAAI,MAAM,CAAC,MAAM,IAAI,0BAA0B,CAAC;AACrF,CAAC;AAED,MAAM,UAAU,SAAS,CAAC,MAAsB;IAC9C,OAAO,OAAO,CAAC,GAAG,CAAC,gBAAgB,IAAI,MAAM,CAAC,MAAM,CAAC;AACvD,CAAC;AAED,MAAM,UAAU,cAAc;IAC5B,OAAO,OAAO,CAAC,GAAG,CAAC,qBAAqB,IAAI,sBAAsB,CAAC;AACrE,CAAC"}
@@ -0,0 +1,16 @@
1
+ export interface Contact {
2
+ agent_id: string;
3
+ alias?: string;
4
+ notes?: string;
5
+ [key: string]: unknown;
6
+ }
7
+ export type Contacts = Record<string, Contact>;
8
+ export declare function loadContacts(): Contacts;
9
+ export declare function saveContacts(contacts: Contacts): void;
10
+ export declare function addContact(name: string, agentId: string, meta?: {
11
+ alias?: string;
12
+ notes?: string;
13
+ }): void;
14
+ export declare function removeContact(name: string): void;
15
+ export declare function resolveRecipient(value: string): string;
16
+ export declare function resolveRecipients(values: string[]): string[];
@@ -0,0 +1,53 @@
1
+ import fs from 'node:fs';
2
+ import path from 'node:path';
3
+ import { CONFIG_DIR } from './config.js';
4
+ import { CliError } from './errors.js';
5
+ const CONTACTS_FILE = path.join(CONFIG_DIR, 'contacts.json');
6
+ export function loadContacts() {
7
+ try {
8
+ const raw = fs.readFileSync(CONTACTS_FILE, 'utf-8');
9
+ return JSON.parse(raw);
10
+ }
11
+ catch {
12
+ return {};
13
+ }
14
+ }
15
+ export function saveContacts(contacts) {
16
+ fs.mkdirSync(CONFIG_DIR, { recursive: true });
17
+ fs.writeFileSync(CONTACTS_FILE, JSON.stringify(contacts, null, 2), 'utf-8');
18
+ }
19
+ export function addContact(name, agentId, meta) {
20
+ if (!agentId.startsWith('trip1')) {
21
+ throw new CliError('INVALID_AGENT_ID', 'Agent ID must start with trip1');
22
+ }
23
+ const contacts = loadContacts();
24
+ contacts[name] = { agent_id: agentId, ...meta };
25
+ saveContacts(contacts);
26
+ }
27
+ export function removeContact(name) {
28
+ const contacts = loadContacts();
29
+ if (!contacts[name]) {
30
+ throw new CliError('CONTACT_NOT_FOUND', `Contact "${name}" not found`);
31
+ }
32
+ delete contacts[name];
33
+ saveContacts(contacts);
34
+ }
35
+ export function resolveRecipient(value) {
36
+ if (value.startsWith('trip1'))
37
+ return value;
38
+ const contacts = loadContacts();
39
+ if (contacts[value])
40
+ return contacts[value].agent_id;
41
+ return value; // pass through to server for alias resolution
42
+ }
43
+ export function resolveRecipients(values) {
44
+ const contacts = loadContacts();
45
+ return values.map((v) => {
46
+ if (v.startsWith('trip1'))
47
+ return v;
48
+ if (contacts[v])
49
+ return contacts[v].agent_id;
50
+ return v;
51
+ });
52
+ }
53
+ //# sourceMappingURL=contacts.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"contacts.js","sourceRoot":"","sources":["../src/contacts.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,SAAS,CAAC;AACzB,OAAO,IAAI,MAAM,WAAW,CAAC;AAC7B,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AACzC,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AAEvC,MAAM,aAAa,GAAG,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,eAAe,CAAC,CAAC;AAW7D,MAAM,UAAU,YAAY;IAC1B,IAAI,CAAC;QACH,MAAM,GAAG,GAAG,EAAE,CAAC,YAAY,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC;QACpD,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,CAAa,CAAC;IACrC,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,EAAE,CAAC;IACZ,CAAC;AACH,CAAC;AAED,MAAM,UAAU,YAAY,CAAC,QAAkB;IAC7C,EAAE,CAAC,SAAS,CAAC,UAAU,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;IAC9C,EAAE,CAAC,aAAa,CAAC,aAAa,EAAE,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC;AAC9E,CAAC;AAED,MAAM,UAAU,UAAU,CACxB,IAAY,EACZ,OAAe,EACf,IAAyC;IAEzC,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,OAAO,CAAC,EAAE,CAAC;QACjC,MAAM,IAAI,QAAQ,CAAC,kBAAkB,EAAE,gCAAgC,CAAC,CAAC;IAC3E,CAAC;IACD,MAAM,QAAQ,GAAG,YAAY,EAAE,CAAC;IAChC,QAAQ,CAAC,IAAI,CAAC,GAAG,EAAE,QAAQ,EAAE,OAAO,EAAE,GAAG,IAAI,EAAE,CAAC;IAChD,YAAY,CAAC,QAAQ,CAAC,CAAC;AACzB,CAAC;AAED,MAAM,UAAU,aAAa,CAAC,IAAY;IACxC,MAAM,QAAQ,GAAG,YAAY,EAAE,CAAC;IAChC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;QACpB,MAAM,IAAI,QAAQ,CAAC,mBAAmB,EAAE,YAAY,IAAI,aAAa,CAAC,CAAC;IACzE,CAAC;IACD,OAAO,QAAQ,CAAC,IAAI,CAAC,CAAC;IACtB,YAAY,CAAC,QAAQ,CAAC,CAAC;AACzB,CAAC;AAED,MAAM,UAAU,gBAAgB,CAAC,KAAa;IAC5C,IAAI,KAAK,CAAC,UAAU,CAAC,OAAO,CAAC;QAAE,OAAO,KAAK,CAAC;IAC5C,MAAM,QAAQ,GAAG,YAAY,EAAE,CAAC;IAChC,IAAI,QAAQ,CAAC,KAAK,CAAC;QAAE,OAAO,QAAQ,CAAC,KAAK,CAAC,CAAC,QAAQ,CAAC;IACrD,OAAO,KAAK,CAAC,CAAC,8CAA8C;AAC9D,CAAC;AAED,MAAM,UAAU,iBAAiB,CAAC,MAAgB;IAChD,MAAM,QAAQ,GAAG,YAAY,EAAE,CAAC;IAChC,OAAO,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE;QACtB,IAAI,CAAC,CAAC,UAAU,CAAC,OAAO,CAAC;YAAE,OAAO,CAAC,CAAC;QACpC,IAAI,QAAQ,CAAC,CAAC,CAAC;YAAE,OAAO,QAAQ,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC;QAC7C,OAAO,CAAC,CAAC;IACX,CAAC,CAAC,CAAC;AACL,CAAC"}
@@ -0,0 +1,16 @@
1
+ export interface Keypair {
2
+ publicKeyHex: string;
3
+ secretKeyHex: string;
4
+ }
5
+ export declare function generateKeypair(): Keypair;
6
+ export declare function publicKeyToAgentId(publicKeyHex: string): string;
7
+ export interface CapabilityTokenOptions {
8
+ sub: string;
9
+ iss: string;
10
+ perm: string[];
11
+ exp?: number;
12
+ aud?: string;
13
+ }
14
+ export declare function sign(data: Buffer, secretKeyHex: string): Buffer;
15
+ export declare function signPayload(payload: Record<string, unknown>, secretKeyHex: string): string;
16
+ export declare function createCapabilityToken(opts: CapabilityTokenOptions, secretKeyHex: string): string;
package/dist/crypto.js ADDED
@@ -0,0 +1,40 @@
1
+ import { generateKeyPairSync, sign as ed25519Sign, createPrivateKey } from 'node:crypto';
2
+ import { bech32 } from 'bech32';
3
+ const AGENT_HRP = 'trip';
4
+ const BECH32_LIMIT = 90;
5
+ // ASN.1 DER prefix for Ed25519 PKCS8 private key (prepend to 32-byte raw key)
6
+ const PKCS8_ED25519_PREFIX = Buffer.from('302e020100300506032b657004220420', 'hex');
7
+ export function generateKeypair() {
8
+ const { publicKey, privateKey } = generateKeyPairSync('ed25519');
9
+ const rawPub = publicKey.export({ type: 'spki', format: 'der' }).subarray(12);
10
+ const rawPriv = privateKey.export({ type: 'pkcs8', format: 'der' }).subarray(16);
11
+ return {
12
+ publicKeyHex: rawPub.toString('hex'),
13
+ secretKeyHex: rawPriv.toString('hex'),
14
+ };
15
+ }
16
+ export function publicKeyToAgentId(publicKeyHex) {
17
+ const bytes = Buffer.from(publicKeyHex, 'hex');
18
+ const words = bech32.toWords(bytes);
19
+ return bech32.encode(AGENT_HRP, words, BECH32_LIMIT);
20
+ }
21
+ export function sign(data, secretKeyHex) {
22
+ const rawKey = Buffer.from(secretKeyHex, 'hex');
23
+ const derKey = Buffer.concat([PKCS8_ED25519_PREFIX, rawKey]);
24
+ const keyObj = createPrivateKey({ key: derKey, format: 'der', type: 'pkcs8' });
25
+ return ed25519Sign(null, data, keyObj);
26
+ }
27
+ export function signPayload(payload, secretKeyHex) {
28
+ const payloadB64 = Buffer.from(JSON.stringify(payload)).toString('base64url');
29
+ const signature = sign(Buffer.from(payloadB64), secretKeyHex);
30
+ return `${payloadB64}.${signature.toString('base64url')}`;
31
+ }
32
+ export function createCapabilityToken(opts, secretKeyHex) {
33
+ const payload = { sub: opts.sub, iss: opts.iss, perm: opts.perm };
34
+ if (opts.exp != null)
35
+ payload.exp = opts.exp;
36
+ if (opts.aud != null)
37
+ payload.aud = opts.aud;
38
+ return signPayload(payload, secretKeyHex);
39
+ }
40
+ //# sourceMappingURL=crypto.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"crypto.js","sourceRoot":"","sources":["../src/crypto.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,IAAI,IAAI,WAAW,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;AACzF,OAAO,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAEhC,MAAM,SAAS,GAAG,MAAM,CAAC;AACzB,MAAM,YAAY,GAAG,EAAE,CAAC;AAExB,8EAA8E;AAC9E,MAAM,oBAAoB,GAAG,MAAM,CAAC,IAAI,CAAC,kCAAkC,EAAE,KAAK,CAAC,CAAC;AAOpF,MAAM,UAAU,eAAe;IAC7B,MAAM,EAAE,SAAS,EAAE,UAAU,EAAE,GAAG,mBAAmB,CAAC,SAAS,CAAC,CAAC;IACjE,MAAM,MAAM,GAAI,SAAS,CAAC,MAAM,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,CAAY,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;IAC1F,MAAM,OAAO,GAAI,UAAU,CAAC,MAAM,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,CAAY,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;IAC7F,OAAO;QACL,YAAY,EAAE,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC;QACpC,YAAY,EAAE,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC;KACtC,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,kBAAkB,CAAC,YAAoB;IACrD,MAAM,KAAK,GAAG,MAAM,CAAC,IAAI,CAAC,YAAY,EAAE,KAAK,CAAC,CAAC;IAC/C,MAAM,KAAK,GAAG,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;IACpC,OAAO,MAAM,CAAC,MAAM,CAAC,SAAS,EAAE,KAAK,EAAE,YAAY,CAAC,CAAC;AACvD,CAAC;AAUD,MAAM,UAAU,IAAI,CAAC,IAAY,EAAE,YAAoB;IACrD,MAAM,MAAM,GAAG,MAAM,CAAC,IAAI,CAAC,YAAY,EAAE,KAAK,CAAC,CAAC;IAChD,MAAM,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,oBAAoB,EAAE,MAAM,CAAC,CAAC,CAAC;IAC7D,MAAM,MAAM,GAAG,gBAAgB,CAAC,EAAE,GAAG,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,OAAO,EAAE,CAAC,CAAC;IAC/E,OAAO,WAAW,CAAC,IAAI,EAAE,IAAI,EAAE,MAAM,CAAC,CAAC;AACzC,CAAC;AAED,MAAM,UAAU,WAAW,CAAC,OAAgC,EAAE,YAAoB;IAChF,MAAM,UAAU,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC;IAC9E,MAAM,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,YAAY,CAAC,CAAC;IAC9D,OAAO,GAAG,UAAU,IAAI,SAAS,CAAC,QAAQ,CAAC,WAAW,CAAC,EAAE,CAAC;AAC5D,CAAC;AAED,MAAM,UAAU,qBAAqB,CAAC,IAA4B,EAAE,YAAoB;IACtF,MAAM,OAAO,GAA4B,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,CAAC;IAC3F,IAAI,IAAI,CAAC,GAAG,IAAI,IAAI;QAAE,OAAO,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC;IAC7C,IAAI,IAAI,CAAC,GAAG,IAAI,IAAI;QAAE,OAAO,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC;IAC7C,OAAO,WAAW,CAAC,OAAO,EAAE,YAAY,CAAC,CAAC;AAC5C,CAAC"}
@@ -7,3 +7,10 @@ export declare const formatVersionCreated: Formatter;
7
7
  export declare const formatVersionDeleted: Formatter;
8
8
  export declare const formatConfigSaved: Formatter;
9
9
  export declare const formatAuthKey: Formatter;
10
+ export declare const formatInbox: Formatter;
11
+ export declare const formatContacts: Formatter;
12
+ export declare const formatContactResolved: Formatter;
13
+ export declare const formatMessageSent: Formatter;
14
+ export declare const formatMessages: Formatter;
15
+ export declare const formatShareLink: Formatter;
16
+ export declare const formatThreadCreated: Formatter;
@@ -72,6 +72,118 @@ export const formatAuthKey = (data) => {
72
72
  lines.push(` ${data.note}`);
73
73
  return lines.join('\n');
74
74
  };
75
+ export const formatInbox = (data) => {
76
+ const lines = [];
77
+ const threads = data.threads ?? [];
78
+ const assets = data.assets ?? [];
79
+ if (threads.length > 0) {
80
+ lines.push(`THREADS (${threads.length})`);
81
+ for (const t of threads) {
82
+ const count = t.new_message_count ? `+${t.new_message_count} msg${t.new_message_count > 1 ? 's' : ''}` : 'no new';
83
+ const intent = t.last_intent ? ` last: ${t.last_intent}` : '';
84
+ const preview = t.last_body_preview ? ` "${t.last_body_preview}"` : '';
85
+ const ago = formatTimeAgo(new Date(t.updated_at));
86
+ lines.push(` ${t.thread_id.slice(0, 8)} ${count.padEnd(10)}${intent}${preview} ${ago}`);
87
+ }
88
+ }
89
+ else {
90
+ lines.push('THREADS (none)');
91
+ }
92
+ lines.push('');
93
+ if (assets.length > 0) {
94
+ lines.push(`ASSETS (${assets.length})`);
95
+ for (const a of assets) {
96
+ const title = a.title ?? '(untitled)';
97
+ const versions = `+${a.new_version_count} ver${a.new_version_count > 1 ? 's' : ''}`;
98
+ const ago = formatTimeAgo(new Date(a.updated_at));
99
+ lines.push(` ${title.padEnd(20)} v${a.latest_version} ${versions} ${ago}`);
100
+ }
101
+ }
102
+ else {
103
+ lines.push('ASSETS (none)');
104
+ }
105
+ return lines.join('\n');
106
+ };
107
+ export const formatContacts = (data) => {
108
+ const contacts = data;
109
+ const entries = Object.entries(contacts);
110
+ if (entries.length === 0)
111
+ return 'No contacts.';
112
+ const lines = [`${entries.length} contact(s):\n`];
113
+ lines.push(`${'NAME'.padEnd(16)} ${'AGENT ID'.padEnd(24)} ${'ALIAS'.padEnd(16)} NOTES`);
114
+ for (const [name, c] of entries) {
115
+ const alias = c.alias || '—';
116
+ const notes = c.notes || '';
117
+ const idShort = c.agent_id.length > 20 ? c.agent_id.slice(0, 20) + '...' : c.agent_id;
118
+ lines.push(`${name.padEnd(16)} ${idShort.padEnd(24)} ${alias.padEnd(16)} ${notes}`);
119
+ }
120
+ return lines.join('\n');
121
+ };
122
+ export const formatContactResolved = (data) => {
123
+ return `${data.name}: ${data.agent_id}`;
124
+ };
125
+ export const formatMessageSent = (data) => {
126
+ const lines = [];
127
+ if (data.thread_id)
128
+ lines.push(`Thread: ${data.thread_id}`);
129
+ if (data.message_id)
130
+ lines.push(`Message: ${data.message_id}`);
131
+ if (data.id)
132
+ lines.push(`Message: ${data.id}`);
133
+ if (data.sequence)
134
+ lines.push(`Sequence: #${data.sequence}`);
135
+ return lines.join('\n');
136
+ };
137
+ export const formatMessages = (data) => {
138
+ const messages = data;
139
+ if (!Array.isArray(messages) || messages.length === 0)
140
+ return 'No messages.';
141
+ const lines = [];
142
+ for (const m of messages) {
143
+ const sender = m.sender?.agent_id?.slice(0, 12) || m.sender?.user_id || 'unknown';
144
+ const intent = m.intent ? ` [${m.intent}]` : '';
145
+ const ago = formatTimeAgo(new Date(m.created_at));
146
+ lines.push(`#${m.sequence} ${sender}... ${ago}${intent}`);
147
+ lines.push(` ${m.body}`);
148
+ lines.push('');
149
+ }
150
+ return lines.join('\n').trimEnd();
151
+ };
152
+ export const formatShareLink = (data) => {
153
+ const lines = ['Share link generated'];
154
+ if (data.url)
155
+ lines.push(` URL: ${data.url}`);
156
+ if (data.token)
157
+ lines.push(` Token: ${data.token}`);
158
+ const perm = data.perm;
159
+ if (Array.isArray(perm))
160
+ lines.push(` Perms: ${perm.join(', ')}`);
161
+ if (data.exp)
162
+ lines.push(` Expires: ${new Date(data.exp * 1000).toISOString()}`);
163
+ if (data.aud)
164
+ lines.push(` For: ${data.aud}`);
165
+ return lines.join('\n');
166
+ };
167
+ export const formatThreadCreated = (data) => {
168
+ const lines = ['Thread created'];
169
+ if (data.id)
170
+ lines.push(` ID: ${data.id}`);
171
+ const participants = data.participants;
172
+ if (Array.isArray(participants)) {
173
+ lines.push(` Participants: ${participants.length}`);
174
+ }
175
+ return lines.join('\n');
176
+ };
177
+ function formatTimeAgo(date) {
178
+ const seconds = Math.floor((Date.now() - date.getTime()) / 1000);
179
+ if (seconds < 60)
180
+ return `${seconds}s ago`;
181
+ if (seconds < 3600)
182
+ return `${Math.floor(seconds / 60)}m ago`;
183
+ if (seconds < 86400)
184
+ return `${Math.floor(seconds / 3600)}h ago`;
185
+ return `${Math.floor(seconds / 86400)}d ago`;
186
+ }
75
187
  function formatBytes(bytes) {
76
188
  if (bytes === 0)
77
189
  return '0 B';
@@ -1 +1 @@
1
- {"version":3,"file":"formatters.js","sourceRoot":"","sources":["../src/formatters.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"formatters.js","sourceRoot":"","sources":["../src/formatters.ts"],"names":[],"mappings":"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"}