@sphereon/oid4vci-client 0.8.2-next.6 → 0.8.2-next.88
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/README.md +9 -8
- package/dist/AccessTokenClient.d.ts +0 -1
- package/dist/AccessTokenClient.d.ts.map +1 -1
- package/dist/AccessTokenClient.js +11 -18
- package/dist/AccessTokenClient.js.map +1 -1
- package/dist/AuthorizationCodeClient.d.ts +9 -0
- package/dist/AuthorizationCodeClient.d.ts.map +1 -0
- package/dist/AuthorizationCodeClient.js +132 -0
- package/dist/AuthorizationCodeClient.js.map +1 -0
- package/dist/AuthorizationDetailsBuilder.d.ts.map +1 -1
- package/dist/AuthorizationDetailsBuilder.js.map +1 -1
- package/dist/CredentialOfferClient.d.ts.map +1 -1
- package/dist/CredentialOfferClient.js +3 -1
- package/dist/CredentialOfferClient.js.map +1 -1
- package/dist/CredentialRequestClient.d.ts +15 -0
- package/dist/CredentialRequestClient.d.ts.map +1 -1
- package/dist/CredentialRequestClient.js +91 -43
- package/dist/CredentialRequestClient.js.map +1 -1
- package/dist/CredentialRequestClientBuilder.d.ts +19 -7
- package/dist/CredentialRequestClientBuilder.d.ts.map +1 -1
- package/dist/CredentialRequestClientBuilder.js +31 -1
- package/dist/CredentialRequestClientBuilder.js.map +1 -1
- package/dist/MetadataClient.d.ts.map +1 -1
- package/dist/MetadataClient.js +12 -1
- package/dist/MetadataClient.js.map +1 -1
- package/dist/OpenID4VCIClient.d.ts +62 -27
- package/dist/OpenID4VCIClient.d.ts.map +1 -1
- package/dist/OpenID4VCIClient.js +255 -176
- package/dist/OpenID4VCIClient.js.map +1 -1
- package/dist/ProofOfPossessionBuilder.d.ts +3 -1
- package/dist/ProofOfPossessionBuilder.d.ts.map +1 -1
- package/dist/ProofOfPossessionBuilder.js +5 -0
- package/dist/ProofOfPossessionBuilder.js.map +1 -1
- package/dist/functions/AuthorizationUtil.d.ts +3 -0
- package/dist/functions/AuthorizationUtil.d.ts.map +1 -0
- package/dist/functions/AuthorizationUtil.js +22 -0
- package/dist/functions/AuthorizationUtil.js.map +1 -0
- package/dist/functions/ProofUtil.d.ts +2 -1
- package/dist/functions/ProofUtil.d.ts.map +1 -1
- package/dist/functions/ProofUtil.js +6 -4
- package/dist/functions/ProofUtil.js.map +1 -1
- package/dist/index.d.ts +1 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +1 -0
- package/dist/index.js.map +1 -1
- package/dist/types/index.d.ts +1 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +2 -0
- package/dist/types/index.js.map +1 -0
- package/lib/AccessTokenClient.ts +16 -20
- package/lib/AuthorizationCodeClient.ts +163 -0
- package/lib/AuthorizationDetailsBuilder.ts +2 -2
- package/lib/CredentialOfferClient.ts +4 -1
- package/lib/CredentialRequestClient.ts +116 -45
- package/lib/CredentialRequestClientBuilder.ts +53 -8
- package/lib/MetadataClient.ts +13 -1
- package/lib/OpenID4VCIClient.ts +348 -216
- package/lib/ProofOfPossessionBuilder.ts +8 -0
- package/lib/__tests__/AccessTokenClient.spec.ts +2 -0
- package/lib/__tests__/CredentialRequestClient.spec.ts +28 -8
- package/lib/__tests__/EBSIE2E.spec.test.ts +145 -0
- package/lib/__tests__/MetadataClient.spec.ts +4 -1
- package/lib/__tests__/OpenID4VCIClient.spec.ts +117 -76
- package/lib/__tests__/OpenID4VCIClientPAR.spec.ts +59 -49
- package/lib/__tests__/SdJwt.spec.ts +163 -0
- package/lib/__tests__/SphereonE2E.spec.test.ts +2 -2
- package/lib/__tests__/data/VciDataFixtures.ts +14 -13
- package/lib/functions/AuthorizationUtil.ts +18 -0
- package/lib/functions/ProofUtil.ts +18 -4
- package/lib/index.ts +1 -0
- package/lib/types/index.ts +0 -0
- package/package.json +8 -6
|
@@ -12,80 +12,102 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
12
12
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
13
13
|
};
|
|
14
14
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
-
exports.CredentialRequestClient = void 0;
|
|
15
|
+
exports.CredentialRequestClient = exports.buildProof = void 0;
|
|
16
16
|
const oid4vci_common_1 = require("@sphereon/oid4vci-common");
|
|
17
17
|
const debug_1 = __importDefault(require("debug"));
|
|
18
18
|
const ProofOfPossessionBuilder_1 = require("./ProofOfPossessionBuilder");
|
|
19
19
|
const functions_1 = require("./functions");
|
|
20
20
|
const debug = (0, debug_1.default)('sphereon:oid4vci:credential');
|
|
21
|
+
function buildProof(proofInput, opts) {
|
|
22
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
23
|
+
if ('proof_type' in proofInput) {
|
|
24
|
+
if (opts.cNonce) {
|
|
25
|
+
throw Error(`Cnonce param is only supported when using a Proof of Posession builder`);
|
|
26
|
+
}
|
|
27
|
+
return yield ProofOfPossessionBuilder_1.ProofOfPossessionBuilder.fromProof(proofInput, opts.version).build();
|
|
28
|
+
}
|
|
29
|
+
if (opts.cNonce) {
|
|
30
|
+
proofInput.withAccessTokenNonce(opts.cNonce);
|
|
31
|
+
}
|
|
32
|
+
return yield proofInput.build();
|
|
33
|
+
});
|
|
34
|
+
}
|
|
35
|
+
exports.buildProof = buildProof;
|
|
21
36
|
class CredentialRequestClient {
|
|
22
37
|
get credentialRequestOpts() {
|
|
23
38
|
return this._credentialRequestOpts;
|
|
24
39
|
}
|
|
40
|
+
isDeferred() {
|
|
41
|
+
return this._isDeferred;
|
|
42
|
+
}
|
|
25
43
|
getCredentialEndpoint() {
|
|
26
44
|
return this.credentialRequestOpts.credentialEndpoint;
|
|
27
45
|
}
|
|
46
|
+
getDeferredCredentialEndpoint() {
|
|
47
|
+
return this.credentialRequestOpts.deferredCredentialEndpoint;
|
|
48
|
+
}
|
|
28
49
|
constructor(builder) {
|
|
50
|
+
this._isDeferred = false;
|
|
29
51
|
this._credentialRequestOpts = Object.assign({}, builder);
|
|
30
52
|
}
|
|
31
53
|
acquireCredentialsUsingProof(opts) {
|
|
32
54
|
return __awaiter(this, void 0, void 0, function* () {
|
|
33
|
-
const { credentialTypes, proofInput, format } = opts;
|
|
34
|
-
const request = yield this.createCredentialRequest({ proofInput, credentialTypes, format, version: this.version() });
|
|
55
|
+
const { credentialTypes, proofInput, format, context } = opts;
|
|
56
|
+
const request = yield this.createCredentialRequest({ proofInput, credentialTypes, context, format, version: this.version() });
|
|
35
57
|
return yield this.acquireCredentialsUsingRequest(request);
|
|
36
58
|
});
|
|
37
59
|
}
|
|
38
60
|
acquireCredentialsUsingRequest(uniformRequest) {
|
|
39
61
|
return __awaiter(this, void 0, void 0, function* () {
|
|
40
|
-
|
|
41
|
-
if (!this.isV11OrHigher()) {
|
|
42
|
-
let format = uniformRequest.format;
|
|
43
|
-
if (format === 'jwt_vc_json') {
|
|
44
|
-
format = 'jwt_vc';
|
|
45
|
-
}
|
|
46
|
-
else if (format === 'jwt_vc_json-ld') {
|
|
47
|
-
format = 'ldp_vc';
|
|
48
|
-
}
|
|
49
|
-
request = {
|
|
50
|
-
format,
|
|
51
|
-
proof: uniformRequest.proof,
|
|
52
|
-
type: 'types' in uniformRequest
|
|
53
|
-
? uniformRequest.types.filter((t) => t !== 'VerifiableCredential')[0]
|
|
54
|
-
: uniformRequest.credential_definition.types[0],
|
|
55
|
-
};
|
|
56
|
-
}
|
|
62
|
+
const request = (0, oid4vci_common_1.getCredentialRequestForVersion)(uniformRequest, this.version());
|
|
57
63
|
const credentialEndpoint = this.credentialRequestOpts.credentialEndpoint;
|
|
58
64
|
if (!(0, functions_1.isValidURL)(credentialEndpoint)) {
|
|
59
65
|
debug(`Invalid credential endpoint: ${credentialEndpoint}`);
|
|
60
66
|
throw new Error(oid4vci_common_1.URL_NOT_VALID);
|
|
61
67
|
}
|
|
62
68
|
debug(`Acquiring credential(s) from: ${credentialEndpoint}`);
|
|
69
|
+
debug(`request\n: ${JSON.stringify(request, null, 2)}`);
|
|
63
70
|
const requestToken = this.credentialRequestOpts.token;
|
|
64
|
-
|
|
65
|
-
|
|
71
|
+
let response = yield (0, functions_1.post)(credentialEndpoint, JSON.stringify(request), { bearerToken: requestToken });
|
|
72
|
+
this._isDeferred = (0, oid4vci_common_1.isDeferredCredentialResponse)(response);
|
|
73
|
+
if (this.isDeferred() && this.credentialRequestOpts.deferredCredentialAwait && response.successBody) {
|
|
74
|
+
response = yield this.acquireDeferredCredential(response.successBody, { bearerToken: this.credentialRequestOpts.token });
|
|
75
|
+
}
|
|
76
|
+
debug(`Credential endpoint ${credentialEndpoint} response:\r\n${JSON.stringify(response, null, 2)}`);
|
|
66
77
|
return response;
|
|
67
78
|
});
|
|
68
79
|
}
|
|
80
|
+
acquireDeferredCredential(response, opts) {
|
|
81
|
+
var _a;
|
|
82
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
83
|
+
const transactionId = response.transaction_id;
|
|
84
|
+
const bearerToken = (_a = response.acceptance_token) !== null && _a !== void 0 ? _a : opts === null || opts === void 0 ? void 0 : opts.bearerToken;
|
|
85
|
+
const deferredCredentialEndpoint = this.getDeferredCredentialEndpoint();
|
|
86
|
+
if (!deferredCredentialEndpoint) {
|
|
87
|
+
throw Error(`No deferred credential endpoint supplied.`);
|
|
88
|
+
}
|
|
89
|
+
else if (!bearerToken) {
|
|
90
|
+
throw Error(`No bearer token present and refresh for defered endpoint not supported yet`);
|
|
91
|
+
// todo updated bearer token with new c_nonce
|
|
92
|
+
}
|
|
93
|
+
return yield (0, oid4vci_common_1.acquireDeferredCredential)({
|
|
94
|
+
bearerToken,
|
|
95
|
+
transactionId,
|
|
96
|
+
deferredCredentialEndpoint,
|
|
97
|
+
deferredCredentialAwait: this.credentialRequestOpts.deferredCredentialAwait,
|
|
98
|
+
deferredCredentialIntervalInMS: this.credentialRequestOpts.deferredCredentialIntervalInMS,
|
|
99
|
+
});
|
|
100
|
+
});
|
|
101
|
+
}
|
|
69
102
|
createCredentialRequest(opts) {
|
|
70
103
|
var _a;
|
|
71
104
|
return __awaiter(this, void 0, void 0, function* () {
|
|
72
105
|
const { proofInput } = opts;
|
|
73
106
|
const formatSelection = (_a = opts.format) !== null && _a !== void 0 ? _a : this.credentialRequestOpts.format;
|
|
74
|
-
|
|
75
|
-
if (opts.version < oid4vci_common_1.OpenId4VCIVersion.VER_1_0_11) {
|
|
76
|
-
if (formatSelection === 'jwt_vc' || formatSelection === 'jwt') {
|
|
77
|
-
format = 'jwt_vc_json';
|
|
78
|
-
}
|
|
79
|
-
else if (formatSelection === 'ldp_vc' || formatSelection === 'ldp') {
|
|
80
|
-
format = 'jwt_vc_json-ld';
|
|
81
|
-
}
|
|
82
|
-
}
|
|
83
|
-
if (!format) {
|
|
107
|
+
if (!formatSelection) {
|
|
84
108
|
throw Error(`Format of credential to be issued is missing`);
|
|
85
109
|
}
|
|
86
|
-
|
|
87
|
-
throw Error(`Invalid format of credential to be issued: ${format}`);
|
|
88
|
-
}
|
|
110
|
+
const format = (0, oid4vci_common_1.getUniformFormat)(formatSelection);
|
|
89
111
|
const typesSelection = (opts === null || opts === void 0 ? void 0 : opts.credentialTypes) && (typeof opts.credentialTypes === 'string' || opts.credentialTypes.length > 0)
|
|
90
112
|
? opts.credentialTypes
|
|
91
113
|
: this.credentialRequestOpts.credentialTypes;
|
|
@@ -93,17 +115,43 @@ class CredentialRequestClient {
|
|
|
93
115
|
if (types.length === 0) {
|
|
94
116
|
throw Error(`Credential type(s) need to be provided`);
|
|
95
117
|
}
|
|
118
|
+
// FIXME: this is mixing up the type (as id) from v8/v9 and the types (from the vc.type) from v11
|
|
96
119
|
else if (!this.isV11OrHigher() && types.length !== 1) {
|
|
97
120
|
throw Error('Only a single credential type is supported for V8/V9');
|
|
98
121
|
}
|
|
99
|
-
const proof =
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
122
|
+
const proof = yield buildProof(proofInput, opts);
|
|
123
|
+
// TODO: we should move format specific logic
|
|
124
|
+
if (format === 'jwt_vc_json' || format === 'jwt_vc') {
|
|
125
|
+
return {
|
|
126
|
+
types,
|
|
127
|
+
format,
|
|
128
|
+
proof,
|
|
129
|
+
};
|
|
130
|
+
}
|
|
131
|
+
else if (format === 'jwt_vc_json-ld' || format === 'ldp_vc') {
|
|
132
|
+
if (this.version() >= oid4vci_common_1.OpenId4VCIVersion.VER_1_0_12 && !opts.context) {
|
|
133
|
+
throw Error('No @context value present, but it is required');
|
|
134
|
+
}
|
|
135
|
+
return {
|
|
136
|
+
format,
|
|
137
|
+
proof,
|
|
138
|
+
// Ignored because v11 does not have the context value, but it is required in v12
|
|
139
|
+
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
|
|
140
|
+
// @ts-ignore
|
|
141
|
+
credential_definition: Object.assign({ types }, (opts.context && { '@context': opts.context })),
|
|
142
|
+
};
|
|
143
|
+
}
|
|
144
|
+
else if (format === 'vc+sd-jwt') {
|
|
145
|
+
if (types.length > 1) {
|
|
146
|
+
throw Error(`Only a single credential type is supported for ${format}`);
|
|
147
|
+
}
|
|
148
|
+
return {
|
|
149
|
+
format,
|
|
150
|
+
proof,
|
|
151
|
+
vct: types[0],
|
|
152
|
+
};
|
|
153
|
+
}
|
|
154
|
+
throw new Error(`Unsupported format: ${format}`);
|
|
107
155
|
});
|
|
108
156
|
}
|
|
109
157
|
version() {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"CredentialRequestClient.js","sourceRoot":"","sources":["../lib/CredentialRequestClient.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,
|
|
1
|
+
{"version":3,"file":"CredentialRequestClient.js","sourceRoot":"","sources":["../lib/CredentialRequestClient.ts"],"names":[],"mappings":"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"}
|
|
@@ -3,10 +3,19 @@ import { CredentialFormat } from '@sphereon/ssi-types';
|
|
|
3
3
|
import { CredentialRequestClient } from './CredentialRequestClient';
|
|
4
4
|
export declare class CredentialRequestClientBuilder {
|
|
5
5
|
credentialEndpoint?: string;
|
|
6
|
+
deferredCredentialEndpoint?: string;
|
|
7
|
+
deferredCredentialAwait: boolean;
|
|
8
|
+
deferredCredentialIntervalInMS: number;
|
|
6
9
|
credentialTypes: string[];
|
|
7
10
|
format?: CredentialFormat | OID4VCICredentialFormat;
|
|
8
11
|
token?: string;
|
|
9
12
|
version?: OpenId4VCIVersion;
|
|
13
|
+
static fromCredentialIssuer({ credentialIssuer, metadata, version, credentialTypes, }: {
|
|
14
|
+
credentialIssuer: string;
|
|
15
|
+
metadata?: EndpointMetadata;
|
|
16
|
+
version?: OpenId4VCIVersion;
|
|
17
|
+
credentialTypes: string | string[];
|
|
18
|
+
}): CredentialRequestClientBuilder;
|
|
10
19
|
static fromURI({ uri, metadata }: {
|
|
11
20
|
uri: string;
|
|
12
21
|
metadata?: EndpointMetadata;
|
|
@@ -22,13 +31,16 @@ export declare class CredentialRequestClientBuilder {
|
|
|
22
31
|
credentialOffer: CredentialOfferRequestWithBaseUrl;
|
|
23
32
|
metadata?: EndpointMetadata;
|
|
24
33
|
}): CredentialRequestClientBuilder;
|
|
25
|
-
withCredentialEndpointFromMetadata(metadata: CredentialIssuerMetadata):
|
|
26
|
-
withCredentialEndpoint(credentialEndpoint: string):
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
34
|
+
withCredentialEndpointFromMetadata(metadata: CredentialIssuerMetadata): this;
|
|
35
|
+
withCredentialEndpoint(credentialEndpoint: string): this;
|
|
36
|
+
withDeferredCredentialEndpointFromMetadata(metadata: CredentialIssuerMetadata): this;
|
|
37
|
+
withDeferredCredentialEndpoint(deferredCredentialEndpoint: string): this;
|
|
38
|
+
withDeferredCredentialAwait(deferredCredentialAwait: boolean, deferredCredentialIntervalInMS?: number): this;
|
|
39
|
+
withCredentialType(credentialTypes: string | string[]): this;
|
|
40
|
+
withFormat(format: CredentialFormat | OID4VCICredentialFormat): this;
|
|
41
|
+
withToken(accessToken: string): this;
|
|
42
|
+
withTokenFromResponse(response: AccessTokenResponse): this;
|
|
43
|
+
withVersion(version: OpenId4VCIVersion): this;
|
|
32
44
|
build(): CredentialRequestClient;
|
|
33
45
|
}
|
|
34
46
|
//# sourceMappingURL=CredentialRequestClientBuilder.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"CredentialRequestClientBuilder.d.ts","sourceRoot":"","sources":["../lib/CredentialRequestClientBuilder.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,mBAAmB,EACnB,wBAAwB,EAExB,iCAAiC,EAEjC,gBAAgB,
|
|
1
|
+
{"version":3,"file":"CredentialRequestClientBuilder.d.ts","sourceRoot":"","sources":["../lib/CredentialRequestClientBuilder.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,mBAAmB,EACnB,wBAAwB,EAExB,iCAAiC,EAEjC,gBAAgB,EAGhB,uBAAuB,EACvB,iBAAiB,EACjB,6BAA6B,EAC9B,MAAM,0BAA0B,CAAC;AAClC,OAAO,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;AAGvD,OAAO,EAAE,uBAAuB,EAAE,MAAM,2BAA2B,CAAC;AAEpE,qBAAa,8BAA8B;IACzC,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAC5B,0BAA0B,CAAC,EAAE,MAAM,CAAC;IACpC,uBAAuB,UAAS;IAChC,8BAA8B,SAAQ;IACtC,eAAe,EAAE,MAAM,EAAE,CAAM;IAC/B,MAAM,CAAC,EAAE,gBAAgB,GAAG,uBAAuB,CAAC;IACpD,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,OAAO,CAAC,EAAE,iBAAiB,CAAC;WAEd,oBAAoB,CAAC,EACjC,gBAAgB,EAChB,QAAQ,EACR,OAAO,EACP,eAAe,GAChB,EAAE;QACD,gBAAgB,EAAE,MAAM,CAAC;QACzB,QAAQ,CAAC,EAAE,gBAAgB,CAAC;QAC5B,OAAO,CAAC,EAAE,iBAAiB,CAAC;QAC5B,eAAe,EAAE,MAAM,GAAG,MAAM,EAAE,CAAC;KACpC,GAAG,8BAA8B;WAYd,OAAO,CAAC,EAAE,GAAG,EAAE,QAAQ,EAAE,EAAE;QAAE,GAAG,EAAE,MAAM,CAAC;QAAC,QAAQ,CAAC,EAAE,gBAAgB,CAAA;KAAE,GAAG,OAAO,CAAC,8BAA8B,CAAC;WAKvH,0BAA0B,CAAC,IAAI,EAAE;QAC7C,OAAO,EAAE,6BAA6B,CAAC;QACvC,MAAM,CAAC,EAAE,MAAM,CAAC;QAChB,OAAO,CAAC,EAAE,MAAM,CAAC;QACjB,OAAO,CAAC,EAAE,iBAAiB,CAAC;QAC5B,QAAQ,CAAC,EAAE,gBAAgB,CAAC;KAC7B,GAAG,8BAA8B;WAsBpB,mBAAmB,CAAC,EAChC,eAAe,EACf,QAAQ,GACT,EAAE;QACD,eAAe,EAAE,iCAAiC,CAAC;QACnD,QAAQ,CAAC,EAAE,gBAAgB,CAAC;KAC7B,GAAG,8BAA8B;IAQ3B,kCAAkC,CAAC,QAAQ,EAAE,wBAAwB,GAAG,IAAI;IAK5E,sBAAsB,CAAC,kBAAkB,EAAE,MAAM,GAAG,IAAI;IAKxD,0CAA0C,CAAC,QAAQ,EAAE,wBAAwB,GAAG,IAAI;IAKpF,8BAA8B,CAAC,0BAA0B,EAAE,MAAM,GAAG,IAAI;IAKxE,2BAA2B,CAAC,uBAAuB,EAAE,OAAO,EAAE,8BAA8B,CAAC,EAAE,MAAM,GAAG,IAAI;IAM5G,kBAAkB,CAAC,eAAe,EAAE,MAAM,GAAG,MAAM,EAAE,GAAG,IAAI;IAK5D,UAAU,CAAC,MAAM,EAAE,gBAAgB,GAAG,uBAAuB,GAAG,IAAI;IAKpE,SAAS,CAAC,WAAW,EAAE,MAAM,GAAG,IAAI;IAKpC,qBAAqB,CAAC,QAAQ,EAAE,mBAAmB,GAAG,IAAI;IAK1D,WAAW,CAAC,OAAO,EAAE,iBAAiB,GAAG,IAAI;IAK7C,KAAK,IAAI,uBAAuB;CAMxC"}
|
|
@@ -15,8 +15,22 @@ const CredentialOfferClient_1 = require("./CredentialOfferClient");
|
|
|
15
15
|
const CredentialRequestClient_1 = require("./CredentialRequestClient");
|
|
16
16
|
class CredentialRequestClientBuilder {
|
|
17
17
|
constructor() {
|
|
18
|
+
this.deferredCredentialAwait = false;
|
|
19
|
+
this.deferredCredentialIntervalInMS = 5000;
|
|
18
20
|
this.credentialTypes = [];
|
|
19
21
|
}
|
|
22
|
+
static fromCredentialIssuer({ credentialIssuer, metadata, version, credentialTypes, }) {
|
|
23
|
+
var _a;
|
|
24
|
+
const issuer = credentialIssuer;
|
|
25
|
+
const builder = new CredentialRequestClientBuilder();
|
|
26
|
+
builder.withVersion(version !== null && version !== void 0 ? version : oid4vci_common_1.OpenId4VCIVersion.VER_1_0_11);
|
|
27
|
+
builder.withCredentialEndpoint((_a = metadata === null || metadata === void 0 ? void 0 : metadata.credential_endpoint) !== null && _a !== void 0 ? _a : (issuer.endsWith('/') ? `${issuer}credential` : `${issuer}/credential`));
|
|
28
|
+
if (metadata === null || metadata === void 0 ? void 0 : metadata.deferred_credential_endpoint) {
|
|
29
|
+
builder.withDeferredCredentialEndpoint(metadata.deferred_credential_endpoint);
|
|
30
|
+
}
|
|
31
|
+
builder.withCredentialType(credentialTypes);
|
|
32
|
+
return builder;
|
|
33
|
+
}
|
|
20
34
|
static fromURI({ uri, metadata }) {
|
|
21
35
|
return __awaiter(this, void 0, void 0, function* () {
|
|
22
36
|
const offer = yield CredentialOfferClient_1.CredentialOfferClient.fromURI(uri);
|
|
@@ -31,13 +45,16 @@ class CredentialRequestClientBuilder {
|
|
|
31
45
|
const issuer = (_c = (0, oid4vci_common_1.getIssuerFromCredentialOfferPayload)(request.credential_offer)) !== null && _c !== void 0 ? _c : metadata === null || metadata === void 0 ? void 0 : metadata.issuer;
|
|
32
46
|
builder.withVersion(version);
|
|
33
47
|
builder.withCredentialEndpoint((_d = metadata === null || metadata === void 0 ? void 0 : metadata.credential_endpoint) !== null && _d !== void 0 ? _d : (issuer.endsWith('/') ? `${issuer}credential` : `${issuer}/credential`));
|
|
48
|
+
if (metadata === null || metadata === void 0 ? void 0 : metadata.deferred_credential_endpoint) {
|
|
49
|
+
builder.withDeferredCredentialEndpoint(metadata.deferred_credential_endpoint);
|
|
50
|
+
}
|
|
34
51
|
if (version <= oid4vci_common_1.OpenId4VCIVersion.VER_1_0_08) {
|
|
35
52
|
//todo: This basically sets all types available during initiation. Probably the user only wants a subset. So do we want to do this?
|
|
36
53
|
builder.withCredentialType(request.original_credential_offer.credential_type);
|
|
37
54
|
}
|
|
38
55
|
else {
|
|
39
56
|
// todo: look whether this is correct
|
|
40
|
-
builder.withCredentialType(
|
|
57
|
+
builder.withCredentialType((0, oid4vci_common_1.getTypesFromOffer)(request.credential_offer));
|
|
41
58
|
}
|
|
42
59
|
return builder;
|
|
43
60
|
}
|
|
@@ -56,6 +73,19 @@ class CredentialRequestClientBuilder {
|
|
|
56
73
|
this.credentialEndpoint = credentialEndpoint;
|
|
57
74
|
return this;
|
|
58
75
|
}
|
|
76
|
+
withDeferredCredentialEndpointFromMetadata(metadata) {
|
|
77
|
+
this.deferredCredentialEndpoint = metadata.deferred_credential_endpoint;
|
|
78
|
+
return this;
|
|
79
|
+
}
|
|
80
|
+
withDeferredCredentialEndpoint(deferredCredentialEndpoint) {
|
|
81
|
+
this.deferredCredentialEndpoint = deferredCredentialEndpoint;
|
|
82
|
+
return this;
|
|
83
|
+
}
|
|
84
|
+
withDeferredCredentialAwait(deferredCredentialAwait, deferredCredentialIntervalInMS) {
|
|
85
|
+
this.deferredCredentialAwait = deferredCredentialAwait;
|
|
86
|
+
this.deferredCredentialIntervalInMS = deferredCredentialIntervalInMS !== null && deferredCredentialIntervalInMS !== void 0 ? deferredCredentialIntervalInMS : 5000;
|
|
87
|
+
return this;
|
|
88
|
+
}
|
|
59
89
|
withCredentialType(credentialTypes) {
|
|
60
90
|
this.credentialTypes = Array.isArray(credentialTypes) ? credentialTypes : [credentialTypes];
|
|
61
91
|
return this;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"CredentialRequestClientBuilder.js","sourceRoot":"","sources":["../lib/CredentialRequestClientBuilder.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,
|
|
1
|
+
{"version":3,"file":"CredentialRequestClientBuilder.js","sourceRoot":"","sources":["../lib/CredentialRequestClientBuilder.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MetadataClient.d.ts","sourceRoot":"","sources":["../lib/MetadataClient.ts"],"names":[],"mappings":"AAAA,OAAO,EAGL,wBAAwB,EACxB,sBAAsB,EACtB,iCAAiC,EACjC,sBAAsB,EAEtB,cAAc,EACd,kBAAkB,EACnB,MAAM,0BAA0B,CAAC;AAOlC,qBAAa,cAAc;IACzB;;;;OAIG;WACiB,sCAAsC,CAAC,eAAe,EAAE,iCAAiC,GAAG,OAAO,CAAC,sBAAsB,CAAC;IAI/I;;;OAGG;WACiB,6CAA6C,CAAC,OAAO,EAAE,sBAAsB,GAAG,OAAO,CAAC,sBAAsB,CAAC;IAQnI;;;;OAIG;WACiB,mBAAmB,CAAC,MAAM,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE;QAAE,eAAe,EAAE,OAAO,CAAA;KAAE,GAAG,OAAO,CAAC,sBAAsB,CAAC;
|
|
1
|
+
{"version":3,"file":"MetadataClient.d.ts","sourceRoot":"","sources":["../lib/MetadataClient.ts"],"names":[],"mappings":"AAAA,OAAO,EAGL,wBAAwB,EACxB,sBAAsB,EACtB,iCAAiC,EACjC,sBAAsB,EAEtB,cAAc,EACd,kBAAkB,EACnB,MAAM,0BAA0B,CAAC;AAOlC,qBAAa,cAAc;IACzB;;;;OAIG;WACiB,sCAAsC,CAAC,eAAe,EAAE,iCAAiC,GAAG,OAAO,CAAC,sBAAsB,CAAC;IAI/I;;;OAGG;WACiB,6CAA6C,CAAC,OAAO,EAAE,sBAAsB,GAAG,OAAO,CAAC,sBAAsB,CAAC;IAQnI;;;;OAIG;WACiB,mBAAmB,CAAC,MAAM,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE;QAAE,eAAe,EAAE,OAAO,CAAA;KAAE,GAAG,OAAO,CAAC,sBAAsB,CAAC;IA8H7H;;;;OAIG;WACiB,gCAAgC,CAClD,UAAU,EAAE,MAAM,EAClB,IAAI,CAAC,EAAE;QACL,eAAe,CAAC,EAAE,OAAO,CAAC;KAC3B,GACA,OAAO,CAAC,cAAc,CAAC,wBAAwB,CAAC,GAAG,SAAS,CAAC;IAMhE;;;;;;OAMG;WACiB,iBAAiB,CAAC,CAAC,EACrC,IAAI,EAAE,MAAM,EACZ,YAAY,EAAE,kBAAkB,EAChC,IAAI,CAAC,EAAE;QAAE,eAAe,CAAC,EAAE,OAAO,CAAA;KAAE,GACnC,OAAO,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC;CAU9B"}
|
package/dist/MetadataClient.js
CHANGED
|
@@ -50,6 +50,7 @@ class MetadataClient {
|
|
|
50
50
|
return __awaiter(this, void 0, void 0, function* () {
|
|
51
51
|
let token_endpoint;
|
|
52
52
|
let credential_endpoint;
|
|
53
|
+
let deferred_credential_endpoint;
|
|
53
54
|
let authorization_endpoint;
|
|
54
55
|
let authorizationServerType = 'OID4VCI';
|
|
55
56
|
let authorization_server = issuer;
|
|
@@ -58,6 +59,7 @@ class MetadataClient {
|
|
|
58
59
|
if (credentialIssuerMetadata) {
|
|
59
60
|
debug(`Issuer ${issuer} OID4VCI well-known server metadata\r\n${JSON.stringify(credentialIssuerMetadata)}`);
|
|
60
61
|
credential_endpoint = credentialIssuerMetadata.credential_endpoint;
|
|
62
|
+
deferred_credential_endpoint = credentialIssuerMetadata.deferred_credential_endpoint;
|
|
61
63
|
if (credentialIssuerMetadata.token_endpoint) {
|
|
62
64
|
token_endpoint = credentialIssuerMetadata.token_endpoint;
|
|
63
65
|
}
|
|
@@ -109,12 +111,20 @@ class MetadataClient {
|
|
|
109
111
|
token_endpoint = authMetadata.token_endpoint;
|
|
110
112
|
if (authMetadata.credential_endpoint) {
|
|
111
113
|
if (credential_endpoint && authMetadata.credential_endpoint !== credential_endpoint) {
|
|
112
|
-
debug(`Credential issuer has a different credential_endpoint (${credential_endpoint}) from the Authorization Server (${authMetadata.
|
|
114
|
+
debug(`Credential issuer has a different credential_endpoint (${credential_endpoint}) from the Authorization Server (${authMetadata.credential_endpoint}). Will use the issuer value`);
|
|
113
115
|
}
|
|
114
116
|
else {
|
|
115
117
|
credential_endpoint = authMetadata.credential_endpoint;
|
|
116
118
|
}
|
|
117
119
|
}
|
|
120
|
+
if (authMetadata.deferred_credential_endpoint) {
|
|
121
|
+
if (deferred_credential_endpoint && authMetadata.deferred_credential_endpoint !== deferred_credential_endpoint) {
|
|
122
|
+
debug(`Credential issuer has a different deferred_credential_endpoint (${deferred_credential_endpoint}) from the Authorization Server (${authMetadata.deferred_credential_endpoint}). Will use the issuer value`);
|
|
123
|
+
}
|
|
124
|
+
else {
|
|
125
|
+
deferred_credential_endpoint = authMetadata.deferred_credential_endpoint;
|
|
126
|
+
}
|
|
127
|
+
}
|
|
118
128
|
}
|
|
119
129
|
if (!authorization_endpoint) {
|
|
120
130
|
debug(`Issuer ${issuer} does not expose authorization_endpoint, so only pre-auth will be supported`);
|
|
@@ -146,6 +156,7 @@ class MetadataClient {
|
|
|
146
156
|
issuer,
|
|
147
157
|
token_endpoint,
|
|
148
158
|
credential_endpoint,
|
|
159
|
+
deferred_credential_endpoint,
|
|
149
160
|
authorization_server,
|
|
150
161
|
authorization_endpoint,
|
|
151
162
|
authorizationServerType,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MetadataClient.js","sourceRoot":"","sources":["../lib/MetadataClient.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,6DAUkC;AAClC,kDAA0B;AAE1B,2CAAsC;AAEtC,MAAM,KAAK,GAAG,IAAA,eAAK,EAAC,2BAA2B,CAAC,CAAC;AAEjD,MAAa,cAAc;IACzB;;;;OAIG;IACI,MAAM,CAAO,sCAAsC,CAAC,eAAkD;;YAC3G,OAAO,cAAc,CAAC,6CAA6C,CAAC,eAAe,CAAC,gBAAgB,CAAC,CAAC;QACxG,CAAC;KAAA;IAED;;;OAGG;IACI,MAAM,CAAO,6CAA6C,CAAC,OAA+B;;YAC/F,MAAM,MAAM,GAAG,IAAA,oDAAmC,EAAC,OAAO,CAAC,CAAC;YAC5D,IAAI,MAAM,EAAE;
|
|
1
|
+
{"version":3,"file":"MetadataClient.js","sourceRoot":"","sources":["../lib/MetadataClient.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,70 +1,105 @@
|
|
|
1
|
-
import { AccessTokenResponse, Alg,
|
|
1
|
+
import { AccessTokenResponse, Alg, AuthorizationRequestOpts, AuthorizationResponse, AuthzFlowType, CredentialOfferRequestWithBaseUrl, CredentialResponse, CredentialSupported, EndpointMetadataResult, JWK, OID4VCICredentialFormat, OpenId4VCIVersion, PKCEOpts, ProofOfPossessionCallbacks } from '@sphereon/oid4vci-common';
|
|
2
2
|
import { CredentialFormat } from '@sphereon/ssi-types';
|
|
3
|
-
interface
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
3
|
+
export interface OpenID4VCIClientState {
|
|
4
|
+
credentialIssuer: string;
|
|
5
|
+
credentialOffer?: CredentialOfferRequestWithBaseUrl;
|
|
6
|
+
clientId?: string;
|
|
7
|
+
kid?: string;
|
|
8
|
+
jwk?: JWK;
|
|
9
|
+
alg?: Alg | string;
|
|
10
|
+
endpointMetadata?: EndpointMetadataResult;
|
|
11
|
+
accessTokenResponse?: AccessTokenResponse;
|
|
12
|
+
authorizationRequestOpts?: AuthorizationRequestOpts;
|
|
13
|
+
pkce: PKCEOpts;
|
|
14
|
+
authorizationURL?: string;
|
|
15
15
|
}
|
|
16
16
|
export declare class OpenID4VCIClient {
|
|
17
|
-
private readonly
|
|
18
|
-
private _clientId?;
|
|
19
|
-
private _kid;
|
|
20
|
-
private _alg;
|
|
21
|
-
private _endpointMetadata;
|
|
22
|
-
private _accessTokenResponse;
|
|
17
|
+
private readonly _state;
|
|
23
18
|
private constructor();
|
|
24
|
-
static
|
|
19
|
+
static fromCredentialIssuer({ kid, alg, retrieveServerMetadata, clientId, credentialIssuer, pkce, authorizationRequest, createAuthorizationRequestURL, }: {
|
|
20
|
+
credentialIssuer: string;
|
|
21
|
+
kid?: string;
|
|
22
|
+
alg?: Alg | string;
|
|
23
|
+
retrieveServerMetadata?: boolean;
|
|
24
|
+
clientId?: string;
|
|
25
|
+
createAuthorizationRequestURL?: boolean;
|
|
26
|
+
authorizationRequest?: AuthorizationRequestOpts;
|
|
27
|
+
pkce?: PKCEOpts;
|
|
28
|
+
}): Promise<OpenID4VCIClient>;
|
|
29
|
+
static fromState({ state }: {
|
|
30
|
+
state: OpenID4VCIClientState | string;
|
|
31
|
+
}): Promise<OpenID4VCIClient>;
|
|
32
|
+
static fromURI({ uri, kid, alg, retrieveServerMetadata, clientId, pkce, createAuthorizationRequestURL, authorizationRequest, resolveOfferUri, }: {
|
|
25
33
|
uri: string;
|
|
26
34
|
kid?: string;
|
|
27
35
|
alg?: Alg | string;
|
|
28
36
|
retrieveServerMetadata?: boolean;
|
|
37
|
+
createAuthorizationRequestURL?: boolean;
|
|
29
38
|
resolveOfferUri?: boolean;
|
|
39
|
+
pkce?: PKCEOpts;
|
|
30
40
|
clientId?: string;
|
|
41
|
+
authorizationRequest?: AuthorizationRequestOpts;
|
|
31
42
|
}): Promise<OpenID4VCIClient>;
|
|
43
|
+
/**
|
|
44
|
+
* Allows you to create an Authorization Request URL when using an Authorization Code flow. This URL needs to be accessed using the front channel (browser)
|
|
45
|
+
*
|
|
46
|
+
* The Identity provider would present a login screen typically; after you authenticated, it would redirect to the provided redirectUri; which can be same device or cross-device
|
|
47
|
+
* @param opts
|
|
48
|
+
*/
|
|
49
|
+
createAuthorizationRequestUrl(opts?: {
|
|
50
|
+
authorizationRequest?: AuthorizationRequestOpts;
|
|
51
|
+
pkce?: PKCEOpts;
|
|
52
|
+
}): Promise<string>;
|
|
32
53
|
retrieveServerMetadata(): Promise<EndpointMetadataResult>;
|
|
33
|
-
|
|
34
|
-
acquirePushedAuthorizationRequestURI({ codeChallengeMethod, codeChallenge, authorizationDetails, redirectUri, scope, }: AuthRequestOpts): Promise<string>;
|
|
35
|
-
handleAuthorizationDetails(authorizationDetails?: AuthDetails | AuthDetails[]): AuthDetails | AuthDetails[] | undefined;
|
|
36
|
-
private handleLocations;
|
|
54
|
+
private calculatePKCEOpts;
|
|
37
55
|
acquireAccessToken(opts?: {
|
|
38
56
|
pin?: string;
|
|
39
57
|
clientId?: string;
|
|
40
58
|
codeVerifier?: string;
|
|
59
|
+
authorizationResponse?: string | AuthorizationResponse;
|
|
41
60
|
code?: string;
|
|
42
61
|
redirectUri?: string;
|
|
43
62
|
}): Promise<AccessTokenResponse>;
|
|
44
|
-
acquireCredentials({ credentialTypes, proofCallbacks, format, kid, alg, jti, }: {
|
|
63
|
+
acquireCredentials({ credentialTypes, context, proofCallbacks, format, kid, jwk, alg, jti, deferredCredentialAwait, deferredCredentialIntervalInMS, }: {
|
|
45
64
|
credentialTypes: string | string[];
|
|
65
|
+
context?: string[];
|
|
46
66
|
proofCallbacks: ProofOfPossessionCallbacks<any>;
|
|
47
67
|
format?: CredentialFormat | OID4VCICredentialFormat;
|
|
48
68
|
kid?: string;
|
|
69
|
+
jwk?: JWK;
|
|
49
70
|
alg?: Alg | string;
|
|
50
71
|
jti?: string;
|
|
72
|
+
deferredCredentialAwait?: boolean;
|
|
73
|
+
deferredCredentialIntervalInMS?: number;
|
|
51
74
|
}): Promise<CredentialResponse>;
|
|
75
|
+
exportState(): Promise<string>;
|
|
52
76
|
getCredentialsSupported(restrictToInitiationTypes: boolean, format?: (OID4VCICredentialFormat | string) | (OID4VCICredentialFormat | string)[]): CredentialSupported[];
|
|
53
77
|
getCredentialOfferTypes(): string[][];
|
|
54
78
|
issuerSupportedFlowTypes(): AuthzFlowType[];
|
|
55
|
-
|
|
79
|
+
isFlowTypeSupported(flowType: AuthzFlowType): boolean;
|
|
80
|
+
get authorizationURL(): string | undefined;
|
|
81
|
+
hasAuthorizationURL(): boolean;
|
|
82
|
+
get credentialOffer(): CredentialOfferRequestWithBaseUrl | undefined;
|
|
56
83
|
version(): OpenId4VCIVersion;
|
|
57
84
|
get endpointMetadata(): EndpointMetadataResult;
|
|
58
85
|
get kid(): string;
|
|
59
86
|
get alg(): string;
|
|
87
|
+
set clientId(value: string | undefined);
|
|
60
88
|
get clientId(): string | undefined;
|
|
89
|
+
hasAccessTokenResponse(): boolean;
|
|
61
90
|
get accessTokenResponse(): AccessTokenResponse;
|
|
62
91
|
getIssuer(): string;
|
|
63
92
|
getAccessTokenEndpoint(): string;
|
|
64
93
|
getCredentialEndpoint(): string;
|
|
94
|
+
hasDeferredCredentialEndpoint(): boolean;
|
|
95
|
+
getDeferredCredentialEndpoint(): string;
|
|
96
|
+
/**
|
|
97
|
+
* Too bad we need a method like this, but EBSI is not exposing metadata
|
|
98
|
+
*/
|
|
99
|
+
isEBSI(): boolean | undefined;
|
|
65
100
|
private assertIssuerData;
|
|
66
101
|
private assertServerMetadata;
|
|
67
102
|
private assertAccessToken;
|
|
103
|
+
private syncAuthorizationRequestOpts;
|
|
68
104
|
}
|
|
69
|
-
export {};
|
|
70
105
|
//# sourceMappingURL=OpenID4VCIClient.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"OpenID4VCIClient.d.ts","sourceRoot":"","sources":["../lib/OpenID4VCIClient.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,mBAAmB,EACnB,GAAG,EACH,
|
|
1
|
+
{"version":3,"file":"OpenID4VCIClient.d.ts","sourceRoot":"","sources":["../lib/OpenID4VCIClient.ts"],"names":[],"mappings":"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"}
|