Releases: use-ink/ink
v3.3.1
Version 3.3.1
At the moment teams which use both Substrate and ink! in the same codebase are
experiencing some issues with updating to Substrate's polkadot-0.9.27
branch.
This is because that branch uses the secp256k1@0.24
, which is incompatible with
secp256k1@0.22
This release bumps the secp256k1
version from v0.22
to v0.24
.
v3.3.0
Version 3.3.0
This release restores SemVer compatibility in the v3.x
series of releases, as well as compatibility with the v0.13.0
release of the substrate-contracts-node
.
Compatibility
This version will work fine with substrate-contracts-node versions from 0.13.0 up to 0.16.0.
Changed
Context: user-reported issues on our SE unveiled backward incompatibility introduced in 3.1.0 release.
The following has been done to restore backward compatibility:
- Reverted backward-incompatible piece of #1224.
- The return signature of
ink_env::set_contract_storage()
was changed to return anOption<u32>
.
This could have broken existing code, so this should've been done in aMAJOR
release. - Under the hood the PR also changed
Mapping::insert()
to use a new SEAL API
([seal1] seal_set_storage
), which resulted inCodeRejected
errors in nodes which did not have this API (e.gsubstrate-contracts-node@0.13.0
).
- The return signature of
- Reverted "Optimise deny_payment. Use everywhere semantic of deny (#1267)"
- Reverted backward-incompatible piece of #1233.
- The removal of the
eth_compatibility
crate should have been done in aMAJOR
release.
- The removal of the
All these breaking changes are subjects to the upcoming MAJOR ink! release 4.0.0.
v3.2.0
Version 3.2.0
Compatibility
We recommend using a version of the pallet-contracts
later than c0ee2ad (May 23, 2022) in your node.
This is the case in the latest release of the substrate-contracts-node
v0.16.0.
Added
Changed
- Two functions have been stabilized:
ink_env::ecdsa_recover
andink_env::ecdsa_to_eth_address
‒ #1270 #1273
Fixed
v3.1.0
Version 3.1.0
Compatibility
We recommend using a version of the pallet-contracts
later than 7d233c2 (May 13, 2022) in your node.
This is the case in the latest release of the substrate-contracts-node
v0.15.1 and the latest Polkadot release v0.9.22.
Breaking Changes
There are two breaking changes in this release:
- As part of #1235 the message selectors of your contract may change. A change of selectors would affect your client, frontend, Dapp, etc..
- As part of #1233 we removed the
eth_compatibility
crate.
Its recovery functionality has been moved toink_env
now:ink_env::ecdsa_to_eth_address
. The reason for this change is that we moved the gas-expensive crypto operations intopallet-contracts
.
The cratesto_default_account_id
function has been removed; the reason for this change is that ink! doesn't have knowledge about the specific Substrate types on the underlying chain. If you want to retain the function in your contract and are just using standard Substrate types you should add the prior functionality to your contract ‒ it was a simple<Blake2x256 as CryptoHash>::hash(&ecdsa_pubkey[u8; 33])
.
New API functions
We added two new Mapping
API functions: Mapping::contains
and Mapping::insert_return_size
‒ #1224. These are more gas-efficient than whatever you were using previously.
Additionaly there are a couple new ink_env
functions now:
New Upgradeable Contract Example
We've added a new example: upgradeable-contracts/set-code-hash
.
It illustrates how the newly added ink_env::set_code_hash
can be used to implement an upgradeable contract that replaces its own code.
Added
- Implement
seal_code_hash
andseal_own_code_hash
‒ #1205 - Add
set_code_hash
function and example ‒ #1203 - Implement
ink_env::ecdsa_to_eth_address
‒ #1233 - Add
Mapping::contains(key)
andMapping::insert_return_size(key, val)
‒ #1224
Fixed
- Fix ordering of message ids if the trait is implemented before the inherent section ‒ #1235
Removed
- Removed
eth_compatibility
crate and moved its functionality partly intoink_env
‒ #1233
v3.0.1
v3.0.0
Version 3.0.0
This is the stable release for ink! 3.0.
It took us a while to get here and going forward we want to do smaller releases more often.
Please note that ink! has not been audited.
Compatibility
We recommend using a version of the contracts
pallet later than cc282f84ba53ed2a08374d2a655dc8f08cbc5e86 (March 15, 2022) in your node.
This is the case in the latest release of the substrate-contracts-node
: v0.10.0.
Breaking Changes
We replaced the default off-chain testing environment
The off-chain testing environment can be used to write unit tests for your smart contract with a simulated chain. We've now replaced the existing off-chain environment with a new one, which has a bit of a different API.
The major changes are that there is no longer any notion of "execution context" ‒ so no more push_execution_context
or pop_execution_context
. You can achieve all the same things with the new API, see here for the API documentation.
We've also switched all our examples to this new environment, you can find more "template use-cases" there (e.g. for chain extension testing)
We removed the dynamic storage allocator
More details on the reasoning behind this can be found in #1148.
CallBuilder
API changed to support delegate
calls
The CallBuilder
API changed to now support two types of calls:
Call
: a cross-contract call.
This was the default until this new API change.DelegateCall
: a delegated call.
This enables writing upgradeable contracts using thedelegate
pattern. An example has been added to demonstrate this:delegate-calls
.
This is a breaking change, users must now specify the call_type
to the builder manually.
If you want to keep existing behavior you just need to specify the type Call
now.
More details on this change can be found in #1133.
Unify ink_env::{eval_contract, invoke_contract}
The API for eval_contract
and invoke_contract
changed. You can read more about the change in #1165.
Added
- Added
keep_attr
to#[ink::contract]
and#[ink::trait_definition]
‒ #1145 (thanks @xgreenx).. - Implemented the
seal_is_contract
andseal_caller_is_origin
API ‒ #1129 #1166. - Add tests in experimental off-chain env for
trait-erc20
‒ #1158. - Add tests in experimental off-chain env for
erc721
‒ #1157. - Add tests in experimental off-chain env for
multisig
‒ #1159. - Add tests in experimental off-chain env for
dns
‒ #1156. - Implemented chain extension testing in experimental off-chain env ‒ #1152.
Changed
- Replaced default off-chain testing engine with experimental one ‒ #1144.
- Changed
CallBuilder
API to now support delegate calls ‒ #1133 (thanks @VargSupercolony and @xgreenx). - Unify
ink_env::{eval_contract, invoke_contract}
‒ #1165.
Removed
ink! 3.0.0 RC 9
Version 3.0-rc9
This is the 9th release candidate for ink! 3.0.
Breaking Changes
We removed all data structures other than Mapping
from the public ink! API
This is a drastic breaking change; it was no easy decision for us.
It affects Lazy
and Memory
as well. The rationale behind this change,
as well as some notes on migrating existing contracts, are explained
in #1111 and
#1137.
If you used Memory
in your contract, you can achieve the same functionality
by passing this data via arguments. If you think there's a case to be
made for bringing it back, please get in contact with us.
If you use ink_storage::Mapping
in your contract, you need to initialize the data structure using the helper function
ink_lang::utils::initialize_contract(…)
.
For more code examples you can take a look at our examples, e.g.
erc20
.
Please upgrade scale-info
and parity-scale-codec
in your contract's dependencies
In this release candidate we upgraded scale-info
and parity-scale-codec
. You have to use a compatible
version in your contract's Cargo.toml
as well; cargo-contract
will throw an error otherwise.
The Cargo.toml
should contain
scale-info = { version = "2", default-features = false, features = ["derive"], optional = true }
scale = { package = "parity-scale-codec", version = "3", default-features = false, features = ["derive", "full"] }
Added
- Export
ink_lang::utils::initialize_contract(…)
- #1077. - Add
get_owner()
function todns
example contract - #1118 (thanks @agryaznov). - Improved usage documentation of
ink_storage::Mapping
- #1138.
Changed
- Updated to
parity-scale-codec = "3"
andscale-info = "2"
- #1132.
Removed
- Remove
collection
andlazy
modules from public ink! API - #1111. - Remove
Memory
from public ink! API - #1137.
Fixed
ink! 3.0.0 RC 8
Version 3.0-rc8
This is the 8th release candidate for ink! 3.0.
Compatibility
You need to upgrade to a new version of the contracts
pallet in order to use this
ink! release. Specifically we recommend you upgrade to at least the pallet version
249dbbb
(or newer than Jan 17, 2022).
For substrate-contracts-node
we just issued a new release v0.5.0
, which has been synchronized
to the latest Substrate master
and hence is compatible with this ink! release candidate.
Also, the metadata changed with this release, so you need to have a recent version of
the user interface you are using. For polkadot-js/api
and polkadot-js/apps
the metadata
changes are supported since Jan 19, 2022.
Metadata Changes
There are two metadata changes in this release candidate:
For messages and constructors: name: Array
➔ label: String
The messages and constructors exposed by a contract were previously denoted with
"name": ["foo", "bar"]
Now they are instead denoted with
"label": "foo"
For public contract methods that are implemented from a trait, the trait name is prefixed to
the method name with ::
as the separator. So e.g. trait_name::get_owner
.
The ink! PR which implemented this is #923,
for the polkadot-js/api
it was polkadot-js/api#4255.
Constructors got a new field: payable: bool
Constructors now have to be specified payable
if it's intended for them to receive value
(i.e. tokens). This is a breaking change, beforehand they were by default payable,
now they are by default non-payable.
The ink! PR which implemented this is #1065, the PR that updated the ink!
metadata to V3 is #1100, and for the polkadot-js/api
it was polkadot-js/api#4432.
Changed
- Update metadate to support payable constructors - #1100.
- Make constructors non-payable by default, require specifying
payable
explicitly - #1065. - Renamed the error code
EcdsaRecoverFailed
toEcdsaRecoveryFailed
‒ #1064. - Renamed the
ink_env
functiontransferred_balance()
totransferred_value()
‒ #1063. - Removed the error codes
BelowSubsistenceThreshold
andNewContractNotFunded
‒ #1062. - Updated ink! to use the most recent
contracts
pallet API ‒ #1053. - Explicitly link against
rlibc
to get non-buggy version ofmemcpy
‒ #1049. - Changed the metadata field
name
tolabel
for messages and constructors ‒ #923 (thanks @xgreenx).
Added
- Added a
remove
method to theMapping
data structure ‒ #1023.
ink! 3.0.0 RC 7
Version 3.0-rc7
This is the 7th release candidate for ink! 3.0.
Since our last release candidate we implemented a number of contract size improvements.
With those improvements the size of our erc20
example has reduced significantly:
Release Build with cargo-contract |
||
---|---|---|
erc20 |
3.0.0-rc6 |
29.3 K |
erc20 |
3.0.0-rc7 |
10.4 K |
The savings apply partly to our other examples; for erc20
they are most
significant since it has been migrated to use a new Mapping
data structure, which we introduce with this release candidate.
The other examples will be migrated to this new data structure as a next step.
Removed
- Removed the state rent API ‒ #1036.
Added
- Added support for wildcard selectors ‒ #1020.
- This enables writing upgradable smart contracts using the proxy/forward pattern.
We added a new example to illustrate this ‒ the proxy example. - Annotating a wildcard selector in traits is not supported.
- This enables writing upgradable smart contracts using the proxy/forward pattern.
- The ink! codegen now heavily relies on static type information based on traits defined in
ink_lang
‒ #665.- Some of those traits and their carried information can be used for static reflection of ink!
smart contracts. Those types and traits reside in the newink_lang::reflect
module and is
publicly usable by ink! smart contract authors.
- Some of those traits and their carried information can be used for static reflection of ink!
Changed
- Upgraded to the
seal_call
v1 API ‒ #960.- This API now enables control over the behavior of cross-contract calls, e.g. to forward/clone input,
enable tail calls and control reentrancy.
The crate documentation contains more details on theCallFlags
. - Note: The default behavior of cross-contract calls now disallows reentering the calling contract.
- This API now enables control over the behavior of cross-contract calls, e.g. to forward/clone input,
- ink! contract definitions via
#[ink::contract]
‒ #665.
For ink! smart contracts we now generate two contract types. GivenMyContract
:MyContract
will still be the storage struct.
However, it can now additionally be used as static dependency in other smart contracts.
Static dependencies can be envisioned as being directly embedded into a smart contract.MyContractRef
is pretty much the same of what we had gotten with the oldink-as-dependency
.
It is a typed thin-wrapper around anAccountId
that is mirroring the ink! smart contract's API
and implemented traits.
- ink! trait definitions via
#[ink::trait_definition]
‒ #665.- ink! trait definitions no longer can define trait constructors.
- ink! trait implementations now inherit
selector
andpayable
properties for trait messages.- Now explicitly setting
selector
orpayable
property for an implemented ink! trait method
will only act as a guard that the set property is in fact the same as defined by the ink!
trait definition.
- Now explicitly setting
- Improved some ink! specific compile errors ‒ #665.
- For example, when using ink! messages and constructors which have inputs (or
outputs) that cannot be encoded (or decoded) using the SCALE codec.
- For example, when using ink! messages and constructors which have inputs (or
- Simplified selector computation for ink! trait methods ‒ #665.
- Now selectors are encoded as
blake2b({namespace}::{trait_identifier}::{message_identifier})[0..4]
.
If nonamespace
is set for the ink! trait definition then the formula is
blake2b({trait_identifier}::{message_identifier})[0..4]
.
Wheretrait_identifier
andmessage_identifier
both refer to the identifiers of the ink! trait
definition and ink! trait message respectively.
- Now selectors are encoded as
- We switched to Rust edition 2021 ‒ #977.
- Update chain extension example to show argument passing ‒ #1029.
Fixed
- Contracts now revert the transaction if an ink! message returns
Result::Err
‒ #975, #998.- It is still possible to match against a
Result
return type for a called dependency contract
‒ i.e. a sub-contract specified in the contract'sCargo.toml
.
- It is still possible to match against a
- We implemented a number of Wasm contract size improvements:
ink! 3.0.0 RC 6
Version 3.0-rc6
This is the 6th release candidate for ink! 3.0.
Added
- Added an Ethereum-compatibility function to recover a public key from an ECDSA signature and message hash - #914 (thanks @xgreenx).
Changed
- Update to
scale-info
1.0 - #845. - Message and constructor selectors no longer take their inputs as string, but as
u32
decodable integer - #928.
For example:- It is no longer possible to specify a selector as
#[ink(selector = "0xC0DECAFE")]
. - The newly allowed formats are
#[ink(selector = 0xC0DECAFE)]
and#[ink(selector = 42)]
. - Smart contract authors are required to update their smart contracts for this change.
- It is no longer possible to specify a selector as
- Improved the
multisig
example - #962. - Changed the link to our beginner's workshop to the migrated workshop on
substrate.io
- #957.
Fixed
- Fixed a mistake in the
ink_env::block_timestamp()
documentation - #937.