Skip to main content

Soroban Settings

Soroban has a large collection of settings stored on-ledger that can be modified through a validator vote. Here you can find out how to propose a new settings upgrade as well as how to examine a proposed upgrade. You can also look at the Commands page for more details on the stellar-core commands used below.

Propose a Settings Upgrade

This section will describe how to propose a settings upgrade, but take a look at the Upgrading the Network page for more information on how the settings upgrade mechanism works internally.

info

If you are being asked to vote for an upgrade, please move on to the Examine a Proposed Upgrade section for details on how to accomplish that.

Helper Script

A script to help you create the transactions below is available in the stellar-core GitHub repo, with usage details also available. We've saved the information below for now, because it's important to be aware of how the underlying process to generate the transactions works in case the script has some issues.

1. Create an Upgrade Set

The stellar CLI tool allows for the use of a JSON input file to encode a collection of Soroban settings into an base64-encoded string representing the XDR type ConfigUpgradeSet. You can use the pubnet_phase1.json and pubnet_phase2.json files as a starting point to formulate your upgrade proposal. You can also pull directly from a running core node using http-command 'sorobaninfo?format=upgrade_xdr' | stellar-xdr decode --type ConfigUpgradeSet --output json-formatted. This will allow you to get the exact settings running on that core node in JSON format, making it easier to change only the value you want to. Once you have your JSON file with updated values, use the following command to create the required upgrade set XDR:

stellar xdr encode --type ConfigUpgradeSet path/to/upgrade.json

The output of the phase 2 JSON file, for example, would look like:

AAAAAgAAAAEAAAAAHc1lAAAAAAAF9eEAAAAAAAAAABkCgAAAAAAAAgAAAMgAB6EgAAAAfQABEXAAAAAoAAIIAAAAABkAAQQAAAAAAAAAGGoAAAAAAAAnEAAAAAAAAAb6AAAAAukO3QD///////0NfwAAAAAAAOFfAAAD6A==
info

stellar CLI can be installed using brew or cargo:

brew install stellar-cli
# OR
cargo install --locked stellar-cli --features opt

You can also download a precompiled binary of the latest release for your system from GitHub.

2. Generate Settings Upgrade Transactions

You can use stellar-core's get-settings-upgrade-txs command to create a series of transactions that will:

  1. Restore the Wasm entry from the next step (if it exists).
  2. Upload a simple smart contract's Wasm bytecode to the network that allows for Temporary ledger entries to be created, keyed using Bytes SCVals.
  3. Create's a contract instance from the previously uploaded Wasm bytecode.
  4. Invoke the newly created contract instance's write function with your (validated) base64-encoded upgrade set.

You're required to provide four arguments for this command:

  • PUBLIC_KEY: (positional) the public key that will be the source for these transactions. Note that you will be submitting transactions, so the account for the public key specified must exist and have the funds to pay the transaction fees.
  • SEQUENCE_NUMBER: (positional) the current sequence number for the specified public key.
  • NETWORK_PASSPHRASE: (positional) the network passphrase for the network these transactions will be submitted to.
  • --xdr AAAA...: the base64-encoded upgrade set generated in step 1.
  • --signtxs: (optional) if provided, this command will prompt you for a secret key and will return signed transactions that can be submitted to the network right away.

For example, the command for the phase 2 upgrade might have looked like this:

sudo -u stellar stellar-core --conf /etc/stellar/stellar-core.cfg get-settings-upgrade-txs \
GAUQW73V52I2WLIPKCKYXZBHIYFTECS7UPSG4OSVUHNDXEZJJWFXZG56 \
73014444032 \
"Public Global Stellar Network ; September 2015" \
--xdr AAAAAgAAAAE... \
--signtxs

This command's output will include three sets of TransactionEnvelopes and corresponding transaction Hashes, followed by a base64-encoded ConfigUpgradeSetKey XDR string:

