Skip to content

Commit

Permalink
Merge branch 'main' of github.com:european-epc-competence-center/vc-v…
Browse files Browse the repository at this point in the history
…erifier
  • Loading branch information
F-Node-Karlsruhe committed Feb 7, 2023
2 parents 2cc3fa4 + 66948f3 commit 39205ce
Show file tree
Hide file tree
Showing 9 changed files with 661 additions and 188 deletions.
2 changes: 1 addition & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@

# VC Verifier

The [EECC Verifier](https://ssi.eecc.de/verifier/) for verifiable credentials provides a verification API as well as the corresponding UI. It's primary purpose is to aggregate data from various VCs and display them in a comprehensible manner as a product passport.
The [EECC Verifier](https://ssi.eecc.de/verifier/) for verifiable credentials provides a verification API as well as the corresponding UI. It's primary purpose is to aggregate data from various VCs and display them in a comprehensible manner as a product passport. [See here for an example.](https://ssi.eecc.de/verifier/#/verify?subjectId=https%3A%2F%2Fid.eecc.de/01/04012345999990/10/20210401-A/21/XYZ-1234)

This tool uses the libraries by [Digital Bazaar, Inc.](https://github.com/digitalbazaar), in particular

Expand Down
302 changes: 291 additions & 11 deletions api/src/routers/verify/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ import { VerifyRoutes } from '../../routes/index.js';


const verifyRoutes = new VerifyRoutes();
const { verifyCredential, verifyCredentials, verifySubjectsVCs } = verifyRoutes
const { fetchAndVerify, verify, verifySubjectsVCs } = verifyRoutes

export const verifyRouter = Router();

Expand All @@ -30,11 +30,34 @@ export const verifyRouter = Router();
* @property {object} proof.required - The cryptographic signature of the issuer over the credential
*/

/**
* API model of a signed presentation
* @summary Refers to W3C Presentation
* @typedef {object} SignedPresentation
* @property {array<string>} context.required - The JSON-LD context URIs of the presentation
* @property {array<string>} type.required - The types of the presentation. Should be 'VerifiablePresentation'
* @property {string} holder.required - The DID of the holder of the credentials, i.e. the presenter
* @property {array<SignedCredential>} verifiableCredential.required - Array of included credentials
* @property {object} proof.required - The cryptographic signature of the holder over the presentation
*/

/**
* API model of a verifiable. Can be either a SignedCredentials or SignedPresentation
* @typedef {object} Verifiable
* @summary Refers to W3C verifiable credentials and presentation
* @typedef {object} Verifiable
* @property {array<string>} context.required - The JSON-LD context URIs of the presentation
* @property {array<string>} type.required - The types of the verifiable
* @property {object} proof.required - The cryptographic signature
*/

/**
* Verifier response object
* @summary The respsonse object of the verifier containing the original credential and the verification result
* @typedef {object} VerifierResponse
* @property {array<object>} results.required - Array of results including both successes and errors
* @property {array<object>} results - Array of results including both successes and errors for credentials
* @property {array<object>} credentialResults - Results of the credentials contained in the presentation
* @property {array<object>} presentationResult - Result of the presentation
* @property {boolean} verified.required - Boolean if the whole verification was successful
*/

Expand Down Expand Up @@ -81,17 +104,17 @@ export const verifyRouter = Router();
]
}
*/
verifyRouter.get('/vc/:vcid', verifyCredential);
verifyRouter.get('/vc/:vcid', fetchAndVerify);

/**
* POST /api/verifier/vc
* @summary Verifies an array of VCs
* POST /api/verifier
* @summary Verifies an array of verifiables
* @tags Verify
* @param {array<VerifierResponse>} request.body.required - Array of verifiable credentials
* @param {array<Verifiable>} request.body.required - Array of verifiables either of type SignedPresentation or SignedCredential - application/json
* @return {array<object>} 200 - success response - application/json
* @return {object} 400 - bad request response - application/json
*
* @example request - Example request
* @example request - Credential request
[
{
"@context": [
Expand All @@ -113,7 +136,96 @@ export const verifyRouter = Router();
}
}
]
* @example response - 200 - credentials verified
* @example request - Presentation request
[
{
"@context": [
"https://www.w3.org/2018/credentials/v1",
"https://ssi.eecc.de/api/registry/context",
"https://w3id.org/security/suites/ed25519-2020/v1"
],
"type": [
"VerifiablePresentation"
],
"verifiableCredential": [
{
"@context": [
"https://www.w3.org/2018/credentials/v1",
"https://ssi.eecc.de/api/registry/context/productpassport",
"https://w3id.org/security/suites/ed25519-2020/v1"
],
"id": "https://ssi.eecc.de/api/registry/vc/cf43356c-a9f3-418a-a3ff-baca5a14d668",
"type": [
"VerifiableCredential",
"ProductPassportCredential"
],
"issuer": {
"id": "did:web:ssi.eecc.de",
"image": "https://id.eecc.de/assets/img/logo_big.png",
"name": "EECC"
},
"issuanceDate": "2023-01-25T16:01:26Z",
"credentialSubject": {
"id": "https://id.eecc.de/01/04012345999990/10/20210401-A/21/XYZ-1234",
"digital_link": "https://id.eecc.de/01/04012345999990/10/20210401-A/21/XYZ-1234"
},
"proof": {
"type": "Ed25519Signature2020",
"created": "2023-01-25T16:01:26Z",
"proofPurpose": "assertionMethod",
"verificationMethod": "did:web:ssi.eecc.de#z6MkoHWsmSZnHisAxnVdokYHnXaVqWFZ4H33FnNg13zyymxd",
"proofValue": "z5YUnCUVWgAwc1iTQ61jtUyjBNLZELGMxnbsekFDQLd4ZNbPo45we4xxZjV5pqb3jqPo7ryKMmMY9dySNERz1huLJ"
}
},
{
"@context": [
"https://www.w3.org/2018/credentials/v1",
"https://ssi.eecc.de/api/registry/context/productpassport",
"https://w3id.org/security/suites/ed25519-2020/v1"
],
"id": "https://ssi.eecc.de/api/registry/vc/03bb6e67-ecf3-4b71-99bd-fc4c7c37b8ce",
"type": [
"VerifiableCredential",
"ProductPassportCredential"
],
"issuer": {
"id": "did:web:ssi.eecc.de",
"image": "https://id.eecc.de/assets/img/logo_big.png",
"name": "EECC"
},
"issuanceDate": "2023-01-25T16:01:01Z",
"credentialSubject": {
"id": "https://id.eecc.de/01/04012345999990/10/20210401-A",
"country_of_origin": "Germany",
"digital_link": "https://id.eecc.de/01/04012345999990/10/20210401-A",
"production_date": "2021-04-01"
},
"proof": {
"type": "Ed25519Signature2020",
"created": "2023-01-25T16:01:01Z",
"proofPurpose": "assertionMethod",
"verificationMethod": "did:web:ssi.eecc.de#z6MkoHWsmSZnHisAxnVdokYHnXaVqWFZ4H33FnNg13zyymxd",
"proofValue": "z5AUbYQjMaK27aLWUibQWGLXUNeP1dgEHHdCFGm13GvEwa3sV2BxtDjwSyJdrgeJsqXTZG7fqwyRVMRrP6CmfLMhF"
}
}
],
"holder": {
"id": "did:web:ssi.eecc.de",
"image": "https://id.eecc.de/assets/img/logo_big.png",
"name": "EECC"
},
"proof": {
"type": "Ed25519Signature2020",
"created": "2023-02-02T14:29:09Z",
"verificationMethod": "did:web:ssi.eecc.de#z6MkoHWsmSZnHisAxnVdokYHnXaVqWFZ4H33FnNg13zyymxd",
"proofPurpose": "authentication",
"challenge": "testchallenge",
"domain": "ssi.eecc.de",
"proofValue": "z4A8Xexpe2bjH5WefUKErHvvvaYRHWz4ogWHq9r31EHo44CJX7drJpyyPVwfN5ohxTMMsmrkaWwbWQkUWf1iq3CC8"
}
}
]
* @example response - 200 - Credentials verified
[
{
"verified": true,
Expand Down Expand Up @@ -149,13 +261,181 @@ export const verifyRouter = Router();
}
]
}
]
* @example response - 200 - Presentations verified
[
{
"verified": true,
"presentationResult": {
"verified": true,
"results": [
{
"proof": {
"@context": [
"https://www.w3.org/2018/credentials/v1",
"https://ssi.eecc.de/api/registry/context",
"https://w3id.org/security/suites/ed25519-2020/v1"
],
"type": "Ed25519Signature2020",
"created": "2023-02-02T14:29:09Z",
"verificationMethod": "did:web:ssi.eecc.de#z6MkoHWsmSZnHisAxnVdokYHnXaVqWFZ4H33FnNg13zyymxd",
"proofPurpose": "authentication",
"challenge": "testchallenge",
"domain": "ssi.eecc.de",
"proofValue": "z4A8Xexpe2bjH5WefUKErHvvvaYRHWz4ogWHq9r31EHo44CJX7drJpyyPVwfN5ohxTMMsmrkaWwbWQkUWf1iq3CC8"
},
"verified": true,
"verificationMethod": {
"id": "did:web:ssi.eecc.de#z6MkoHWsmSZnHisAxnVdokYHnXaVqWFZ4H33FnNg13zyymxd",
"type": "Ed25519VerificationKey2020",
"controller": "did:web:ssi.eecc.de",
"publicKeyMultibase": "z6MkoHWsmSZnHisAxnVdokYHnXaVqWFZ4H33FnNg13zyymxd",
"@context": [
"https://www.w3.org/ns/did/v1",
"https://w3id.org/security/suites/ed25519-2020/v1",
"https://w3id.org/security/suites/x25519-2020/v1"
]
},
"purposeResult": {
"valid": true,
"controller": {
"@context": [
"https://www.w3.org/ns/did/v1",
"https://w3id.org/security/suites/ed25519-2020/v1",
"https://w3id.org/security/suites/x25519-2020/v1"
],
"id": "did:web:ssi.eecc.de",
"verificationMethod": [
{
"id": "did:web:ssi.eecc.de#z6MkoHWsmSZnHisAxnVdokYHnXaVqWFZ4H33FnNg13zyymxd",
"type": "Ed25519VerificationKey2020",
"controller": "did:web:ssi.eecc.de",
"publicKeyMultibase": "z6MkoHWsmSZnHisAxnVdokYHnXaVqWFZ4H33FnNg13zyymxd"
},
{
"id": "did:web:ssi.eecc.de#products",
"type": "Ed25519VerificationKey2020",
"controller": "did:web:ssi.eecc.de",
"publicKeyMultibase": "z6Mkiaw6Uva4gJnZizeFLyxhMfy6V6eWzCm6pwNCzvSQhHy6"
},
{
"id": "did:web:ssi.eecc.de#z6MknBXhTcvvJRpNk8cdC9LgCccj8W4n26zXUawCAYV6DwPG",
"type": "Ed25519VerificationKey2020",
"controller": "did:web:ssi.eecc.de",
"publicKeyMultibase": "z6MknBXhTcvvJRpNk8cdC9LgCccj8W4n26zXUawCAYV6DwPG"
}
],
"assertionMethod": [
"did:web:ssi.eecc.de#z6MkoHWsmSZnHisAxnVdokYHnXaVqWFZ4H33FnNg13zyymxd",
"did:web:ssi.eecc.de#products",
"did:web:ssi.eecc.de#z6MknBXhTcvvJRpNk8cdC9LgCccj8W4n26zXUawCAYV6DwPG"
],
"authentication": [
"did:web:ssi.eecc.de#z6MkoHWsmSZnHisAxnVdokYHnXaVqWFZ4H33FnNg13zyymxd"
],
"capabilityDelegation": [
"did:web:ssi.eecc.de#z6MkoHWsmSZnHisAxnVdokYHnXaVqWFZ4H33FnNg13zyymxd"
],
"capabilityInvocation": [
"did:web:ssi.eecc.de#z6MkoHWsmSZnHisAxnVdokYHnXaVqWFZ4H33FnNg13zyymxd"
],
"service": [
{
"id": "did:web:ssi.eecc.de#website",
"type": "LinkedDomains",
"serviceEndpoint": "https://id.eecc.de"
},
{
"id": "did:web:ssi.eecc.de#eecc-registry",
"type": "CredentialRegistry",
"serviceEndpoint": "https://ssi.eecc.de/api/registry/vcs/"
}
]
}
}
}
]
},
"credentialResults": [
{
"verified": true,
"results": [
{
"proof": {
"@context": [
"https://www.w3.org/2018/credentials/v1",
"https://ssi.eecc.de/api/registry/context/productpassport",
"https://w3id.org/security/suites/ed25519-2020/v1"
],
"type": "Ed25519Signature2020",
"created": "2023-01-25T16:01:26Z",
"proofPurpose": "assertionMethod",
"verificationMethod": "did:web:ssi.eecc.de#z6MkoHWsmSZnHisAxnVdokYHnXaVqWFZ4H33FnNg13zyymxd",
"proofValue": "z5YUnCUVWgAwc1iTQ61jtUyjBNLZELGMxnbsekFDQLd4ZNbPo45we4xxZjV5pqb3jqPo7ryKMmMY9dySNERz1huLJ"
},
"verified": true,
"verificationMethod": {
"id": "did:web:ssi.eecc.de#z6MkoHWsmSZnHisAxnVdokYHnXaVqWFZ4H33FnNg13zyymxd",
"type": "Ed25519VerificationKey2020",
"controller": "did:web:ssi.eecc.de",
"publicKeyMultibase": "z6MkoHWsmSZnHisAxnVdokYHnXaVqWFZ4H33FnNg13zyymxd",
"@context": [
"https://www.w3.org/ns/did/v1",
"https://w3id.org/security/suites/ed25519-2020/v1",
"https://w3id.org/security/suites/x25519-2020/v1"
]
},
"purposeResult": {
"valid": true
}
}
],
"credentialId": "https://ssi.eecc.de/api/registry/vc/cf43356c-a9f3-418a-a3ff-baca5a14d668"
},
{
"verified": true,
"results": [
{
"proof": {
"@context": [
"https://www.w3.org/2018/credentials/v1",
"https://ssi.eecc.de/api/registry/context/productpassport",
"https://w3id.org/security/suites/ed25519-2020/v1"
],
"type": "Ed25519Signature2020",
"created": "2023-01-25T16:01:01Z",
"proofPurpose": "assertionMethod",
"verificationMethod": "did:web:ssi.eecc.de#z6MkoHWsmSZnHisAxnVdokYHnXaVqWFZ4H33FnNg13zyymxd",
"proofValue": "z5AUbYQjMaK27aLWUibQWGLXUNeP1dgEHHdCFGm13GvEwa3sV2BxtDjwSyJdrgeJsqXTZG7fqwyRVMRrP6CmfLMhF"
},
"verified": true,
"verificationMethod": {
"id": "did:web:ssi.eecc.de#z6MkoHWsmSZnHisAxnVdokYHnXaVqWFZ4H33FnNg13zyymxd",
"type": "Ed25519VerificationKey2020",
"controller": "did:web:ssi.eecc.de",
"publicKeyMultibase": "z6MkoHWsmSZnHisAxnVdokYHnXaVqWFZ4H33FnNg13zyymxd",
"@context": [
"https://www.w3.org/ns/did/v1",
"https://w3id.org/security/suites/ed25519-2020/v1",
"https://w3id.org/security/suites/x25519-2020/v1"
]
},
"purposeResult": {
"valid": true
}
}
],
"credentialId": "https://ssi.eecc.de/api/registry/vc/03bb6e67-ecf3-4b71-99bd-fc4c7c37b8ce"
}
]
}
]
*/
verifyRouter.post('/vc', verifyCredentials);
verifyRouter.post('/', verify);

/**
* GET /api/verifier/id/{subjectId}
* @summary Verifies a all queryable vcs of an subjectId
* @summary Verifies a all queryable vcs of a subjectId
* @tags Verify
* @param {string} subjectId.path.required The identifier of the verifiable credential
* @return {array<VerifierResponse>} 200 - success response - application/json
Expand Down Expand Up @@ -199,5 +479,5 @@ export const verifyRouter = Router();
}
]
*/
verifyRouter.get('/id/:subjectId', verifySubjectsVCs);
verifyRouter.get('/id/:subjectId', verifySubjectsVCs);

Loading

0 comments on commit 39205ce

Please sign in to comment.