Important: This documentation covers Yarn 1 (Classic).
For Yarn 2+ docs and migration guide, see yarnpkg.com.

Package detail

iron-webcrypto

brc-dd4.6mMIT1.2.1TypeScript support: included

a cryptographic utility for sealing-unsealing a JSON object using symmetric key encryption with message integrity verification

authentication, data integrity, encryption, webcrypto

readme

iron-webcrypto

jsDocs.io downloads npm deno jsr

This module is a replacement for @hapi/iron, written using standard APIs like Web Crypto and Uint8Array, which make this compatible with a variety of runtimes like Node.js, Deno, Bun, browsers, workers, and edge environments. Refer @hapi/iron's docs on what it does and how it works.

Check out unjs/h3 and vvo/iron-session to see this module in use!


Installation

For Node.js and Bun, run any of the following commands depending on your package manager / runtime:

npm add iron-webcrypto
yarn add iron-webcrypto
pnpm add iron-webcrypto
bun add iron-webcrypto

You can then import it using:

import * as Iron from 'iron-webcrypto'

If using JSR, run any of the following commands depending on your package manager / runtime:

npx jsr add @brc-dd/iron
yarn dlx jsr add @brc-dd/iron
pnpm dlx jsr add @brc-dd/iron
bunx jsr add @brc-dd/iron
deno add @brc-dd/iron

You can then import it using:

import * as Iron from '@brc-dd/iron'

On Deno, you can also use any of the following imports:

import * as Iron from 'https://deno.land/x/iron@v1.2.1/mod.ts'
import * as Iron from 'https://esm.sh/iron-webcrypto@1.2.1'
import * as Iron from 'npm:iron-webcrypto@1.2.1'

Don't use this module directly in the browser. While it will work, it's not recommended to use it in client-side code because of the security implications.

Usage

Refer @hapi/iron's docs. There are certain differences.

You need to pass a Web Crypto implementation as the first parameter to each function. For example:

Iron.seal(obj, password, Iron.defaults)

becomes:

Iron.seal(_crypto, obj, password, Iron.defaults)

where _crypto is your Web Crypto implementation. Generally, this will be available in your context. For example, globalThis.crypto in browsers, workers, edge runtimes, Deno, Bun, and Node.js v19+; require('crypto').webcrypto in Node.js v15+. You can directly use uncrypto for this too. Also, you might need to polyfill this for older Node.js versions. I recommend using @peculiar/webcrypto for that.

There are certain other differences because of the underlying implementation using standard APIs instead of Node.js-specific ones like node:crypto and node:buffer. There might also be differences in certain error messages because of this.

Security Considerations

Users are responsible for implementing iron-webcrypto in a secure manner and ensuring the security of their cryptographic keys. I DO NOT guarantee the security of this module. So far, no security vulnerabilities have been reported, but I am no cryptography expert. Quoting MDN:

The Web Crypto API provides a number of low-level cryptographic primitives. It's very easy to misuse them, and the pitfalls involved can be very subtle.

Even assuming you use the basic cryptographic functions correctly, secure key management and overall security system design are extremely hard to get right, and are generally the domain of specialist security experts.

Errors in security system design and implementation can make the security of the system completely ineffective.

As a request, it would be great if someone with expertise in this field could thoroughly review the code.

Credits

@hapi/iron
    Copyright (c) 2012-2022, Project contributors
    Copyright (c) 2012-2020, Sideway Inc
    All rights reserved.
    https://cdn.jsdelivr.net/npm/@hapi/iron@7.0.1/LICENSE.md

@smithy/util-base64
    Copyright 2018-2020 Amazon.com, Inc. or its affiliates. All Rights Reserved.
    https://cdn.jsdelivr.net/npm/@smithy/util-base64@2.3.0/LICENSE

@smithy/util-utf8
    Copyright 2018-2020 Amazon.com, Inc. or its affiliates. All Rights Reserved.
    https://cdn.jsdelivr.net/npm/@smithy/util-utf8@2.3.0/LICENSE

Sponsors

brc-dd's sponsors

changelog

1.2.1 (2024-05-09)

Bug Fixes

1.2.0 (2024-05-09)

Bug Fixes

  • broken aes-128-ctr mode (8356294)

1.1.1 (2024-04-20)

Bug Fixes

  • types: it wrongfully allowed using digest algorithms in encryption options (3f72198)

1.1.0 (2024-03-09)

1.0.0 (2023-10-14)

0.10.1 (2023-09-01)

Bug Fixes

  • deno: types not being pickup (f0793da)

0.10.0 (2023-09-01)

0.9.0 (2023-09-01)

Bug Fixes

  • types: prevent false ts errors with node webcrypto (a0f1b6e)

0.8.2 (2023-08-29)

0.8.1 (2023-08-29)

0.8.0 (2023-07-17)

0.7.1 (2023-06-26)

0.7.0 (2023-04-22)

0.6.0 (2023-03-14)

Bug Fixes

  • types: emit .d.cts files and fix export map (d1cb1e6)

0.5.0 (2023-02-11)

0.4.0 (2023-02-07)

Features

  • drop dependency on buffer and use standard uint8array (#5) (285bfd9)

0.3.1 (2023-02-07)

Bug Fixes

  • group exports to default (45f96d5)

0.3.0 (2023-02-07)

Bug Fixes

  • don't polyfill buffer on node (#4) (421c853)

0.2.7 (2022-12-17)

Bug Fixes

  • reorder exports to move types to top (e3bb1cb)

0.2.6 (2022-11-20)

0.2.5 (2022-09-09)

Bug Fixes

  • return null if decrypted string is empty (a87ed60)

Performance Improvements

  • use interfaces instead of types (e898dbf)

0.2.4 (2022-09-01)

Bug Fixes

0.2.3 (2022-09-01)

Bug Fixes

0.2.2 (2022-08-28)

0.2.1 (2022-08-28)

Performance Improvements

  • externalize buffer and re-export all types (df68feb)

0.2.0 (2022-08-27)

0.1.0 (2022-06-08)

Features

  • rely on manual dependency injection (2c79346)

0.0.2 (2022-06-08)

Bug Fixes

  • make esbuild think @peculiar/webcrypto is external (fe10385)

0.0.1 (2022-05-19)

Features