Security News
The Risks of Misguided Research in Supply Chain Security
Snyk's use of malicious npm packages for research raises ethical concerns, highlighting risks in public deployment, data exfiltration, and unauthorized testing.
The did-JWT library allows you to sign and verify JSON Web Tokens (JWT). Public keys are resolved using the Decentralized ID (DID) of the iss
claim of the JWT.
ES256K
the secp256k1 ECDSA curveES256K-R
the secp256k1 ECDSA curve with recovery parameterThe PublicKey
section of a DID document contains one or more Public Keys. We support the following types:
Name | Encoding | Algorithm's |
---|---|---|
Secp256k1SignatureVerificationKey2018 | publicKeyHex | ES256K , ES256K-R |
Secp256k1VerificationKey2018 | publicKeyHex | ES256K , ES256K-R |
Secp256k1VerificationKey2018 | ethereumAddress | ES256K-R |
Name | Description | Required |
---|---|---|
iss | The DID of the signing identity | yes |
sub | The DID of the subject of the JWT | no |
aud | The DID or URL of the audience of the JWT. Our libraries or app will not accept any JWT that has someone else as the audience | no |
iat | The time of issuance | yes |
exp | Expiration time of JWT | no |
npm install did-jwt
or if you use yarn
yarn add did-jwt
Use the createJWT()
function
import { createJWT, SimpleSigner } from 'did-jwt'
const signer = SimpleSigner('PRIVATEKEY')
createJWT(
{aud: 'did:uport:2nQtiQG6Cgm1GYTBaaKAgr76uY7iSexUkqY', exp: 1485321133, name: 'Bob Smith'},
{issuer: 'did:uport:2nQtiQG6Cgm1GYTBaaKAgr76uY7iSexUkqX', signer}).then(jwt => {
console.log(jwt)
})
createJWT(payload, settings)
Name | Description | Required |
---|---|---|
payload | an object containing any claims you want to encode in the JWT including optional standard claims such as sub , aud and exp | yes |
settings.issuer | The DID of the audience of the JWT | yes |
settings.signer | A signing function (see SimpleSigner) | yes |
settings.expiresIn | How many seconds after signing should the JWT be valid (sets the exp claim) | no |
The createJWT()
function returns a Promise.
A successfull call returns an object containing the following attributes:
Name | Description |
---|---|
jwt | String containing a JSON Web Tokens (JWT) |
If there are any errors found during the signing process the promise is rejected with a clear error message.
Use the verifyJWT()
function
import { verifyJWT } from 'did-jwt'
verifyJWT('eyJ0eXAiOiJKV1QiLCJhbGciOiJFUzI1NksifQ.eyJpc3MiOiJkaWQ6dXBvcn....', {audience: 'Your DID'}).then({payload, doc, did, signer, jwt} => {
console.log(payload)
})
verifyJWT(jwt, options)
Name | Description | Required |
---|---|---|
jwt | String containing a JSON Web Tokens (JWT) | yes |
options.auth | Require signer to be listed in the authentication section of the DID document (for Authentication of a user with DID-AUTH) | |
options.audience | The DID of the audience of the JWT | no |
options.callbackUrl | The the URL receiving the JWT | no |
The verifyJWT()
function returns a Promise.
A successfull call returns an object containing the following attributes:
Name | Description |
---|---|
payload | An object containing the JSON parsed contents of the payload section of the JWT |
issuer | The DID of the issuer of the JWT |
signer | An object containing information about which key signed the JWT. This is useful if a DID document has multiple keys listed |
doc | The DID Document of the issuer of the JWT |
jwt | The original JWT passed in to the function |
If there are any errors found during the verification process the promise is rejected with a clear error message.
We provide a simple signing abstraction that makes it easy to add support for your own Key Management infrastructure.
For most people you can use our SimpleSigner()
function to creaate a signer function using a hex encoded private key.
import { SimpleSigner } from 'did-jwt'
const signer = SimpleSigner('278a5de700e29faae8e40e366ec5012b5ec63d36ec77e8a2417154cc1d25383f')
SimpleSigner(privateKey)
Name | Description | Required |
---|---|---|
privateKey | hex encoded secp256k1 privatekey | yes |
Note this is NOT a constructor, but a higher order function that returns a signing function.
You can easily create custom signers that integrates into your existing signing infrastructure. A signer function takes the raw data to be signed and returns a Promise containing the signature parameters.
function mySigner (hash) {
return new Promise((resolve, reject) => {
const signature = /// sign it
resolve(signature)
})
}
Name | Description | Required |
---|---|---|
hash | Buffer containing hash of data to be signed | yes |
Your function must returns a Promise.
A successfull call returns an object containing the following attributes:
Name | Description | Required |
---|---|---|
r | Hex encoded r value of secp256k1 signature | yes |
s | Hex encoded s value of secp256k1 signature | yes |
recoveryParam | Recovery parameter of signature (can be used to calculate signing public key) | only required for (ES256K-R ) |
FAQs
Library for Signing and Verifying JWTs that use DIDs as issuers and JWEs that use DIDs as recipients
The npm package did-jwt receives a total of 80,097 weekly downloads. As such, did-jwt popularity was classified as popular.
We found that did-jwt demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 6 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Snyk's use of malicious npm packages for research raises ethical concerns, highlighting risks in public deployment, data exfiltration, and unauthorized testing.
Research
Security News
Socket researchers found several malicious npm packages typosquatting Chalk and Chokidar, targeting Node.js developers with kill switches and data theft.
Security News
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.