@sphereon/ssi-sdk.uni-resolver-registrar-api 0.33.1-next.2 → 0.33.1-next.68

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.
package/dist/index.d.ts CHANGED
@@ -1,7 +1,161 @@
1
+ import { DIDDocument } from '@sphereon/did-uni-client';
2
+ import { GenericAuthArgs, ISingleEndpointOpts, ExpressSupport } from '@sphereon/ssi-express-support';
3
+ import { JsonWebKey } from '@sphereon/ssi-types';
4
+ import { IDataStoreORM, IDIDManager, IKeyManager, IResolver, IAgentContext, TAgent } from '@veramo/core';
5
+ import { VerificationMethod } from 'did-resolver';
6
+ import express, { Router, Express } from 'express';
7
+
8
+ type IRequiredPlugins = IDataStoreORM & IDIDManager & IKeyManager & IResolver;
9
+ type IRequiredContext = IAgentContext<IRequiredPlugins>;
10
+ interface DidRegistrationCreateRequest {
11
+ did?: string;
12
+ jobId: string;
13
+ options: DidRegistrationOptions;
14
+ secret: DidRegistrationSecret;
15
+ didDocument?: DIDDocument;
16
+ }
17
+ interface DidRegistrationUpdateRequest {
18
+ did: string;
19
+ jobId: string;
20
+ options: DidRegistrationOptions;
21
+ secret: DidRegistrationSecret;
22
+ didDocumentOperation: DidDocumentOperation[];
23
+ didDocument?: DIDDocument[];
24
+ }
25
+ interface DidRegistrationDeactivateRequest {
26
+ did: string;
27
+ jobId?: string;
28
+ options?: DidRegistrationOptions;
29
+ secret?: DidRegistrationSecret;
30
+ }
31
+ type DidDocumentOperation = 'setDidDocument' | 'addToDidDocument' | 'removeFromDidDocument' | string;
32
+ interface DidRegistrationOptions {
33
+ network?: string;
34
+ storeSecrets?: boolean;
35
+ returnSecrets?: boolean;
36
+ [x: string]: any;
37
+ }
38
+ interface DidRegistrationSecret {
39
+ seed?: string;
40
+ verificationMethod?: CreateVerificationMethod[];
41
+ [x: string]: any;
42
+ }
43
+ interface CreateVerificationMethod extends VerificationMethod {
44
+ privateKeyBase58?: string;
45
+ privateKeyBase64?: string;
46
+ privateKeyJwk?: JsonWebKey;
47
+ privateKeyHex?: string;
48
+ privateKeyMultibase?: string;
49
+ purpose?: ('authentication' | 'assertionMethod' | 'capabilityDelegation' | 'capabilityInvocation')[];
50
+ }
51
+ interface CreateState {
52
+ jobId: string;
53
+ didState: DidState;
54
+ didRegistrationMetadata?: Record<string, any>;
55
+ didDocumentMetadata?: Record<string, any>;
56
+ }
57
+ type DidStateValue = 'finished' | 'failed' | 'action' | 'wait' | 'exists';
58
+ type DidStateAction = 'redirect' | 'getVerificationMethod' | 'signPayload' | 'decryptPayload';
59
+ interface DidState {
60
+ state: DidStateValue;
61
+ action?: DidStateAction;
62
+ wait?: string;
63
+ waitTime?: number;
64
+ did: string;
65
+ secret?: DidRegistrationSecret;
66
+ didDocument?: DIDDocument;
67
+ }
68
+ interface IDidWebServiceOpts {
69
+ globalAuth?: GenericAuthArgs;
70
+ endpointOpts?: IGlobalDidWebEndpointOpts;
71
+ enableFeatures?: DidWebServiceFeatures[];
72
+ }
73
+ interface IDidAPIOpts {
74
+ endpointOpts?: IDidAPIEndpointOpts;
75
+ enableFeatures?: DidApiFeatures[];
76
+ }
77
+ interface IDidAPIEndpointOpts {
78
+ basePath?: string;
79
+ globalAuth?: GenericAuthArgs;
80
+ createDid?: ICreateDidEndpointOpts;
81
+ resolveDid?: IResolveEndpointOpts;
82
+ deactivateDid?: ISingleEndpointOpts;
83
+ getDidMethods?: ISingleEndpointOpts;
84
+ }
85
+ interface IGlobalDidWebEndpointOpts extends ISingleEndpointOpts {
86
+ hostname?: string;
87
+ disableWellKnown?: boolean;
88
+ disableSubPaths?: boolean;
89
+ }
90
+ interface ICreateDidEndpointOpts extends ISingleEndpointOpts {
91
+ kms?: string;
92
+ storeSecrets?: boolean;
93
+ noErrorOnExistingDid?: boolean;
94
+ defaultMethod?: string;
95
+ }
96
+ interface IResolveEndpointOpts extends ISingleEndpointOpts {
97
+ mode?: 'local' | 'hybrid' | 'global';
98
+ }
99
+ type DidWebServiceFeatures = 'did-web-global-resolution';
100
+ type DidApiFeatures = 'did-resolve' | 'did-persist';
101
+
102
+ declare function createDidEndpoint(router: Router, context: IRequiredContext, opts?: ICreateDidEndpointOpts): void;
103
+ declare function getDidMethodsEndpoint(router: Router, context: IRequiredContext, opts?: ISingleEndpointOpts): void;
104
+ declare function resolveDidEndpoint(router: Router, context: IRequiredContext, opts?: IResolveEndpointOpts): void;
1
105
  /**
2
- * @public
106
+ * @param router
107
+ * @param context
108
+ * @param opts
3
109
  */
4
- export * from './uni-resolver-api-server';
5
- export * from './types';
6
- export * from './api-functions';
7
- //# sourceMappingURL=index.d.ts.map
110
+ declare function deleteDidEndpoint(router: Router, context: IRequiredContext, opts?: ISingleEndpointOpts): void;
111
+ declare function deactivateDidEndpoint(router: Router, context: IRequiredContext, opts?: ISingleEndpointOpts): void;
112
+ /**
113
+ * Endpoint that eases DID web resolution, by mapping did-web paths to stored agent DIDs.
114
+ *
115
+ * Typically, you will have a reverse proxy or load balancer in front of this endpoint.
116
+ *
117
+ * Some examples of how did:web behaves:
118
+ * did:web:example.com resolves to https://example.com/.well-known/did.json
119
+ * did:web:example.com:sub:paths resolves to https://example.com/sub/paths/did.json
120
+ *
121
+ * This endpoint translate both forms by looking at the paths that end in /did.json.
122
+ *
123
+ * @param router
124
+ * @param context
125
+ * @param opts
126
+ */
127
+ declare function didWebDomainEndpoint(router: Router, context: IRequiredContext, opts?: IGlobalDidWebEndpointOpts): void;
128
+
129
+ declare class UniResolverApiServer {
130
+ get router(): express.Router;
131
+ private readonly _express;
132
+ private readonly _agent;
133
+ private readonly _opts?;
134
+ private readonly _router;
135
+ constructor(args: {
136
+ agent: TAgent<IRequiredPlugins>;
137
+ expressSupport: ExpressSupport;
138
+ opts?: IDidAPIOpts;
139
+ });
140
+ get agent(): TAgent<IRequiredPlugins>;
141
+ get opts(): IDidAPIOpts | undefined;
142
+ get express(): Express;
143
+ }
144
+
145
+ declare class DidWebServer {
146
+ get router(): express.Router | undefined;
147
+ private readonly _express;
148
+ private readonly _agent;
149
+ private readonly _opts?;
150
+ private readonly _router;
151
+ constructor(args: {
152
+ agent: TAgent<IRequiredPlugins>;
153
+ expressSupport: ExpressSupport;
154
+ opts?: IDidWebServiceOpts;
155
+ });
156
+ get agent(): TAgent<IRequiredPlugins> | undefined;
157
+ get opts(): IDidWebServiceOpts | undefined;
158
+ get express(): Express | undefined;
159
+ }
160
+
161
+ export { type CreateState, type CreateVerificationMethod, type DidApiFeatures, type DidDocumentOperation, type DidRegistrationCreateRequest, type DidRegistrationDeactivateRequest, type DidRegistrationOptions, type DidRegistrationSecret, type DidRegistrationUpdateRequest, type DidState, type DidStateAction, type DidStateValue, DidWebServer, type DidWebServiceFeatures, type ICreateDidEndpointOpts, type IDidAPIEndpointOpts, type IDidAPIOpts, type IDidWebServiceOpts, type IGlobalDidWebEndpointOpts, type IRequiredContext, type IRequiredPlugins, type IResolveEndpointOpts, UniResolverApiServer, createDidEndpoint, deactivateDidEndpoint, deleteDidEndpoint, didWebDomainEndpoint, getDidMethodsEndpoint, resolveDidEndpoint };
package/dist/index.js CHANGED
@@ -1,23 +1,392 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
- for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
1
+ var __defProp = Object.defineProperty;
2
+ var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
3
+
4
+ // src/api-functions.ts
5
+ import { getAgentDIDMethods, toDidDocument, toDidResolutionResult } from "@sphereon/ssi-sdk-ext.did-utils";
6
+ import { JwkKeyUse } from "@sphereon/ssi-sdk-ext.key-utils";
7
+ import { checkAuth, sendErrorResponse } from "@sphereon/ssi-express-support";
8
+ import { parseDid } from "@sphereon/ssi-types";
9
+ import { v4 } from "uuid";
10
+ import Debug from "debug";
11
+ var debug = Debug("sphereon:ssi-sdk:uni-resolver-registrar");
12
+ function createDidEndpoint(router, context, opts) {
13
+ if (opts?.enabled === false) {
14
+ console.log(`create DID endpoint is disabled`);
15
+ return;
16
+ }
17
+ const path = opts?.path ?? "/identifiers";
18
+ router.post(path, checkAuth(opts?.endpoint), async (request, response) => {
19
+ try {
20
+ const createRequest = request.body;
21
+ if (!createRequest) {
22
+ return sendErrorResponse(response, 400, "No DID create request present");
23
+ }
24
+ const did = createRequest.did;
25
+ const didMethod = request.query.method ?? (did ? parseDid(did).method : opts?.defaultMethod);
26
+ const allDidMethods = await getAgentDIDMethods(context);
27
+ if (!didMethod) {
28
+ return sendErrorResponse(response, 400, "No DID method supplied or deductible");
29
+ } else if (did && parseDid(did).method != didMethod) {
30
+ return sendErrorResponse(response, 400, "DID method did not match method param");
31
+ } else if (!allDidMethods.includes(didMethod)) {
32
+ return sendErrorResponse(response, 400, "DID method not supported");
33
+ }
34
+ const provider = `did:${didMethod}`;
35
+ const jobId = createRequest.jobId ?? v4();
36
+ let alias = void 0;
37
+ if (didMethod === "web") {
38
+ if (!did) {
39
+ return sendErrorResponse(response, 400, 'Please provide a value for "did" in the request body when creating a DID web');
40
+ }
41
+ alias = parseDid(did).id;
42
+ if (!alias) {
43
+ return sendErrorResponse(response, 400, "Could not determine alias from did:web DID value: " + did);
44
+ }
45
+ }
46
+ let identifier;
47
+ let state;
48
+ if (opts?.noErrorOnExistingDid && did) {
49
+ try {
50
+ identifier = await context.agent.didManagerGet({
51
+ did
52
+ });
53
+ state = "exists";
54
+ } catch (e) {
55
+ }
56
+ }
57
+ if (identifier === void 0) {
58
+ if (createRequest.options.storeSecrets === false) {
59
+ return sendErrorResponse(response, 400, "Only storeSecrets mode is supported currently");
60
+ } else if (createRequest.options.storeSecrets || opts?.storeSecrets) {
61
+ identifier = await context.agent.didManagerCreate({
62
+ provider,
63
+ alias,
64
+ kms: opts?.kms
65
+ });
66
+ state = "finished";
67
+ } else {
68
+ return sendErrorResponse(response, 400, "Only storeSecrets mode is supported currently");
69
+ }
70
+ }
71
+ if (!identifier || !state) {
72
+ return sendErrorResponse(response, 400, "An identifier and did state should be present at this point");
73
+ }
74
+ const didDocument = toDidDocument(identifier, {
75
+ did,
76
+ use: [
77
+ JwkKeyUse.Signature,
78
+ JwkKeyUse.Encryption
79
+ ]
80
+ });
81
+ const createState = {
82
+ jobId,
83
+ didState: {
84
+ did: identifier.did,
85
+ state,
86
+ didDocument
87
+ }
88
+ };
89
+ response.statusCode = 200;
90
+ return response.send(createState);
91
+ } catch (e) {
92
+ return sendErrorResponse(response, 500, e.message, e);
93
+ }
94
+ });
95
+ }
96
+ __name(createDidEndpoint, "createDidEndpoint");
97
+ function getDidMethodsEndpoint(router, context, opts) {
98
+ if (opts?.enabled === false) {
99
+ console.log(`Get DID methods endpoint is disabled`);
100
+ return;
101
+ }
102
+ const path = opts?.path ?? "/methods";
103
+ router.get(path, checkAuth(opts?.endpoint), async (request, response) => {
104
+ try {
105
+ const methods = await getAgentDIDMethods(context);
106
+ response.statusCode = 200;
107
+ return response.send(methods);
108
+ } catch (e) {
109
+ return sendErrorResponse(response, 500, e.message, e);
110
+ }
111
+ });
112
+ }
113
+ __name(getDidMethodsEndpoint, "getDidMethodsEndpoint");
114
+ async function agentDidToResolutionResult(context, did) {
115
+ try {
116
+ const identifier = await context.agent.didManagerGet({
117
+ did
118
+ });
119
+ debug(JSON.stringify(identifier, null, 2));
120
+ return toDidResolutionResult(identifier, {
121
+ did,
122
+ supportedMethods: await getAgentDIDMethods(context)
123
+ });
124
+ } catch (error) {
125
+ console.log(JSON.stringify(error.message));
126
+ return {
127
+ didDocument: null,
128
+ didResolutionMetadata: {
129
+ error: "notFound"
130
+ },
131
+ didDocumentMetadata: {}
132
+ };
133
+ }
134
+ }
135
+ __name(agentDidToResolutionResult, "agentDidToResolutionResult");
136
+ function resolveDidEndpoint(router, context, opts) {
137
+ if (opts?.enabled === false) {
138
+ console.log(`Resolve DID endpoint is disabled`);
139
+ return;
140
+ }
141
+ const path = opts?.path ?? "/identifiers/:identifier";
142
+ router.get(path, checkAuth(opts?.endpoint), async (request, response) => {
143
+ try {
144
+ const did = request.params.identifier;
145
+ if (!did) {
146
+ return sendErrorResponse(response, 400, "no identifier provided");
147
+ }
148
+ const mode = request.query.mode?.toString().toLowerCase() ?? opts?.mode?.toLowerCase() ?? "hybrid";
149
+ let resolutionResult;
150
+ if (mode === "local" || mode === "hybrid") {
151
+ resolutionResult = await agentDidToResolutionResult(context, did);
152
+ }
153
+ if (mode !== "local" && !resolutionResult?.didDocument) {
154
+ resolutionResult = await context.agent.resolveDid({
155
+ didUrl: did
156
+ });
157
+ }
158
+ response.statusCode = 200;
159
+ return response.send(resolutionResult);
160
+ } catch (e) {
161
+ return sendErrorResponse(response, 500, e.message, e);
162
+ }
163
+ });
164
+ }
165
+ __name(resolveDidEndpoint, "resolveDidEndpoint");
166
+ function deleteDidEndpoint(router, context, opts) {
167
+ if (opts?.enabled === false) {
168
+ console.log(`Deactivate DID endpoint is disabled`);
169
+ return;
170
+ }
171
+ router.delete(opts?.path ?? "/identifiers/:identifier", checkAuth(opts?.endpoint), async (request, response) => {
172
+ try {
173
+ const did = request.params.identifier;
174
+ if (!did) {
175
+ return sendErrorResponse(response, 400, "no DID provided");
176
+ }
177
+ const result = await context.agent.didManagerDelete({
178
+ did
179
+ });
180
+ if (!result) {
181
+ return sendErrorResponse(response, 404, `id ${did} not found`);
182
+ }
183
+ response.statusCode = 200;
184
+ return response.send();
185
+ } catch (e) {
186
+ return sendErrorResponse(response, 500, e.message, e);
187
+ }
188
+ });
189
+ }
190
+ __name(deleteDidEndpoint, "deleteDidEndpoint");
191
+ function deactivateDidEndpoint(router, context, opts) {
192
+ if (opts?.enabled === false) {
193
+ console.log("Deactivate DID endpoint is disabled");
194
+ return;
195
+ }
196
+ router.post(opts?.path ?? "/deactivate", checkAuth(opts?.endpoint), async (request, response) => {
197
+ try {
198
+ const deactivateRequest = request.body;
199
+ if (!deactivateRequest) {
200
+ return sendErrorResponse(response, 400, "Invalid request body", {
201
+ state: "failed"
202
+ });
203
+ }
204
+ const { did, jobId = v4() } = deactivateRequest;
205
+ if (!did) {
206
+ return sendErrorResponse(response, 400, "No DID provided", {
207
+ state: "failed"
208
+ });
209
+ }
210
+ const result = await context.agent.didManagerDelete({
211
+ did
212
+ });
213
+ if (!result) {
214
+ return sendErrorResponse(response, 404, `DID ${did} not found`, {
215
+ state: "failed"
216
+ });
217
+ }
218
+ response.status(200).json({
219
+ state: "finished",
220
+ did,
221
+ jobId
222
+ });
223
+ return response.send();
224
+ } catch (e) {
225
+ return sendErrorResponse(response, 500, e.message, {
226
+ state: "failed",
227
+ errorDetails: e
228
+ });
229
+ }
230
+ });
231
+ }
232
+ __name(deactivateDidEndpoint, "deactivateDidEndpoint");
233
+ function didWebDomainEndpoint(router, context, opts) {
234
+ if (opts?.enabled === false) {
235
+ console.log(`DID Web domain resolution endpoint is disabled`);
236
+ return;
237
+ }
238
+ router.get(opts?.path ?? ":path(*)/did.json", checkAuth(opts?.endpoint), async (request, response) => {
239
+ try {
240
+ const path = request.params.path;
241
+ if (!path || path.length === 0) {
242
+ return sendErrorResponse(response, 404, "Not found");
243
+ }
244
+ let did;
245
+ did = `did:web:${opts?.hostname?.replace("https://", "")?.replace("http://", "") ?? request.hostname}`;
246
+ if (path !== "/.well-known") {
247
+ if (opts?.disableSubPaths) {
248
+ return sendErrorResponse(response, 404, "Not found");
249
+ }
250
+ const suffix = path.replace(/\//g, ":").replace(/%2F/g, ":");
251
+ if (!suffix.startsWith(":")) {
252
+ did += ":";
253
+ }
254
+ did += suffix;
255
+ } else if (opts?.disableWellKnown) {
256
+ return sendErrorResponse(response, 404, "Not found");
257
+ }
258
+ const resolutionResult = await agentDidToResolutionResult(context, did);
259
+ if (!resolutionResult || !resolutionResult.didDocument || resolutionResult?.didResolutionMetadata?.error === "notFound") {
260
+ return sendErrorResponse(response, 404, "Not found");
261
+ }
262
+ response.statusCode = 200;
263
+ return response.send(resolutionResult.didDocument);
264
+ } catch (e) {
265
+ return sendErrorResponse(response, 500, e.message, e);
266
+ }
267
+ });
268
+ }
269
+ __name(didWebDomainEndpoint, "didWebDomainEndpoint");
270
+
271
+ // src/uni-resolver-api-server.ts
272
+ import { agentContext } from "@sphereon/ssi-sdk.core";
273
+ import { copyGlobalAuthToEndpoints } from "@sphereon/ssi-express-support";
274
+ import express from "express";
275
+ var UniResolverApiServer = class {
276
+ static {
277
+ __name(this, "UniResolverApiServer");
278
+ }
279
+ get router() {
280
+ return this._router;
281
+ }
282
+ _express;
283
+ _agent;
284
+ _opts;
285
+ _router;
286
+ constructor(args) {
287
+ const { agent, opts } = args;
288
+ this._agent = agent;
289
+ copyGlobalAuthToEndpoints({
290
+ opts,
291
+ keys: [
292
+ "getDidMethods",
293
+ "createDid",
294
+ "resolveDid",
295
+ "deactivateDid"
296
+ ]
297
+ });
298
+ this._opts = opts;
299
+ this._express = args.expressSupport.express;
300
+ this._router = express.Router();
301
+ const context = agentContext(agent);
302
+ const features = opts?.enableFeatures ?? [
303
+ "did-resolve",
304
+ "did-persist"
305
+ ];
306
+ console.log(`DID Uni Resolver and Registrar API enabled, with features: ${JSON.stringify(features)}}`);
307
+ if (features.includes("did-resolve")) {
308
+ resolveDidEndpoint(this.router, context, opts?.endpointOpts?.resolveDid);
309
+ getDidMethodsEndpoint(this.router, context, opts?.endpointOpts?.getDidMethods);
310
+ }
311
+ if (features.includes("did-persist")) {
312
+ createDidEndpoint(this.router, context, opts?.endpointOpts?.createDid);
313
+ deleteDidEndpoint(this.router, context, opts?.endpointOpts?.deactivateDid);
314
+ deactivateDidEndpoint(this.router, context, opts?.endpointOpts?.deactivateDid);
315
+ }
316
+ this._express.use(opts?.endpointOpts?.basePath ?? "", this.router);
317
+ }
318
+ get agent() {
319
+ return this._agent;
320
+ }
321
+ get opts() {
322
+ return this._opts;
323
+ }
324
+ get express() {
325
+ return this._express;
326
+ }
327
+ };
328
+
329
+ // src/did-web-server.ts
330
+ import { agentContext as agentContext2 } from "@sphereon/ssi-sdk.core";
331
+ import express2 from "express";
332
+ var DidWebServer = class {
333
+ static {
334
+ __name(this, "DidWebServer");
335
+ }
336
+ get router() {
337
+ return this._router;
338
+ }
339
+ _express;
340
+ _agent;
341
+ _opts;
342
+ _router;
343
+ constructor(args) {
344
+ const { agent, opts } = args;
345
+ const features = opts?.enableFeatures ?? [];
346
+ if (!features.includes("did-web-global-resolution")) {
347
+ console.log("did:web hosting service NOT enabled");
348
+ return;
349
+ }
350
+ this._agent = agent;
351
+ if (opts?.globalAuth) {
352
+ copyGlobalAuthToEndpoint(opts, "endpointOpts");
353
+ }
354
+ this._opts = opts;
355
+ this._express = args.expressSupport.express;
356
+ this._router = express2.Router();
357
+ const context = agentContext2(agent);
358
+ console.log(`did:web hosting service enabled`);
359
+ didWebDomainEndpoint(this.router, context, opts?.endpointOpts);
360
+ this._express.use(this.router);
361
+ }
362
+ get agent() {
363
+ return this._agent;
364
+ }
365
+ get opts() {
366
+ return this._opts;
367
+ }
368
+ get express() {
369
+ return this._express;
370
+ }
371
+ };
372
+ function copyGlobalAuthToEndpoint(opts, key) {
373
+ if (opts?.globalAuth) {
374
+ opts[key] = {
375
+ ...opts?.globalAuth,
376
+ // @ts-ignore
377
+ ...opts[key]
378
+ };
379
+ }
380
+ }
381
+ __name(copyGlobalAuthToEndpoint, "copyGlobalAuthToEndpoint");
382
+ export {
383
+ DidWebServer,
384
+ UniResolverApiServer,
385
+ createDidEndpoint,
386
+ deactivateDidEndpoint,
387
+ deleteDidEndpoint,
388
+ didWebDomainEndpoint,
389
+ getDidMethodsEndpoint,
390
+ resolveDidEndpoint
15
391
  };
16
- Object.defineProperty(exports, "__esModule", { value: true });
17
- /**
18
- * @public
19
- */
20
- __exportStar(require("./uni-resolver-api-server"), exports);
21
- __exportStar(require("./types"), exports);
22
- __exportStar(require("./api-functions"), exports);
23
392
  //# sourceMappingURL=index.js.map
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA;;GAEG;AACH,4DAAyC;AACzC,0CAAuB;AACvB,kDAA+B"}
1
+ {"version":3,"sources":["../src/api-functions.ts","../src/uni-resolver-api-server.ts","../src/did-web-server.ts"],"sourcesContent":["import { DIDResolutionResult } from '@sphereon/did-uni-client'\nimport { getAgentDIDMethods, toDidDocument, toDidResolutionResult } from '@sphereon/ssi-sdk-ext.did-utils'\nimport { JwkKeyUse } from '@sphereon/ssi-sdk-ext.key-utils'\nimport { checkAuth, ISingleEndpointOpts, sendErrorResponse } from '@sphereon/ssi-express-support'\nimport { parseDid } from '@sphereon/ssi-types'\nimport { IIdentifier } from '@veramo/core'\nimport { Request, Response, Router } from 'express'\nimport { v4 } from 'uuid'\nimport {\n CreateState,\n DidRegistrationCreateRequest,\n DidRegistrationDeactivateRequest,\n DidStateValue,\n ICreateDidEndpointOpts,\n IGlobalDidWebEndpointOpts,\n IRequiredContext,\n IResolveEndpointOpts,\n} from './types'\nimport Debug from 'debug'\n\nconst debug = Debug('sphereon:ssi-sdk:uni-resolver-registrar')\n\nexport function createDidEndpoint(router: Router, context: IRequiredContext, opts?: ICreateDidEndpointOpts) {\n if (opts?.enabled === false) {\n console.log(`create DID endpoint is disabled`)\n return\n }\n const path = opts?.path ?? '/identifiers'\n\n router.post(path, checkAuth(opts?.endpoint), async (request: Request, response: Response) => {\n try {\n const createRequest: DidRegistrationCreateRequest = request.body\n if (!createRequest) {\n return sendErrorResponse(response, 400, 'No DID create request present')\n }\n const did = createRequest.did\n const didMethod = (request.query.method as string) ?? (did ? parseDid(did).method : opts?.defaultMethod)\n const allDidMethods = await getAgentDIDMethods(context)\n if (!didMethod) {\n return sendErrorResponse(response, 400, 'No DID method supplied or deductible')\n } else if (did && parseDid(did).method != didMethod) {\n return sendErrorResponse(response, 400, 'DID method did not match method param')\n } else if (!allDidMethods.includes(didMethod)) {\n return sendErrorResponse(response, 400, 'DID method not supported')\n }\n const provider = `did:${didMethod}`\n const jobId = createRequest.jobId ?? v4()\n let alias: string | undefined = undefined\n if (didMethod === 'web') {\n if (!did) {\n return sendErrorResponse(response, 400, 'Please provide a value for \"did\" in the request body when creating a DID web')\n }\n alias = parseDid(did).id\n if (!alias) {\n return sendErrorResponse(response, 400, 'Could not determine alias from did:web DID value: ' + did)\n }\n }\n\n let identifier: IIdentifier | undefined\n let state: DidStateValue | undefined\n if (opts?.noErrorOnExistingDid && did) {\n try {\n identifier = await context.agent.didManagerGet({ did })\n state = 'exists'\n } catch (e) {\n // Okay, since we will create a new one\n }\n }\n if (identifier === undefined) {\n if (createRequest.options.storeSecrets === false) {\n return sendErrorResponse(response, 400, 'Only storeSecrets mode is supported currently')\n /*const memoryKMS = new SphereonKeyManager({\n store: new MemoryKeyStore(),\n kms: {'mem': new KeyManagementSystem(new MemoryPrivateKeyStore())}\n })\n identifier = await memoryKMS..didManagerCreate({provider, alias, kms: opts?.kms})*/\n } else if (createRequest.options.storeSecrets || opts?.storeSecrets) {\n identifier = await context.agent.didManagerCreate({ provider, alias, kms: opts?.kms })\n state = 'finished'\n } else {\n return sendErrorResponse(response, 400, 'Only storeSecrets mode is supported currently')\n }\n }\n if (!identifier || !state) {\n return sendErrorResponse(response, 400, 'An identifier and did state should be present at this point')\n }\n\n const didDocument = toDidDocument(identifier, { did, use: [JwkKeyUse.Signature, JwkKeyUse.Encryption] })\n const createState: CreateState = {\n jobId,\n didState: {\n did: identifier.did,\n state,\n didDocument,\n },\n }\n response.statusCode = 200\n return response.send(createState)\n } catch (e) {\n return sendErrorResponse(response, 500, e.message as string, e)\n }\n })\n}\n\nexport function getDidMethodsEndpoint(router: Router, context: IRequiredContext, opts?: ISingleEndpointOpts) {\n if (opts?.enabled === false) {\n console.log(`Get DID methods endpoint is disabled`)\n return\n }\n const path = opts?.path ?? '/methods'\n router.get(path, checkAuth(opts?.endpoint), async (request: Request, response: Response) => {\n try {\n const methods = await getAgentDIDMethods(context) // these are already without the 'did:' prefix\n response.statusCode = 200\n return response.send(methods)\n } catch (e) {\n return sendErrorResponse(response, 500, e.message as string, e)\n }\n })\n}\n\nasync function agentDidToResolutionResult(context: IRequiredContext, did: string) {\n try {\n const identifier = await context.agent.didManagerGet({ did })\n debug(JSON.stringify(identifier, null, 2))\n return toDidResolutionResult(identifier, {\n did,\n supportedMethods: await getAgentDIDMethods(context),\n })\n } catch (error) {\n console.log(JSON.stringify(error.message))\n return {\n didDocument: null,\n didResolutionMetadata: {\n error: 'notFound',\n },\n didDocumentMetadata: {},\n }\n }\n}\n\nexport function resolveDidEndpoint(router: Router, context: IRequiredContext, opts?: IResolveEndpointOpts) {\n if (opts?.enabled === false) {\n console.log(`Resolve DID endpoint is disabled`)\n return\n }\n const path = opts?.path ?? '/identifiers/:identifier'\n router.get(path, checkAuth(opts?.endpoint), async (request: Request, response: Response) => {\n try {\n const did = request.params.identifier\n if (!did) {\n return sendErrorResponse(response, 400, 'no identifier provided')\n }\n const mode = request.query.mode?.toString().toLowerCase() ?? opts?.mode?.toLowerCase() ?? 'hybrid'\n let resolutionResult: DIDResolutionResult | undefined\n if (mode === 'local' || mode === 'hybrid') {\n resolutionResult = await agentDidToResolutionResult(context, did)\n }\n if (mode !== 'local' && !resolutionResult?.didDocument) {\n resolutionResult = await context.agent.resolveDid({ didUrl: did })\n }\n\n response.statusCode = 200\n return response.send(resolutionResult)\n } catch (e) {\n return sendErrorResponse(response, 500, e.message as string, e)\n }\n })\n}\n\n/**\n * @param router\n * @param context\n * @param opts\n */\nexport function deleteDidEndpoint(router: Router, context: IRequiredContext, opts?: ISingleEndpointOpts) {\n if (opts?.enabled === false) {\n console.log(`Deactivate DID endpoint is disabled`)\n return\n }\n router.delete(opts?.path ?? '/identifiers/:identifier', checkAuth(opts?.endpoint), async (request: Request, response: Response) => {\n try {\n const did = request.params.identifier\n if (!did) {\n return sendErrorResponse(response, 400, 'no DID provided')\n }\n\n const result = await context.agent.didManagerDelete({ did })\n if (!result) {\n return sendErrorResponse(response, 404, `id ${did} not found`)\n }\n response.statusCode = 200\n return response.send()\n } catch (e) {\n return sendErrorResponse(response, 500, e.message as string, e)\n }\n })\n}\n\nexport function deactivateDidEndpoint(router: Router, context: IRequiredContext, opts?: ISingleEndpointOpts) {\n if (opts?.enabled === false) {\n console.log('Deactivate DID endpoint is disabled')\n return\n }\n\n router.post(opts?.path ?? '/deactivate', checkAuth(opts?.endpoint), async (request: Request, response: Response) => {\n try {\n const deactivateRequest: DidRegistrationDeactivateRequest = request.body\n if (!deactivateRequest) {\n return sendErrorResponse(response, 400, 'Invalid request body', { state: 'failed' })\n }\n\n const { did, jobId = v4() } = deactivateRequest\n if (!did) {\n return sendErrorResponse(response, 400, 'No DID provided', { state: 'failed' })\n }\n\n const result = await context.agent.didManagerDelete({ did })\n if (!result) {\n return sendErrorResponse(response, 404, `DID ${did} not found`, { state: 'failed' })\n }\n\n response.status(200).json({\n state: 'finished',\n did,\n jobId,\n })\n return response.send()\n } catch (e) {\n return sendErrorResponse(response, 500, e.message as string, { state: 'failed', errorDetails: e })\n }\n })\n}\n\n/**\n * Endpoint that eases DID web resolution, by mapping did-web paths to stored agent DIDs.\n *\n * Typically, you will have a reverse proxy or load balancer in front of this endpoint.\n *\n * Some examples of how did:web behaves:\n * did:web:example.com resolves to https://example.com/.well-known/did.json\n * did:web:example.com:sub:paths resolves to https://example.com/sub/paths/did.json\n *\n * This endpoint translate both forms by looking at the paths that end in /did.json.\n *\n * @param router\n * @param context\n * @param opts\n */\nexport function didWebDomainEndpoint(router: Router, context: IRequiredContext, opts?: IGlobalDidWebEndpointOpts) {\n if (opts?.enabled === false) {\n console.log(`DID Web domain resolution endpoint is disabled`)\n return\n }\n router.get(opts?.path ?? ':path(*)/did.json', checkAuth(opts?.endpoint), async (request: Request, response: Response) => {\n try {\n const path = request.params.path\n if (!path || path.length === 0) {\n return sendErrorResponse(response, 404, 'Not found')\n }\n let did: string\n did = `did:web:${opts?.hostname?.replace('https://', '')?.replace('http://', '') ?? request.hostname}`\n if (path !== '/.well-known') {\n if (opts?.disableSubPaths) {\n return sendErrorResponse(response, 404, 'Not found')\n }\n const suffix = path.replace(/\\//g, ':').replace(/%2F/g, ':')\n if (!suffix.startsWith(':')) {\n did += ':'\n }\n did += suffix\n } else if (opts?.disableWellKnown) {\n return sendErrorResponse(response, 404, 'Not found')\n }\n\n const resolutionResult = await agentDidToResolutionResult(context, did)\n if (!resolutionResult || !resolutionResult.didDocument || resolutionResult?.didResolutionMetadata?.error === 'notFound') {\n return sendErrorResponse(response, 404, 'Not found')\n }\n response.statusCode = 200\n return response.send(resolutionResult.didDocument)\n } catch (e) {\n return sendErrorResponse(response, 500, e.message as string, e)\n }\n })\n}\n","import { agentContext } from '@sphereon/ssi-sdk.core'\nimport { copyGlobalAuthToEndpoints, ExpressSupport } from '@sphereon/ssi-express-support'\nimport { TAgent } from '@veramo/core'\n\nimport express, { Express, Router } from 'express'\nimport { createDidEndpoint, deleteDidEndpoint, deactivateDidEndpoint, getDidMethodsEndpoint, resolveDidEndpoint } from './api-functions'\nimport { IDidAPIOpts, IRequiredPlugins } from './types'\n\nexport class UniResolverApiServer {\n get router(): express.Router {\n return this._router\n }\n\n private readonly _express: Express\n private readonly _agent: TAgent<IRequiredPlugins>\n private readonly _opts?: IDidAPIOpts\n private readonly _router: Router\n\n constructor(args: { agent: TAgent<IRequiredPlugins>; expressSupport: ExpressSupport; opts?: IDidAPIOpts }) {\n const { agent, opts } = args\n this._agent = agent\n copyGlobalAuthToEndpoints({ opts, keys: ['getDidMethods', 'createDid', 'resolveDid', 'deactivateDid'] })\n this._opts = opts\n this._express = args.expressSupport.express\n this._router = express.Router()\n const context = agentContext(agent)\n const features = opts?.enableFeatures ?? ['did-resolve', 'did-persist']\n console.log(`DID Uni Resolver and Registrar API enabled, with features: ${JSON.stringify(features)}}`)\n\n // DID endpoints\n if (features.includes('did-resolve')) {\n resolveDidEndpoint(this.router, context, opts?.endpointOpts?.resolveDid)\n getDidMethodsEndpoint(this.router, context, opts?.endpointOpts?.getDidMethods)\n }\n if (features.includes('did-persist')) {\n createDidEndpoint(this.router, context, opts?.endpointOpts?.createDid)\n deleteDidEndpoint(this.router, context, opts?.endpointOpts?.deactivateDid) // not in spec.\n deactivateDidEndpoint(this.router, context, opts?.endpointOpts?.deactivateDid)\n }\n this._express.use(opts?.endpointOpts?.basePath ?? '', this.router)\n }\n\n get agent(): TAgent<IRequiredPlugins> {\n return this._agent\n }\n\n get opts(): IDidAPIOpts | undefined {\n return this._opts\n }\n\n get express(): Express {\n return this._express\n }\n}\n","import { agentContext } from '@sphereon/ssi-sdk.core'\nimport { ExpressSupport } from '@sphereon/ssi-express-support'\nimport { TAgent } from '@veramo/core'\n\nimport express, { Express, Router } from 'express'\nimport { didWebDomainEndpoint } from './api-functions'\nimport { IDidWebServiceOpts, IRequiredPlugins } from './types'\n\nexport class DidWebServer {\n get router(): express.Router | undefined {\n return this._router\n }\n\n private readonly _express: Express | undefined\n private readonly _agent: TAgent<IRequiredPlugins> | undefined\n private readonly _opts?: IDidWebServiceOpts\n private readonly _router: Router | undefined\n\n constructor(args: { agent: TAgent<IRequiredPlugins>; expressSupport: ExpressSupport; opts?: IDidWebServiceOpts }) {\n const { agent, opts } = args\n const features = opts?.enableFeatures ?? []\n if (!features.includes('did-web-global-resolution')) {\n console.log('did:web hosting service NOT enabled')\n return\n }\n\n this._agent = agent\n if (opts?.globalAuth) {\n copyGlobalAuthToEndpoint(opts, 'endpointOpts')\n }\n\n this._opts = opts\n this._express = args.expressSupport.express\n this._router = express.Router()\n\n const context = agentContext(agent)\n\n console.log(`did:web hosting service enabled`)\n\n didWebDomainEndpoint(this.router!, context, opts?.endpointOpts)\n this._express.use(this.router!)\n }\n\n get agent(): TAgent<IRequiredPlugins> | undefined {\n return this._agent\n }\n\n get opts(): IDidWebServiceOpts | undefined {\n return this._opts\n }\n\n get express(): Express | undefined {\n return this._express\n }\n}\n\nfunction copyGlobalAuthToEndpoint(opts: IDidWebServiceOpts, key: string) {\n if (opts?.globalAuth) {\n // @ts-ignore\n opts[key] = {\n ...opts?.globalAuth,\n // @ts-ignore\n ...opts[key],\n }\n }\n}\n"],"mappings":"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","names":["getAgentDIDMethods","toDidDocument","toDidResolutionResult","JwkKeyUse","checkAuth","sendErrorResponse","parseDid","v4","Debug","debug","Debug","createDidEndpoint","router","context","opts","enabled","console","log","path","post","checkAuth","endpoint","request","response","createRequest","body","sendErrorResponse","did","didMethod","query","method","parseDid","defaultMethod","allDidMethods","getAgentDIDMethods","includes","provider","jobId","v4","alias","undefined","id","identifier","state","noErrorOnExistingDid","agent","didManagerGet","e","options","storeSecrets","didManagerCreate","kms","didDocument","toDidDocument","use","JwkKeyUse","Signature","Encryption","createState","didState","statusCode","send","message","getDidMethodsEndpoint","get","methods","agentDidToResolutionResult","JSON","stringify","toDidResolutionResult","supportedMethods","error","didResolutionMetadata","didDocumentMetadata","resolveDidEndpoint","params","mode","toString","toLowerCase","resolutionResult","resolveDid","didUrl","deleteDidEndpoint","delete","result","didManagerDelete","deactivateDidEndpoint","deactivateRequest","status","json","errorDetails","didWebDomainEndpoint","length","hostname","replace","disableSubPaths","suffix","startsWith","disableWellKnown","agentContext","copyGlobalAuthToEndpoints","express","UniResolverApiServer","router","_router","_express","_agent","_opts","constructor","args","agent","opts","copyGlobalAuthToEndpoints","keys","expressSupport","express","Router","context","agentContext","features","enableFeatures","console","log","JSON","stringify","includes","resolveDidEndpoint","endpointOpts","resolveDid","getDidMethodsEndpoint","getDidMethods","createDidEndpoint","createDid","deleteDidEndpoint","deactivateDid","deactivateDidEndpoint","use","basePath","agentContext","express","DidWebServer","router","_router","_express","_agent","_opts","constructor","args","agent","opts","features","enableFeatures","includes","console","log","globalAuth","copyGlobalAuthToEndpoint","expressSupport","express","Router","context","agentContext","didWebDomainEndpoint","endpointOpts","use","key"]}