Changelog
[Unreleased]
Added
- dev: Goose recipes for changelog and commit message generation with Just commands (thesimplekid).
 
- cashu: 
KeySetInfos type alias and KeySetInfosMethods trait for filtering keysets (thesimplekid). 
- cdk: Mint lifecycle management with 
start() and stop() methods for graceful background service control (thesimplekid). 
- cdk: Background task management for invoice payment monitoring with proper shutdown handling (thesimplekid).
 
- cashu: NUT-19 support in the wallet (crodas).
 
- cdk: SIG_ALL support for swap and melt operations (thesimplekid).
 
- cdk-sql-common: Add cache to SQL statements for better performance (crodas).
 
Changed
- cdk: Refactored wallet keyset management methods for better clarity and separation of concerns (thesimplekid).
 
- cdk: Renamed 
get_keyset_keys to fetch_keyset_keys to indicate network operation (thesimplekid). 
- cdk: Renamed 
get_active_mint_keyset to fetch_active_keyset for consistency (thesimplekid). 
- cdk: Updated 
get_active_mint_keysets to refresh_keysets with improved keyset refresh logic (thesimplekid). 
- cdk: Improved 
load_mint_keysets method to be the primary method for getting keysets for token operations (thesimplekid). 
- cdk: Enhanced keyset management with better offline/online operation separation (thesimplekid).
 
- cdk: Updated method documentation to clarify storage vs network operations (thesimplekid).
 
- cdk: Refactored invoice payment monitoring to use centralized lifecycle management instead of manual task spawning (thesimplekid).
 
- cdk-mintd: Updated to use new mint lifecycle methods for improved service management (thesimplekid).
 
- cdk-integration-tests: Updated test utilities to use new mint lifecycle management (thesimplekid).
 
- cdk-sqlite: Introduce 
cdk-sql-common crate for shared SQL storage codebase (crodas). 
- cdk-sqlite: Rename 
still_active to stale for better clarity (crodas). 
Fixed
- cashu: Fixed CurrencyUnit custom units preserving original case instead of being converted to uppercase (thesimplekid).
 
- cdk-sqlite: Fix 
get_mint_quote_by_request_lookup_id function synchronization (crodas). 
- cdk-common: Fix TransactionId::from_hex to check bytes length before copy to avoid panic (codingpeanut157).
 
- cdk: Include change in melt quote state updates (thesimplekid).
 
Migration
- cdk-sql-common: Improve migrations with namespaced and global migrations support (crodas).
 
Summary
Version 0.11.0 brings significant architectural changes to enhance database reliability and performance. The major changes include:
Database Engine Change: Replaced sqlx with rusqlite as the SQLite database driver and removed support for redb. This change provides better performance and reliability for database operations.
 
Transaction Management: Introduced robust database transaction support that encapsulates all database changes. The new Transaction trait implements a rollback operation on Drop unless explicitly committed, ensuring data integrity.
 
Race Condition Prevention: Added READ-and-lock operations to securely read and lock records from the database for exclusive access, preventing race conditions in concurrent operations.
 
⚠️ Important Migration Note for redb Users
If you are currently running a mint with redb, you must migrate to SQLite before upgrading to v0.11. Follow these steps:
- Stop your current mint
 
- Back up your database
 
- Use the migration script available at: https://github.com/cashubtc/cdk/blob/main/misc/convert_redb_to_sqlite.sh
 
- Update your config file to target the SQLite database engine
 
- Start your mint with v0.11
 
Added
Changed
- cdk-sqlite: remove sqlx in favor of rusqlite (crodas).
 
- cdk-lnd: use custom tonic gRPC instead of fedimint-tonic-grpc PR (thesimplekid).
 
- cdk-cln: remove the us of mutex on cln client PR (thesimplekid).
 
Fixed
- mint start up check was not checking unpaid quotes PR (gudnuf).
 
- Naming of blinded_message column on blind_signatures was y PR (thesimplekid).
 
- cdk-cli: Create wallets for non sat units if supported PR (thesimplekid).
 
Removed
Fix
Added
Changed
Changed
- Melt will perform swap before attempting to melt if exact amount is not available PR (crodas).
 
Fixed
- Handle old nut15 format to keep compatibility with older nutshell version PR (thesimplekid).
 
Added
Changed
- Refactored Lightning module to use common types PR (thesimplekid).
 
