Up to higher level directory | |||
Name | Date | Size | |
---|---|---|---|
payload.json | 03-Dec-2014 | 601 | |
private_key.pem | 03-Dec-2014 | 1.6K | |
public_key.pem | 03-Dec-2014 | 451 | |
README | 03-Dec-2014 | 964 | |
verified_contents.json | 03-Dec-2014 | 1.5K |
1 2 The public/private key pairs were generated with the following commands: 3 4 openssl genrsa -out private_key.pem 2048 5 openssl rsa -in private_key.pem -pubout -out public_key.pem 6 7 8 The signature was generated by: 9 10 1) Take the contents of payload.json and base64url encode them: 11 cat payload.json | tr -d \\n | base64 -w0 | tr / _ | tr + \- | tr -d '=' > payload_encoded.txt 12 13 2) Put the contents of payload_encoded.txt into the "payload" field of 14 verified_contents.json. 15 16 3) Copy the contents of the "protected" field from verified_contents.json into 17 protected.txt. 18 19 4) Concatenate the "protected" and "payload" fields with a '.' separator. 20 21 echo -n '.' | cat protected.txt - payload_encoded.txt > signature_input.txt 22 23 5) Sign it 24 25 tr -d \\n < signature_input.txt | openssl dgst -sha256 -sign private_key.pem -binary | base64 -w0 | tr / _ | tr + \- | tr -d '=' > signature.txt 26 27 6) Put the contents of signature.txt into the "signature" field in 28 verified_contents.json. 29