Releases: MystenLabs/sui
testnet-v1.30.2
#18904: fixing builds for our release pipeline
testnet-v1.30.1
Protocol
Sui Protocol Version in this release: 53
#18756: Enables the native randomness (random beacon) feature on Sui Mainnet.
CLI
#18706: Additional compiler errors for incomplete name access chains (such as some_pkg::some_module::
) might appear in the compiler output.
#18607: Changed sui start
to allow configurable hosts for indexer (--indexer-host
), GraphQL (--graphql-host
), and faucet (--faucet-host
) services. This enables the use of sui start
from a Docker container. By default, all services start with 0.0.0.0
host.
JSON-RPC
#18720: Bugfix for displaying PTBs where a pure input has been used multiple times.
#18712: Nodes (Validators and Full nodes): Bugfix for fetching package information over JSON-RPC from fullnodes, where a package containing UTF8 string constants could fail to disassemble.
GRAPHQL
#18666: Output node estimation has been made more accurate -- the estimate should now track the theoretical max number of nodes on the JSON data
output.
#18664: The service now detects unsupported directives on query variable definitions.
#18662: x-sui-rpc-version
is no longer an accepted request header, as versions are now selected by modifying the path.
#18661: Passing an unsupported directive to the service is now treated as a BAD_USER_INPUT
rather than an INTERNAL_SERVER_ERROR
.
#18486: Introduces an optional rootVersion
parameter to Query.owner
. This can be used to do versioned lookups when reading dynamic fields rooted on a wrapped object or another dynamic object field.
#18552: Introduces a new scalar -- UInt53
-- to represent unsigned 53 bit integer values. Some uses of Int
in the existing schema have been replaced with UInt53
. All clients need to register the new scalar, and clients for statically typed languages also need to use a wider (64 bit, for instance), unsigned type to hold the value.
Full log:
devnet-v1.30.0
Protocol
Sui Protocol Version in this release: 53
#18756: Enables the native randomness (random beacon) feature on Sui Mainnet.
CLI
#18706: Additional compiler errors for incomplete name access chains (such as some_pkg::some_module::
) might appear in the compiler output.
#18607: Changed sui start
to allow configurable hosts for indexer (--indexer-host
), GraphQL (--graphql-host
), and faucet (--faucet-host
) services. This enables the use of sui start
from a Docker container. By default, all services start with 0.0.0.0
host.
JSON-RPC
#18720: Bugfix for displaying PTBs where a pure input has been used multiple times.
#18712: Nodes (Validators and Full nodes): Bugfix for fetching package information over JSONRPC from fullnodes, where a package containing UTF8 string constants could fail to disassemble.
GRAPHQL
#18666: Output node estimation has been made more accurate -- the estimate should now track the theoretical max number of nodes on the JSON data
output.
#18664: The service now detects unsupported directives on query variable definitions.
#18662: x-sui-rpc-version
is no longer an accepted request header, as versions are now selected by modifying the path.
#18661: Passing an unsupported directive to the service is now treated as a BAD_USER_INPUT
rather than an INTERNAL_SERVER_ERROR
.
#18486: Introduces an optional rootVersion
parameter to Query.owner
. This can be used to do versioned lookups when reading dynamic fields rooted on a wrapped object or another dynamic object field.
#18552: Introduces a new scalar -- UInt53
-- to represent unsigned 53 bit integer values. Some uses of Int
in the existing schema have been replaced with UInt53
. All clients need to register the new scalar, and clients for statically typed languages also need to use a wider (64 bit, for instance), unsigned type to hold the value.
Full log:
mainnet-v1.29.2
Protocol
Sui Protocol Version in this release: 52
#18302: Enable soft bundle on Protocol Version 50 in devnet and testnet.
#18462: This change updates the ascii module in the following ways: Adds new methods to std::ascii
:
ascii::append(&mut String, String)
ascii::is_empty(): bool
ascii::substring(&String, i, j): String
ascii::index_of(&String, &String): u64
ascii::to_uppercase(&String): String
ascii::to_lowercase(&String): String
These additions make the ASCII interface more similar to the UTF8 one.
Renames:
string::bytes() to string::as_bytes()
string::sub_string() to string::substring()
Deprecates:
string::sub_string
in favor ofstring::substring
string::bytes
in favor ofstring::as_bytes
Additional changes:
- updates
std::type_name
to usestd::substring
- removes use statements for implicit imports
- renames constants from
E_INDEX
to conventionalEIndexOutOfBounds
#18473: Enable Mysticeti for mainnet.
#18569: Enables Move enums (https://move-book.com/reference/enums.html) in testnet.
GraphQL
#17934: When dynamic fields are selected under the object field if it is a dynamic object field, then its contents will be from the latest version that is at most equal to its parent object's version.
#18347: Fix a bug where starting the service using a config with not all fields set would result in the unset fields being zeroed out rather than taking their usual default values (as would happen if no config had been explicitly supplied).
#18580: Added the health endpoint to version routes as well.
CLI
#18204: Integrated sui-test-validator
into sui start
.
sui start
can now be used to also start an indexer, a GraphQL service,
or a faucet. Note that you need to build sui
with --features indexer
, and have installed libpq
to start the indexer and GraphQL
services. By default, this feature is turned off to preserve backward
compatibility of sui start
. Alternatively, you can download the latest
release and use the sui-pg
binary, which is built using the indexer
feature.
- the default behavior of the existing
sui start
is preserved - the default
sui-test-validator
behavior can be achieved by passing
two flags:sui start --force-regenesis --with-faucet
. - adds a
sui-test-validator.sh
bash script tosui/scripts
folder
that is executable to keep backward compatibility with the previous
binary
#17995: Running sui client publish
or sui client upgrade
will now cause package addresses to be tracked in the Move.lock
file. This removes the need to manually record or edit published-at
addresses in the Move.toml
file going forward. See docs PR #18433 for full details.
#18470: Running sui client publish
and sui client upgrade
will now manage addresses when publishing a package to one or more chains. Refer to the documentation on Automated Address Management for usage and guidelines.
#18515: Starting with v1.29, sui-test-validator
binary will no longer be used to start a network. If you used it in the past, download the latest release archive and use the sui-pg
binary if you need to start an indexer or GraphQL service, or build from source with the indexer feature enabled: cargo build --bin sui --features indexer
. You can also use the sui/scripts/sui-test-validator.sh
drop-in replacement script to run the commands as you used to.
If you only used sui-test-validator
to start a local network from a
new genesis, use sui start --with-faucet --force-regenesis
which will
exhibit the exact same behavior.
Finally, if you only used sui start
before, the behavior is preserved
and you can continue using it as before.
#18553: sui client faucet
received some improvements in the way it handles and responds to errors from the faucet service.
#18574: When you call sui start without a sui config directory, the command generates a genesis along with all the config files. The client.yaml file that the process generates creates a localnet
with IP set to 0.0.0.0
, which leads to problems on Windows. This change fixes that issue by setting the IP to 127.0.0.1
. This is also the case when using sui genesis
.
Nodes
#18712: Bugfix for fetching package information over JSON-RPC from fullnodes, where a package containing UTF8 string constants could fail to disassemble.
Full log:
testnet-v1.29.2
#18712: Nodes (Validators and Full nodes): Bugfix for fetching package information over JSON-RPC
from fullnodes, where a package containing UTF8 string constants could fail to disassemble.
mainnet-v1.28.4
#18712: Nodes (Validators and Full nodes): Bugfix for fetching package information over JSON-RPC
from fullnodes, where a package containing UTF8 string constants could fail to disassemble.
testnet-v1.29.1
Protocol
Sui Protocol Version in this release: 52
#18302: Enable soft bundle on Protocol Version 50 in devnet and testnet.
#18462: This change updates the ascii module in the following ways: Adds new methods to std::ascii
:
ascii::append(&mut String, String)
ascii::is_empty(): bool
ascii::substring(&String, i, j): String
ascii::index_of(&String, &String): u64
ascii::to_uppercase(&String): String
ascii::to_lowercase(&String): String
These additions make the ASCII interface more similar to the UTF8 one.
Renames:
string::bytes() to string::as_bytes()
string::sub_string() to string::substring()
Deprecates:
string::sub_string
in favor ofstring::substring
string::bytes
in favor ofstring::as_bytes
Additional changes:
- updates
std::type_name
to usestd::substring
- removes use statements for implicit imports
- renames constants from
E_INDEX
to conventionalEIndexOutOfBounds
#18473: Enable Mysticeti for mainnet.
#18569: Enables Move enums (https://move-book.com/reference/enums.html) in testnet.
GraphQL
#17934: When dynamic fields are selected under the object field if it is a dynamic object field, then its contents will be from the latest version that is at most equal to its parent object's version.
#18347: Fix a bug where starting the service using a config with not all fields set would result in the unset fields being zeroed out rather than taking their usual default values (as would happen if no config had been explicitly supplied).
#18580: Added the health endpoint to version routes as well.
CLI
#18204: Integrated sui-test-validator
into sui start
.
sui start
can now be used to also start an indexer, a GraphQL service,
or a faucet. Note that you need to build sui
with --features indexer
, and have installed libpq
to start the indexer and GraphQL
services. By default, this feature is turned off to preserve backward
compatibility of sui start
. Alternatively, you can download the latest
release and use the sui-pg
binary, which is built using the indexer
feature.
- the default behavior of the existing
sui start
is preserved - the default
sui-test-validator
behavior can be achieved by passing
two flags:sui start --force-regenesis --with-faucet
. - adds a
sui-test-validator.sh
bash script tosui/scripts
folder
that is executable to keep backward compatibility with the previous
binary
#17995: Running sui client publish
or sui client upgrade
will now cause package addresses to be tracked in the Move.lock
file. This removes the need to manually record or edit published-at
addresses in the Move.toml
file going forward. See docs PR #18433 for full details.
#18470: Running sui client publish
and sui client upgrade
will now manage addresses when publishing a package to one or more chains. Refer to the documentation on Automated Address Management for usage and guidelines.
#18515: Starting with v1.29, sui-test-validator
binary will no longer be used to start a network. If you used it in the past, download the latest release archive and use the sui-pg
binary if you need to start an indexer or GraphQL service, or build from source with the indexer feature enabled: cargo build --bin sui --features indexer
. You can also use the sui/scripts/sui-test-validator.sh
drop-in replacement script to run the commands as you used to.
If you only used sui-test-validator
to start a local network from a
new genesis, use sui start --with-faucet --force-regenesis
which will
exhibit the exact same behavior.
Finally, if you only used sui start
before, the behavior is preserved
and you can continue using it as before.
#18553: sui client faucet
received some improvements in the way it handles and responds to errors from the faucet service.
#18574: When you call sui start without a sui config directory, the command generates a genesis along with all the config files. The client.yaml file that the process generates creates a localnet
with IP set to 0.0.0.0
, which leads to problems on Windows. This change fixes that issue by setting the IP to 127.0.0.1
. This is also the case when using sui genesis
.
Full log:
mainnet-v1.28.3
Protocol
Sui Protocol Version in this release: 51
#18536: Defer all possible errors from connect_lazy until request time
#18206: Explicitly set the number of leaders per round to 1 for Mysticeti commits
#17868: A new feature flag and protocol config fields will be introduced.
#18233: Refactor the DKG to allow protocol upgrades of the cryptographic protocol, and migrate to V1 (controlled by a protocol config parameter).
Nodes (Validators and Full nodes)
#18175: Added MAX_ANNOTATED_VALUE_SIZE
environment variable which can be used to override the MAX_BOUND
for annotated values at startup (useful if encountering "Deserialized value too large"
errors). If the MAX_ANNOTATED_VALUE_SIZE
is not set, MAX_BOUND
will default to the existing max bound of ~1MiB.
#17868: A new API SoftBundleCertifiedTransactionsV3
will be added.
#18233: Refactor the DKG to allow protocol upgrades of the cryptographic protocol, and migrate to V1 (controlled by a protocol config parameter).
Indexer
#18175: Added MAX_ANNOTATED_VALUE_SIZE
environment variable which can be used to override the MAX_BOUND
for annotated values at startup (useful if encountering "Deserialized value too large"
errors). If the MAX_ANNOTATED_VALUE_SIZE
is not set, MAX_BOUND
will default to the existing max bound of ~1MiB.
JSON-RPC
#18099: Enable configuring the jsonrpc server type via the jsonrpc-server-type
field in the node config as follows:
'websocket' for a websocket based service (deprecated)
'http' for an http based service
'both' for both a websocket and http based service (deprecated)
The default is 'http' if not specified.
This also formally deprecates the websocket jsonrpc service which will be removed completely within another few releases. For now users can opt back in to enabling this service by setting the `jsonrpc-server-type` config. We have found that this service is overall unreliable and leads to production issues/missing data or events when used and as such have decided to sunset it.
Deprecate the websocket-based jsonrpc service
#18175: Added MAX_ANNOTATED_VALUE_SIZE
environment variable which can be used to override the MAX_BOUND
for annotated values at startup (useful if encountering "Deserialized value too large"
errors). If the MAX_ANNOTATED_VALUE_SIZE
is not set, MAX_BOUND
will default to the existing max bound of ~1MiB.
GraphQL
#18175: Added MAX_ANNOTATED_VALUE_SIZE
environment variable which can be used to override the MAX_BOUND
for annotated values at startup (useful if encountering "Deserialized value too large"
errors). If the MAX_ANNOTATED_VALUE_SIZE
is not set, MAX_BOUND
will default to the existing max bound of ~1MiB.
CLI
#17920: Add better rendering for Move aborts, and added support for rendering clever errors.
Full log:
devnet-v1.29.0
Protocol
Sui Protocol Version in this release: 52
#18302: Enable soft bundle on Protocol Version 50 in devnet and testnet.
#18462: This change updates the ascii module in the following ways: Adds new methods to std::ascii
:
ascii::append(&mut String, String)
ascii::is_empty(): bool
ascii::substring(&String, i, j): String
ascii::index_of(&String, &String): u64
ascii::to_uppercase(&String): String
ascii::to_lowercase(&String): String
These additions make the ASCII interface more similar to the UTF8 one.
Renames:
string::bytes() to string::as_bytes()
string::sub_string() to string::substring()
Deprecates:
string::sub_string
in favour ofstring::substring
string::bytes
in favour ofstring::as_bytes
Additional changes:
- updates
std::type_name
to usestd::substring
- removes use statements for implicit imports
- renames constants from
E_INDEX
to conventionalEIndexOutOfBounds
#18473: Enable Mysticeti for mainnet.
#18569: Enables Move enums (https://move-book.com/reference/enums.html) in testnet.
GraphQL
#17934: When dynamic fields are selected under the object field if it is a dynamic object field, then its contents will be from the latest version that is at most equal to its parent object's version.
#18347: Fix a bug where starting the service using a config with not all fields set would result in the unset fields being zeroed out rather than taking their usual default values (as would happen if no config had been explicitly supplied).
#18580: Added the health endpoint to version routes as well.
CLI
#18204: Integrated sui-test-validator
into sui start
.
sui start
can now be used to also start an indexer, a GraphQL service,
or a faucet. Note that you need to build sui
with --features indexer
, and have installed libpq
to start the indexer and GraphQL
services. By default, this feature is turned off to preserve backward
compatibility of sui start
. Alternatively, you can download the latest
release and use the sui-pg
binary, which is built using the indexer
feature.
- the default behaviour of the existing
sui start
is preserved - the default
sui-test-validator
behaviour can be achieved by passing
two flags:sui start --force-regenesis --with-faucet
. - adds a
sui-test-validator.sh
bash script tosui/scripts
folder
that is executable to keep backward compatibility with the previous
binary
#17995: Running sui client publish
or sui client upgrade
will now cause package addresses to be tracked in the Move.lock
file. This removes the need to manually record or edit published-at
addresses in the Move.toml
file going forward. See docs PR #18433 for full details.
#18470: Running sui client publish
and sui client upgrade
will now manage addresses when publishing a package to one or more chains. Refer to the documentation on Automated Address Management for usage and guidelines.
#18515: Starting with v1.29, sui-test-validator
binary will no longer be used to start a network. If you used it in the past, download the latest release archive and use the sui-pg
binary if you need to start an indexer or GraphQL service, or build from source with the indexer feature enabled: cargo build --bin sui --features indexer
. You can also use the sui/scripts/sui-test-validator.sh
drop-in replacement script to run the commands as you used to.
If you only used sui-test-validator
to start a local network from a
new genesis, use sui start --with-faucet --force-regenesis
which will
exhibit the exact same behaviour.
Finally, if you only used sui start
before, the behaviour is preserved
and you can continue using it as before.
#18553: sui client faucet
received some improvements in the way it handles and responds to errors from the faucet service.
#18574: When you call sui start without a sui config directory, the command generates a genesis along with all the config files. The client.yaml file that the process generates creates a localnet with IP set to 0.0.0.0
, which leads to problems on Windows. This change fixes that issue by setting the IP to 127.0.0.1
. This is also the case when using sui genesis
.
Full log:
devnet-afe6d26-v1.29.0
Sui devnet (afe6d26) v1.29.0 release