Skip to content

Releases: paulmillr/noble-ed25519

2.2.3

07 Jan 21:41
2.2.3
a2d9484
Compare
Choose a tag to compare

Revert requirement for crypto.subtle, introduced in 2.2.0. This ensures synchronous environments work correctly without it. Closes #108.

Full Changelog: 2.2.2...2.2.3

2.2.2

02 Jan 19:24
2.2.2
3506e40
Compare
Choose a tag to compare
  • Improve documentation for public methods. This ensures efficient auto-generated docs on JSR.

Full Changelog: 2.2.1...2.2.2

2.2.1

02 Jan 01:35
2.2.1
d7ec803
Compare
Choose a tag to compare

Same as 2.2.0, but now publishing to JSR without slow-types option.

Full Changelog: 2.2.0...2.2.1

2.2.0

02 Jan 01:33
2.2.0
b2ab7fc
Compare
Choose a tag to compare

What's Changed

  • Improve hex and bytes conversion
  • Improve types: use isolatedDeclarations option

New Contributors

Full Changelog: 2.1.0...2.2.0

2.1.0

24 Mar 11:09
2.1.0
90058fe
Compare
Choose a tag to compare

This release comes one year after v2.0.0, following rare update schedule for easy auditability.

  • verify: accept { zip215: false } option that forces FIPS verification behavior
  • verify: throw less direct errors, return false instead
  • Point.fromHex: accept second optional argument zip215: boolean
  • Point#toAffine: convert ZERO points properly
  • au8: improve Uint8Array check to work in extension context
  • signAsync: Prohibit passing objects, which were incorrectly mangled to Uint8Array
    • This could have produced incorrect signatures for object-based messages

New Contributors

Full Changelog: 2.0.0...2.1.0

2.0.0

24 Mar 10:03
2.0.0
12137de
Compare
Choose a tag to compare

v2 features improved security and smaller attack surface.
The goal of v2 is to provide minimum possible JS library which is safe and fast.

That means the library was reduced 4x, to just over 300 lines. Library size is now less than 4KB.
In order to achieve the goal, some features were moved to noble-curves,
which is even safer and faster drop-in replacement library with same API.
Switch to curves if you intend to keep using these features:

  • x25519 / curve25519 / getSharedSecret
  • ristretto255 / RistrettoPoint
  • Using utils.precompute() for non-base point
  • Support for environments which don't support bigint literals
  • Common.js support
  • Support for node.js 18 and older without shim

Other changes for upgrading from @noble/ed25519 1.7 to 2.0:

  • Methods are now sync by default; use getPublicKeyAsync, signAsync, verifyAsync for async versions
  • bigint is no longer allowed in getPublicKey, sign, verify. Reason: ed25519 is LE, can lead to bugs
  • Point (2d xy) has been changed to ExtendedPoint (xyzt)
  • Signature was removed: just use raw bytes or hex now
  • utils were split into utils (same api as in noble-curves) and
    etc (sha512Sync and others)

Pull request: #76

Full Changelog: 1.7.3...2.0.0

1.7.3

07 Feb 10:02
1.7.3
7e4f9da
Compare
Choose a tag to compare

Don't use bigint literals for bad engines

1.7.2

04 Feb 08:52
1.7.2
9fb2bf2
Compare
Choose a tag to compare
  • Fix isTorsionFree bug
  • Improve constant-timeness

Full Changelog: 1.7.1...1.7.2

1.7.1

11 Sep 16:41
1.7.1
c0b1120
Compare
Choose a tag to compare

The library now works with React Native 0.70. Remove all bigint ** pow operators to improve compact w bad parsers.

Full Changelog: 1.7.0...1.7.1

1.7.0

26 Aug 03:20
1.7.0
13fdc78
Compare
Choose a tag to compare

Add synchronous methods.

import { sha512 } from '@noble/hashes/sha512';
ed.utils.sha512Sync = (...m) => sha512(ed.utils.concatBytes(...m));
const { getPublicKey, sign, verify, getExtendedPublicKey } = ed.sync;
getPublicKey(privKey);

Full Changelog: 1.6.1...1.7.0