From f8e9ab434c16ef7db0d70e6c944d54724b6dd6de Mon Sep 17 00:00:00 2001 From: Wind4Greg Date: Mon, 16 Dec 2024 16:13:53 -0800 Subject: [PATCH] Added Employment authorization document test vector. --- .../employ/canonDocDataInt.txt | 24 ++++++ .../employ/combinedHashDataInt.txt | 1 + .../eddsa-rdfc-2022/employ/docHashDataInt.txt | 1 + .../employ/proofCanonDataInt.txt | 5 ++ .../employ/proofConfigDataInt.json | 11 +++ .../employ/proofHashDataInt.txt | 1 + .../employ/sigBTC58DataInt.txt | 1 + .../eddsa-rdfc-2022/employ/sigHexDataInt.txt | 1 + .../eddsa-rdfc-2022/employ/signedDataInt.json | 46 ++++++++++++ TestVectors/employmentAuth.json | 38 ++++++++++ index.html | 74 +++++++++++++++++++ 11 files changed, 203 insertions(+) create mode 100644 TestVectors/eddsa-rdfc-2022/employ/canonDocDataInt.txt create mode 100644 TestVectors/eddsa-rdfc-2022/employ/combinedHashDataInt.txt create mode 100644 TestVectors/eddsa-rdfc-2022/employ/docHashDataInt.txt create mode 100644 TestVectors/eddsa-rdfc-2022/employ/proofCanonDataInt.txt create mode 100644 TestVectors/eddsa-rdfc-2022/employ/proofConfigDataInt.json create mode 100644 TestVectors/eddsa-rdfc-2022/employ/proofHashDataInt.txt create mode 100644 TestVectors/eddsa-rdfc-2022/employ/sigBTC58DataInt.txt create mode 100644 TestVectors/eddsa-rdfc-2022/employ/sigHexDataInt.txt create mode 100644 TestVectors/eddsa-rdfc-2022/employ/signedDataInt.json create mode 100644 TestVectors/employmentAuth.json diff --git a/TestVectors/eddsa-rdfc-2022/employ/canonDocDataInt.txt b/TestVectors/eddsa-rdfc-2022/employ/canonDocDataInt.txt new file mode 100644 index 0000000..1eee94f --- /dev/null +++ b/TestVectors/eddsa-rdfc-2022/employ/canonDocDataInt.txt @@ -0,0 +1,24 @@ + . +_:c14n0 . +_:c14n0 . +_:c14n0 "Example Country Employment Authorization Document." . +_:c14n0 "Employment Authorization Document" . +_:c14n0 _:c14n1 . +_:c14n0 . +_:c14n0 "2019-12-03T00:00:00Z"^^ . +_:c14n0 "2029-12-03T00:00:00Z"^^ . +_:c14n1 . +_:c14n1 . +_:c14n1 "JACOB" . +_:c14n1 "1999-07-17"^^ . +_:c14n1 "SMITH" . +_:c14n1 "Male" . +_:c14n1 "JOHN" . +_:c14n1 . +_:c14n1 "Bahamas" . +_:c14n1 _:c14n2 . +_:c14n1 "2015-01-01"^^ . +_:c14n2 . +_:c14n2 "83627465" . +_:c14n2 "C09" . +_:c14n2 "999-999-999" . diff --git a/TestVectors/eddsa-rdfc-2022/employ/combinedHashDataInt.txt b/TestVectors/eddsa-rdfc-2022/employ/combinedHashDataInt.txt new file mode 100644 index 0000000..94ccf3d --- /dev/null +++ b/TestVectors/eddsa-rdfc-2022/employ/combinedHashDataInt.txt @@ -0,0 +1 @@ +bea7b7acfbad0126b135104024a5f1733e705108f42d59668b05c0c50004c6b0e21de16d0139192fe6ea51851d3bb55d55937eb88f80b7f3ba3b79af16bc643f \ No newline at end of file diff --git a/TestVectors/eddsa-rdfc-2022/employ/docHashDataInt.txt b/TestVectors/eddsa-rdfc-2022/employ/docHashDataInt.txt new file mode 100644 index 0000000..f3096b6 --- /dev/null +++ b/TestVectors/eddsa-rdfc-2022/employ/docHashDataInt.txt @@ -0,0 +1 @@ +e21de16d0139192fe6ea51851d3bb55d55937eb88f80b7f3ba3b79af16bc643f \ No newline at end of file diff --git a/TestVectors/eddsa-rdfc-2022/employ/proofCanonDataInt.txt b/TestVectors/eddsa-rdfc-2022/employ/proofCanonDataInt.txt new file mode 100644 index 0000000..4244e64 --- /dev/null +++ b/TestVectors/eddsa-rdfc-2022/employ/proofCanonDataInt.txt @@ -0,0 +1,5 @@ +_:c14n0 "2023-02-24T23:36:38Z"^^ . +_:c14n0 . +_:c14n0 "eddsa-rdfc-2022"^^ . +_:c14n0 . +_:c14n0 . diff --git a/TestVectors/eddsa-rdfc-2022/employ/proofConfigDataInt.json b/TestVectors/eddsa-rdfc-2022/employ/proofConfigDataInt.json new file mode 100644 index 0000000..cc04663 --- /dev/null +++ b/TestVectors/eddsa-rdfc-2022/employ/proofConfigDataInt.json @@ -0,0 +1,11 @@ +{ + "type": "DataIntegrityProof", + "cryptosuite": "eddsa-rdfc-2022", + "created": "2023-02-24T23:36:38Z", + "verificationMethod": "did:key:z6MkrJVnaZkeFzdQyMZu1cgjg7k1pZZ6pvBQ7XJPt4swbTQ2#z6MkrJVnaZkeFzdQyMZu1cgjg7k1pZZ6pvBQ7XJPt4swbTQ2", + "proofPurpose": "assertionMethod", + "@context": [ + "https://www.w3.org/ns/credentials/v2", + "https://w3id.org/citizenship/v4rc1" + ] +} \ No newline at end of file diff --git a/TestVectors/eddsa-rdfc-2022/employ/proofHashDataInt.txt b/TestVectors/eddsa-rdfc-2022/employ/proofHashDataInt.txt new file mode 100644 index 0000000..26fce0d --- /dev/null +++ b/TestVectors/eddsa-rdfc-2022/employ/proofHashDataInt.txt @@ -0,0 +1 @@ +bea7b7acfbad0126b135104024a5f1733e705108f42d59668b05c0c50004c6b0 \ No newline at end of file diff --git a/TestVectors/eddsa-rdfc-2022/employ/sigBTC58DataInt.txt b/TestVectors/eddsa-rdfc-2022/employ/sigBTC58DataInt.txt new file mode 100644 index 0000000..d98b083 --- /dev/null +++ b/TestVectors/eddsa-rdfc-2022/employ/sigBTC58DataInt.txt @@ -0,0 +1 @@ +z64e3a7hAtYQ3pqCdBsPLRpNqJd5YTzbMP7WrotbqY7HtANPq3ZSYoycsz3tHxzqJM5GVR5bUk7TpjoxgdUDXMQaR \ No newline at end of file diff --git a/TestVectors/eddsa-rdfc-2022/employ/sigHexDataInt.txt b/TestVectors/eddsa-rdfc-2022/employ/sigHexDataInt.txt new file mode 100644 index 0000000..ae038d5 --- /dev/null +++ b/TestVectors/eddsa-rdfc-2022/employ/sigHexDataInt.txt @@ -0,0 +1 @@ +fd390da7cb1fb09628217967dd67b0cbcc8fd00a9eb4f7cc90561b0695380b603d856b9663b53c69e78f4004b67e2d1b06a8dd00e424e779ff52203767f0840e \ No newline at end of file diff --git a/TestVectors/eddsa-rdfc-2022/employ/signedDataInt.json b/TestVectors/eddsa-rdfc-2022/employ/signedDataInt.json new file mode 100644 index 0000000..72f23fc --- /dev/null +++ b/TestVectors/eddsa-rdfc-2022/employ/signedDataInt.json @@ -0,0 +1,46 @@ +{ + "@context": [ + "https://www.w3.org/ns/credentials/v2", + "https://w3id.org/citizenship/v4rc1" + ], + "type": [ + "VerifiableCredential", + "EmploymentAuthorizationDocumentCredential" + ], + "issuer": { + "id": "did:key:zDnaegE6RR3atJtHKwTRTWHsJ3kNHqFwv7n9YjTgmU7TyfU76", + "image": "" + }, + "credentialSubject": { + "type": [ + "Person", + "EmployablePerson" + ], + "givenName": "JOHN", + "additionalName": "JACOB", + "familyName": "SMITH", + "image": "", + "gender": "Male", + "residentSince": "2015-01-01", + "birthCountry": "Bahamas", + "birthDate": "1999-07-17", + "employmentAuthorizationDocument": { + "type": "EmploymentAuthorizationDocument", + "identifier": "83627465", + "lprCategory": "C09", + "lprNumber": "999-999-999" + } + }, + "name": "Employment Authorization Document", + "description": "Example Country Employment Authorization Document.", + "validFrom": "2019-12-03T00:00:00Z", + "validUntil": "2029-12-03T00:00:00Z", + "proof": { + "type": "DataIntegrityProof", + "cryptosuite": "eddsa-rdfc-2022", + "created": "2023-02-24T23:36:38Z", + "verificationMethod": "did:key:z6MkrJVnaZkeFzdQyMZu1cgjg7k1pZZ6pvBQ7XJPt4swbTQ2#z6MkrJVnaZkeFzdQyMZu1cgjg7k1pZZ6pvBQ7XJPt4swbTQ2", + "proofPurpose": "assertionMethod", + "proofValue": "z64e3a7hAtYQ3pqCdBsPLRpNqJd5YTzbMP7WrotbqY7HtANPq3ZSYoycsz3tHxzqJM5GVR5bUk7TpjoxgdUDXMQaR" + } +} \ No newline at end of file diff --git a/TestVectors/employmentAuth.json b/TestVectors/employmentAuth.json new file mode 100644 index 0000000..1de9226 --- /dev/null +++ b/TestVectors/employmentAuth.json @@ -0,0 +1,38 @@ +{ + "@context": [ + "https://www.w3.org/ns/credentials/v2", + "https://w3id.org/citizenship/v4rc1" + ], + "type": [ + "VerifiableCredential", + "EmploymentAuthorizationDocumentCredential" + ], + "issuer": { + "id": "did:key:zDnaegE6RR3atJtHKwTRTWHsJ3kNHqFwv7n9YjTgmU7TyfU76", + "image": "" + }, + "credentialSubject": { + "type": [ + "Person", + "EmployablePerson" + ], + "givenName": "JOHN", + "additionalName": "JACOB", + "familyName": "SMITH", + "image": "", + "gender": "Male", + "residentSince": "2015-01-01", + "birthCountry": "Bahamas", + "birthDate": "1999-07-17", + "employmentAuthorizationDocument": { + "type": "EmploymentAuthorizationDocument", + "identifier": "83627465", + "lprCategory": "C09", + "lprNumber": "999-999-999" + } + }, + "name": "Employment Authorization Document", + "description": "Example Country Employment Authorization Document.", + "validFrom": "2019-12-03T00:00:00Z", + "validUntil": "2029-12-03T00:00:00Z" + } \ No newline at end of file diff --git a/index.html b/index.html index 2c110c9..1c727c5 100644 --- a/index.html +++ b/index.html @@ -2304,6 +2304,80 @@

