Smart-contract-verifier - service for verification of EVM based contracts. Ideologically, it accepts bytecode to be verified and potential source files as input and returns whether those files and bytecode correspond to each other.
The service consists of 2 parts, a verification library and a transport layer that serves requests:
- smart-contract-verifier - implements actual verification logic as a library and exposes an interface to be used by the transport layer;
- A transport layer that implements some APIs over the service (smart-contract-verifier-server).
For now, GRPC and REST API over HTTP services are available as the transport layer. However, the transport protocol is not limited to our implementation, and you could implement your own APIs using the library crate.
There are several ways to run the service discussed below.
Note: for our description we will use an HTTP/GRPC server implementation; in case of a custom API implementation, you should change smart-contract-verifier-server
to your values.
You can build the provided sources using Dockerfile or docker-compose files.
Alternatively, you can use docker images from our registry
Preparation:
-
Install rustup from rustup.rs.
-
Make sure that openssl is installed:
-
macOS:
$ brew install openssl@1.1
-
Arch Linux
$ sudo pacman -S pkg-config openssl
-
Debian and Ubuntu
$ sudo apt-get install pkg-config libssl-dev
-
Fedora
$ sudo dnf install pkg-config openssl-devel
-
-
Make sure protobuf is installed and the version (
$ protoc --version
) is at leastv3.15.0
.If protobuf version is too old, you may see the following error:
Explicit 'optional' labels are disallowed in the Proto3 syntax.
-
Install
protoc-gen-openapiv2
. You may find useful the following Action we use in our Github pipeline.If not installed, you may see the following error:
Error: Custom { kind: Other, error: "protoc failed: Unknown flag: --openapiv2_opt\n" }
Build blockscout smart-contract-verifier:
git clone git@github.com:blockscout/blockscout-rs.git
cd blockscout-rs/smart-contract-verifier
cargo build --release --bin smart-contract-verifier-server
You can find the built binary in target/release/
folder.
Another way to install the binary without cloning the repository is to use cargo straightway:
cargo install --git https://github.com/blockscout/blockscout-rs smart-contract-verifier-server
In that case, you can run the binary using just smart-contract-verifier-server
.
For the details of how to run the service, go into corresponding transport protocol layer description: