Skip to content

Releases: ElementsProject/libwally-core

Release 1.5.1

22 Aug 04:40
release_1.5.1
a445157

Choose a tag to compare

Version 1.5.1

Added

  • python: Add wheels for Python 3.13, remove support for Python 3.8.

Fixed

  • python: Fix source builds for newer pip versions.
  • java: Fix tx_get_input_signature_hash to allow passing a null cache to disable caching.

Release 1.5.0

31 Jul 16:42
release_1.5.0
a90aa3c

Choose a tag to compare

Version 1.5.0

Added

  • psbt: add psbt_get_input_signature_type to get the type of signature required by an input.
  • descriptor: Add support for Elements el-prefixed descriptor builtins as used in rust-elements.
  • descriptor: Add support for parsing Elements ct descriptors with slip77(), elip150() and raw hex blinding keys.
  • descriptor: Add support for generating Elements confidential addresses from ct descriptors.
  • descriptor: Expose functions to perform ELIP-150 blinding key tweaking.
  • crypto: Add ec_public_key_tweak to tweak standard (non-xonly) pubkeys.
  • elements: Add asset_blinding_key_to_ec_public_key to compute the blinding pubkey from a blinding key.

Changed

  • psbt: Speed up p2tr signing slightly.
  • descriptor: Allow U type children for thresh() expressions.
  • build: Further extend CI coverage for scan-build/valgrind/asan checks.

Fixed

  • tx: Fix taproot cached hashing when using external sha256 implementations.
  • wasm: Fixes for es6 and cjs.
  • address_to_scriptpubkey: Correctly handle WALLY_NETWORK_BITCOIN_REGTEST.
  • amalgamation: Support all supported standard configurations. Minor improvements to make usage easier/more robust.
  • Various minor code and build fixes.

Version 1.4.0

11 Mar 19:13
release_1.4.0
12f5ac4

Choose a tag to compare

Version 1.4.0

Added

  • tx: Add caching to signature hash generation/PSBT signing making signing faster.
  • tx: Add support for generating Elements taproot signature hashes and signing Elements taproot inputs.
  • descriptor: Add support for "tr()/rawtr()" keyspend-only taproot descriptors.
  • descriptor: Add support for parsing Elements-core compatible descriptors, including taproot.
  • psbt: Add accessors for keypath/taproot related fields.
  • pset: Add support for ELIP-101 genesis hash.
  • psbt: Add support for serializing/parsing/combining signature-only PSBTs.
  • script: Add support for generating Elements p2tr scripts.
  • BIP85: Add support for deriving RSA keys via BIP85.
  • base64/psbt: Add support for parsing from known length (non-NUL terminated) strings.
  • build: Add Debian Bookworm docker build image.

Changed

  • tx: Re-implement signature hash generation to use less stack space and CPU independently of caching.
  • amalgamation: Provide the amalgamated build as a single source file, make it simpler to use.
  • build: CI improvements: New valgrind, scan-build and ubsan/addrcheck/etc builds. Add CI/test runs
    for builds with elements support disabled and minimal (embedded) builds.
  • build: Update/extend tests to make it easier to catch errors in the new CI builds.

Fixed

  • psbt: Fix detection of expired CSV inputs for v0 PSBTs.
  • psbt: Fix finalization of non-optimized CSV inputs (e.g. Green Liquid 2of2).
  • tx: Fix incorrect sighash masking for BTC taproot inputs.
  • build: Various fixes and test improvements for non-Elements builds.
  • Various minor code and build fixes.

Release 1.3.1

26 Sep 11:53
release_1.3.1
e04e8b3

Choose a tag to compare

Version 1.3.1

Added

  • Elements: Add wally_tx_get_elements_weight_discount for computing ELIP-0200 weight discounts.

Changed

  • Update JS dependencies.

Fixed

  • Minor build/CI fixes.

Release 1.3.0

20 Jul 22:02
release_1.3.0
11e1bf6

Choose a tag to compare

Version 1.3.0

Added

  • script: Add support for fetching the CSV block count for Green CSV scripts.
  • psbt_finalize: Add support for finalizing Green CSV inputs.

Changed

  • PSBT: Do not serialize witness data for input non-witness UTXOs, in order to match the current behaviour of Bitcoin core.
  • Java: Bump source version from 1.7 to 1.8 as 1.7 is no longer supported.

Fixed

  • psbt_sign_bip32: Fix signing with parent/master keys. Only already-derived keys would result in signed inputs previously.
  • PSET: Allow signing pre-segwit inputs.
  • PSET: Allow generating explicit proofs for inputs with only a non-witness UTXO.
  • wally_scriptpubkey_get_type: Mark all scripts starting with OP_RETURN as WALLY_SCRIPT_TYPE_OP_RETURN.
  • bip32: Fix/generalize Elements pubkey tweaking
  • Tx: Allow arbitrarily large transactions when constructing from hex/bytes.
  • Build: cmake fixes

Release 1.2.0

09 Feb 06:56
release_1.2.0
1e71763

Choose a tag to compare

Version 1.2.0

Added

  • Python: Add Python 3.12 wheels to the binary releases/PyPI.
  • tx: expose wally_tx_input_clone/wally_tx_input_clone_alloc for input cloning.
  • Build: Add new static analysis CI runs.

Changed

  • Javascript: The npm build now uses nodejs 20, as nodejs 16 is end-of-life.
  • Android: Update android NDK to version 26b.
  • libsecp256k1-zkp: The library has been updated to include the latest
    changes to its cmake infrastructure.
  • cmake: Now takes advantage of the new libsecp256k1-zkp cmake files to build
    experimental modules and export the project in cmake style. cmake now also
    builds test and collects coverage data.

Fixed

  • Build: Don't use which on Debian as it is now deprecated.
  • Various bug fixes from static analysis.
  • Various build and documentation fixes.

Release 1.1.0

28 Jan 21:42
release_1.1.0
4d38a6d

Choose a tag to compare

Added

  • PSBT: Allow extracting partially finalized transactions in wally_psbt_extract by passing a new WALLY_PSBT_EXTRACT_OPT_FINAL flag.
  • tx: Allow getting the number of items in a transactions input witness via wally_tx_input_get_witness_num_items / wally_tx_get_input_witness_num_items.

Fixed

  • tx: tx_input_get_witness now correctly returns 0 bytes written if passed a NULL input.

Release 1.0.0

20 Nov 09:31
release_1.0.0
6f67467

Choose a tag to compare

This release contains ABI changes; it is not ABI compatible with prior versions.

Added

  • The library version number is now available as compile time constants (WALLY_MAJOR_VER, WALLY_MINOR_VER, WALLY_PATCH_VER, WALLY_BUILD_VER), and at runtime via wally_get_build_version.
  • Added support for wallet policies (bitcoin/bips#1389).
  • Added support for iterating and querying keys in descriptor/policy expressions, including support for key origin information such as fingerprint and path.
  • The library allocation functions (which may be overridden by the caller at runtime) are now exposed as wally_[malloc|calloc|free|strdup|strdump_n]. Libraries using wally that wish to respect the callers allocation strategy can use these to avoid having to expose their own customizable allocator.
  • Added support for encrypted request/response protocols using ephemeral keys via wally_aes_cbc_with_ecdh_key.
  • The PyPI wheel uploads now include an sdist source distribution, allowing install on otherwise-unsupported architectures.

Changed

  • The library now follows semantic versioning as per https://semver.org/.
  • Elements support is now enabled by default, reflecting the common library usage. Please see the configure --help entries for --disable-elements and --disable-elements-abi for details.
  • The ABI of the library is now consistent by default regardless of whether it is built with or without Elements support.
  • The constant EC_SIGNATURE_DER_MAX_LOW_R_LEN has been changed from 71 to 70, to reflect that wally always produced low-R, low-S signatures when grinding.
  • When configured to build as a static library, linking to libwallycore.a requires additionally linking to libsecp256k1.a.
  • Wally can now be configured to build against a system-wide libsecp256k1 by passing --with-system-secp256k1 to configure.
  • The Python wheel can now be built with standard Python tooling such as build, and can be built from an uploaded source distribution.
  • The Python wheel can now be built with dynamic linking to libwallycore and libsecp256k1-zkp/libsecp256k1.
  • libsecp256k1-zkp has been updated to the latest master version as at the time of release.
  • Some functions in the c++ header wally.hpp have changed interface slightly. Note that this header is deprecated and will be replaced in an upcoming release with higher level wrappers in the same manner as Python and JS.
  • The docker-based builds have been streamlined and simplified. NPM builds in particular are now much faster.

Fixed

  • Fixed a bug affecting signing PSBT taproot inputs.
  • Fixed extern libsecp256k1-zkp linkage for windows static builds.
  • Several build fixes/improvements and CI updates have been made.

Release 0.9.2

30 Aug 11:20
release_0.9.2
00230f6

Choose a tag to compare

This is the last planned release before wally moves to semantic versioning and a consistent ABI for elements/non-elements builds with release 1.0.0. Upgrading is recommended for all users.

  • Fixes for huge transactions and PSBT/PSET files
  • Fix external linkage for BIP85 functions
  • Add missing psbt_is_input_finalized function
  • Build and packaging fixes

Release 0.9.1

02 Aug 00:55
release_0.9.1
3d2f0d4

Choose a tag to compare

Note: This release contains minor ABI changes, please see CHANGES.md for details.

  • Fix a bug with incorrect nonce commitments when mapping Elements transaction outputs to PSET
  • Avoid potential resource exhaustion for platforms with odd malloc semantics when provided with malicious input
  • Add support for descriptors containing built-in wrappers with constant arguments and empty descriptors via raw()
  • Add various PSBT/transaction/witness stack helper functions
  • Improve the reliability of clearing memory on all platforms
  • Remove end of life Python 3.6/3.7 support, add support for 3.11
  • Add musl/x64 Python wheels to the release (e.g. Alpine Linux)
  • Documentation updates, various minor build and bug fixes