This section will guide you how to install the software required for developing a runtime and client using the Oasis SDK. After successfully completing all the described steps you will be able to start building your first runtime!
If you already have everything set up, feel free to skip to the next section.
The following is a list of prerequisites required to start developing using the Oasis SDK:
rustup cannot be installed alongside a distribution packaged Rust version. You will need to remove it (if it's present) before you can start using rustup.
Install it by running:
curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh
If you want to avoid directly executing a shell script fetched the
internet, you can also download
rustup-init executable for your platform
and run it manually.
This will run
rustup-init which will download and install the latest stable
version of Rust on your system.
Rust Toolchain Version
The version of the Rust toolchain we use in the Oasis SDK is specified in the rust-toolchain file.
The rustup-installed versions of
rustc and other tools will
automatically detect this file and use the appropriate version of the Rust
toolchain. When you are building applications that
use the SDK, it is recommended that you copy the same rust-toolchain file to
your project's top-level directory as well.
To install the appropriate version of the Rust toolchain, make sure you are in the project directory and run:
This will automatically install the appropriate Rust toolchain (if not present) and output something similar to:
nightly-2022-08-22-x86_64-unknown-linux-gnu (overridden by '/code/rust-toolchain')
rustc 1.65.0-nightly (c0941dfb5 2022-08-21)
(OPTIONAL) Fortanix SGX Rust Target
Required if you want to build runtimes that run inside the Intel SGX trusted execution environment.
To add the Fortanix SGX Rust target run the following in the project directory:
rustup target add x86_64-fortanix-unknown-sgx
Required if you want to use the Go Client SDK.
At least version 1.18.5 is required. If your distribution provides a new-enough version of Go, just use that.
install the Go version provided by your distribution,
install the desired version of Go, e.g. 1.18.5, with:
go get golang.org/dl/go1.18.5
Oasis Core Installation
The SDK requires utilities provided by Oasis Core in order to be able to run a local test network for development purposes.
The recommended way is to download a pre-built release (at least version
22.2) from the Oasis Core releases page. After downloading the binary
release (e.g. into
it as follows:
tar xf ~/Downloads/oasis_core_22.2_linux_amd64.tar.gz --strip-components=1
# This environment variable will be used throughout this guide.