๐Ÿ“ฆ ljharb / side-channel

Store information about any JS value in a side channel. Uses WeakMap if available.

โ˜… 18 stars โ‘‚ 10 forks ๐Ÿ‘ 18 watching โš–๏ธ MIT License
๐Ÿ“ฅ Clone https://github.com/ljharb/side-channel.git
HTTPS git clone https://github.com/ljharb/side-channel.git
SSH git clone git@github.com:ljharb/side-channel.git
CLI gh repo clone ljharb/side-channel
Jordan Harband Jordan Harband [readme] replace runkit CI badge with shields.io check-runs badge 7e0c956 7 days ago ๐Ÿ“ History
๐Ÿ“‚ main View all commits โ†’
๐Ÿ“ .github
๐Ÿ“ test
๐Ÿ“„ .editorconfig
๐Ÿ“„ .eslintrc
๐Ÿ“„ .gitignore
๐Ÿ“„ .npmrc
๐Ÿ“„ .nycrc
๐Ÿ“„ CHANGELOG.md
๐Ÿ“„ index.d.ts
๐Ÿ“„ index.js
๐Ÿ“„ LICENSE
๐Ÿ“„ package.json
๐Ÿ“„ README.md
๐Ÿ“„ tsconfig.json
๐Ÿ“„ README.md

side-channel Version Badge

github actions coverage License Downloads

npm badge

Store information about any JS value in a side channel. Uses WeakMap if available.

Warning: in an environment that lacks WeakMap, this implementation will leak memory until you delete the key.

Getting started

npm install --save side-channel

Usage/Examples

const assert = require('assert');
const getSideChannel = require('side-channel');

const channel = getSideChannel();

const key = {};
assert.equal(channel.has(key), false);
assert.throws(() => channel.assert(key), TypeError);

channel.set(key, 42);

channel.assert(key); // does not throw
assert.equal(channel.has(key), true);
assert.equal(channel.get(key), 42);

channel.delete(key);
assert.equal(channel.has(key), false);
assert.throws(() => channel.assert(key), TypeError);

Tests

Clone the repo, npm install, and run npm test