@credo-ts/openid4vc 0.6.0-pr-2094-20241120130052 → 0.6.0-pr-2100-20241121224938
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/build/openid4vc-holder/OpenId4VcHolderApi.d.ts +12 -11
- package/build/openid4vc-holder/OpenId4VcHolderApi.js +21 -10
- package/build/openid4vc-holder/OpenId4VcHolderApi.js.map +1 -1
- package/build/openid4vc-holder/OpenId4VciHolderService.js +3 -0
- package/build/openid4vc-holder/OpenId4VciHolderService.js.map +1 -1
- package/build/openid4vc-holder/OpenId4VciHolderServiceOptions.d.ts +2 -1
- package/build/openid4vc-holder/OpenId4VciHolderServiceOptions.js.map +1 -1
- package/build/openid4vc-holder/OpenId4vcSiopHolderService.d.ts +5 -170
- package/build/openid4vc-holder/OpenId4vcSiopHolderService.js +66 -89
- package/build/openid4vc-holder/OpenId4vcSiopHolderService.js.map +1 -1
- package/build/openid4vc-holder/OpenId4vcSiopHolderServiceOptions.d.ts +13 -26
- package/build/openid4vc-issuer/OpenId4VcIssuerModule.js +0 -2
- package/build/openid4vc-issuer/OpenId4VcIssuerModule.js.map +1 -1
- package/build/openid4vc-issuer/OpenId4VcIssuerModuleConfig.d.ts +7 -7
- package/build/openid4vc-issuer/OpenId4VcIssuerModuleConfig.js +2 -10
- package/build/openid4vc-issuer/OpenId4VcIssuerModuleConfig.js.map +1 -1
- package/build/openid4vc-issuer/OpenId4VcIssuerService.js +14 -6
- package/build/openid4vc-issuer/OpenId4VcIssuerService.js.map +1 -1
- package/build/openid4vc-issuer/OpenId4VcIssuerServiceOptions.d.ts +7 -2
- package/build/openid4vc-verifier/OpenId4VcSiopVerifierService.d.ts +3 -12
- package/build/openid4vc-verifier/OpenId4VcSiopVerifierService.js +26 -24
- package/build/openid4vc-verifier/OpenId4VcSiopVerifierService.js.map +1 -1
- package/build/openid4vc-verifier/OpenId4VcSiopVerifierServiceOptions.d.ts +12 -1
- package/build/openid4vc-verifier/OpenId4VcVerifierModule.js +0 -3
- package/build/openid4vc-verifier/OpenId4VcVerifierModule.js.map +1 -1
- package/build/openid4vc-verifier/router/index.d.ts +0 -1
- package/build/openid4vc-verifier/router/index.js +1 -3
- package/build/openid4vc-verifier/router/index.js.map +1 -1
- package/build/shared/models/OpenId4VcJwtIssuer.d.ts +1 -4
- package/build/shared/models/index.d.ts +2 -0
- package/build/shared/models/index.js.map +1 -1
- package/build/shared/transform.js +1 -0
- package/build/shared/transform.js.map +1 -1
- package/build/shared/utils.d.ts +3 -11
- package/build/shared/utils.js +8 -100
- package/build/shared/utils.js.map +1 -1
- package/package.json +4 -6
- package/build/openid4vc-issuer/router/federationEndpoint.d.ts +0 -2
- package/build/openid4vc-issuer/router/federationEndpoint.js +0 -89
- package/build/openid4vc-issuer/router/federationEndpoint.js.map +0 -1
- package/build/openid4vc-verifier/router/federationEndpoint.d.ts +0 -2
- package/build/openid4vc-verifier/router/federationEndpoint.js +0 -118
- package/build/openid4vc-verifier/router/federationEndpoint.js.map +0 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../src/shared/utils.ts"],"names":[],"mappings":";;
|
|
1
|
+
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../src/shared/utils.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
"name": "@credo-ts/openid4vc",
|
|
3
3
|
"main": "build/index",
|
|
4
4
|
"types": "build/index",
|
|
5
|
-
"version": "0.6.0-pr-
|
|
5
|
+
"version": "0.6.0-pr-2100-20241121224938",
|
|
6
6
|
"files": [
|
|
7
7
|
"build"
|
|
8
8
|
],
|
|
@@ -17,16 +17,14 @@
|
|
|
17
17
|
"directory": "packages/openid4vc"
|
|
18
18
|
},
|
|
19
19
|
"dependencies": {
|
|
20
|
-
"@sphereon/did-auth-siop": "
|
|
20
|
+
"@sphereon/did-auth-siop": "https://gitpkg.vercel.app/animo/OID4VC/packages/siop-oid4vp?funke",
|
|
21
21
|
"@sphereon/oid4vc-common": "0.16.1-fix.173",
|
|
22
22
|
"@sphereon/ssi-types": "0.30.2-next.135",
|
|
23
|
-
"@openid-federation/core": "0.1.1-alpha.13",
|
|
24
23
|
"class-transformer": "^0.5.1",
|
|
25
24
|
"rxjs": "^7.8.0",
|
|
26
|
-
"zod": "^3.23.8",
|
|
27
25
|
"@animo-id/oid4vci": "0.1.3",
|
|
28
26
|
"@animo-id/oauth2": "0.1.3",
|
|
29
|
-
"@credo-ts/core": "0.6.0-pr-
|
|
27
|
+
"@credo-ts/core": "0.6.0-pr-2100-20241121224938"
|
|
30
28
|
},
|
|
31
29
|
"devDependencies": {
|
|
32
30
|
"@types/express": "^4.17.21",
|
|
@@ -34,7 +32,7 @@
|
|
|
34
32
|
"nock": "^14.0.0-beta.16",
|
|
35
33
|
"rimraf": "^4.4.0",
|
|
36
34
|
"typescript": "~5.5.2",
|
|
37
|
-
"@credo-ts/tenants": "0.6.0-pr-
|
|
35
|
+
"@credo-ts/tenants": "0.6.0-pr-2100-20241121224938"
|
|
38
36
|
},
|
|
39
37
|
"scripts": {
|
|
40
38
|
"build": "pnpm run clean && pnpm run compile",
|
|
@@ -1,89 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.configureFederationEndpoint = configureFederationEndpoint;
|
|
4
|
-
const core_1 = require("@credo-ts/core");
|
|
5
|
-
const core_2 = require("@openid-federation/core");
|
|
6
|
-
const router_1 = require("../../shared/router");
|
|
7
|
-
// TODO: It's also possible that the issuer and the verifier can have the same openid-federation endpoint. In that case we need to combine them.
|
|
8
|
-
function configureFederationEndpoint(router) {
|
|
9
|
-
// TODO: this whole result needs to be cached and the ttl should be the expires of this node
|
|
10
|
-
router.get('/.well-known/openid-federation', async (request, response, next) => {
|
|
11
|
-
var _a, _b;
|
|
12
|
-
const { agentContext, issuer } = (0, router_1.getRequestContext)(request);
|
|
13
|
-
try {
|
|
14
|
-
// TODO: Should be only created once per issuer and be used between instances
|
|
15
|
-
const federationKey = await agentContext.wallet.createKey({
|
|
16
|
-
keyType: core_1.KeyType.Ed25519,
|
|
17
|
-
});
|
|
18
|
-
const now = new Date();
|
|
19
|
-
const expires = new Date(now.getTime() + 1000 * 60 * 60 * 24); // 1 day from now
|
|
20
|
-
// TODO: We need to generate a key and always use that for the entity configuration
|
|
21
|
-
const jwk = (0, core_1.getJwkFromKey)(federationKey);
|
|
22
|
-
const kid = federationKey.fingerprint;
|
|
23
|
-
const alg = jwk.supportedSignatureAlgorithms[0];
|
|
24
|
-
const issuerDisplay = (_a = issuer.display) === null || _a === void 0 ? void 0 : _a[0];
|
|
25
|
-
const accessTokenSigningKey = core_1.Key.fromFingerprint(issuer.accessTokenPublicKeyFingerprint);
|
|
26
|
-
const entityConfiguration = await (0, core_2.createEntityConfiguration)({
|
|
27
|
-
claims: {
|
|
28
|
-
sub: issuer.issuerId,
|
|
29
|
-
iss: issuer.issuerId,
|
|
30
|
-
iat: now,
|
|
31
|
-
exp: expires,
|
|
32
|
-
jwks: {
|
|
33
|
-
keys: [Object.assign({ kid, alg }, jwk.toJson())],
|
|
34
|
-
},
|
|
35
|
-
metadata: {
|
|
36
|
-
federation_entity: issuerDisplay
|
|
37
|
-
? {
|
|
38
|
-
organization_name: issuerDisplay.name,
|
|
39
|
-
logo_uri: (_b = issuerDisplay.logo) === null || _b === void 0 ? void 0 : _b.uri,
|
|
40
|
-
}
|
|
41
|
-
: undefined,
|
|
42
|
-
openid_provider: {
|
|
43
|
-
// TODO: The type isn't correct yet down the line so that needs to be updated before
|
|
44
|
-
// credential_issuer: issuerMetadata.issuerUrl,
|
|
45
|
-
// token_endpoint: issuerMetadata.tokenEndpoint,
|
|
46
|
-
// credential_endpoint: issuerMetadata.credentialEndpoint,
|
|
47
|
-
// authorization_server: issuerMetadata.authorizationServer,
|
|
48
|
-
// authorization_servers: issuerMetadata.authorizationServer
|
|
49
|
-
// ? [issuerMetadata.authorizationServer]
|
|
50
|
-
// : undefined,
|
|
51
|
-
// credentials_supported: issuerMetadata.credentialsSupported,
|
|
52
|
-
// credential_configurations_supported: issuerMetadata.credentialConfigurationsSupported,
|
|
53
|
-
// display: issuerMetadata.issuerDisplay,
|
|
54
|
-
// dpop_signing_alg_values_supported: issuerMetadata.dpopSigningAlgValuesSupported,
|
|
55
|
-
client_registration_types_supported: ['automatic'],
|
|
56
|
-
jwks: {
|
|
57
|
-
keys: [
|
|
58
|
-
Object.assign({
|
|
59
|
-
// TODO: Not 100% sure if this is the right key that we want to expose here or a different one
|
|
60
|
-
kid: accessTokenSigningKey.fingerprint }, (0, core_1.getJwkFromKey)(accessTokenSigningKey).toJson()),
|
|
61
|
-
],
|
|
62
|
-
},
|
|
63
|
-
},
|
|
64
|
-
},
|
|
65
|
-
},
|
|
66
|
-
header: {
|
|
67
|
-
kid,
|
|
68
|
-
alg,
|
|
69
|
-
typ: 'entity-statement+jwt',
|
|
70
|
-
},
|
|
71
|
-
signJwtCallback: ({ toBeSigned }) => agentContext.wallet.sign({
|
|
72
|
-
data: toBeSigned,
|
|
73
|
-
key: federationKey,
|
|
74
|
-
}),
|
|
75
|
-
});
|
|
76
|
-
response.writeHead(200, { 'Content-Type': 'application/entity-statement+jwt' }).end(entityConfiguration);
|
|
77
|
-
}
|
|
78
|
-
catch (error) {
|
|
79
|
-
agentContext.config.logger.error('Failed to create entity configuration', {
|
|
80
|
-
error,
|
|
81
|
-
});
|
|
82
|
-
(0, router_1.sendErrorResponse)(response, next, agentContext.config.logger, 500, 'invalid_request', error);
|
|
83
|
-
return;
|
|
84
|
-
}
|
|
85
|
-
// NOTE: if we don't call next, the agentContext session handler will NOT be called
|
|
86
|
-
next();
|
|
87
|
-
});
|
|
88
|
-
}
|
|
89
|
-
//# sourceMappingURL=federationEndpoint.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"federationEndpoint.js","sourceRoot":"","sources":["../../../src/openid4vc-issuer/router/federationEndpoint.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,118 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.configureFederationEndpoint = configureFederationEndpoint;
|
|
4
|
-
const core_1 = require("@credo-ts/core");
|
|
5
|
-
const core_2 = require("@openid-federation/core");
|
|
6
|
-
const did_auth_siop_1 = require("@sphereon/did-auth-siop");
|
|
7
|
-
const router_1 = require("../../shared/router");
|
|
8
|
-
const OpenId4VcSiopVerifierService_1 = require("../OpenId4VcSiopVerifierService");
|
|
9
|
-
const OpenId4VcVerifierModuleConfig_1 = require("../OpenId4VcVerifierModuleConfig");
|
|
10
|
-
// TODO: Add types but this function is originally from the @
|
|
11
|
-
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
12
|
-
const createRPRegistrationMetadataPayload = (opts) => {
|
|
13
|
-
const rpRegistrationMetadataPayload = {
|
|
14
|
-
id_token_signing_alg_values_supported: opts.idTokenSigningAlgValuesSupported,
|
|
15
|
-
request_object_signing_alg_values_supported: opts.requestObjectSigningAlgValuesSupported,
|
|
16
|
-
response_types_supported: opts.responseTypesSupported,
|
|
17
|
-
scopes_supported: opts.scopesSupported,
|
|
18
|
-
subject_types_supported: opts.subjectTypesSupported,
|
|
19
|
-
subject_syntax_types_supported: opts.subject_syntax_types_supported || ['did:web:', 'did:ion:'],
|
|
20
|
-
vp_formats: opts.vpFormatsSupported,
|
|
21
|
-
client_name: opts.clientName,
|
|
22
|
-
logo_uri: opts.logo_uri,
|
|
23
|
-
tos_uri: opts.tos_uri,
|
|
24
|
-
client_purpose: opts.clientPurpose,
|
|
25
|
-
client_id: opts.client_id,
|
|
26
|
-
};
|
|
27
|
-
const languageTagEnabledFieldsNamesMapping = new Map();
|
|
28
|
-
languageTagEnabledFieldsNamesMapping.set('clientName', 'client_name');
|
|
29
|
-
languageTagEnabledFieldsNamesMapping.set('clientPurpose', 'client_purpose');
|
|
30
|
-
// TODO: Do we need this?
|
|
31
|
-
const languageTaggedFields = did_auth_siop_1.LanguageTagUtils.getLanguageTaggedPropertiesMapped(opts, languageTagEnabledFieldsNamesMapping);
|
|
32
|
-
languageTaggedFields.forEach((value, key) => {
|
|
33
|
-
const _key = key;
|
|
34
|
-
rpRegistrationMetadataPayload[_key] = value;
|
|
35
|
-
});
|
|
36
|
-
return (0, did_auth_siop_1.removeNullUndefined)(rpRegistrationMetadataPayload);
|
|
37
|
-
};
|
|
38
|
-
function configureFederationEndpoint(router) {
|
|
39
|
-
// TODO: this whole result needs to be cached and the ttl should be the expires of this node
|
|
40
|
-
// TODO: This will not work for multiple instances so we have to save it in the database.
|
|
41
|
-
const federationKeyMapping = new Map();
|
|
42
|
-
const rpSigningKeyMapping = new Map();
|
|
43
|
-
router.get('/.well-known/openid-federation', async (request, response, next) => {
|
|
44
|
-
const { agentContext, verifier } = (0, router_1.getRequestContext)(request);
|
|
45
|
-
const verifierService = agentContext.dependencyManager.resolve(OpenId4VcSiopVerifierService_1.OpenId4VcSiopVerifierService);
|
|
46
|
-
const verifierConfig = agentContext.dependencyManager.resolve(OpenId4VcVerifierModuleConfig_1.OpenId4VcVerifierModuleConfig);
|
|
47
|
-
try {
|
|
48
|
-
let federationKey = federationKeyMapping.get(verifier.verifierId);
|
|
49
|
-
if (!federationKey) {
|
|
50
|
-
federationKey = await agentContext.wallet.createKey({
|
|
51
|
-
keyType: core_1.KeyType.Ed25519,
|
|
52
|
-
});
|
|
53
|
-
federationKeyMapping.set(verifier.verifierId, federationKey);
|
|
54
|
-
}
|
|
55
|
-
let rpSigningKey = rpSigningKeyMapping.get(verifier.verifierId);
|
|
56
|
-
if (!rpSigningKey) {
|
|
57
|
-
rpSigningKey = await agentContext.wallet.createKey({
|
|
58
|
-
keyType: core_1.KeyType.Ed25519,
|
|
59
|
-
});
|
|
60
|
-
rpSigningKeyMapping.set(verifier.verifierId, rpSigningKey);
|
|
61
|
-
}
|
|
62
|
-
const relyingParty = await verifierService.getRelyingParty(agentContext, verifier, {
|
|
63
|
-
clientId: verifierConfig.baseUrl,
|
|
64
|
-
clientIdScheme: 'entity_id',
|
|
65
|
-
authorizationResponseUrl: `${verifierConfig.baseUrl}/siop/${verifier.verifierId}/authorize`,
|
|
66
|
-
});
|
|
67
|
-
const verifierEntityId = `${verifierConfig.baseUrl}/${verifier.verifierId}`;
|
|
68
|
-
const rpMetadata = createRPRegistrationMetadataPayload(relyingParty.createRequestOptions.clientMetadata);
|
|
69
|
-
// TODO: We also need to cache the entity configuration until it expires
|
|
70
|
-
const now = new Date();
|
|
71
|
-
// TODO: We also need to check if the x509 certificate is still valid until this expires
|
|
72
|
-
const expires = new Date(now.getTime() + 1000 * 60 * 60 * 24); // 1 day
|
|
73
|
-
const jwk = (0, core_1.getJwkFromKey)(federationKey);
|
|
74
|
-
const alg = jwk.supportedSignatureAlgorithms[0];
|
|
75
|
-
const kid = federationKey.fingerprint;
|
|
76
|
-
const entityConfiguration = await (0, core_2.createEntityConfiguration)({
|
|
77
|
-
header: {
|
|
78
|
-
kid,
|
|
79
|
-
alg,
|
|
80
|
-
typ: 'entity-statement+jwt',
|
|
81
|
-
},
|
|
82
|
-
claims: {
|
|
83
|
-
sub: verifierEntityId,
|
|
84
|
-
iss: verifierEntityId,
|
|
85
|
-
iat: now,
|
|
86
|
-
exp: expires,
|
|
87
|
-
jwks: {
|
|
88
|
-
keys: [Object.assign({ kid, alg }, jwk.toJson())],
|
|
89
|
-
},
|
|
90
|
-
metadata: {
|
|
91
|
-
federation_entity: {
|
|
92
|
-
organization_name: rpMetadata.client_name,
|
|
93
|
-
logo_uri: rpMetadata.logo_uri,
|
|
94
|
-
},
|
|
95
|
-
openid_relying_party: Object.assign(Object.assign({}, rpMetadata), { jwks: {
|
|
96
|
-
keys: [Object.assign({ kid, alg }, (0, core_1.getJwkFromKey)(rpSigningKey).toJson())],
|
|
97
|
-
}, client_registration_types: ['automatic'] }),
|
|
98
|
-
},
|
|
99
|
-
},
|
|
100
|
-
signJwtCallback: ({ toBeSigned }) => agentContext.wallet.sign({
|
|
101
|
-
data: toBeSigned,
|
|
102
|
-
key: federationKey,
|
|
103
|
-
}),
|
|
104
|
-
});
|
|
105
|
-
response.writeHead(200, { 'Content-Type': 'application/entity-statement+jwt' }).end(entityConfiguration);
|
|
106
|
-
}
|
|
107
|
-
catch (error) {
|
|
108
|
-
agentContext.config.logger.error('Failed to create entity configuration', {
|
|
109
|
-
error,
|
|
110
|
-
});
|
|
111
|
-
(0, router_1.sendErrorResponse)(response, next, agentContext.config.logger, 500, 'invalid_request', error);
|
|
112
|
-
return;
|
|
113
|
-
}
|
|
114
|
-
// NOTE: if we don't call next, the agentContext session handler will NOT be called
|
|
115
|
-
next();
|
|
116
|
-
});
|
|
117
|
-
}
|
|
118
|
-
//# sourceMappingURL=federationEndpoint.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"federationEndpoint.js","sourceRoot":"","sources":["../../../src/openid4vc-verifier/router/federationEndpoint.ts"],"names":[],"mappings":"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"}
|