@mcp-i/core 0.1.0

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 (226) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +390 -0
  3. package/dist/auth/handshake.d.ts +104 -0
  4. package/dist/auth/handshake.d.ts.map +1 -0
  5. package/dist/auth/handshake.js +230 -0
  6. package/dist/auth/handshake.js.map +1 -0
  7. package/dist/auth/index.d.ts +3 -0
  8. package/dist/auth/index.d.ts.map +1 -0
  9. package/dist/auth/index.js +2 -0
  10. package/dist/auth/index.js.map +1 -0
  11. package/dist/auth/types.d.ts +31 -0
  12. package/dist/auth/types.d.ts.map +1 -0
  13. package/dist/auth/types.js +7 -0
  14. package/dist/auth/types.js.map +1 -0
  15. package/dist/delegation/audience-validator.d.ts +9 -0
  16. package/dist/delegation/audience-validator.d.ts.map +1 -0
  17. package/dist/delegation/audience-validator.js +17 -0
  18. package/dist/delegation/audience-validator.js.map +1 -0
  19. package/dist/delegation/bitstring.d.ts +37 -0
  20. package/dist/delegation/bitstring.d.ts.map +1 -0
  21. package/dist/delegation/bitstring.js +117 -0
  22. package/dist/delegation/bitstring.js.map +1 -0
  23. package/dist/delegation/cascading-revocation.d.ts +45 -0
  24. package/dist/delegation/cascading-revocation.d.ts.map +1 -0
  25. package/dist/delegation/cascading-revocation.js +148 -0
  26. package/dist/delegation/cascading-revocation.js.map +1 -0
  27. package/dist/delegation/delegation-graph.d.ts +49 -0
  28. package/dist/delegation/delegation-graph.d.ts.map +1 -0
  29. package/dist/delegation/delegation-graph.js +99 -0
  30. package/dist/delegation/delegation-graph.js.map +1 -0
  31. package/dist/delegation/did-key-resolver.d.ts +64 -0
  32. package/dist/delegation/did-key-resolver.d.ts.map +1 -0
  33. package/dist/delegation/did-key-resolver.js +154 -0
  34. package/dist/delegation/did-key-resolver.js.map +1 -0
  35. package/dist/delegation/did-web-resolver.d.ts +83 -0
  36. package/dist/delegation/did-web-resolver.d.ts.map +1 -0
  37. package/dist/delegation/did-web-resolver.js +218 -0
  38. package/dist/delegation/did-web-resolver.js.map +1 -0
  39. package/dist/delegation/index.d.ts +21 -0
  40. package/dist/delegation/index.d.ts.map +1 -0
  41. package/dist/delegation/index.js +21 -0
  42. package/dist/delegation/index.js.map +1 -0
  43. package/dist/delegation/outbound-headers.d.ts +81 -0
  44. package/dist/delegation/outbound-headers.d.ts.map +1 -0
  45. package/dist/delegation/outbound-headers.js +139 -0
  46. package/dist/delegation/outbound-headers.js.map +1 -0
  47. package/dist/delegation/outbound-proof.d.ts +43 -0
  48. package/dist/delegation/outbound-proof.d.ts.map +1 -0
  49. package/dist/delegation/outbound-proof.js +52 -0
  50. package/dist/delegation/outbound-proof.js.map +1 -0
  51. package/dist/delegation/statuslist-manager.d.ts +44 -0
  52. package/dist/delegation/statuslist-manager.d.ts.map +1 -0
  53. package/dist/delegation/statuslist-manager.js +126 -0
  54. package/dist/delegation/statuslist-manager.js.map +1 -0
  55. package/dist/delegation/storage/memory-graph-storage.d.ts +70 -0
  56. package/dist/delegation/storage/memory-graph-storage.d.ts.map +1 -0
  57. package/dist/delegation/storage/memory-graph-storage.js +145 -0
  58. package/dist/delegation/storage/memory-graph-storage.js.map +1 -0
  59. package/dist/delegation/storage/memory-statuslist-storage.d.ts +19 -0
  60. package/dist/delegation/storage/memory-statuslist-storage.d.ts.map +1 -0
  61. package/dist/delegation/storage/memory-statuslist-storage.js +33 -0
  62. package/dist/delegation/storage/memory-statuslist-storage.js.map +1 -0
  63. package/dist/delegation/utils.d.ts +49 -0
  64. package/dist/delegation/utils.d.ts.map +1 -0
  65. package/dist/delegation/utils.js +131 -0
  66. package/dist/delegation/utils.js.map +1 -0
  67. package/dist/delegation/vc-issuer.d.ts +56 -0
  68. package/dist/delegation/vc-issuer.d.ts.map +1 -0
  69. package/dist/delegation/vc-issuer.js +80 -0
  70. package/dist/delegation/vc-issuer.js.map +1 -0
  71. package/dist/delegation/vc-verifier.d.ts +112 -0
  72. package/dist/delegation/vc-verifier.d.ts.map +1 -0
  73. package/dist/delegation/vc-verifier.js +280 -0
  74. package/dist/delegation/vc-verifier.js.map +1 -0
  75. package/dist/index.d.ts +45 -0
  76. package/dist/index.d.ts.map +1 -0
  77. package/dist/index.js +53 -0
  78. package/dist/index.js.map +1 -0
  79. package/dist/logging/index.d.ts +2 -0
  80. package/dist/logging/index.d.ts.map +1 -0
  81. package/dist/logging/index.js +2 -0
  82. package/dist/logging/index.js.map +1 -0
  83. package/dist/logging/logger.d.ts +23 -0
  84. package/dist/logging/logger.d.ts.map +1 -0
  85. package/dist/logging/logger.js +82 -0
  86. package/dist/logging/logger.js.map +1 -0
  87. package/dist/middleware/index.d.ts +7 -0
  88. package/dist/middleware/index.d.ts.map +1 -0
  89. package/dist/middleware/index.js +7 -0
  90. package/dist/middleware/index.js.map +1 -0
  91. package/dist/middleware/with-mcpi.d.ts +152 -0
  92. package/dist/middleware/with-mcpi.d.ts.map +1 -0
  93. package/dist/middleware/with-mcpi.js +472 -0
  94. package/dist/middleware/with-mcpi.js.map +1 -0
  95. package/dist/proof/errors.d.ts +49 -0
  96. package/dist/proof/errors.d.ts.map +1 -0
  97. package/dist/proof/errors.js +61 -0
  98. package/dist/proof/errors.js.map +1 -0
  99. package/dist/proof/generator.d.ts +65 -0
  100. package/dist/proof/generator.d.ts.map +1 -0
  101. package/dist/proof/generator.js +163 -0
  102. package/dist/proof/generator.js.map +1 -0
  103. package/dist/proof/index.d.ts +4 -0
  104. package/dist/proof/index.d.ts.map +1 -0
  105. package/dist/proof/index.js +4 -0
  106. package/dist/proof/index.js.map +1 -0
  107. package/dist/proof/verifier.d.ts +108 -0
  108. package/dist/proof/verifier.d.ts.map +1 -0
  109. package/dist/proof/verifier.js +299 -0
  110. package/dist/proof/verifier.js.map +1 -0
  111. package/dist/providers/base.d.ts +64 -0
  112. package/dist/providers/base.d.ts.map +1 -0
  113. package/dist/providers/base.js +19 -0
  114. package/dist/providers/base.js.map +1 -0
  115. package/dist/providers/index.d.ts +3 -0
  116. package/dist/providers/index.d.ts.map +1 -0
  117. package/dist/providers/index.js +3 -0
  118. package/dist/providers/index.js.map +1 -0
  119. package/dist/providers/memory.d.ts +33 -0
  120. package/dist/providers/memory.d.ts.map +1 -0
  121. package/dist/providers/memory.js +102 -0
  122. package/dist/providers/memory.js.map +1 -0
  123. package/dist/session/index.d.ts +2 -0
  124. package/dist/session/index.d.ts.map +1 -0
  125. package/dist/session/index.js +2 -0
  126. package/dist/session/index.js.map +1 -0
  127. package/dist/session/manager.d.ts +77 -0
  128. package/dist/session/manager.d.ts.map +1 -0
  129. package/dist/session/manager.js +251 -0
  130. package/dist/session/manager.js.map +1 -0
  131. package/dist/types/protocol.d.ts +320 -0
  132. package/dist/types/protocol.d.ts.map +1 -0
  133. package/dist/types/protocol.js +229 -0
  134. package/dist/types/protocol.js.map +1 -0
  135. package/dist/utils/base58.d.ts +31 -0
  136. package/dist/utils/base58.d.ts.map +1 -0
  137. package/dist/utils/base58.js +104 -0
  138. package/dist/utils/base58.js.map +1 -0
  139. package/dist/utils/base64.d.ts +13 -0
  140. package/dist/utils/base64.d.ts.map +1 -0
  141. package/dist/utils/base64.js +99 -0
  142. package/dist/utils/base64.js.map +1 -0
  143. package/dist/utils/crypto-service.d.ts +37 -0
  144. package/dist/utils/crypto-service.d.ts.map +1 -0
  145. package/dist/utils/crypto-service.js +153 -0
  146. package/dist/utils/crypto-service.js.map +1 -0
  147. package/dist/utils/did-helpers.d.ts +156 -0
  148. package/dist/utils/did-helpers.d.ts.map +1 -0
  149. package/dist/utils/did-helpers.js +193 -0
  150. package/dist/utils/did-helpers.js.map +1 -0
  151. package/dist/utils/ed25519-constants.d.ts +18 -0
  152. package/dist/utils/ed25519-constants.d.ts.map +1 -0
  153. package/dist/utils/ed25519-constants.js +21 -0
  154. package/dist/utils/ed25519-constants.js.map +1 -0
  155. package/dist/utils/index.d.ts +5 -0
  156. package/dist/utils/index.d.ts.map +1 -0
  157. package/dist/utils/index.js +5 -0
  158. package/dist/utils/index.js.map +1 -0
  159. package/package.json +105 -0
  160. package/src/__tests__/integration/full-flow.test.ts +362 -0
  161. package/src/__tests__/providers/base.test.ts +173 -0
  162. package/src/__tests__/providers/memory.test.ts +332 -0
  163. package/src/__tests__/utils/mock-providers.ts +319 -0
  164. package/src/__tests__/utils/node-crypto-provider.ts +93 -0
  165. package/src/auth/handshake.ts +411 -0
  166. package/src/auth/index.ts +11 -0
  167. package/src/auth/types.ts +40 -0
  168. package/src/delegation/__tests__/audience-validator.test.ts +110 -0
  169. package/src/delegation/__tests__/bitstring.test.ts +346 -0
  170. package/src/delegation/__tests__/cascading-revocation.test.ts +624 -0
  171. package/src/delegation/__tests__/delegation-graph.test.ts +623 -0
  172. package/src/delegation/__tests__/did-key-resolver.test.ts +265 -0
  173. package/src/delegation/__tests__/did-web-resolver.test.ts +467 -0
  174. package/src/delegation/__tests__/outbound-headers.test.ts +230 -0
  175. package/src/delegation/__tests__/outbound-proof.test.ts +179 -0
  176. package/src/delegation/__tests__/statuslist-manager.test.ts +515 -0
  177. package/src/delegation/__tests__/utils.test.ts +185 -0
  178. package/src/delegation/__tests__/vc-issuer.test.ts +487 -0
  179. package/src/delegation/__tests__/vc-verifier.test.ts +1029 -0
  180. package/src/delegation/audience-validator.ts +24 -0
  181. package/src/delegation/bitstring.ts +160 -0
  182. package/src/delegation/cascading-revocation.ts +224 -0
  183. package/src/delegation/delegation-graph.ts +143 -0
  184. package/src/delegation/did-key-resolver.ts +181 -0
  185. package/src/delegation/did-web-resolver.ts +270 -0
  186. package/src/delegation/index.ts +33 -0
  187. package/src/delegation/outbound-headers.ts +193 -0
  188. package/src/delegation/outbound-proof.ts +90 -0
  189. package/src/delegation/statuslist-manager.ts +219 -0
  190. package/src/delegation/storage/__tests__/memory-graph-storage.test.ts +366 -0
  191. package/src/delegation/storage/__tests__/memory-statuslist-storage.test.ts +228 -0
  192. package/src/delegation/storage/memory-graph-storage.ts +178 -0
  193. package/src/delegation/storage/memory-statuslist-storage.ts +42 -0
  194. package/src/delegation/utils.ts +189 -0
  195. package/src/delegation/vc-issuer.ts +137 -0
  196. package/src/delegation/vc-verifier.ts +440 -0
  197. package/src/index.ts +264 -0
  198. package/src/logging/__tests__/logger.test.ts +366 -0
  199. package/src/logging/index.ts +6 -0
  200. package/src/logging/logger.ts +91 -0
  201. package/src/middleware/__tests__/with-mcpi.test.ts +504 -0
  202. package/src/middleware/index.ts +16 -0
  203. package/src/middleware/with-mcpi.ts +766 -0
  204. package/src/proof/__tests__/proof-generator.test.ts +483 -0
  205. package/src/proof/__tests__/verifier.test.ts +488 -0
  206. package/src/proof/errors.ts +75 -0
  207. package/src/proof/generator.ts +255 -0
  208. package/src/proof/index.ts +22 -0
  209. package/src/proof/verifier.ts +449 -0
  210. package/src/providers/base.ts +68 -0
  211. package/src/providers/index.ts +15 -0
  212. package/src/providers/memory.ts +130 -0
  213. package/src/session/__tests__/session-manager.test.ts +342 -0
  214. package/src/session/index.ts +7 -0
  215. package/src/session/manager.ts +332 -0
  216. package/src/types/protocol.ts +596 -0
  217. package/src/utils/__tests__/base58.test.ts +281 -0
  218. package/src/utils/__tests__/base64.test.ts +239 -0
  219. package/src/utils/__tests__/crypto-service.test.ts +530 -0
  220. package/src/utils/__tests__/did-helpers.test.ts +156 -0
  221. package/src/utils/base58.ts +115 -0
  222. package/src/utils/base64.ts +116 -0
  223. package/src/utils/crypto-service.ts +209 -0
  224. package/src/utils/did-helpers.ts +210 -0
  225. package/src/utils/ed25519-constants.ts +23 -0
  226. package/src/utils/index.ts +9 -0