- Updated LND to support mission control and improved requery behavior PR (lollerfirst).
 
Fixed
Fixed
- Remove URLs in gRPC management interface (thesimplekid).
 
- Only count signatures from unique pubkeys (thesimplekid).
 
- Race conditions with proof state updates (crodas).
 
- Debug print of Info struct (thesimplekid).
 
- Correct mnemonic hashing in Debug implementation (thesimplekid).
 
Changed
Added
Changed
Fixed
- Creation of memory sqlite db PR (crodas).
 
- cdk-cli: Ensure auth wallet is created before attempting to mint pending PR (thesimplekid).
 
- cdk-mint-rpc: Adding mint urls was not updating correctly PR (thesimplekid).
 
- cdk-mint-rpc: Fixed setting long description PR (thesimplekid).
 
Fixed
Changed
Fixed
- cdk: Proof matches conditions was not matching payment conditions correctly (thesimplekid).
 
- cdk: Updating mint_url would remove proofs when we want to keep them (ok300).
 
- Wallet: Fix ability to receive cashu tokens that include DLEQ proofs (ok300).
 
- cdk-sqlite: Wallet was not storing dleq proofs (thesimplekid).
 
Changed
- Updated MSRV to 1.75.0 (thesimplekid).
 
- cdk-sqlite: Do not use 
UPDATE OR REPLACE (crodas). 
- cdk: Refactor keyset init (lollerfirst).
 
- Feature-gated lightning backends (CLN, LND, LNbits, FakeWallet) for selective compilation (thesimplekid).
 
- cdk-sqlite: Update sqlx to 0.7.4 (benthecarman).
 
- Unifies and optimizes the proof selection algorithm to use Wallet::select_proofs (davidcaseria).
 
- Wallet::send now requires a PreparedSend (davidcaseria).
 
- WalletDatabase proof state update functions have been consolidated into update_proofs_state (davidcaseria).
 
- Moved 
MintQuote and MeltQuote from cashu to cdk-common (thesimplekid). 
Added
Removed
- Remove support for Memory Database in cdk (crodas).
 
- Remove 
AmountStr (crodas). 
- Remove 
get_nostr_last_checked from WalletDatabase (thesimplekid). 
- Remove 
add_nostr_last_checked from WalletDatabase (thesimplekid). 
Changed
Fixed
Fixed
- cdk-mintd: Fixed mint and melt error on mint initialized with RPC interface disabled (ok300).
 
Changed
- cdk: Debug print of 
Id is hex (thesimplekid). 
- cdk: Debug print of mint secret is the hash (thesimplekid).
 
- cdk: Use check_incoming payment on attempted mint or check mint quote (thesimplekid).
 
- cdk-cln: Use 
call_typed for cln rpc calls (daywalker90). 
Added
- cdk: Mint builder add ability to set custom derivation paths (thesimplekid).
 
Fixed
Changed
- Moved db traits to 
cdk-common (crodas). 
- Moved other common types to 
cdk-common (crodas). 
Wallet::mint returns the minted Proofs and not just the amount (davidcaseria). 
Added
Token::to_raw_bytes serializes generic token to raw bytes (lollerfirst). 
Token::try_from for Vec<u8> constructs a generic token from raw bytes (lollerfirst). 
TokenV4::to_raw_bytes() serializes a TokenV4 to raw bytes following the spec (lollerfirst). 
Wallet::receive_raw which receives raw binary tokens (lollerfirst). 
- cdk-mint-rpc: Mint management gRPC client and server (thesimplekid).
 
- cdk-common: cdk specific types and traits (crodas).
 
- cashu: Core types and functions defined in NUTs (crodas).
 
Fixed
- Multimint unit check when wallet receiving token (thesimplekid).
 
- Mint start up with most recent keyset after a rotation (thesimplekid).
 
Fixed
- cdk: Missing check on mint that outputs equals the quote amount (thesimplekid).
 
- cdk: Reset mint quote status if in state that cannot continue (thesimplekid).
 
Added
Changed
- cdk: Enforce 
quote_id to uuid type in mint (tdelabro). 
- cdk: Refactor wallet mint connector (ok300).
 
Added
- cdk: 
NUT19 Settings in NUT06 info (thesimplekid). 
- cdk: 
NUT17 Websocket support for wallet (crodas). 
- cdk-axum: Redis cache backend (crodas).
 