Representation: eddsa-rdfc-2022


       
+      
+

Enhanced Example for Representation: eddsa-rdfc-2022

+

+Here we again go through the steps of creating an `eddsa-rdfc-2022` signed +credential but with a more complicated input document. The +representation of the public key and the representation of the private key +are shown below. +

+
+{
+    publicKeyMultibase: "z6MkrJVnaZkeFzdQyMZu1cgjg7k1pZZ6pvBQ7XJPt4swbTQ2",
+    secretKeyMultibase: "z3u2en7t5LR2WtQH5PfFqMqwVHBeXouLzo6haApm8XHqvjxq"
+}
+        
+ +

+Signing begins with a credential without an attached proof, which is converted +to canonical form, and then hashed, as shown in the following three examples. +

+ +

+
+        

+
+
+        

+
+        

+The next step is to take the proof options document, convert it to canonical +form, and obtain its hash, as shown in the next three examples. +

+ +

+
+        

+
+        

+
+        

+Finally, we concatenate the hash of the proof options followed by the hash of +the credential without proof, use the private key with the combined hash to +compute the Ed25519 signature, and then base58-btc encode the signature. +

+ +

+
+        

+
+        

+
+        

Assemble the signed credential with the following two steps:

+
    +
  1. +Add the proofValue field with the previously computed base58-btc +value to the proof options document. +
  2. +
  3. +Set the proof field of the credential to the augmented proof +option document. +
  4. +
+ +

+      

Representation: eddsa-jcs-2022