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

Package detail

hpke-js

dajiaji175.8kMIT1.6.2TypeScript support: included

A Hybrid Public Key Encryption (HPKE) module for various JavaScript runtimes

hpke, public-key-encryption, rfc9180, e2ee, kem, kdf, kyber, aead, post-quantum, pqc, security, encryption

readme

hpke-js

A TypeScript Hybrid Public Key Encryption (HPKE) implementation build on top of Web Cryptography API. This module works on web browsers, Node.js, Deno and various other JavaScript runtimes.

Index

Installation

Where possible, it is recommended to use @hpke/core along with extension modules (such as @hpke/chacha20poly1305) instead of hpke-js.

Node.js

You can install the package with npm, yarn or pnpm.

# Using npm:
npm install hpke-js
yarn add hpke-js
pnpm install hpke-js
# Using jsr:
npx jsr add hpke-js
yarn dlx jsr add hpke-js
pnpm dlx jsr add hpke-js

The above manner can be used with other JavaScript runtimes that support npm, such as Cloudflare Workers and Bun.

Then, you can use the module from code like this:

import { AeadId, CipherSuite, KdfId, KemId } from "hpke-js";

Deno

For Deno, it is recommended to use the jsr.io registry.

deno add jsr:@hpke/hpke-js

Web Browsers

Followings are how to use the module with typical CDNs. Other CDNs can be used as well.

Using esm.sh:

<!-- use a specific version -->
<script type="module">
  import {
    AeadId,
    CipherSuite,
    KdfId,
    KemId,
  } from "https://esm.sh/hpke-js@<SEMVER>";
  // import * as hpke from "https://esm.sh/@hpke/core@<SEMVER>";
  // ...
</script>

<!-- use the latest stable version -->
<script type="module">
  import {
    AeadId,
    CipherSuite,
    KdfId,
    KemId,
  } from "https://esm.sh/hpke-js";
  // import * as hpke from "https://esm.sh/@hpke/core";
  // ...
</script>

Using unpkg:

<!-- use a specific version -->
<script type="module">
  import {
    AeadId,
    CipherSuite,
    KdfId,
    KemId,
  } from "https://unpkg.com/hpke-js@<SEMVER>/esm/mod.js";
  // import * as hpke from "https://unpkg.com/@hpke/core@<SEMVER>/esm/mod.js";
  // ...
</script>

Usage

This section shows some typical usage examples.

Node.js

import { AeadId, CipherSuite, KdfId, KemId } from "hpke-js";

async function doHpke() {
  const suite = new CipherSuite({
    kem: KemId.DhkemX25519HkdfSha256,
    kdf: KdfId.HkdfSha256,
    aead: AeadId.Chacha20Poly1305,
  });

  // A recipient generates a key pair.
  const rkp = await suite.kem.generateKeyPair();

  // A sender encrypts a message with the recipient public key.
  const sender = await suite.createSenderContext({
    recipientPublicKey: rkp.publicKey,
  });
  const ct = await sender.seal(new TextEncoder().encode("Hello world!"));

  // The recipient decrypts it.
  const recipient = await suite.createRecipientContext({
    recipientKey: rkp.privateKey,
    enc: sender.enc,
  });
  const pt = await recipient.open(ct);

  // Hello world!
  console.log("decrypted: ", new TextDecoder().decode(pt));
}

try {
  doHpke();
} catch (e) {
  console.log("failed:", e.message);
}

Deno

import { AeadId, CipherSuite, KdfId, KemId } from "@hpke/hpke-js";

async function doHpke() {
  const suite = new CipherSuite({
    kem: KemId.DhkemX25519HkdfSha256,
    kdf: KdfId.HkdfSha256,
    aead: AeadId.Chacha20Poly1305,
  });

  const rkp = await suite.kem.generateKeyPair();

  const sender = await suite.createSenderContext({
    recipientPublicKey: rkp.publicKey,
  });

  // encrypt
  const ct = await sender.seal(new TextEncoder().encode("Hello world!"));

  const recipient = await suite.createRecipientContext({
    recipientKey: rkp.privateKey,
    enc: sender.enc,
  });

  // decrypt
  const pt = await recipient.open(ct);

  // Hello world!
  console.log(new TextDecoder().decode(pt));
}

try {
  doHpke();
} catch (_err: unknown) {
  console.log("failed.");
}

Web Browsers

