Skip to content

Latest commit

 

History

History
304 lines (176 loc) · 6.31 KB

jwt_sign.SignJWT.md

File metadata and controls

304 lines (176 loc) · 6.31 KB

Class: SignJWT

jwt/sign.SignJWT

The SignJWT class is a utility for creating Compact JWS formatted JWT strings.

example ESM import

import { SignJWT } from 'jose/jwt/sign'

example CJS import

const { SignJWT } = require('jose/jwt/sign')

example Deno import

import { SignJWT } from 'https://deno.land/x/jose@v3.18.0/jwt/sign.ts'

example Usage

const jwt = await new SignJWT({ 'urn:example:claim': true })
  .setProtectedHeader({ alg: 'ES256' })
  .setIssuedAt()
  .setIssuer('urn:example:issuer')
  .setAudience('urn:example:audience')
  .setExpirationTime('2h')
  .sign(privateKey)

console.log(jwt)

Hierarchy

  • ProduceJWT

    SignJWT

Table of contents

Constructors

Methods

Constructors

constructor

new SignJWT(payload)

Parameters

Name Type Description
payload JWTPayload The JWT Claims Set object.

Inherited from

ProduceJWT.constructor

Defined in

lib/jwt_producer.ts:15

Methods

setAudience

setAudience(audience): SignJWT

Set "aud" (Audience) Claim.

Parameters

Name Type Description
audience string | string[] "aud" (Audience) Claim value to set on the JWT Claims Set.

Returns

SignJWT

Inherited from

ProduceJWT.setAudience

Defined in

lib/jwt_producer.ts:47


setExpirationTime

setExpirationTime(input): SignJWT

Set "exp" (Expiration Time) Claim.

Parameters

Name Type Description
input string | number "exp" (Expiration Time) Claim value to set on the JWT Claims Set. When number is passed that is used as a value, when string is passed it is resolved to a time span and added to the current timestamp.

Returns

SignJWT

Inherited from

ProduceJWT.setExpirationTime

Defined in

lib/jwt_producer.ts:85


setIssuedAt

setIssuedAt(input?): SignJWT

Set "iat" (Issued At) Claim.

Parameters

Name Type Description
input? number "iat" (Issued At) Claim value to set on the JWT Claims Set. Default is current timestamp.

Returns

SignJWT

Inherited from

ProduceJWT.setIssuedAt

Defined in

lib/jwt_producer.ts:100


setIssuer

setIssuer(issuer): SignJWT

Set "iss" (Issuer) Claim.

Parameters

Name Type Description
issuer string "Issuer" Claim value to set on the JWT Claims Set.

Returns

SignJWT

Inherited from

ProduceJWT.setIssuer

Defined in

lib/jwt_producer.ts:27


setJti

setJti(jwtId): SignJWT

Set "jti" (JWT ID) Claim.

Parameters

Name Type Description
jwtId string "jti" (JWT ID) Claim value to set on the JWT Claims Set.

Returns

SignJWT

Inherited from

ProduceJWT.setJti

Defined in

lib/jwt_producer.ts:57


setNotBefore

setNotBefore(input): SignJWT

Set "nbf" (Not Before) Claim.

Parameters

Name Type Description
input string | number "nbf" (Not Before) Claim value to set on the JWT Claims Set. When number is passed that is used as a value, when string is passed it is resolved to a time span and added to the current timestamp.

Returns

SignJWT

Inherited from

ProduceJWT.setNotBefore

Defined in

lib/jwt_producer.ts:69


setProtectedHeader

setProtectedHeader(protectedHeader): SignJWT

Sets the JWS Protected Header on the SignJWT object.

Parameters

Name Type Description
protectedHeader JWSHeaderParameters JWS Protected Header.

Returns

SignJWT

Defined in

jwt/sign.ts:46


setSubject

setSubject(subject): SignJWT

Set "sub" (Subject) Claim.

Parameters

Name Type Description
subject string "sub" (Subject) Claim value to set on the JWT Claims Set.

Returns

SignJWT

Inherited from

ProduceJWT.setSubject

Defined in

lib/jwt_producer.ts:37


sign

sign(key, options?): Promise<string>

Signs and returns the JWT.

Parameters

Name Type Description
key KeyLike Private Key or Secret to sign the JWT with.
options? SignOptions JWT Sign options.

Returns

Promise<string>

Defined in

jwt/sign.ts:57