- cdk-mints: Get mint settings from env vars (thesimplekid).
 
- cdk-axum: HTTP compression support (ok300).
 
Fixed
- cdk-sqlite: Keyset counter was overwritten when keyset was fetched from mint (thesimplekid).
 
- cdk-cli: On 
mint use unit from cli args (thesimplekid). 
- cdk-cli: On 
restore create wallet if it does not exist (thesimplekid). 
- cdk: Signaling support for optional nuts (thesimplekid).
 
- cdk-phd: Check payment has valid uuid (thesimplekid).
 
Changed
- cdk: Bump 
bitcoin to 0.32.2 (prusnak). 
- cdk: Bump 
lightning-invoice to 0.32.2 (prusnak). 
- cdk: Bump 
lightning to 0.0.124 (prusnak). 
- cdk: 
PaymentMethod as a non_exhaustive enum (thesimplekid). 
- cdk: 
CurrencyUnit as a non_exhaustive enum (thesimplekid). 
- cdk: Enforce token is single mint (thesimplekid).
 
- cdk: Mint will return change for over paid melt even over fee reserve (davidcaseria).
 
- cdk: Refactor ln_backeds to be on the 
cdk::Mint and not with axum (thesimplekid). 
- cdk: Change is returned in the check quote response (thesimplekid).
 
- cdk: Move unit conversion util fn to amount module (davidcaseria).
 
- cdk: Remove spent proofs from db when check state is called (mubarak23).
 
- cdk: Use 
MintUrl directly in wallet client (ok300). 
- cdk-cli: Change cdk-cli pay command to melt (mubarak23).
 
- cdk: Rename 
Wallet::get_proofs to Wallet::get_unspent_proofs (ok300). 
- cdk: 
Id to u32 changed from TryFrom to From (vnprc). 
Added
- cdk: Added description to 
MintQuoteBolt11Request (lollerfirst). 
- cdk(wallet): Added description to 
mint_quote (lollerfirst). 
- cdk: Add 
amount and fee_paid to Melted (davidcaseria). 
- cdk: Add 
from_proofs on Melted (davidcaseria). 
- cdk: Add unit on 
PaymentResponse (thesimplekid). 
- cdk: Add description for mint quote (lollerfirst).
 
- cdk-axum: Add cache to some endpoints (lollerfirst).
 
- cdk: Add Proofs trait (ok300).
 
- cdk: Wallet verifies keyset id when first fetching keys (thesimplekid).
 
- cdk-mintd: Add swagger docs (ok300).
 
- cdk: NUT18 payment request support (thesimplekid).
 
- cdk: Add 
Wallet::get_proofs_with (ok300). 
- cdk: Mint NUT-17 Websocket support (crodas).
 
Removed
Fixed
- cdk: Check of inputs to include fee (thesimplekid).
 
- cdk: Make unit mandatory in tokenv4 (ok300).
 
Changed
Added
Fixed
- cdk(mint): Use checked addition on amount to ensure there is no overflow (thesimplekid).
 
Removed
Changed
- cdk(wallet): 
fn send returns Token so the user can use the struct of convert it to a v3 or v4 string (thesimplekid). 
- cdk(wallet): Publicly export 
MultiMintWallet (thesimplekid). 
- cdk(cdk-database/mint): Get 
pending and spent proofs by ys or secrets instead of a single proofs (thesimplekid). 
- cdk(cdk-database/mint): Change 
add_blind_signature to add_blind_signatures (thesimplekid). 
- cdk(cdk-database/mint): Rename 
add_active_keyset to set_active_keyset (thesimplekid). 
- cdk(cdk-database/wallet): Change 
get_proofs to return Vec<ProofInfo> instead of Option<Vec<ProofInfo>> (thesimplekid). 
- cdk-cli: Receive will add wallet when receiving if mint is unknown (thesimplekid).
 
- cdk(cdk-database/mint): Rename 
get_blinded_signatures to get_blind_signatures (thesimplekid). 
- cdk(cdk-database/mint): Rename 
get_blinded_signatures_for_keyset to get_blind_signatures_for_keyset (thesimplekid). 
- cdk(mint): Typo rename 
total_redeame to total_redeemed (vnprc). 
- cdk(mint): Refactored 
MintKeySet::generate_from_xpriv and MintKeySet::generate_from_seed methods to accept max_order, currency_unit, and derivation_path parameters directly (vnprc). 
- cdk(wallet): Return WalletKey for UnknownWallet error (davidcaseria).
 
