diff --git a/CHANGELOG.md b/CHANGELOG.md index 4abc1b9d33..608a1aab42 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,3 +1,34 @@ +## [4.0.0-beta.4](///compare/v4.0.0-beta.3...v4.0.0-beta.4) (2026-06-09) + + +### ⚠ BREAKING CHANGES + +* **platform-wallet:** add platform-wallet-storage crate (sqlite persister) (#3625) + +### Features + +* add IdentityCreateFromShieldedPool state transition (shielded-pool-funded identity creation) ([#3816](undefined/undefined/undefined/issues/3816)) +* **drive:** shielded fees for Shield/ShieldFromAssetLock + shield credit conservation ([#3793](undefined/undefined/undefined/issues/3793)) +* **platform-wallet:** add platform-wallet-storage crate (sqlite persister) ([#3625](undefined/undefined/undefined/issues/3625)) +* shielded scan-based spend detection and OVK outgoing-note history ([#3819](undefined/undefined/undefined/issues/3819)) +* **swift-sdk:** iOS simluator writes logs to disk ([#3785](undefined/undefined/undefined/issues/3785)) + + +### Bug Fixes + +* **dpp:** return error instead of panicking on storage-fee refund div-by-zero ([#3799](undefined/undefined/undefined/issues/3799)) +* **drive:** charge fees for unshield and shielded withdrawal ([#3800](undefined/undefined/undefined/issues/3800)) +* **drive:** correct fee/credit accounting on the address-funding asset-lock penalty path ([#3818](undefined/undefined/undefined/issues/3818)) +* **drive:** strict merged-query verification for unshield & shielded withdrawal proofs ([#3814](undefined/undefined/undefined/issues/3814)) +* **drive:** unify shielded pool genesis/upgrade construction to prevent state divergence ([#3801](undefined/undefined/undefined/issues/3801)) +* **platform-wallet:** zeroize private keys when freeing preview rows ([#3797](undefined/undefined/undefined/issues/3797)) +* **rs-sdk-ffi:** shrink signature allocation to len before leaking (capacity UB) ([#3798](undefined/undefined/undefined/issues/3798)) + + +### Miscellaneous Chores + +* tidy follow-ups from the shielded withdrawal fee review ([#3802](undefined/undefined/undefined/issues/3802)) + ## [4.0.0-beta.3](https://github.com/dashpay/platform/compare/v4.0.0-beta.2...v4.0.0-beta.3) (2026-06-04) diff --git a/Cargo.lock b/Cargo.lock index ca1c96561f..b172250b45 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -1038,7 +1038,7 @@ dependencies = [ [[package]] name = "check-features" -version = "4.0.0-beta.3" +version = "4.0.0-beta.4" dependencies = [ "toml 0.8.23", ] @@ -1505,7 +1505,7 @@ dependencies = [ [[package]] name = "dapi-grpc" -version = "4.0.0-beta.3" +version = "4.0.0-beta.4" dependencies = [ "dash-platform-macros", "futures-core", @@ -1592,7 +1592,7 @@ dependencies = [ [[package]] name = "dash-async" -version = "4.0.0-beta.3" +version = "4.0.0-beta.4" dependencies = [ "thiserror 2.0.18", "tokio", @@ -1601,7 +1601,7 @@ dependencies = [ [[package]] name = "dash-context-provider" -version = "4.0.0-beta.3" +version = "4.0.0-beta.4" dependencies = [ "dash-async", "dpp", @@ -1632,7 +1632,7 @@ dependencies = [ [[package]] name = "dash-platform-balance-checker" -version = "4.0.0-beta.3" +version = "4.0.0-beta.4" dependencies = [ "anyhow", "clap", @@ -1647,7 +1647,7 @@ dependencies = [ [[package]] name = "dash-platform-macros" -version = "4.0.0-beta.3" +version = "4.0.0-beta.4" dependencies = [ "heck 0.5.0", "quote", @@ -1656,7 +1656,7 @@ dependencies = [ [[package]] name = "dash-sdk" -version = "4.0.0-beta.3" +version = "4.0.0-beta.4" dependencies = [ "arc-swap", "assert_matches", @@ -1800,7 +1800,7 @@ dependencies = [ [[package]] name = "dashpay-contract" -version = "4.0.0-beta.3" +version = "4.0.0-beta.4" dependencies = [ "platform-value", "platform-version", @@ -1810,7 +1810,7 @@ dependencies = [ [[package]] name = "data-contracts" -version = "4.0.0-beta.3" +version = "4.0.0-beta.4" dependencies = [ "dashpay-contract", "dpns-contract", @@ -2004,7 +2004,7 @@ checksum = "1435fa1053d8b2fbbe9be7e97eca7f33d37b28409959813daefc1446a14247f1" [[package]] name = "dpns-contract" -version = "4.0.0-beta.3" +version = "4.0.0-beta.4" dependencies = [ "platform-value", "platform-version", @@ -2014,7 +2014,7 @@ dependencies = [ [[package]] name = "dpp" -version = "4.0.0-beta.3" +version = "4.0.0-beta.4" dependencies = [ "anyhow", "assert_matches", @@ -2072,7 +2072,7 @@ dependencies = [ [[package]] name = "dpp-json-convertible-derive" -version = "4.0.0-beta.3" +version = "4.0.0-beta.4" dependencies = [ "proc-macro2", "quote", @@ -2081,7 +2081,7 @@ dependencies = [ [[package]] name = "drive" -version = "4.0.0-beta.3" +version = "4.0.0-beta.4" dependencies = [ "arc-swap", "assert_matches", @@ -2122,7 +2122,7 @@ dependencies = [ [[package]] name = "drive-abci" -version = "4.0.0-beta.3" +version = "4.0.0-beta.4" dependencies = [ "arc-swap", "assert_matches", @@ -2183,7 +2183,7 @@ dependencies = [ [[package]] name = "drive-proof-verifier" -version = "4.0.0-beta.3" +version = "4.0.0-beta.4" dependencies = [ "bincode", "dapi-grpc", @@ -3849,7 +3849,7 @@ dependencies = [ [[package]] name = "json-schema-compatibility-validator" -version = "4.0.0-beta.3" +version = "4.0.0-beta.4" dependencies = [ "assert_matches", "json-patch", @@ -3991,7 +3991,7 @@ dependencies = [ [[package]] name = "keyword-search-contract" -version = "4.0.0-beta.3" +version = "4.0.0-beta.4" dependencies = [ "base58", "platform-value", @@ -4174,7 +4174,7 @@ dependencies = [ [[package]] name = "masternode-reward-shares-contract" -version = "4.0.0-beta.3" +version = "4.0.0-beta.4" dependencies = [ "platform-value", "platform-version", @@ -4942,7 +4942,7 @@ checksum = "19f132c84eca552bf34cab8ec81f1c1dcc229b811638f9d283dceabe58c5569e" [[package]] name = "platform-encryption" -version = "4.0.0-beta.3" +version = "4.0.0-beta.4" dependencies = [ "aes", "cbc", @@ -4953,7 +4953,7 @@ dependencies = [ [[package]] name = "platform-serialization" -version = "4.0.0-beta.3" +version = "4.0.0-beta.4" dependencies = [ "bincode", "platform-version", @@ -4961,7 +4961,7 @@ dependencies = [ [[package]] name = "platform-serialization-derive" -version = "4.0.0-beta.3" +version = "4.0.0-beta.4" dependencies = [ "proc-macro2", "quote", @@ -4971,7 +4971,7 @@ dependencies = [ [[package]] name = "platform-value" -version = "4.0.0-beta.3" +version = "4.0.0-beta.4" dependencies = [ "base64 0.22.1", "bincode", @@ -4990,7 +4990,7 @@ dependencies = [ [[package]] name = "platform-value-convertible" -version = "4.0.0-beta.3" +version = "4.0.0-beta.4" dependencies = [ "quote", "syn 2.0.117", @@ -4998,7 +4998,7 @@ dependencies = [ [[package]] name = "platform-version" -version = "4.0.0-beta.3" +version = "4.0.0-beta.4" dependencies = [ "bincode", "grovedb-version", @@ -5008,7 +5008,7 @@ dependencies = [ [[package]] name = "platform-versioning" -version = "4.0.0-beta.3" +version = "4.0.0-beta.4" dependencies = [ "proc-macro2", "quote", @@ -5017,7 +5017,7 @@ dependencies = [ [[package]] name = "platform-wallet" -version = "4.0.0-beta.3" +version = "4.0.0-beta.4" dependencies = [ "arc-swap", "async-trait", @@ -5054,7 +5054,7 @@ dependencies = [ [[package]] name = "platform-wallet-ffi" -version = "4.0.0-beta.3" +version = "4.0.0-beta.4" dependencies = [ "anyhow", "bincode", @@ -5081,7 +5081,7 @@ dependencies = [ [[package]] name = "platform-wallet-storage" -version = "4.0.0-beta.3" +version = "4.0.0-beta.4" dependencies = [ "apple-native-keyring-store", "argon2", @@ -6104,7 +6104,7 @@ dependencies = [ [[package]] name = "rs-dapi" -version = "4.0.0-beta.3" +version = "4.0.0-beta.4" dependencies = [ "async-trait", "axum 0.8.9", @@ -6153,7 +6153,7 @@ dependencies = [ [[package]] name = "rs-dapi-client" -version = "4.0.0-beta.3" +version = "4.0.0-beta.4" dependencies = [ "backon", "chrono", @@ -6178,7 +6178,7 @@ dependencies = [ [[package]] name = "rs-dash-event-bus" -version = "4.0.0-beta.3" +version = "4.0.0-beta.4" dependencies = [ "metrics", "tokio", @@ -6210,7 +6210,7 @@ dependencies = [ [[package]] name = "rs-sdk-ffi" -version = "4.0.0-beta.3" +version = "4.0.0-beta.4" dependencies = [ "async-trait", "bincode", @@ -6243,7 +6243,7 @@ dependencies = [ [[package]] name = "rs-sdk-trusted-context-provider" -version = "4.0.0-beta.3" +version = "4.0.0-beta.4" dependencies = [ "arc-swap", "dash-async", @@ -6262,7 +6262,7 @@ dependencies = [ [[package]] name = "rs-unified-sdk-ffi" -version = "4.0.0-beta.3" +version = "4.0.0-beta.4" dependencies = [ "dash-network", "key-wallet-ffi", @@ -6997,7 +6997,7 @@ checksum = "e3a9fe34e3e7a50316060351f37187a3f546bce95496156754b601a5fa71b76e" [[package]] name = "simple-signer" -version = "4.0.0-beta.3" +version = "4.0.0-beta.4" dependencies = [ "async-trait", "base64 0.22.1", @@ -7130,7 +7130,7 @@ dependencies = [ [[package]] name = "strategy-tests" -version = "4.0.0-beta.3" +version = "4.0.0-beta.4" dependencies = [ "bincode", "dpp", @@ -7522,7 +7522,7 @@ checksum = "1f3ccbac311fea05f86f61904b462b55fb3df8837a366dfc601a0161d0532f20" [[package]] name = "token-history-contract" -version = "4.0.0-beta.3" +version = "4.0.0-beta.4" dependencies = [ "platform-value", "platform-version", @@ -8358,7 +8358,7 @@ dependencies = [ [[package]] name = "wallet-utils-contract" -version = "4.0.0-beta.3" +version = "4.0.0-beta.4" dependencies = [ "platform-value", "platform-version", @@ -8501,7 +8501,7 @@ checksum = "a8145dd1593bf0fb137dbfa85b8be79ec560a447298955877804640e40c2d6ea" [[package]] name = "wasm-dpp" -version = "4.0.0-beta.3" +version = "4.0.0-beta.4" dependencies = [ "anyhow", "async-trait", @@ -8525,7 +8525,7 @@ dependencies = [ [[package]] name = "wasm-dpp2" -version = "4.0.0-beta.3" +version = "4.0.0-beta.4" dependencies = [ "anyhow", "async-trait", @@ -8544,7 +8544,7 @@ dependencies = [ [[package]] name = "wasm-drive-verify" -version = "4.0.0-beta.3" +version = "4.0.0-beta.4" dependencies = [ "base64 0.22.1", "bincode", @@ -8599,7 +8599,7 @@ dependencies = [ [[package]] name = "wasm-sdk" -version = "4.0.0-beta.3" +version = "4.0.0-beta.4" dependencies = [ "base64 0.22.1", "bip39", @@ -9042,7 +9042,7 @@ dependencies = [ [[package]] name = "withdrawals-contract" -version = "4.0.0-beta.3" +version = "4.0.0-beta.4" dependencies = [ "num_enum 0.5.11", "platform-value", diff --git a/Cargo.toml b/Cargo.toml index 52ec18216e..f6f99428dc 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -90,5 +90,5 @@ opt-level = 3 [workspace.package] -version = "4.0.0-beta.3" +version = "4.0.0-beta.4" rust-version = "1.92" diff --git a/package.json b/package.json index 24b476dbb7..5d388acca4 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "@dashevo/platform", - "version": "4.0.0-beta.3", + "version": "4.0.0-beta.4", "private": true, "scripts": { "setup": "yarn install && yarn run build && yarn run configure", diff --git a/packages/bench-suite/package.json b/packages/bench-suite/package.json index 2e5be0804d..6c99cc7c50 100644 --- a/packages/bench-suite/package.json +++ b/packages/bench-suite/package.json @@ -1,7 +1,7 @@ { "name": "@dashevo/bench-suite", "private": true, - "version": "4.0.0-beta.3", + "version": "4.0.0-beta.4", "description": "Dash Platform benchmark tool", "scripts": { "bench": "node ./bin/bench.js", diff --git a/packages/dapi-grpc/package.json b/packages/dapi-grpc/package.json index 35d2fe4140..f40d361b64 100644 --- a/packages/dapi-grpc/package.json +++ b/packages/dapi-grpc/package.json @@ -1,6 +1,6 @@ { "name": "@dashevo/dapi-grpc", - "version": "4.0.0-beta.3", + "version": "4.0.0-beta.4", "description": "DAPI GRPC definition file and generated clients", "browser": "browser.js", "main": "node.js", diff --git a/packages/dapi/package.json b/packages/dapi/package.json index f05a5390bb..bf196776f5 100644 --- a/packages/dapi/package.json +++ b/packages/dapi/package.json @@ -1,7 +1,7 @@ { "name": "@dashevo/dapi", "private": true, - "version": "4.0.0-beta.3", + "version": "4.0.0-beta.4", "description": "A decentralized API for the Dash network", "scripts": { "api": "node scripts/api.js", diff --git a/packages/dash-spv/package.json b/packages/dash-spv/package.json index f9d6217b20..14f9ed430a 100644 --- a/packages/dash-spv/package.json +++ b/packages/dash-spv/package.json @@ -1,6 +1,6 @@ { "name": "@dashevo/dash-spv", - "version": "5.0.0-beta.3", + "version": "5.0.0-beta.4", "description": "Repository containing SPV functions used by @dashevo", "main": "index.js", "scripts": { diff --git a/packages/dashmate/package.json b/packages/dashmate/package.json index 75ada406e0..f8054ef062 100644 --- a/packages/dashmate/package.json +++ b/packages/dashmate/package.json @@ -1,6 +1,6 @@ { "name": "dashmate", - "version": "4.0.0-beta.3", + "version": "4.0.0-beta.4", "description": "Distribution package for Dash node installation", "scripts": { "lint": "eslint .", diff --git a/packages/dashpay-contract/package.json b/packages/dashpay-contract/package.json index 223a5a37bc..97f62a80ae 100644 --- a/packages/dashpay-contract/package.json +++ b/packages/dashpay-contract/package.json @@ -1,6 +1,6 @@ { "name": "@dashevo/dashpay-contract", - "version": "4.0.0-beta.3", + "version": "4.0.0-beta.4", "description": "Reference contract of the DashPay DPA on Dash Evolution", "scripts": { "lint": "eslint .", diff --git a/packages/dpns-contract/package.json b/packages/dpns-contract/package.json index ecd3b0fb1c..1d1498f33a 100644 --- a/packages/dpns-contract/package.json +++ b/packages/dpns-contract/package.json @@ -1,6 +1,6 @@ { "name": "@dashevo/dpns-contract", - "version": "4.0.0-beta.3", + "version": "4.0.0-beta.4", "description": "A contract and helper scripts for DPNS DApp", "scripts": { "lint": "eslint .", diff --git a/packages/js-dapi-client/package.json b/packages/js-dapi-client/package.json index c8ce89d20f..ce871260cc 100644 --- a/packages/js-dapi-client/package.json +++ b/packages/js-dapi-client/package.json @@ -1,6 +1,6 @@ { "name": "@dashevo/dapi-client", - "version": "4.0.0-beta.3", + "version": "4.0.0-beta.4", "description": "Client library used to access Dash DAPI endpoints", "main": "lib/index.js", "contributors": [ diff --git a/packages/js-dash-sdk/package.json b/packages/js-dash-sdk/package.json index f169b86a18..1bd8678e14 100644 --- a/packages/js-dash-sdk/package.json +++ b/packages/js-dash-sdk/package.json @@ -1,6 +1,6 @@ { "name": "dash", - "version": "7.0.0-beta.3", + "version": "7.0.0-beta.4", "description": "Dash library for JavaScript/TypeScript ecosystem (Wallet, DAPI, Primitives, BLS, ...)", "main": "build/index.js", "unpkg": "dist/dash.min.js", diff --git a/packages/js-evo-sdk/package.json b/packages/js-evo-sdk/package.json index 7237b95928..bea742818d 100644 --- a/packages/js-evo-sdk/package.json +++ b/packages/js-evo-sdk/package.json @@ -1,6 +1,6 @@ { "name": "@dashevo/evo-sdk", - "version": "4.0.0-beta.3", + "version": "4.0.0-beta.4", "type": "module", "main": "./dist/evo-sdk.module.js", "types": "./dist/sdk.d.ts", diff --git a/packages/js-grpc-common/package.json b/packages/js-grpc-common/package.json index 8a98b5ad45..117303f64c 100644 --- a/packages/js-grpc-common/package.json +++ b/packages/js-grpc-common/package.json @@ -1,6 +1,6 @@ { "name": "@dashevo/grpc-common", - "version": "4.0.0-beta.3", + "version": "4.0.0-beta.4", "description": "Common GRPC library", "main": "index.js", "scripts": { diff --git a/packages/keyword-search-contract/package.json b/packages/keyword-search-contract/package.json index e229c00ff1..999cc154ed 100644 --- a/packages/keyword-search-contract/package.json +++ b/packages/keyword-search-contract/package.json @@ -1,6 +1,6 @@ { "name": "@dashevo/keyword-search-contract", - "version": "4.0.0-beta.3", + "version": "4.0.0-beta.4", "description": "A contract that allows searching for contracts", "scripts": { "lint": "eslint .", diff --git a/packages/masternode-reward-shares-contract/package.json b/packages/masternode-reward-shares-contract/package.json index f46300845c..1cfecd7ae9 100644 --- a/packages/masternode-reward-shares-contract/package.json +++ b/packages/masternode-reward-shares-contract/package.json @@ -1,6 +1,6 @@ { "name": "@dashevo/masternode-reward-shares-contract", - "version": "4.0.0-beta.3", + "version": "4.0.0-beta.4", "description": "A contract and helper scripts for reward sharing", "scripts": { "lint": "eslint .", diff --git a/packages/platform-test-suite/package.json b/packages/platform-test-suite/package.json index b549b13e0f..95899f8f26 100644 --- a/packages/platform-test-suite/package.json +++ b/packages/platform-test-suite/package.json @@ -1,7 +1,7 @@ { "name": "@dashevo/platform-test-suite", "private": true, - "version": "4.0.0-beta.3", + "version": "4.0.0-beta.4", "description": "Dash Network end-to-end tests", "scripts": { "test": "yarn exec bin/test.sh", diff --git a/packages/token-history-contract/package.json b/packages/token-history-contract/package.json index 884806cc44..afc80147a5 100644 --- a/packages/token-history-contract/package.json +++ b/packages/token-history-contract/package.json @@ -1,6 +1,6 @@ { "name": "@dashevo/token-history-contract", - "version": "4.0.0-beta.3", + "version": "4.0.0-beta.4", "description": "The token history contract", "scripts": { "lint": "eslint .", diff --git a/packages/wallet-lib/package.json b/packages/wallet-lib/package.json index b11b6e1780..9531627ada 100644 --- a/packages/wallet-lib/package.json +++ b/packages/wallet-lib/package.json @@ -1,6 +1,6 @@ { "name": "@dashevo/wallet-lib", - "version": "11.0.0-beta.3", + "version": "11.0.0-beta.4", "description": "Light wallet library for Dash", "main": "src/index.js", "unpkg": "dist/wallet-lib.min.js", diff --git a/packages/wallet-utils-contract/package.json b/packages/wallet-utils-contract/package.json index fb1d416751..cb53c61d3f 100644 --- a/packages/wallet-utils-contract/package.json +++ b/packages/wallet-utils-contract/package.json @@ -1,6 +1,6 @@ { "name": "@dashevo/wallet-utils-contract", - "version": "4.0.0-beta.3", + "version": "4.0.0-beta.4", "description": "A contract and helper scripts for Wallet DApp", "scripts": { "lint": "eslint .", diff --git a/packages/wasm-dpp/package.json b/packages/wasm-dpp/package.json index 49bc15f96e..167eff4793 100644 --- a/packages/wasm-dpp/package.json +++ b/packages/wasm-dpp/package.json @@ -1,6 +1,6 @@ { "name": "@dashevo/wasm-dpp", - "version": "4.0.0-beta.3", + "version": "4.0.0-beta.4", "description": "The JavaScript implementation of the Dash Platform Protocol", "main": "dist/index.js", "types": "dist/index.d.ts", diff --git a/packages/wasm-dpp2/package.json b/packages/wasm-dpp2/package.json index 5e0b7d3717..1a955d80f3 100644 --- a/packages/wasm-dpp2/package.json +++ b/packages/wasm-dpp2/package.json @@ -1,6 +1,6 @@ { "name": "@dashevo/wasm-dpp2", - "version": "4.0.0-beta.3", + "version": "4.0.0-beta.4", "type": "module", "main": "./dist/dpp.js", "types": "./dist/dpp.d.ts", diff --git a/packages/wasm-drive-verify/package.json b/packages/wasm-drive-verify/package.json index 6010517ad3..31b353a9ca 100644 --- a/packages/wasm-drive-verify/package.json +++ b/packages/wasm-drive-verify/package.json @@ -3,7 +3,7 @@ "collaborators": [ "Dash Core Group " ], - "version": "4.0.0-beta.3", + "version": "4.0.0-beta.4", "license": "MIT", "description": "WASM bindings for Drive verify functions", "repository": { diff --git a/packages/wasm-sdk/package.json b/packages/wasm-sdk/package.json index dcc46355c0..d707c9702a 100644 --- a/packages/wasm-sdk/package.json +++ b/packages/wasm-sdk/package.json @@ -1,6 +1,6 @@ { "name": "@dashevo/wasm-sdk", - "version": "4.0.0-beta.3", + "version": "4.0.0-beta.4", "type": "module", "main": "./dist/sdk.js", "types": "./dist/sdk.d.ts", diff --git a/packages/withdrawals-contract/package.json b/packages/withdrawals-contract/package.json index 4c162830d6..44ceb3f573 100644 --- a/packages/withdrawals-contract/package.json +++ b/packages/withdrawals-contract/package.json @@ -1,6 +1,6 @@ { "name": "@dashevo/withdrawals-contract", - "version": "4.0.0-beta.3", + "version": "4.0.0-beta.4", "description": "Data Contract to manipulate and track withdrawals", "scripts": { "build": "",