HTTP JSON API which hosts a database of Entropy program metadata of open source programs which can be verified that the source code corresponds to the on-chain binary.
This works by compiling the program in a docker container using a known image. Reliably, building the same version of the program with the same docker image will give the same binary hash. To add a program to the database, you give the URL of a git repository containing the program. The program gets compiled on the server side, and metadata from the program's Cargo.toml
file gets stored under the binary hash. This hash can be used when specifying the program for an Entropy account.
There are two ways to add a program's metadata and get the hash of the compiled program in the response.
Give the git repository URL, which is passed directly to git clone
, in a POST
request to /add-program-git
.
echo -n "https://github.com/myusername/my-program.git" | http post localhost:3000/add-program-git
The response contains a series of BuildResponse
messages, with logging forwarded from the build.
If the program successfully compiles, the final message will contain the wasm binary together with its hash which is how it will be referred to on-chain. Bear in mind this can take a couple of minutes.
You can pipe a program's source code to the service using tar
and a POST
request to /add-program-tar
:
cd some_example_program
tar cvf - . | http post localhost:3000/add-program-tar
Be aware this may fail if you accidentally include the ./target
directory, and the http request becomes too big.
You can tell tar to exclude stuff like this:
tar --exclude='./target' --exclude='./.git' -cvf - . | http post localhost:3000/add-program-tar
You can get a list of all program hashes as a JSON encoded array of hex strings by making a GET
request to /programs
:
http localhost:3000/programs
Example response:
[
"64871473c40795324d86d6cb0a42c0a2b546fefe02785d8f6f0124ac2b2200e9",
"7d6ae77343476f9e585e23f81731fe2d287a3d9cc003cbd73235c2a2634e2ebe",
"a947e55b58659b5abaed2c710b9a6741fc728c81fd5b44201953745372597be5"
]
You can get JSON metadata about a particular program by making a GET
request to /program/
followed by the hex encoded hash of its binary:
http localhost:3000/program/a947e55b58659b5abaed2c710b9a6741fc728c81fd5b44201953745372597be5
Example reponse:
{
"authors": [
"peg <ameba23@systemli.org>"
],
"categories": [],
"default_run": null,
"dependencies": [
{
"features": [],
"kind": "normal",
"name": "entropy-programs-core",
"optional": false,
"path": null,
"registry": null,
"rename": null,
"req": "*",
"source": "git+https://github.com/entropyxyz/programs.git?tag=v0.8.0",
"target": null,
"uses_default_features": true
}
],
"description": null,
"documentation": null,
"edition": "2021",
"features": {},
"homepage": null,
"id": "program-always-fails 0.1.0 (path+file:///tmp/turnip/tf5ffe-1)",
"keywords": [],
"license": "Unlicense",
"license_file": null,
"links": null,
"manifest_path": "/tmp/turnip/tf5ffe-1/Cargo.toml",
"metadata": {
"component": {
"dependencies": {},
"package": "entropy:program-always-fails"
},
"entropy-program": {
"docker-image": "peg997/build-entropy-programs:version0.1"
}
},
"name": "program-always-fails",
"publish": null,
"readme": "README.md",
"repository": "https://github.com/ameba23/program-always-fails",
"rust_version": null,
"source": null,
"targets": [
{
"crate_types": [
"cdylib"
],
"doc": true,
"doctest": false,
"edition": "2021",
"kind": [
"cdylib"
],
"name": "program-always-fails",
"required-features": [],
"src_path": "/tmp/turnip/tf5ffe-1/src/lib.rs",
"test": true
}
],
"version": "0.1.0"
}
There is also a simple command-line client given as an example. For usage information run:
cargo run --example client help
Docker is required in order to build programs deterministically and git is required to be able to clone program repos. You also need the cargo-metadata
binary. If you have rust installed this comes by default, so the simplest was to get it is to install rust.
Start the http server with:
cargo run
This will start listening on port 3000. To use port 1234:
cargo run -- 1234
The following http usage examples use the http client httpie.