- cdk(cdk-lightning): 
CreateInvoiceResponse added expiry time to better support backends where it cannot be set (thesimplekid). 
- cdk(cdk-lightning): Use 
Amount type instead of u64 (thesimplekid). 
- cdk(cdk-lightning): 
CreateInvoice requires unit argument (thesimplekid). 
- cdk(cdk/multi_mint_wallet): 
get_balances returns a BTreeMap instead of HashMap (thesimplekid). 
Added
- cdk(NUT-11): Add 
Copy on SigFlag (thesimplekid). 
- cdk(wallet): Add 
fn send_proofs that marks proofs as reserved and creates token (thesimplekid). 
- cdk(wallet): Add 
fn melt_proofs that uses specific proofs for melt instead of selecting (thesimplekid). 
- cdk-cli(receive): Add support for signing keys to be nostr nsec encoded (thesimplekid).
 
- cdk-fake-wallet: Add Fake wallet for testing (thesimplekid).
 
- cdk(cdk-database/mint): Add 
add_proofs, get_proofs_by_ys, get_proofs_states, and update_proofs_states (thesimplekid). 
- cdk(cdk-database/mint): Add 
get_blinded_signatures_for_keyset to get all blind signatures for a keyset_id (thesimplekid). 
- cdk(mint): Add 
total_issued and total_redeamed (thesimplekid). 
- cdk(cdk-database/mint) Add 
get_proofs_by_keyset_id (thesimplekid). 
- cdk(wallet/mint): Add 
mint_icon_url (cjbeery24). 
- cdk: Add 
MintUrl that sanitizes mint url by removing trailing / (cjbeery24). 
- cdk(cdk-database/mint): Add 
update_proofs that both adds new ProofInfos to the db and deletes (davidcaseria). 
- cdk(cdk-database/mint): Add 
set_pending_proofs, reserve_proofs, and set_unspent_proofs (davidcaseria). 
Fixed
- cdk(mint): 
SIG_ALL is not allowed in melt (thesimplekid). 
- cdk(mint): On 
swap verify correct number of sigs on outputs when SigAll (thesimplekid). 
- cdk(mint): Use amount in payment_quote response from ln backend (thesimplekid).
 
- cdk(mint): Create new keysets for added supported units (thesimplekid).
 
- cdk(mint): If there is an error in swap proofs should be reset to unspent (thesimplekid).
 
Removed
- cdk(wallet): Remove unused argument 
SplitTarget on melt (thesimplekid). 
- cdk(cdk-database/mint): Remove 
get_spent_proofs, get_spent_proofs_by_ys,get_pending_proofs, get_pending_proofs_by_ys, and remove_pending_proofs (thesimplekid). 
- cdk: Remove 
UncheckedUrl in favor of MintUrl (cjbeery24). 
- cdk(cdk-database/mint): Remove 
set_proof_state, remove_proofs and add_proofs (davidcaseria). 
Summary
This release introduces TokenV4, which uses CBOR encoding as the default token format. It also includes fee support for both wallet and mint operations.
When sending, the sender can choose to include the necessary fee to ensure that the receiver can redeem the full sent amount. If this is not done, the receiver will be responsible for the fee.
Additionally, this release introduces a Mint binary cdk-mintd that uses the cdk-axum crate as a web server to create a full Cashu mint. When paired with a Lightning backend, currently implemented as Core Lightning, it is included in this release as cdk-cln.
Changed
- cdk(wallet): 
wallet:receive will not claim proofs from a mint other than the wallet's mint (thesimplekid). 
- cdk(NUT00): 
Token is changed from a struct to enum of either TokenV4 or Tokenv3 (thesimplekid). 
- cdk(NUT00): Rename 
MintProofs to TokenV3Token (thesimplekid). 
- cdk(wallet): Additional arguments in 
send send_kind and include_fees for control of how to handle fees in a send (thesimplekid). 
- cdk(wallet): Additional arguments in 
create_swap include_fees for control of if fees to redeem the send proofs are included in send amount (thesimplekid). 
Added
Fixed
Changed
- cdk(wallet): 
wallet::total_pending_balance does not include reserved proofs (thesimplekid). 
Added