Skip to content

Latest commit

 

History

History
127 lines (75 loc) · 3.69 KB

GeneralEncrypt.md

File metadata and controls

127 lines (75 loc) · 3.69 KB

Class: GeneralEncrypt

Support from the community to continue maintaining and improving this module is welcome. If you find the module useful, please consider supporting the project by becoming a sponsor.

The GeneralEncrypt class is used to build and encrypt General JWE objects.

This class is exported (as a named export) from the main 'jose' module entry point as well as from its subpath export 'jose/jwe/general/encrypt'.

Example

const jwe = await new jose.GeneralEncrypt(
  new TextEncoder().encode('It’s a dangerous business, Frodo, going out your door.'),
)
  .setProtectedHeader({ enc: 'A256GCM' })
  .addRecipient(ecPublicKey)
  .setUnprotectedHeader({ alg: 'ECDH-ES+A256KW' })
  .addRecipient(rsaPublicKey)
  .setUnprotectedHeader({ alg: 'RSA-OAEP-384' })
  .encrypt()

console.log(jwe)

Constructors

new GeneralEncrypt()

new GeneralEncrypt(plaintext): GeneralEncrypt

Parameters

Parameter Type Description
plaintext Uint8Array Binary representation of the plaintext to encrypt.

Returns

GeneralEncrypt

Methods

addRecipient()

addRecipient(key, options?): Recipient

Adds an additional recipient for the General JWE object.

Parameters

Parameter Type Description
key Uint8Array | KeyLike Public Key or Secret to encrypt the Content Encryption Key for the recipient with. See Algorithm Key Requirements.
options? CritOption JWE Encryption options.

Returns

Recipient


encrypt()

encrypt(): Promise<GeneralJWE>

Encrypts and resolves the value of the General JWE object.

Returns

Promise<GeneralJWE>


setAdditionalAuthenticatedData()

setAdditionalAuthenticatedData(aad): this

Sets the Additional Authenticated Data on the GeneralEncrypt object.

Parameters

Parameter Type Description
aad Uint8Array Additional Authenticated Data.

Returns

this


setProtectedHeader()

setProtectedHeader(protectedHeader): this

Sets the JWE Protected Header on the GeneralEncrypt object.

Parameters

Parameter Type Description
protectedHeader JWEHeaderParameters JWE Protected Header object.

Returns

this


setSharedUnprotectedHeader()

setSharedUnprotectedHeader(sharedUnprotectedHeader): this

Sets the JWE Shared Unprotected Header on the GeneralEncrypt object.

Parameters

Parameter Type Description
sharedUnprotectedHeader JWEHeaderParameters JWE Shared Unprotected Header object.

Returns

this