@@ -0,0 +1,148 @@
1
+ /**
2
+ * Cascading Revocation Manager
3
+ *
4
+ * Implements cascading revocation per Python POC design.
5
+ * When a parent delegation is revoked, all children are automatically revoked.
6
+ *
7
+ * Related Spec: MCP-I §4.4, Delegation Chains
8
+ */
9
+ export class CascadingRevocationManager {
10
+ graph;
11
+ statusList;
12
+ constructor(graph, statusList) {
13
+ this.graph = graph;
14
+ this.statusList = statusList;
15
+ }
16
+ async revokeDelegation(delegationId, options = {}) {
17
+ const maxDepth = options.maxDepth || 100;
18
+ const events = [];
19
+ const targetNode = await this.graph.getNode(delegationId);
20
+ if (!targetNode) {
21
+ throw new Error(`Delegation not found: ${delegationId}`);
22
+ }
23
+ const depth = await this.graph.getDepth(delegationId);
24
+ if (depth > maxDepth) {
25
+ throw new Error(`Delegation depth ${depth} exceeds maximum ${maxDepth}`);
26
+ }
27
+ const rootEvent = await this.revokeNode(targetNode, true, options.reason, options.dryRun);
28
+ events.push(rootEvent);
29
+ if (options.onRevoke) {
30
+ await options.onRevoke(rootEvent);
31
+ }
32
+ const descendants = await this.graph.getDescendants(delegationId);
33
+ for (const descendant of descendants) {
34
+ const event = await this.revokeNode(descendant, false, `Cascaded from ${delegationId}`, options.dryRun, delegationId);
35
+ events.push(event);
36
+ if (options.onRevoke) {
37
+ await options.onRevoke(event);
38
+ }
39
+ }
40
+ return events;
41
+ }
42
+ async revokeNode(node, isRoot, reason, dryRun, parentId) {
43
+ const event = {
44
+ delegationId: node.id,
45
+ isRoot,
46
+ parentId,
47
+ timestamp: Date.now(),
48
+ reason,
49
+ };
50
+ if (dryRun) {
51
+ return event;
52
+ }
53
+ if (node.credentialStatusId) {
54
+ const credentialStatus = this.parseCredentialStatus(node.credentialStatusId);
55
+ if (credentialStatus) {
56
+ await this.statusList.updateStatus(credentialStatus, true);
57
+ }
58
+ }
59
+ return event;
60
+ }
61
+ async restoreDelegation(delegationId) {
62
+ const node = await this.graph.getNode(delegationId);
63
+ if (!node) {
64
+ throw new Error(`Delegation not found: ${delegationId}`);
65
+ }
66
+ const event = {
67
+ delegationId: node.id,
68
+ isRoot: true,
69
+ timestamp: Date.now(),
70
+ reason: 'Restored',
71
+ };
72
+ if (node.credentialStatusId) {
73
+ const credentialStatus = this.parseCredentialStatus(node.credentialStatusId);
74
+ if (credentialStatus) {
75
+ await this.statusList.updateStatus(credentialStatus, false);
76
+ }
77
+ }
78
+ return event;
79
+ }
80
+ async isRevoked(delegationId) {
81
+ const chain = await this.graph.getChain(delegationId);
82
+ for (const node of chain.reverse()) {
83
+ if (node.credentialStatusId) {
84
+ const credentialStatus = this.parseCredentialStatus(node.credentialStatusId);
85
+ if (credentialStatus) {
86
+ const isRevoked = await this.statusList.checkStatus(credentialStatus);
87
+ if (isRevoked) {
88
+ return {
89
+ revoked: true,
90
+ reason: node.id === delegationId ? 'Directly revoked' : 'Ancestor revoked',
91
+ revokedAncestor: node.id === delegationId ? undefined : node.id,
92
+ };
93
+ }
94
+ }
95
+ }
96
+ }
97
+ return { revoked: false };
98
+ }
99
+ async getRevokedInSubtree(rootId) {
100
+ const descendants = await this.graph.getDescendants(rootId);
101
+ const revoked = [];
102
+ const rootRevoked = await this.isRevoked(rootId);
103
+ if (rootRevoked.revoked) {
104
+ revoked.push(rootId);
105
+ }
106
+ for (const node of descendants) {
107
+ const isRevoked = await this.isRevoked(node.id);
108
+ if (isRevoked.revoked) {
109
+ revoked.push(node.id);
110
+ }
111
+ }
112
+ return revoked;
113
+ }
114
+ parseCredentialStatus(credentialStatusId) {
115
+ const match = credentialStatusId.match(/^(.+)#(\d+)$/);
116
+ if (!match)
117
+ return null;
118
+ const [, statusListCredential, indexStr] = match;
119
+ const index = parseInt(indexStr, 10);
120
+ return {
121
+ id: credentialStatusId,
122
+ type: 'StatusList2021Entry',
123
+ statusPurpose: 'revocation',
124
+ statusListIndex: index.toString(),
125
+ statusListCredential: statusListCredential,
126
+ };
127
+ }
128
+ async validateDelegation(delegationId) {
129
+ const revokedCheck = await this.isRevoked(delegationId);
130
+ if (revokedCheck.revoked) {
131
+ return {
132
+ valid: false,
133
+ reason: revokedCheck.revokedAncestor
134
+ ? `Ancestor ${revokedCheck.revokedAncestor} is revoked`
135
+ : 'Delegation is revoked',
136
+ };
137
+ }
138
+ const chainValidation = await this.graph.validateChain(delegationId);
139
+ if (!chainValidation.valid) {
140
+ return chainValidation;
141
+ }
142
+ return { valid: true };
143
+ }
144
+ }
145
+ export function createCascadingRevocationManager(graph, statusList) {
146
+ return new CascadingRevocationManager(graph, statusList);
147
+ }
148
+ //# sourceMappingURL=cascading-revocation.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cascading-revocation.js","sourceRoot":"","sources":["../../src/delegation/cascading-revocation.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,49 @@
1
+ /**
2
+ * Delegation Graph Manager
3
+ *
4
+ * Tracks parent-child relationships between delegation credentials.
5
+ * Critical for cascading revocation per Delegation-Revocation.md.
6
+ *
7
+ * Related Spec: MCP-I §4.4, Delegation Chains
8
+ */
9
+ export interface DelegationNode {
10
+ id: string;
11
+ parentId: string | null;
12
+ children: string[];
13
+ issuerDid: string;
14
+ subjectDid: string;
15
+ credentialStatusId?: string;
16
+ }
17
+ export interface DelegationGraphStorageProvider {
18
+ getNode(delegationId: string): Promise<DelegationNode | null>;
19
+ setNode(node: DelegationNode): Promise<void>;
20
+ getChildren(delegationId: string): Promise<DelegationNode[]>;
21
+ getChain(delegationId: string): Promise<DelegationNode[]>;
22
+ getDescendants(delegationId: string): Promise<DelegationNode[]>;
23
+ deleteNode(delegationId: string): Promise<void>;
24
+ }
25
+ export declare class DelegationGraphManager {
26
+ private storage;
27
+ constructor(storage: DelegationGraphStorageProvider);
28
+ registerDelegation(params: {
29
+ id: string;
30
+ parentId: string | null;
31
+ issuerDid: string;
32
+ subjectDid: string;
33
+ credentialStatusId?: string;
34
+ }): Promise<DelegationNode>;
35
+ private addChildToParent;
36
+ getNode(delegationId: string): Promise<DelegationNode | null>;
37
+ getChildren(delegationId: string): Promise<DelegationNode[]>;
38
+ getDescendants(delegationId: string): Promise<DelegationNode[]>;
39
+ getChain(delegationId: string): Promise<DelegationNode[]>;
40
+ isAncestor(ancestorId: string, descendantId: string): Promise<boolean>;
41
+ getDepth(delegationId: string): Promise<number>;
42
+ validateChain(delegationId: string): Promise<{
43
+ valid: boolean;
44
+ reason?: string;
45
+ }>;
46
+ removeDelegation(delegationId: string): Promise<void>;
47
+ }
48
+ export declare function createDelegationGraph(storage: DelegationGraphStorageProvider): DelegationGraphManager;
49
+ //# sourceMappingURL=delegation-graph.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"delegation-graph.d.ts","sourceRoot":"","sources":["../../src/delegation/delegation-graph.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,MAAM,WAAW,cAAc;IAC7B,EAAE,EAAE,MAAM,CAAC;IACX,QAAQ,EAAE,MAAM,GAAG,IAAI,CAAC;IACxB,QAAQ,EAAE,MAAM,EAAE,CAAC;IACnB,SAAS,EAAE,MAAM,CAAC;IAClB,UAAU,EAAE,MAAM,CAAC;IACnB,kBAAkB,CAAC,EAAE,MAAM,CAAC;CAC7B;AAED,MAAM,WAAW,8BAA8B;IAC7C,OAAO,CAAC,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC,cAAc,GAAG,IAAI,CAAC,CAAC;IAC9D,OAAO,CAAC,IAAI,EAAE,cAAc,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAC7C,WAAW,CAAC,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC,cAAc,EAAE,CAAC,CAAC;IAC7D,QAAQ,CAAC,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC,cAAc,EAAE,CAAC,CAAC;IAC1D,cAAc,CAAC,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC,cAAc,EAAE,CAAC,CAAC;IAChE,UAAU,CAAC,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;CACjD;AAED,qBAAa,sBAAsB;IACrB,OAAO,CAAC,OAAO;gBAAP,OAAO,EAAE,8BAA8B;IAErD,kBAAkB,CAAC,MAAM,EAAE;QAC/B,EAAE,EAAE,MAAM,CAAC;QACX,QAAQ,EAAE,MAAM,GAAG,IAAI,CAAC;QACxB,SAAS,EAAE,MAAM,CAAC;QAClB,UAAU,EAAE,MAAM,CAAC;QACnB,kBAAkB,CAAC,EAAE,MAAM,CAAC;KAC7B,GAAG,OAAO,CAAC,cAAc,CAAC;YAmBb,gBAAgB;IAYxB,OAAO,CAAC,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC,cAAc,GAAG,IAAI,CAAC;IAI7D,WAAW,CAAC,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC,cAAc,EAAE,CAAC;IAI5D,cAAc,CAAC,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC,cAAc,EAAE,CAAC;IAI/D,QAAQ,CAAC,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC,cAAc,EAAE,CAAC;IAIzD,UAAU,CAAC,UAAU,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAKtE,QAAQ,CAAC,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAK/C,aAAa,CAAC,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC;QAAE,KAAK,EAAE,OAAO,CAAC;QAAC,MAAM,CAAC,EAAE,MAAM,CAAA;KAAE,CAAC;IA6BjF,gBAAgB,CAAC,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CAc5D;AAED,wBAAgB,qBAAqB,CACnC,OAAO,EAAE,8BAA8B,GACtC,sBAAsB,CAExB"}
@@ -0,0 +1,99 @@
1
+ /**
2
+ * Delegation Graph Manager
3
+ *
4
+ * Tracks parent-child relationships between delegation credentials.
5
+ * Critical for cascading revocation per Delegation-Revocation.md.
6
+ *
7
+ * Related Spec: MCP-I §4.4, Delegation Chains
8
+ */
9
+ export class DelegationGraphManager {
10
+ storage;
11
+ constructor(storage) {
12
+ this.storage = storage;
13
+ }
14
+ async registerDelegation(params) {
15
+ const node = {
16
+ id: params.id,
17
+ parentId: params.parentId,
18
+ children: [],
19
+ issuerDid: params.issuerDid,
20
+ subjectDid: params.subjectDid,
21
+ credentialStatusId: params.credentialStatusId,
22
+ };
23
+ await this.storage.setNode(node);
24
+ if (params.parentId) {
25
+ await this.addChildToParent(params.parentId, params.id);
26
+ }
27
+ return node;
28
+ }
29
+ async addChildToParent(parentId, childId) {
30
+ const parent = await this.storage.getNode(parentId);
31
+ if (!parent) {
32
+ throw new Error(`Parent delegation not found: ${parentId}`);
33
+ }
34
+ if (!parent.children.includes(childId)) {
35
+ parent.children.push(childId);
36
+ await this.storage.setNode(parent);
37
+ }
38
+ }
39
+ async getNode(delegationId) {
40
+ return this.storage.getNode(delegationId);
41
+ }
42
+ async getChildren(delegationId) {
43
+ return this.storage.getChildren(delegationId);
44
+ }
45
+ async getDescendants(delegationId) {
46
+ return this.storage.getDescendants(delegationId);
47
+ }
48
+ async getChain(delegationId) {
49
+ return this.storage.getChain(delegationId);
50
+ }
51
+ async isAncestor(ancestorId, descendantId) {
52
+ const chain = await this.getChain(descendantId);
53
+ return chain.some((node) => node.id === ancestorId);
54
+ }
55
+ async getDepth(delegationId) {
56
+ const chain = await this.getChain(delegationId);
57
+ return chain.length - 1;
58
+ }
59
+ async validateChain(delegationId) {
60
+ const chain = await this.getChain(delegationId);
61
+ if (chain.length === 0) {
62
+ return { valid: false, reason: 'Delegation not found' };
63
+ }
64
+ for (let i = 1; i < chain.length; i++) {
65
+ const parent = chain[i - 1];
66
+ const child = chain[i];
67
+ if (child.issuerDid !== parent.subjectDid) {
68
+ return {
69
+ valid: false,
70
+ reason: `Invalid chain: ${child.id} issued by ${child.issuerDid} but parent ${parent.id} subject is ${parent.subjectDid}`,
71
+ };
72
+ }
73
+ if (child.parentId !== parent.id) {
74
+ return {
75
+ valid: false,
76
+ reason: `Invalid chain: ${child.id} parentId=${child.parentId} but actual parent is ${parent.id}`,
77
+ };
78
+ }
79
+ }
80
+ return { valid: true };
81
+ }
82
+ async removeDelegation(delegationId) {
83
+ const node = await this.storage.getNode(delegationId);
84
+ if (!node)
85
+ return;
86
+ if (node.parentId) {
87
+ const parent = await this.storage.getNode(node.parentId);
88
+ if (parent) {
89
+ parent.children = parent.children.filter((id) => id !== delegationId);
90
+ await this.storage.setNode(parent);
91
+ }
92
+ }
93
+ await this.storage.deleteNode(delegationId);
94
+ }
95
+ }
96
+ export function createDelegationGraph(storage) {
97
+ return new DelegationGraphManager(storage);
98
+ }
99
+ //# sourceMappingURL=delegation-graph.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"delegation-graph.js","sourceRoot":"","sources":["../../src/delegation/delegation-graph.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,64 @@
1
+ /**
2
+ * DID:key Resolver
3
+ *
4
+ * Resolves did:key DIDs to DID Documents with verification methods.
5
+ * Supports Ed25519 keys (multicodec prefix 0xed01).
6
+ *
7
+ * did:key format: did:key:z<multibase-base58btc(<multicodec-prefix><public-key>)>
8
+ *
9
+ * For Ed25519:
10
+ * - Multicodec prefix: 0xed 0x01
11
+ * - Public key: 32 bytes
12
+ * - Multibase prefix: 'z' (base58btc)
13
+ *
14
+ * @see https://w3c-ccg.github.io/did-method-key/
15
+ */
16
+ import type { DIDResolver, DIDDocument } from './vc-verifier.js';
17
+ /**
18
+ * Check if a DID is a valid did:key with Ed25519 key
19
+ *
20
+ * Ed25519 keys in did:key start with 'z6Mk' after the method prefix.
21
+ * The 'z' is the multibase prefix for base58btc, and '6Mk' is the
22
+ * base58-encoded prefix for Ed25519 (0xed 0x01).
23
+ *
24
+ * @param did - The DID to check
25
+ * @returns true if it's a valid did:key with Ed25519 key
26
+ */
27
+ export declare function isEd25519DidKey(did: string): boolean;
28
+ /**
29
+ * Extract the public key bytes from a did:key DID
30
+ *
31
+ * @param did - The did:key DID
32
+ * @returns Public key bytes or null if invalid
33
+ */
34
+ export declare function extractPublicKeyFromDidKey(did: string): Uint8Array | null;
35
+ /**
36
+ * Convert Ed25519 public key bytes to JWK format
37
+ *
38
+ * @param publicKeyBytes - 32-byte Ed25519 public key
39
+ * @returns JWK object
40
+ */
41
+ export declare function publicKeyToJwk(publicKeyBytes: Uint8Array): {
42
+ kty: string;
43
+ crv: string;
44
+ x: string;
45
+ };
46
+ /**
47
+ * Create a DID:key resolver
48
+ *
49
+ * Returns a DIDResolver that can resolve did:key DIDs to DID Documents.
50
+ * Currently supports only Ed25519 keys.
51
+ *
52
+ * @returns DIDResolver implementation for did:key
53
+ */
54
+ export declare function createDidKeyResolver(): DIDResolver;
55
+ /**
56
+ * Resolve a did:key DID synchronously
57
+ *
58
+ * Convenience function for cases where async is not needed.
59
+ *
60
+ * @param did - The did:key DID to resolve
61
+ * @returns DID Document or null if invalid
62
+ */
63
+ export declare function resolveDidKeySync(did: string): DIDDocument | null;
64
+ //# sourceMappingURL=did-key-resolver.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"did-key-resolver.d.ts","sourceRoot":"","sources":["../../src/delegation/did-key-resolver.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;GAcG;AAIH,OAAO,KAAK,EAAE,WAAW,EAAE,WAAW,EAAsB,MAAM,kBAAkB,CAAC;AASrF;;;;;;;;;GASG;AACH,wBAAgB,eAAe,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAEpD;AAED;;;;;GAKG;AACH,wBAAgB,0BAA0B,CAAC,GAAG,EAAE,MAAM,GAAG,UAAU,GAAG,IAAI,CA8BzE;AAED;;;;;GAKG;AACH,wBAAgB,cAAc,CAAC,cAAc,EAAE,UAAU,GAAG;IAC1D,GAAG,EAAE,MAAM,CAAC;IACZ,GAAG,EAAE,MAAM,CAAC;IACZ,CAAC,EAAE,MAAM,CAAC;CACX,CAMA;AAED;;;;;;;GAOG;AACH,wBAAgB,oBAAoB,IAAI,WAAW,CAsClD;AAED;;;;;;;GAOG;AACH,wBAAgB,iBAAiB,CAAC,GAAG,EAAE,MAAM,GAAG,WAAW,GAAG,IAAI,CA2BjE"}
@@ -0,0 +1,154 @@
1
+ /**
2
+ * DID:key Resolver
3
+ *
4
+ * Resolves did:key DIDs to DID Documents with verification methods.
5
+ * Supports Ed25519 keys (multicodec prefix 0xed01).
6
+ *
7
+ * did:key format: did:key:z<multibase-base58btc(<multicodec-prefix><public-key>)>
8
+ *
9
+ * For Ed25519:
10
+ * - Multicodec prefix: 0xed 0x01
11
+ * - Public key: 32 bytes
12
+ * - Multibase prefix: 'z' (base58btc)
13
+ *
14
+ * @see https://w3c-ccg.github.io/did-method-key/
15
+ */
16
+ import { base58Decode } from '../utils/base58.js';
17
+ import { base64urlEncodeFromBytes } from '../utils/base64.js';
18
+ import { logger } from '../logging/index.js';
19
+ /** Ed25519 multicodec prefix (0xed 0x01) */
20
+ const ED25519_MULTICODEC_PREFIX = new Uint8Array([0xed, 0x01]);
21
+ /** Ed25519 public key length */
22
+ const ED25519_PUBLIC_KEY_LENGTH = 32;
23
+ /**
24
+ * Check if a DID is a valid did:key with Ed25519 key
25
+ *
26
+ * Ed25519 keys in did:key start with 'z6Mk' after the method prefix.
27
+ * The 'z' is the multibase prefix for base58btc, and '6Mk' is the
28
+ * base58-encoded prefix for Ed25519 (0xed 0x01).
29
+ *
30
+ * @param did - The DID to check
31
+ * @returns true if it's a valid did:key with Ed25519 key
32
+ */
33
+ export function isEd25519DidKey(did) {
34
+ return did.startsWith('did:key:z6Mk');
35
+ }
36
+ /**
37
+ * Extract the public key bytes from a did:key DID
38
+ *
39
+ * @param did - The did:key DID
40
+ * @returns Public key bytes or null if invalid
41
+ */
42
+ export function extractPublicKeyFromDidKey(did) {
43
+ if (!did.startsWith('did:key:z')) {
44
+ return null;
45
+ }
46
+ try {
47
+ // Extract the multibase-encoded part (after 'did:key:')
48
+ const multibaseKey = did.replace('did:key:', '');
49
+ // Remove the 'z' multibase prefix (base58btc)
50
+ const base58Encoded = multibaseKey.slice(1);
51
+ // Decode from base58
52
+ const multicodecBytes = base58Decode(base58Encoded);
53
+ // Check for Ed25519 multicodec prefix (0xed 0x01)
54
+ if (multicodecBytes.length < ED25519_MULTICODEC_PREFIX.length + ED25519_PUBLIC_KEY_LENGTH ||
55
+ multicodecBytes[0] !== ED25519_MULTICODEC_PREFIX[0] ||
56
+ multicodecBytes[1] !== ED25519_MULTICODEC_PREFIX[1]) {
57
+ return null;
58
+ }
59
+ // Extract the public key (bytes after the prefix)
60
+ return multicodecBytes.slice(ED25519_MULTICODEC_PREFIX.length);
61
+ }
62
+ catch (error) {
63
+ logger.debug('Failed to extract public key from did:key', error);
64
+ return null;
65
+ }
66
+ }
67
+ /**
68
+ * Convert Ed25519 public key bytes to JWK format
69
+ *
70
+ * @param publicKeyBytes - 32-byte Ed25519 public key
71
+ * @returns JWK object
72
+ */
73
+ export function publicKeyToJwk(publicKeyBytes) {
74
+ return {
75
+ kty: 'OKP',
76
+ crv: 'Ed25519',
77
+ x: base64urlEncodeFromBytes(publicKeyBytes),
78
+ };
79
+ }
80
+ /**
81
+ * Create a DID:key resolver
82
+ *
83
+ * Returns a DIDResolver that can resolve did:key DIDs to DID Documents.
84
+ * Currently supports only Ed25519 keys.
85
+ *
86
+ * @returns DIDResolver implementation for did:key
87
+ */
88
+ export function createDidKeyResolver() {
89
+ return {
90
+ resolve: async (did) => {
91
+ // Check if it's a did:key with Ed25519
92
+ if (!isEd25519DidKey(did)) {
93
+ return null;
94
+ }
95
+ // Extract the public key
96
+ const publicKeyBytes = extractPublicKeyFromDidKey(did);
97
+ if (!publicKeyBytes) {
98
+ return null;
99
+ }
100
+ // Convert to JWK
101
+ const publicKeyJwk = publicKeyToJwk(publicKeyBytes);
102
+ // Get the multibase-encoded key for publicKeyMultibase
103
+ const multibaseKey = did.replace('did:key:', '');
104
+ // Construct the verification method
105
+ const verificationMethod = {
106
+ id: `${did}#keys-1`,
107
+ type: 'Ed25519VerificationKey2020',
108
+ controller: did,
109
+ publicKeyJwk,
110
+ publicKeyMultibase: multibaseKey,
111
+ };
112
+ // Construct and return the DID Document
113
+ return {
114
+ id: did,
115
+ verificationMethod: [verificationMethod],
116
+ authentication: [`${did}#keys-1`],
117
+ assertionMethod: [`${did}#keys-1`],
118
+ };
119
+ },
120
+ };
121
+ }
122
+ /**
123
+ * Resolve a did:key DID synchronously
124
+ *
125
+ * Convenience function for cases where async is not needed.
126
+ *
127
+ * @param did - The did:key DID to resolve
128
+ * @returns DID Document or null if invalid
129
+ */
130
+ export function resolveDidKeySync(did) {
131
+ if (!isEd25519DidKey(did)) {
132
+ return null;
133
+ }
134
+ const publicKeyBytes = extractPublicKeyFromDidKey(did);
135
+ if (!publicKeyBytes) {
136
+ return null;
137
+ }
138
+ const publicKeyJwk = publicKeyToJwk(publicKeyBytes);
139
+ const multibaseKey = did.replace('did:key:', '');
140
+ const verificationMethod = {
141
+ id: `${did}#keys-1`,
142
+ type: 'Ed25519VerificationKey2020',
143
+ controller: did,
144
+ publicKeyJwk,
145
+ publicKeyMultibase: multibaseKey,
146
+ };
147
+ return {
148
+ id: did,
149
+ verificationMethod: [verificationMethod],
150
+ authentication: [`${did}#keys-1`],
151
+ assertionMethod: [`${did}#keys-1`],
152
+ };
153
+ }
154
+ //# sourceMappingURL=did-key-resolver.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"did-key-resolver.js","sourceRoot":"","sources":["../../src/delegation/did-key-resolver.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,83 @@
1
+ /**
2
+ * DID:web Resolver
3
+ *
4
+ * Resolves did:web DIDs by fetching /.well-known/did.json from the domain.
5
+ * Supports both root domain DIDs and path-based DIDs.
6
+ *
7
+ * Examples:
8
+ * did:web:example.com → https://example.com/.well-known/did.json
9
+ * did:web:example.com:agents:bot1 → https://example.com/agents/bot1/did.json
10
+ *
11
+ * @see https://w3c-ccg.github.io/did-method-web/
12
+ */
13
+ import type { FetchProvider } from '../providers/base.js';
14
+ import type { DIDResolver, DIDDocument } from './vc-verifier.js';
15
+ /**
16
+ * Parsed components of a did:web DID
17
+ */
18
+ interface ParsedDidWeb {
19
+ domain: string;
20
+ path: string[];
21
+ }
22
+ /**
23
+ * Check if a DID is a did:web DID
24
+ *
25
+ * @param did - The DID to check
26
+ * @returns true if it's a did:web DID
27
+ */
28
+ export declare function isDidWeb(did: string): boolean;
29
+ /**
30
+ * Parse a did:web DID into its components
31
+ *
32
+ * @param did - The did:web DID to parse
33
+ * @returns Parsed components or null if invalid
34
+ */
35
+ export declare function parseDidWeb(did: string): ParsedDidWeb | null;
36
+ /**
37
+ * Convert a did:web DID to its resolution URL
38
+ *
39
+ * did:web:example.com → https://example.com/.well-known/did.json
40
+ * did:web:example.com:path:to:doc → https://example.com/path/to/doc/did.json
41
+ *
42
+ * @param did - The did:web DID
43
+ * @returns The resolution URL or null if invalid
44
+ */
45
+ export declare function didWebToUrl(did: string): string | null;
46
+ /**
47
+ * DID:web resolver implementation
48
+ */
49
+ export declare class DidWebResolver implements DIDResolver {
50
+ private fetchProvider;
51
+ private cache;
52
+ private cacheTtl;
53
+ constructor(fetchProvider: FetchProvider, options?: {
54
+ cacheTtl?: number;
55
+ });
56
+ /**
57
+ * Resolve a did:web DID to its DID Document
58
+ *
59
+ * @param did - The did:web DID to resolve
60
+ * @returns The DID Document or null if resolution fails
61
+ */
62
+ resolve(did: string): Promise<DIDDocument | null>;
63
+ /**
64
+ * Clear the resolution cache
65
+ */
66
+ clearCache(): void;
67
+ /**
68
+ * Clear a specific entry from the cache
69
+ */
70
+ clearCacheEntry(did: string): void;
71
+ }
72
+ /**
73
+ * Create a did:web resolver with the given fetch provider
74
+ *
75
+ * @param fetchProvider - Provider for making HTTP requests
76
+ * @param options - Optional configuration
77
+ * @returns DIDResolver implementation for did:web
78
+ */
79
+ export declare function createDidWebResolver(fetchProvider: FetchProvider, options?: {
80
+ cacheTtl?: number;
81
+ }): DIDResolver;
82
+ export {};
83
+ //# sourceMappingURL=did-web-resolver.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"did-web-resolver.d.ts","sourceRoot":"","sources":["../../src/delegation/did-web-resolver.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;GAWG;AAEH,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,KAAK,EAAE,WAAW,EAAE,WAAW,EAAsB,MAAM,kBAAkB,CAAC;AAGrF;;GAEG;AACH,UAAU,YAAY;IACpB,MAAM,EAAE,MAAM,CAAC;IACf,IAAI,EAAE,MAAM,EAAE,CAAC;CAChB;AA0DD;;;;;GAKG;AACH,wBAAgB,QAAQ,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAE7C;AAED;;;;;GAKG;AACH,wBAAgB,WAAW,CAAC,GAAG,EAAE,MAAM,GAAG,YAAY,GAAG,IAAI,CA0B5D;AAED;;;;;;;;GAQG;AACH,wBAAgB,WAAW,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI,CAsBtD;AAED;;GAEG;AACH,qBAAa,cAAe,YAAW,WAAW;IAChD,OAAO,CAAC,aAAa,CAAgB;IACrC,OAAO,CAAC,KAAK,CAA4D;IACzE,OAAO,CAAC,QAAQ,CAAS;gBAEb,aAAa,EAAE,aAAa,EAAE,OAAO,CAAC,EAAE;QAAE,QAAQ,CAAC,EAAE,MAAM,CAAA;KAAE;IAMzE;;;;;OAKG;IACG,OAAO,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,GAAG,IAAI,CAAC;IAgEvD;;OAEG;IACH,UAAU,IAAI,IAAI;IAIlB;;OAEG;IACH,eAAe,CAAC,GAAG,EAAE,MAAM,GAAG,IAAI;CAGnC;AAED;;;;;;GAMG;AACH,wBAAgB,oBAAoB,CAClC,aAAa,EAAE,aAAa,EAC5B,OAAO,CAAC,EAAE;IAAE,QAAQ,CAAC,EAAE,MAAM,CAAA;CAAE,GAC9B,WAAW,CAEb"}