<html>
  <head></head>
  <body>
    <script type="module">
      import {
        AeadId,
        CipherSuite,
        KdfId,
        KemId,
      } from "https://esm.sh/hpke-js";

      globalThis.doHpke = async () => {
        try {
          const suite = new CipherSuite({
            kem: KemId.DhkemP256HkdfSha256,
            kdf: KdfId.HkdfSha256,
            aead: AeadId.Aes128Gcm,
          });

          const rkp = await suite.kem.generateKeyPair();

          const sender = await suite.createSenderContext({
            recipientPublicKey: rkp.publicKey,
          });

          // encrypt
          const ct = await sender.seal(
            new TextEncoder().encode("Hello world!"),
          );

          const recipient = await suite.createRecipientContext({
            recipientKey: rkp.privateKey, // rkp (CryptoKeyPair) is also acceptable.
            enc: sender.enc,
          });

          // decrypt
          const pt = await recipient.open(ct);

          // Hello world!
          alert(new TextDecoder().decode(pt));
        } catch (err) {
          alert("failed:", err.message);
        }
      };
    </script>
    <button type="button" onclick="doHpke()">do HPKE</button>
  </body>
</html>

Contributing

We welcome all kind of contributions, filing issues, suggesting new features or sending PRs.

changelog

Changes

Version 1.6.1

Released 2024-11-05

Version 1.6.0

Released 2024-11-04

Version 1.5.0

Released 2024-10-12

Version 1.4.3

Released 2024-10-07

Version 1.4.2

Released 2024-10-06

Version 1.4.1

Reverted to 1.3.1 2024-10-06

Version 1.4.0

Released 2024-10-06

Version 1.3.1

Released 2024-09-01

Version 1.3.0

Released 2024-08-31

Version 1.2.9

Released 2024-08-05

Version 1.2.8

Released 2024-08-04

Version 1.2.7

Released 2024-01-28

Version 1.2.6

Released 2024-01-28

Version 1.2.5

Released 2023-11-26

Version 1.2.4

Released 2023-11-05

Version 1.2.3

Released 2023-09-09

Version 1.2.2

Released 2023-08-20

Version 1.2.1

Released 2023-08-19

Version 1.2.0

Released 2023-08-16

Version 1.1.1

Released 2023-08-15

Version 1.1.0

Released 2023-08-15

Version 1.0.4

Released 2023-08-11

Version 1.0.3

Released 2023-08-07

Version 1.0.2

Released 2023-08-06

Version 1.0.1

Released 2023-08-06

Version 1.0.0

Released 2023-08-05

Version 0.22.2

Released 2023-07-28

Version 0.22.1

Released 2023-07-28

Version 0.22.0

Released 2023-07-27

Version 0.21.0

Released 2023-07-25

Version 0.20.0

Released 2023-07-19

Version 0.19.0

Released 2023-07-17

Version 0.18.5

Released 2023-06-13

Version 0.18.4

Released 2023-06-13

Version 0.18.3

Released 2023-04-08

Version 0.18.2

Released 2023-01-17

Version 0.18.1

Released 2023-01-17

Version 0.18.0

Released 2023-01-16

Version 0.17.2

Released 2023-01-16

Version 0.17.1

Released 2023-01-05

Version 0.17.0

Released 2023-01-05

Version 0.16.0

Released 2023-01-04

Version 0.15.0

Released 2022-11-06

Version 0.14.0

Released 2022-10-28

Version 0.13.0

Released 2022-07-01

Version 0.12.1

Released 2022-07-01

Version 0.12.0

Released 2022-06-26

Version 0.11.5

Released 2022-06-18

Version 0.11.4

Released 2022-06-11

Version 0.11.3

Released 2022-06-09

Version 0.11.2

Released 2022-06-07

Version 0.11.1

Released 2022-06-06

Version 0.11.0

Released 2022-06-06

Version 0.10.2

Released 2022-06-05

Version 0.10.1

Released 2022-06-05

Version 0.10.0

Released 2022-06-05

Version 0.9.1

Released 2022-05-29

Version 0.9.0

Released 2022-05-28

Version 0.8.0

Released 2022-05-24

Version 0.7.1

Released 2022-05-22

Version 0.7.0

Released 2022-05-21

Version 0.6.0

Released 2022-05-21

Version 0.5.1

Released 2022-05-16

Version 0.5.0

Released 2022-05-15

Version 0.4.1

Released 2022-05-12

Version 0.4.0

Released 2022-05-10

Version 0.3.1

Released 2022-05-08

Version 0.3.0

Released 2022-05-08

Version 0.2.4

Released 2022-05-07

Version 0.2.3

Released 2022-05-07

Version 0.2.2

Released 2022-05-06

  • Fix bug on using Web Crypto API on Node.js environment.

Version 0.2.1

Released 2022-05-06

  • Add support for Node.js environment.

Version 0.2.0

Released 2022-05-06

  • First public preview release.