# restore Wasm `TransactionEnvelope` (truncated here)
AAAAAgAAAABSvbro8P/XAQP+eTvW1TnB4+r4vZx5fKj+DsWuWN3gjQX14QAAA...LgymJ36XIBrUVMU2wg=
# restore Wasm transaction `Hash`
3a2457d3fc081ab3a72dfe7ee2236f3a282c62f21d7e3dbdb5b13ac0d09c8647
# upload Wasm `TransactionEnvelope` (truncated here)
AAAAAgAAAABi/B0L0JGythwN1lY0aypo19NHxvLCyO5tBEc...wF9wL68IAAAAdkJxSgpyRStTvbSA9jgs=
# upload Wasm transaction `Hash`
19c49f18e5442db9d626f7485c34ecb0cd938034255515099b37acebdb6677a7
# create contract instance `TransactionEnvelope` (truncated here)
AAAAAgAAAABi/B0L0JGythwN1lY0aypo19NHxvLCyO5tBEc...AAd0OB3n3Yadews=
# create contract instance transaction `hash`
9e70cbff631247638fae96b9d996d8d22b6fa75208380d5f5d714a57c0a90947
# invoke contract `TransactionEnvelope` (truncated here)
AAAAAgAAAABi/B0L0JGythwN1lY0aypo19NHxvLCyO5tBEc...F9wX14QAAAAARAAAAAwAAAAAAAAAAAAAAAQAAAAAAAAAYAAAAAAAAAAGd/IhWQcE2UdzIof7ygqCuAmYD8ycsJbB
# invoke contract transaction `Hash`
4f6457d3fc081ab3a72dfe7ee2236f3a282c62f21d7e3dbdb5b13ac0d09c8647
# base64-encoded `ConfigUpgradeSetKey`
nfyIVkHBNlHcyKH+8oKgrgJmA/MnLCW3E4Fhg4XYTkqZa2MyqzRdB2+mN3DOKUFKtZIAXp6o3DHrkgR0mo7rUw==

3. Submit Settings Upgrade Transactions

These four transactions can then be submitted to the network through your node. Replace the blob placeholders below with the TransactionEnvelopes in lines 1, 3, 5, and 7.

note

If you didn't provide the --signtxs parameter to the get-settings-upgrade-txs command, don't forget to sign them before submitting to the network.

http-command 'tx?blob=<LINE_1_OUTPUT>'
http-command 'tx?blob=<LINE_3_OUTPUT>'
http-command 'tx?blob=<LINE_5_OUTPUT>'
http-command 'tx?blob=<LINE_7_OUTPUT>'

4. Verify Proposed Upgrades

You can verify that the proposed upgrades have been set up using stellar-core's dumpproposedsettings command, providing the ConfigUpgradeSetKey XDR string from line 9 above:

http-command 'dumpproposedsettings?blob=<LINE_9_OUTPUT>'

5. Schedule the Upgrades

Now you can schedule the upgrade on all the required validators using stellar-core's upgrades command, providing the ConfigUpgradeSetKey output from line 9 above and an agreed upon time in the future:

http-command 'upgrades?mode=set&upgradetime=YYYY-MM-DDTHH:MM:SSZ&configupgradesetkey=<LINE_9_OUTPUT>'

6. Update Stellar Expert

One of the most-used methods of "watching" an upgrade take place for the network's Soroban settings is the Protocol History page on stellar.expert.

In order to make sure that page gets updated with the proposed upgrades, please fill out a PR against this repository.

Debugging

Once the four transactions are run, you should see the proposed upgrade when running the dumpproposedsettings command (see step 4 above). If you don't, then either one or more of the transactions above failed during application, or the upgrade is invalid.

If any of the transactions above fail during submission, you should get a TransactionResult as a response along with the reason for the failure. The failure will most likely be due to one of the following reasons:

  • Resources are too low. You'll need to increase the hardcoded resources in SettingsUpgradeUtils.cpp.
  • Fee or refundable fee is too low. You'll need to increase them in SettingsUpgradeUtils.cpp.
  • Wasm has expired. You'll need to restore the Wasm.

You should confirm what caused the failure by looking at the TransactionResult of the failed transaction using the Stellar Lab or a block explorer.

If the transactions succeeded but the dumpproposedsettings command still returns an error, then the upgrade is invalid. The error reporting here needs to be improved, but the validity checks happen here.

Examine a Proposed Upgrade

You can use stellar-core's dumpproposedsettings command along with a base64-encoded ConfigUpgradeSetKey XDR string to query a proposed upgrade:

http-command 'dumpproposedsettings?blob=A6MvjFLujnqaZa5hacafWyYwhpk4cgRpyu0z6ilZ0pm1S7fmjSNnsyjGwGodLGiD8ss8S1AHiOBBb6GQbOeMbw=='

Examine Current Settings

You can also get the current Soroban settings to compare against by using stellar-core's sorobaninfo.

http-command 'sorobaninfo?format=detailed'