All notable changes to this project will be documented in this file.
- Client was notified about every REMP status timeout. Now it is notified only once when fallback scenario is started
- Added message monitoring functions to the
processingmodule:monitor_messages,fetch_next_monitor_results,get_monitor_info,cancel_monitor****. - Added
processing.send_messagesfunction. - Improved error resolving for deleted accounts
net.first_remp_status_timeoutconfig parameter default value set to 1 ms in order to start fallback scenario together with REMP statuses processing while REMP is not properly tuned yet.- Network errors are returned on subscription creation if occured
ParamsOfSubscribewas not public.subscribedid not trim subscription query text. It is required for some graphql servers expecting that query text starts from operation text.
api_derivecompilation errors
-
CapSignatureWithIdcapability is supported.Network signature ID is used by VM in signature verifying instructions if capability
CapSignatureWithIdis enabled in blockchain configuration parameters.This parameter should be set to
global_idfield from any blockchain block if network can not be reached at the moment of message encoding and the message is aimed to be sent into network withCapSignatureWithIdenabled. Otherwise signature ID is detected automatically inside message encoding functions.
Overwrite priority: ExecutionOptions.signature_id -> ClientConfig.network.signature_id -> last network blockClientConfig.network.signature_idoptional parameter is added. Specify it in case of offline work for all message signing operations to use.ExecutionOptionsis extended withsignature_idoptional parameter. Specify locally for a particularrun_tvmorrun_executorcall.net.get_signature_idfunction returnsglobal_idifCapSignatureWithIdcapability is enabled,
-
message_idandmessage_dstfields are added to allProcessingEventvariants -
Config parameter
binding: { library: string, version: string }. Binding authors should define this parameter at context initialization. -
tonclient-binding-libraryandtonclient-binding-versionGraphQL request headers. Read more here -
Error.data.binding_libraryandError.data.binding_versionerror data fields. Read more here
abi.get_signature_datafunction ouput parameterhashis renamed tounsignedfor consistency with other crypto functions parameters
- Changed type of the
dictionaryparameter or mnemonic crypto functions and crypto config. Now it usesMnemonicDictionaryenum type instead ofnumber.MnemonicDictionarynumeric constants are compatible with previous values.
debotengine module is deprecated. Debot engine development has migrated to a separate repository (soon will be published). So, in order to reduce sdk binary size, we will removedebotengine module from sdk in the next releases.
abi.get_signature_datafunction that returns signature from message and hash to verify the signature
- local endpoints with port specified are expanded with
httpprotocol instead ofhttps(e.g.localhost:8033in expanded tohttp://localhost:8033/graphql)
-
Resolved endpoints are cached for 10 minutes so subsequent messages sent will not require additional server request
-
Queries are retried in case of network errors when websocket connection is used
-
WaitForTimeouterror code (607) is returned in case ofwait_for_transactionfunction was successfully executed but expected data did not appeared during the specified timeout -
timeoutparameter innet.query_transaction_treebehaviour changed. Now value 0 indicates that no time limit should be used and function will wait for all transactions execution
-
transaction_max_countparameter innet.query_transaction_treewhich controls the count of transaction to be awaited and returned -
data_layoutandfunction_nameparameters inabi.decode_messageandabi.decode_message_bodythat can be used to decode responsible function output and optimize message decoding by strict layout check
-
abi.encode_initial_datafunction properly creates data in case of public key omitted. Nowabi.encode_initial_datacall without initial data values and public key creates the same data as compiled tvc -
Graphql error messages with HTTP response 400 was skipped (was not propagated to the SDK client application).
-
Several misspelling.
-
Message processing freeze in case of large amount of messages parallel processing using Websocket connection
-
Websocket interaction thread panic
-
Debot module:
- fill hash argument in
SDK.signHashmethod with leading zeroes up to 32 bytes.
- fill hash argument in
- Additional info query is removed from
send_messageto minimize API usage
- Error code
Unauthorizedis returned from all network functions in case of authentication failure - Server connection attempt is not retried in case of authentication failure
- Debot module:
- ABI specification v2.3 is supported in DEngine.
- Supported flags
OVERRIDE_TS,OVERRIDE_EXPT,ASYNC_CALLfor external messages in DEngine.
- Support cookies in net module for std mode (not wasm)
- Remove network aliases (main, dev, main.ton.dev, net.ton.dev)
- No balancing logic in case of 1 endpoint + removed the check of REMP support on backend during client initialization. These changes will make client initialization faster -> CLI tools that use SDK will work faster, web pages will load initial data faster.
- Changed 401 error message to response message from API
- Tests improvements: cryptobox tests made stable
crypto.encryption_box_get_inforeturns nacl box public key ininfo.publicfield.- Gosh instruction are supported in local VM and executor:
- execute_diff
- execute_diff_patch_not_quiet
- execute_zip
- execute_unzip
- execute_diff_zip
- execute_diff_patch_zip_not_quiet
- execute_diff_patch_quiet
- execute_diff_patch_zip_quiet
- execute_diff_patch_binary_not_quiet
- execute_diff_patch_binary_zip_not_quiet
- execute_diff_patch_binary_quiet
- execute_diff_patch_binary_zip_quiet
create_crypto_boxoptimisation. When a user creates a crypto box, library encrypts provided secret information using provided password and salt. When library encrypts the secret, it calculates encryption key from password and salt usingscryptfunction which takes a lot of CPU time (about 1 second). So when a user creates many crypto boxes using the same password and salt, it takes a lot of time (about 12 seconds for 10 crypto boxes). With the optimisations introduced in this version the library stores the pair (password+salt => encryption key) in internal cache for approximately 2 seconds. So when a user creates many crypto boxes at a time using the same password and salt, library uses cached information to skip heavy calculations. As a result now it takes only a second to create 10 crypto boxes.
- Some enum types were not properly presented in api.json (some types that use serde(content=" value"))
- Pinned BOC cache now has reference counter for each pin in BOC. BOC can be pinned several times
with the same pin. BOC is removed from cache after all references for all pins are unpinned with
cache_unpinfunction calls. - Fixed error resolving in case when account state was modified after message expiration time. Now appropriate error text is added to error message instead of executor internal error
- client sends
config.network.access_keyasAuthorization: Basic ...orAuthorization: Bearer ...header depending on the value passed: if value is in hex, then it is processed as project secret (basic), if in base64 - then as JWT token (bearer). - client accepts endpoints with
/graphqlsuffixes specified in config.
- Updated zstd in order to fix building.
- Time synchronization check between device and server improved: calculation of time-diff with server is moved from batched query to send_message function and therefore now query execution time does not affect this time diff.
- ABI specification v2.3 is supported
- parameter
addressis added toabi.encode_message_bodyfunction
abimodule errors have been improved
chksig_always_succeedexecution option used in params of thetvm.run_get,tvm.run_tvmandtvm.run_executor.abi.calc_function_idfunctiontokiolibrary is updated to 1.* version
- send
accessKeyheader in api requests (specified inconfig.network.accessKey)
- send headers in
infoapi requests
- build process
- supported removing Copy interface from UInt256
- supported changed interface of
ton_types::Cell
-
client.configfunction that returns the current client config -
run_executor().feesis extended with these fields:ext_in_msg_fee- fee for processing external inbound messagetotal_fwd_fees- total fees of action phaseaccount_fees- total fees the account pays for the transaction
-
mainanddevendpoints aliases for Evernode Cloud Mainnet and Devnet endpoints
- Added documentation for
TransactionFeestype (run_executor().fees). - Documentation now includes
enumtypes descriptions. To achieve it we updated binding-gen: enum of types now produces its own type for each enum variant.
- Websocket errors weren't treated as a network errors. This is why all the processing functions that worked via wss protocol failed on these errors without retries. Now retries are performed.
- SDK tried to rebalance even if only a single endpoint was specified. Now in case of a single endpoint, no rebalancing occurs.
allow_partialflag in allabi.decode_*functions. This flag controls decoder behaviour whether return error or not in case of incomplete BOC decodingREMPsupported.ProcessingEventenum is extended withREMPstatuses (enum of events posted intoprocessing.wait_for_transactionfunction callback )- UNSTABLE.
first_remp_status_timeoutandnext_remp_status_timeoutparameters in network config
network.queries_protocolconfig parameter allows selecting protocol the SDK uses to communicate with GraphQL endpoint:HTTP– SDK performs single HTTP-request for each request.WS– SDK uses single WebSocket connection to send all requests. This protocol is a preferable way when the application sends many GraphQL requests in parallel.
- Debot module:
- If DEngine received a non-zero exit_code while emulating a transaction while sending a message, DEngine will call onErrorId callback of the message.
crypto module:
-
Cryptoboxintroduced: root crypto object that stores encrypted secret and acts as a factory for all crypto primitives used in SDK. Crypto box provides signing and encryption boxes.Functions:
create_crypto_box- initializes cryptobox with secretremove_crypto_box- removes cryptobox and overwrites all secrets with zeroesget_crypto_box_seed_phrase- returns decrypted seed phrase
get_crypto_box_info- returns encrypted cryptobox secret for next cryptobox initializationsget_signing_box_from_crypto_box - derives signing box from secret
get_encryption_box_from_crypto_box - derives encryption box from secret
clear_crypto_box_secret_cache - forces secret cache (signing and encryption) clean up (overwrites all secrets with zeroes).
- returns decrypted seed phrase
-
Support of
initCodeHashin tvm:X-Evernode-Expected-Account-Boc-Version=2 http header added to graphql requests. value=2 means that SDK requests the latest account boc version with initCodeHash support from API. This was done because new boc version is not compatible with old transaction executor, i.e. with previous SDK versions. New transaction executor is compatible with new and old boc formats. New SDK asks for new boc format if it exists,if it does not - old boc version is returned. Previous version of SDK will fetch only old version without initCodeHash support.
Attention! Migrate your applications to the new SDK version ASAP because in some period of time we will stop supporting old boc version in API and default value of X-Evernode-Expected-Account-Boc-Version on backend side will become 2, missing value will cause an error. Now default value on API side is Null which means that API returns the old version. This is done to avoid breaking changes in existing applications and give time to migrate to the new SDK.
- Documentation generator for app object interface fills documentation from
ParamsOfXXXAppObjectenum. - Documentation generator for function with
objparameter add this parameter into parameters section with link to appropriate AppObject interface.
- Added
boc.encode_external_in_messagefunction to encode message BOC based on a low level message parts such as a body, state init etc. - Added
net.subscribefunction to start a low level GraphQL subscription. - Added support for new MYCODE TVM command in
tvm.run_tvmandtvm.run_getfunctions.
- Added
abi.encode_bocfunction to encode parameters with values to BOC, using ABI types. - Added support of
addresstype inboc.encode_boc. - All fetch requests are now called with timeouts to prevent freezing in case of infinite answer.
- Support of
MYCODEinstruction in TVM
- Support breaking changes in
ton-labs-block-jsonv0.7.1 - Updated endpoints for
main.ton.devalias.
- DevNet endpoints now changed to EVER OS domain: eri01.net.everos.dev, rbx01.net.everos.dev, gra01.net.everos.dev
- Debot module:
- Added float numbers support for Json interface
- Added guide for custom giver usage.
- Debot module: fixed a bug in Query.query function called with an empty
variablesfield.
- Empty
function_namefield in the "create run message failed" error.
Function abi.encode_initial_data
which
encodes initial account data with initial values for the contract's static variables and owner's
public key.
This function is analogue of tvm.buildDataInit function in Solidity.
- Subscription for Counterparties failed with 'Unknown type "CounterpartieFilter"' error.
- Fixed building and warning.
- Debot module:
- Added
allow_no_signatureparameter todecode_and_fix_ext_msg()andonerror_idreturn value toprepare_ext_in_message()inner functions used in TS4. - Added support for async external calls.
Queryinterface extended withwaitForCollectionandquerymethods.waitForCollectionallows to wait for completion of async external calls.- Added support for DeBots with ABI 2.2.
- Added
Function proofs.proof_message_data
which proves message data, retrieved
from Graphql API.
-
New module
proofsis introduced! -
Functions
proofs.proof_block_dataandproofs.proof_transaction_datawhich prove block data, retrieved from Graphql API.These are the first functions from proofs series :) Wait for others(
proof_account_data,proof_message_data) in the next releases.Read about them more in the documentation.
-
abi.decode_bocfunction to decode custom BOC data into JSON parameters. -
Ref(<ParamType>)type was added to ABI. Solidity functions use ABI types for builder encoding. The simplest way to decode such a BOC is to use ABI decoding. ABI has it own rules for fields layout in cells so manually encoded BOC can not be described in terms of ABI rules. To solve this problem we introduce a new ABI typeRef(<ParamType>)which allows to storeParamTypeABI parameter in cell reference and, thus, decode manually encoded BOCs. This type is available only indecode_bocfunction and will not be available in ABI messages encoding until it is included into some ABI revision.
-
boc.get_boc_depthfunction to get depth of the provided boc. -
boc.decode_tvcfunction returns additional fieldscode_hash,code_depth,data_hash,data_depthandcompiler_version -
Debot module:
- added
parsefunction to Json interface.
- added
boc.get_code_saltandboc.set_code_saltfunctions for contract code salt management.boc.encode_tvcandboc.decode_tvcfunctions for TVC image encoding and decodingboc.get_compiler_versionfunction extracting compiler version from contract codeabi.update_initial_dataandabi.decode_initial_datafunction for pre-deployment contract data management
-
ABI v2.2 with fixed message body layout supported. See the specification .
Now, for contracts with ABI version < 2.2 compact layout will still be used for compatibility, for contracts with ABI version 2.2 and more - fixed layout will be used. Please, make sure that you updated the ABI if you recompiled your contract with 2.2 ABI, or you may get an inconsistent contract behaviour.
-
Debot module:
- added
getEncryptionBoxInfo,getSigningBoxInfofunctions to Sdk interface. - implemented Query DeBot interface in DEngine.
- added
abi.encode_messageandprocessing.process_messagecreated invalid deploy message in case ofSigner::Nonewas used, and contract could not be deployed.
- Support MacOS aarch64 target
- Information about used endpoint is added to subscription errors.
- Graphql response error codes 500-599 are treated as retriable network errors
- Updated crypto libraries in order to fix building.
- http errors were not processed as network errors and didn't lead to endpoint reconnect and request retry
crypto.create_encryption_boxfunction for creating SDK-defined encryption boxes. First supported algorithm - AES with CBC mode.- Debot module:
- Added public
prepare_ext_in_messagefunction.
- Added public
tvm.run_executordid not work when SDK is configured to use TONOS SE, because of incomplete default blockchain configuration. Now mainnet config from key block 10660619 (last key block at the moment of fix) is used as default.
- Added support of contract error messages. Error messages (for example, require(...) in Solidity)
are now parsed by SDK
and returned in error message. New field
contract_errorwas added to error'sdata.
- Fixed problem with WASM binaries (everx-labs/ever-types#42)
-
ABI version
2.1supported. Attention! If you work with contracts, that contain String parameters, then during migration from ABI 2.0 to 2.1 you will need to remove all String type conversions to bytes and back and pass string to your contract as is. -
Now all requests to GraphQL are limited with timeout to react on unexpected server unavailability. Existing timeouts in waiting functions keep the same behaviour. All other requests timeout now can be set with
net.query_timeoutconfig parameter. Its default value is 60000 ms -
Debot module:
- added
encrypt,decryptfunctions to Sdk interface which accept encryption box handles.
- added
- Deployment with empty signer in cases of public key set in TVC or deploy set.
get_address_typefunction inutilsmodule, which validates address and returns its type. See the documentation.decode_account_datafunction inabimodule that converts account data BOC into JSON representation according to ABI 2.1. See the documentation.- Diagnostic fields
filterandtimestampadded towait_for_collectionerror main.ton.devandnet.ton.devendpoints that will be deprecated on 12.07.21 are now replaced with proper endpoints list, if they were specified in networkendpointsconfig
- Search of the first master blocks during the network start period was fixed in blocks and transactions iterators
- Iterators in
netmodule: robust way to iterate blockchain items (blocks, transactions) in specified range. See documentation forcreate_block_iterator,create_transaction_iterator,resume_block_iterator,resume_transaction_iterator,iterator_next,iterator_removefunctions. - Library adds
http://protocol to endpointslocalhost,127.0.0.1,0.0.0.0if protocol isn't specified in config. - Debot module:
- added tests for Json interface.
- Added support of external encryption boxes. See the documentation
- Debot module:
- Dengine waits for completion of all transactions in a chain initiated by debot's onchain call.
timeoutoption toquery_transaction_tree– timeout used to limit waiting time for the next message and transaction in the transaction tree.
- Improved error messages regarding ABI and JSON interface. SDK now shows additional tips for the user in cases of errors.
- Warnings in Rust 1.52+. Little fixes in the documentation.
total_outputfield in fees was always 0.query_transaction_treedidn't wait for messages.
query_transaction_treefunction that returns messages and transactions tree produced by the specified message was added tonetmodule. See the documentation
AbiData.keytype changed to u32.- attempt to use
orderByinstead oforderinquery_collectionwill raise error.
-
Sync latency detection increases connection reliability. Library will change the current endpoint when it detects data sync latency on it.
-
Configuration parameters:
latency_detection_interval,max_latency. See client documentation for details. -
Debot module:
- signing messages with signing box handles returned from debots.
- return any sdk errors to debot in case of external calls.
- defining signing box handle used to sign message in approve callback.
- Fixed building under Rust versions older than 1.51.
- Debot module:
- implementation of Network DeBot interface in DEngine.
- implementation of
signHashfunction in Sdk interface.
- Debot module:
- fixed bug in Json interface with supporting nested structures and arrays of structures.
- fixed bug in Json interface with keys containing hyphens.
-
net.query_counterparties- allows to query and paginate through the list of accounts that the specified account has interacted with, sorted by the time of the last internal message between accounts. Subscription to counterparties collection is available vianet.subscribe_collectionfunction. -
Blockchain interaction reliability improvement (broadcast): library sends external inbound messages simultaneously to the N randomly chosen endpoints. If all N endpoints failed to response then library repeats sending to another random N endpoints (except the failed one). If all the available endpoints fail to respond then library throws error. The N parameter is taken from
config.network.sending_endpoint_count(default is 2). -
Blockchain interaction reliability improvement (bad delivery list): library tracks endpoints with bad message delivery (expired messages). These endpoints have lower priority when library chooses endpoints to send message.
-
Debot module:
- Implementation of
JsonDeBot interface in DEngine.
- Implementation of
BuilderOp::Integer.sizetype has changed fromu8tou32.- Debot Module:
Sdkinterface functiongetAccountsDataByHashdidn't find accounts bycode_hashwith leading zero.
utils.compress_zstdcompresses data using Facebook's Zstandard algorithm.utils.decompress_zstddecompresses data using Facebook's Zstandard algorithm.- Debot module:
initfunction that creates an instance of DeBot and returns DeBot metadata.- Dengine fetches metadata form DeBot by calling 2 mandatory functions:
getRequiredInterfacesandgetDebotInfo. This data is returned byfetchandinitfunctions. approveDeBot Browser callback which is called by DEngine to request permission for DeBot activities.
- Debot Module:
- [breaking]
fetchfunction doesn't create an instance of debot. It returns DeBot metadata (DebotInfo). - [breaking]
startfunction doesn't create an instance of debot. It accepts DeBot handle created ininitfunction.
- [breaking]
- Some internal refactor due to
ton-blockchanges
- Giver address in tests is calculated from secret key. Default values are provided for TON OS SE giver
utils.calc_storage_feefunction to calculate account storage fee over a some time period.- Debot Module:
- Added unstable functions to
Sdkinterface:getAccountsDataByHash
- Added unstable functions to
- Add optional field
src_addresstoParamsOfEncodeInternalMessage. - Field
abiinParamsOfEncodeInternalMessageis optional and can beNoneifcall_setanddeploy_setareNone. boc.encode_bocfunction provides ability to build and serialize any custom tree of cells. Application can use several base Builder serialization primitives like integers, bitstrings and nested cells.boc.get_blockchain_configfunction can extract blockchain configuration from key block and also from zerostate.tvmmodule functions download current blockchain configuration ifnetis initialized with DApp Server endpoints. Otherwise, default configuration is used.- Debot Module:
- Support for debot invoking in Debot Engine.
sendbrowser callback is used not only for interface calls but to invoke debots. startandfetchfunctions returns debot ABI.- Added new built-in interface
Hexwhich implements hexadecimal encoding and decoding. - Added unstable functions to
Sdkinterface: naclBox, naclBoxOpen, naclKeypairFromSecret, getAccountCodeHash.
- Support for debot invoking in Debot Engine.
- Both
call_setanddeploy_setinParamsOfEncodeInternalMessagecan be omitted. In this caseencode_internal_messagegenerates internal message with empty body. - Debot Module:
sendfunction accepts one argument - serialized internal message as string encoded into base64.
- Debot browser app object and signing box app object descriptions added
- functions-helpers for enum type variable creation for Signer , Abi, ParamsOfAppDebotBrowser
- doc generator: app object interface description, constructor functions-helpers for enum type variable creation, added new line in the end if api.json
- library libsecp256k1 upgraded to fix https://rustsec.org/advisories/RUSTSEC-2019-0027
tuple_list_as_arrayparameter intvm.run_getfunction which controls lists representation. Default is stack-like based on nested tuples. If set totruethen returned lists are encoded as plain arrays. Use this option if you receive this error on Web: "Runtime error. Unreachable code should not be executed..." This reduces stack size requirements for long lists.function_namefield ofCallSetstructure can be the name or id (as string in hex starting with 0x) of the called function.- Fields
config_servers,query_url,account_address,gas_usedadded into specific errors'ClientError.dataobject.
- Binaries download links are now under https protocol
- If you receive this error on Web: "Runtime error. Unreachable code should not be executed..."
in
run_get, use the new parametertuple_list_as_array = true. See the documentation. This may happen, for example, when elector contract contains too many participants
- Debot Module:
- Added new built-in interface
Msgwhich allows to send external message to blockchain and sign it with supplied keypair.
- Added new built-in interface
crypto.hdkey_public_from_xprvused compressed 33-byte form instead of normal 32-byte.
- BOC cache management functions were introduced:
boc.cache_set,boc.cache_getboc.cache_unpin
- Now functions that take boc as a parameter can also take a reference to boc cash instead so that
it decreases the number of boc serialization
and deserializations which drastically improves performance of
run_tvmandrun_executorespecially in case of numerous calls on the same data. boc_cacheparameter intvm.run_tvmandtvm.run_executorfunctions to save resulting messages and account BOCs into cache.return_updated_accountflag parameter introduced intvm.run_tvmandtvm.run_executorfunctions to return updated account state. Important: by default this flag isfalseand account data is not returned.abi.encode_internal_messagefunction to encode an internal ABI-compatible message.- Debot Module:
- Support for get-methods and external calls in debots. Debots can send external inbound messages to destination contracts (signed - for external calls and unsigned - for get-methods) using native language syntax without actions.
- Built-in debot interfaces (interfaces implemented by DEngine). Added two built-in interfaces: base64 and Sdk.
- Added
DebotInterfaceExecutorto automatically route messages to destination interfaces. - Debot's
fetchfunction is optional now. New debots can implement onlystartfunction.
- Expired message wasn't retried if local execution succeeded.
ResponseHandlertype description intomodules.md.
net.batch_queryparameters serialization did't match to docs.- Module description in docs generator contains
nullinstead of summary. - Function result section header hadn't the line separator before.
nacl_sign_detached_verifyfunction to verify detached signature.aggregate_collectionfunction as a wrapper for GraphQL aggregation queries.batch_queryfunction performs multiple queries per single fetch.- Active endpoint invalidation in case of network error occurring.
network.network_retries_countconfig parameter is deprecated.network.max_reconnect_timeoutis introduced that allows to specify maximum network resolving timeout. Default value is 2 min.initial_pubkeyfield inDeploySetto specify public key instead of one from TVC file or provided by signer.- Support for debot interfaces:
sendBrowser Callback to send messages with interface calls to Browser.- new variant
ParamsOfAppDebotBrowser::Send. sendAPI function to send messages from Browser to Debot.run_output.rs- internal structure RunOutput to filter messages generated by debot to 4 categories: interface calls, external calls, get-method calls and invoke calls.
- Device time synchronization is checked only in
send_message. Data querying does not require proper time now
netmodule functions waits fornet.resumecall instead of returning error if called while the module is suspended
- How to work with
Application Objectsspecification added
- Updated the dependence on
ton-labs-abi
reconnect_timeoutparameter inNetworkConfig.endpointsparameter inNetworkConfig. It contains the list of available server addresses to connect. SDK will use one them with the least connect time.server_addressparameter is still supported butendpointsis prevailing.net.fetch_endpointsfunction to receive available endpoints from server.net.set_endpointsfunction to set endpoints list for using on next reconnect.ErrorCodetype in each module spec inapi.json.
- send
GQL_TERMINATE_CONNECTIONand close websocket on leaving ws loop.
- GraphQL optimization: use single web socket to serve all subscriptions.
- Support for the
keep-alivemessages from the GraphQL server. tonclient-core-versionhttp header.net.find_last_shard_blockfunction returning account shard last block ID.boc.get_code_from_tvcfunction extracting contract code from TVC image.- Debot Module:
- Add new variant
ParamsOfAppDebotBrowser::SwitchCompletedto notify browser when all context actions are shown. - Added new 3 engine routines for crypto operations and 1 routine for querying account state ( balance, state type, code, data) that can be used in debots.
- Add new variant
- Debot Module:
- Invoked debot terminated correctly after error occurred during execution of one of its actions. Initial prev_state of invoked debot changed to STATE_EXIT.
- Fixed double jumping to current context in invoker debot after returning control to it from invoked debot.
- Fixed conversation of exception codes thrown by debots to their user-friendly description.
net.querymethod . Performs custom graphql query that can be copied directly from the playground.net.suspendandnet.resumemethods for disabling and enabling network activity. One of the possible use-cases is to manage subscriptions when a mobile application is brought to the background and into the foreground again.- Smart summary and description doc separation.
- ts-generator includes doc comments in JSDoc format.
-
UNSTABLE API. This API is experimental. It can be changed in the next releases.
debotmodule was added with debot engine functions, such as :start,fetch,execute,remove. See thedebotmodule documentation for more info. Check our tests for code examples. -
External signing was supported for message encoding:
SigningBoxtype forSignerenum was supported. Now it is possible to sign messages with externally implemented signing box interface without private key disclosure to the library. Can be used in case of signing via HSM API or via cold wallet - when there is no access to the private key.It is also possible to create a Signing Box instance inside SDK - from a key pair passed into the library with
get_signing_boxmethod. It can be used for some test cases. Also it increases security - you need to pass your keys one time only.Check the
cryptomodule documentation forSigningBoxHandletype andregister_signing_box,get_signing_box,signing_box_get_public_key,signing_box_sign. Check our tests for code examples.
- panic after
tc_destroy_contextcall. Now all contexts use global async runtime - field
mnemonic_hdkey_compliantwas removed fromCryptoConfig(unused by the library) - original and resolved errors are swapped in result. Now
error.codecontains original error code
wasmfeature has been fixedcrypto.factorizedoesn't panic on invalid challengeclient.get_api_referencereturns proper version- ABI JSON with explicit function ID is parsed properly
- Compatible with older rust version change api type derivation with
vec![]instead of prev[].into()
- ChaCha20 encryption support
crypto.chacha20. boc.parse_shardstatefunction for shardstates parsing.boc.get_boc_hashfunction for calculating BOC root hashclient.build_infofully defined and documented.processing.wait_for_transactionandprocessing.process_messagefunctions execute contract locally in case if transaction waiting fails in order to resolve the contract execution errorrun_executor,run_tvmnow returnexit_argin case of TVM errors.- Create the
build_info.jsonon the build stage. Abi::Contractvariant as an alias to deprecatedAbi::SerializedAbi::Jsonvariant to specify an ABI as a raw JSON string.api.jsonnow contains details about numeric types: Number and BigInt are now have new fieldsnumber_typeandnumber_size.api.jsonref type names are fully qualified now in form ofmodule.type, for exampleabi.Signer.
- TS generator fix some field names that is an invalid JS identifiers.
- Use
install_name_toolto fix loading library paths atlibton_client.dylib. api.jsonis reduced, so it can't contain tuple types, only structs. All types are exactly match to JSON.out_of_sync_thresholdconfig parameter isu32
tc_request_ptrfunction to use pointersvoid*instead of request_idu32. This feature is UNSTABLE yet.
- All api functions are defined in mod.rs of appropriate modules
- Function names are the same as API function names:
module.function_name - Parameters naming:
- In snake case
- Base64 suffix is removed from parameter names. For example,
bocBase64is changed toboc
- Parsed boc replaced with unparsed boc in all function input parameters
- All functions take byte arrays in a defined encoding:
base64- encoding used for byte arrays of variable length: text, images, etc.hex-lower-case- encoding used to encode fixed length bit sequences: hashes, keys, salt, etc.
contractsmodule is splitted into 5 modules:tvm- embedded TVM execution functionsboc- raw cell and BOC manipulation functionsabi- abi-compatible messages creation and parsing functionsprocessing- blockchain interaction functionsutils- has onlyconvert_addressATM, later will be used for some useful stuff
querymodule is renamed tonet- new
clientmodule with functionsversion,api_reference - All the environment functions (fetch, websocket, spawn, now, etc.) were abstracted behind a
separate environment layer crate
ClientEnv. The standard core env layer implementation is instd_client_env. Later (in 1.1 release)web_client_envimplementation for Web will be added. - Error codes are distributed across the modules the following way:
client- 0..99,crypto- 100..199,boc- 200..299,abi- 300..399,tvm- 400..499,processing- 500..599,net- 600..699 - Error descriptions related to a module are described in error.rs file in the module's folder
decode_message,process_message,wait_for_transaction,run_tvm,run_executor, etc. (all the functions that return decoded messages) now returns int*/uint* data as a string which can be either decimal or 0x-prefixed hex string. Hex representation can be in any register and have any number of leading zeroes.
-
All the functions are asynchronous
-
All the functions that can be called via JSON-api are public, so that they can be used directly without JSON-api.
-
Inline documentation and api reference added.
-
[breaking]
interops.rs,tonclient.h.create_contextnow takesconfigparameter - context creation and setup happen at the same time. Config structure has been changed. -
[breaking]
crypto module.default values for mnemonic-related functions have been changed:dictionary is 1, for word count is 12, derivation path is 'm/44'/396'/0'/0/0
-
[breaking] crypto module. removed
word_countparameter fromwordsfunction -
[breaking] crypto module.
compliantparameter is removed from functionsmnemonic_derive_sign_keys,hdkey_xprv_derive_path,hdkey_xprv_derive, -
[new] boc module. Functions
parse_block,parse_account,parse_message,parse_transactionthat parse bocs to JSONs are introduced. -
[breaking] net module. Functions
query,wait.for,subscribeare renamed toquery_collection,wait_for_collection,subscribe_collectiontableparameter is renamed tocollection.filterparameter is now optional and ofjsontype (passed as json object instead ofstring) -
[breaking] net module. Function
get.nextis removed. -
[breaking] net module.
subscribe_collectionnow uses callback to return data. -
[breaking] abi module.
decode_messageintroduced instead ofdecode_unknown_run,decode_run_output -
[breaking] abi module.
encode_messageintroduced instead ofencode_unsigned_deploy_message,encode_unsigned_run_message,run.encode_message,deploy.encode_message -
[breaking] abi module.
signer: Signerparameter used instead ofkey_pair: KeyPair, which can be ofNone(unsigned message will be produced),External(data to be signed +unsigned message),Keys(signed message will be produced),SigningBox(message will be signed using a provided interface - will be supported in coming releases) -
[breaking] processing module.
process_messageintroduced instead ofdeployandrun. Parameter set was drastically changed. -
[breaking] processing module.
process_message- now, if the contract was already deployed, deploy fails with an exception of double constructor call. -
[new] processing module.
process_message- any function can be called at deploy, not only constructor, also there can be no function call. -
[new] processing module.
process_messagenow can optionally use callback to monitor message processing (creation, sending, shard block fetching, transaction receiving). -
[fixed] processing module.
process_message- deploy can be performed without a key pair -
[breaking] tvm module.
run_localis divided into 2 functionsrun_tvmandrun_executor. -
[new] tvm module.
run_tvmfunction - performs contract code execution on tvm (part of compute phase). Helps to run contract methods without ACCEPT. Returns account state with updated data, list of external messages and (optional, for ABI contracts only) list of messages decoded data. -
[new] tvm module.
run_executorfunction - performs full contract code execution on Transaction Executor (part of collator protocol that performs all phases and checks and - as a successful result - forms a transaction) Returns updated account state, parsed transaction, list of parsed messages with optional decoded message bodies. -
[breaking] tvm module.
run_getdoes not download account boc from the network anymore, but takes account boc as a parameter.
config.get_api_referenceapi function (pre release).ton_sdk_clicli tool (pre release).- full local run functions use
LocalRunContextto exactly reproduce all transaction parameters and produce the same result as node
waitForTransactiondidn't use prev_alt_ref for block walking
- All methods that require contract's code/data can use field
bocin account document to extract code and data (instead ofcodeanddatafields). - Optional
bocBase64parameter of methodtvm.getthat can be used instead ofcodeBase64anddataBase64.
error.dataobject extended with fieldsaddress,function_name,account_balance,account_address,query_url,config_serverfor appropriate errors
- supports for core context in all platforms
- local run functions return updated contract state when running with
full_run = true - time sync check while initializing
- parallel requests on different contexts don't block each other. Requests on the same context remain sequential
- new transaction wait mechanism. All account's shard blocks are checked for transaction to guarantee message expiration
contracts.wait.transactionfunction for awaiting previously sent message processingcontracts.send.messagereturns message processing state forcontracts.wait.transactionfunctioncontracts.find.shardfunction for account shard matching- added logging on warning messages
- error resolving by local message processing
contracts.resolve.errorfunction for manual error resolving callcontracts.process.transactionfunction processing transaction to check errors and get outputcontracts.run.localandcontracts.run.localfunctions now havefullRunflag to emulate node transaction processing and calculate feestonsdkcommand line tool.ton_clientfunctionget_method_names.
- TON mnemonic functions didn't check validity of the seed phrase.
- Platform builder generates ready to use
index.jsfor web clients (instead of install script ofton-client-web-jsbinding)
tvm.getnow can fetch account data if it is not provided
- Message processing functions added
- Run get methods function added
ed25519-dalekversion updated to1.0.0-pre.3- SDK is fully open sourced since open repo
ton-labs-executorused
- Panic in fee calculation under WASM
reqwestcrate version synced in all projects- Memory leaking in Node JS