Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Proof integration merged #1576

Open
wants to merge 58 commits into
base: master
Choose a base branch
from
Open
Changes from 13 commits
Commits
Show all changes
58 commits
Select commit Hold shift + click to select a range
120921c
Implement accessing store directly through the iavl in cGet
toml01 Apr 17, 2023
2473772
Add block_height to wasm3 context
toml01 Apr 18, 2023
c7492c0
Add block_height to read_db ocall
toml01 Apr 18, 2023
445a78f
Update the read_db api on go-cosmwasm
toml01 Apr 18, 2023
330ba59
Try to fix the cgo interface
toml01 Apr 18, 2023
49815a7
Fix the ocall interface
toml01 Apr 18, 2023
c5b2953
Fixed passing the height to the query
Cashmaney Apr 24, 2023
e457e4b
Fix querying directly from iavl for prefix store
toml01 May 18, 2023
d1c5cb1
Return proof all the way to the enclave
toml01 May 18, 2023
e2c41da
Better errors in go-cosmwasm
toml01 May 18, 2023
4e43271
Clippy it's not you it's me
toml01 May 18, 2023
223abfc
demo of getting module hashes
toml01 Jun 13, 2023
534c94a
Return the full prefixed key with the ocall as well + fix a bug in oc…
toml01 Jun 18, 2023
fcaa722
demo of getting module hashes
toml01 Jun 13, 2023
8cada85
Implement storesRootsFromMultiStore()
toml01 Jun 14, 2023
bda2c52
Fix storesRootsFromMultiStore (hash value of store hash)
toml01 Jun 14, 2023
5d28c26
Some plumbing
toml01 Jun 15, 2023
3276cd4
Construct app hash
toml01 Jun 15, 2023
2442ad9
send the compute root as well
toml01 Jun 18, 2023
bf4de89
READ_PROOFER static struct
toml01 Jun 18, 2023
bd46e69
Verify input to ecall_submit_store_roots and populate READ_PROOFER
toml01 Jun 18, 2023
4833c86
Add verification in ecall_submit_block_signatures()
toml01 Jun 18, 2023
f181e08
clippy
toml01 Jun 18, 2023
2a0f39d
don't verify apphash for the first block
toml01 Jun 19, 2023
f42fd72
Verifying merkle proofs for every read. Still buggy for queries
toml01 Jun 20, 2023
399689c
Return the full prefixed key with the ocall as well + fix a bug in oc…
toml01 Jun 18, 2023
c0102a2
Implement storesRootsFromMultiStore()
toml01 Jun 14, 2023
8536106
Fix storesRootsFromMultiStore (hash value of store hash)
toml01 Jun 14, 2023
da858d3
Some plumbing
toml01 Jun 15, 2023
f6a3468
Construct app hash
toml01 Jun 15, 2023
b69816c
send the compute root as well
toml01 Jun 18, 2023
fd689b2
refactor merkle proofs to be on it's own crate + add a feature flag
toml01 Jun 28, 2023
add04bb
app.go cleanup
toml01 Jul 2, 2023
81596e8
Fixed read db tests without feature
Cashmaney Jul 25, 2023
77480d0
Add merging of multiple kv-caches for the same contract
Cashmaney Jul 26, 2023
da2c772
Add merging of multiple kv-caches for the same contract
Cashmaney Jul 26, 2023
45f9911
fixed clippy warnings
Cashmaney Jul 26, 2023
b0849cd
Fixed tests (remove from cache missing in remove_db because the branc…
Cashmaney Jul 26, 2023
2e0ef3c
Merge remote-tracking branch 'origin/master' into HEAD
Cashmaney Jul 26, 2023
855b0b6
Merged proofs branch with master (does it work?)
Cashmaney Jul 26, 2023
406a303
Merged proofs branch with master (does it work?)
Cashmaney Jul 26, 2023
fa4c10a
Merge remote-tracking branch 'origin/merge-proofs-master' into HEAD
Cashmaney Jul 30, 2023
5696bcb
Merge master with the cache changes
Cashmaney Jul 30, 2023
a18dd5f
Update go-lint.yml
Cashmaney Jul 31, 2023
b1d8448
Update .golangci.yml
Cashmaney Jul 31, 2023
3349a07
Update .golangci.yml
Cashmaney Jul 31, 2023
7b2b85d
fumpt
Cashmaney Jul 31, 2023
2060e15
Update Dockerfile
Cashmaney Aug 1, 2023
556b9a1
Merge pull request #1495 from scrtlabs/cache-with-master
Cashmaney Aug 2, 2023
71d4e2e
Merge branch 'master' into store-merkle-proofs
toml01 Oct 30, 2023
2927ae8
Merge branch 'store-merkle-proofs' into compute-root-validation
toml01 Oct 30, 2023
ee397ab
Merge remote-tracking branch 'origin/store-merkle-proofs' into comput…
toml01 Oct 30, 2023
7bc88bf
Add dependencies for merkle proofs
toml01 Oct 30, 2023
df929f2
compilation and clippy
toml01 Oct 30, 2023
c3fa20c
Merge remote-tracking branch 'origin/compute-root-validation' into pr…
Cashmaney Oct 31, 2023
cf60e62
Fix all the stuff I broke :(
Cashmaney Oct 31, 2023
6168193
Fix all the stuff I broke :(
Cashmaney Nov 1, 2023
72b87f7
Fix all the stuff I broke :(
Cashmaney Nov 1, 2023
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 2 additions & 2 deletions .github/workflows/go-lint.yml
Original file line number Diff line number Diff line change
@@ -16,8 +16,8 @@ jobs:
steps:
- uses: actions/setup-go@v4
with:
go-version: 1.19
- uses: actions/checkout@v3
go-version: 1.21
- uses: actions/checkout@v4
- name: make bin-data-sw
run: |
go install github.com/jteeuwen/go-bindata/go-bindata@latest
4 changes: 4 additions & 0 deletions .vscode/settings.json
Original file line number Diff line number Diff line change
@@ -18,8 +18,12 @@
"integration-tests/contract-v0.10/Cargo.toml",
"cosmwasm/contracts/v1/compute-tests/random-test/Cargo.toml",
"go-cosmwasm/Cargo.toml",
"integration-tests/contract-v0.10/Cargo.toml",
"check-hw/Cargo.toml",
"./cosmwasm/enclaves/shared/block-verifier/Cargo.toml",
"cosmwasm/enclaves/shared/cosmos-proto/Cargo.toml",
"cosmwasm/enclaves/shared/contract-engine/Cargo.toml",
"cosmwasm/enclaves/shared/utils/Cargo.toml",
"check-hw/Cargo.toml",
"./cosmwasm/enclaves/shared/block-verifier/Cargo.toml"
],
26 changes: 25 additions & 1 deletion app/app.go
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
package app

import (
"encoding/binary"
"fmt"
"io"
"net/http"
@@ -344,7 +345,7 @@ func (app *SecretNetworkApp) BeginBlocker(ctx sdk.Context, req abci.RequestBegin
return app.mm.BeginBlock(ctx, req)
}

func storesRootsFromMultiStore(rootMulti *rootmulti.Store) kv.Pairs {
func storesRootsFromMultiStore(rootMulti *rootmulti.Store) kv.Pairs { //[][]byte {
stores := rootMulti.GetStores()
kvs := kv.Pairs{}

@@ -363,6 +364,29 @@ func storesRootsFromMultiStore(rootMulti *rootmulti.Store) kv.Pairs {
return kvs
}

// This is a copy of an internal cosmos-sdk function: https://github.com/scrtlabs/cosmos-sdk/blob/1b9278476b3ac897d8ebb90241008476850bf212/store/internal/maps/maps.go#LL152C1-L152C1
// pairBytes returns key || value, with both the
// key and value length prefixed.
func pairBytes(kv kv.Pair) []byte {
// In the worst case:
// * 8 bytes to Uvarint encode the length of the key
// * 8 bytes to Uvarint encode the length of the value
// So preallocate for the worst case, which will in total
// be a maximum of 14 bytes wasted, if len(key)=1, len(value)=1,
// but that's going to rare.
buf := make([]byte, 8+len(kv.Key)+8+len(kv.Value))

// Encode the key, prefixed with its length.
nlk := binary.PutUvarint(buf, uint64(len(kv.Key)))
nk := copy(buf[nlk:], kv.Key)

// Encode the value, prefixing with its length.
nlv := binary.PutUvarint(buf[nlk+nk:], uint64(len(kv.Value)))
nv := copy(buf[nlk+nk+nlv:], kv.Value)

return buf[:nlk+nk+nlv+nv]
}

// EndBlocker application updates every end block
func (app *SecretNetworkApp) EndBlocker(ctx sdk.Context, req abci.RequestEndBlock) abci.ResponseEndBlock {
return app.mm.EndBlock(ctx, req)
76 changes: 41 additions & 35 deletions cosmwasm/enclaves/Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

13 changes: 9 additions & 4 deletions cosmwasm/enclaves/execute/Cargo.toml
Original file line number Diff line number Diff line change
@@ -32,15 +32,18 @@ test = [
]
use_seed_service_on_bootstrap = []
epid_whitelist_disabled = []
light-client-validation = ["enclave_contract_engine/light-client-validation", "block-verifier"]
light-client-validation = [
"enclave_contract_engine/light-client-validation",
"block-verifier",
]
read-db-proofs = [
"enclave_contract_engine/read-db-proofs",
"block-verifier/read-db-proofs",
]
random = ["enclave_contract_engine/random", "enclave_crypto/random"]
verify-validator-whitelist = [
"block-verifier/verify-validator-whitelist",
"light-client-validation"
"light-client-validation",
]
go-tests = []
check-hw = []
@@ -72,7 +75,7 @@ ctor = "0.1.13"
derive_more = "0.99"
pwasm-utils = { version = "0.12.0", default-features = false }
parity-wasm = { version = "0.45.0", default-features = false, features = [
"sign_ext"
"sign_ext",
] }
base64 = { rev = "dc7389e10817b078f289386b3b6a852ab6c4c021", git = "https://github.com/mesalock-linux/rust-base64-sgx" }
# for attestation
@@ -88,11 +91,13 @@ log = "0.4.17"
simple_logger = { version = "2.3.0", default-features = false, features = [
"stderr",
] }

block-verifier = { path = "../shared/block-verifier", optional = true }
read-verifier = { path = "../shared/read-verifier" }

time = "=0.3.17"
tendermint = { git = "https://github.com/scrtlabs/tendermint-rs", branch = "fix-val-set-parsing", default-features = false }
cosmos-sdk-proto = { version = "0.16.0", default-features = false }
integer-encoding = "3.0.4"

[dependencies.webpki]
git = "https://github.com/mesalock-linux/webpki"
8 changes: 8 additions & 0 deletions cosmwasm/enclaves/execute/Enclave.edl
Original file line number Diff line number Diff line change
@@ -168,6 +168,14 @@ enclave {
uintptr_t in_compute_root_len
);


public sgx_status_t ecall_submit_store_roots(
[in, count=in_roots_len] const uint8_t* in_roots,
uintptr_t in_roots_len,
[in, count=in_compute_root_len] const uint8_t* in_compute_root,
uintptr_t in_compute_root_len
);

};

untrusted {
Loading

Unchanged files with check annotations Beta

package api

Check failure on line 1 in go-cosmwasm/api/iterator.go

GitHub Actions / lint

: # github.com/scrtlabs/SecretNetwork/go-cosmwasm/api
import (
"sync"
code_id []byte,
params []byte,
gasMeter *GasMeter,
store KVStore,

Check failure on line 226 in go-cosmwasm/api/lib.go

GitHub Actions / lint

undefined: KVStore

Check failure on line 226 in go-cosmwasm/api/lib.go

GitHub Actions / lint

undefined: KVStore
api *GoAPI,
querier *Querier,
gasLimit uint64,
params []byte,
msg []byte,
gasMeter *GasMeter,
store KVStore,

Check failure on line 280 in go-cosmwasm/api/lib.go

GitHub Actions / lint

undefined: KVStore

Check failure on line 280 in go-cosmwasm/api/lib.go

GitHub Actions / lint

undefined: KVStore
api *GoAPI,
querier *Querier,
gasLimit uint64,
func getInnerIavl(store sdk.KVStore, key []byte) (iavlStore *iavl.Store, fullKey []byte, err error) {
switch st := store.(type) {
case prefix.Store: // Special case for a prefix store to get the prefixed key
return getInnerIavl(st.GetParent(), st.Key(key))

Check failure on line 18 in go-cosmwasm/api/store.go

GitHub Actions / lint

st.GetParent undefined (type prefix.Store has no field or method GetParent)

Check failure on line 18 in go-cosmwasm/api/store.go

GitHub Actions / lint

st.Key undefined (type prefix.Store has no field or method Key) (typecheck)

Check failure on line 18 in go-cosmwasm/api/store.go

GitHub Actions / lint

st.GetParent undefined (type prefix.Store has no field or method GetParent)

Check failure on line 18 in go-cosmwasm/api/store.go

GitHub Actions / lint

st.Key undefined (type prefix.Store has no field or method Key)) (typecheck)

Check failure on line 18 in go-cosmwasm/api/store.go

GitHub Actions / MacOS-ARM64-CLI

st.GetParent undefined (type prefix.Store has no field or method GetParent)

Check failure on line 18 in go-cosmwasm/api/store.go

GitHub Actions / MacOS-ARM64-CLI

st.Key undefined (type prefix.Store has no field or method Key)
case storeWithParent:
return getInnerIavl(st.GetParent(), key)
case *cache.CommitKVStoreCache:
package enclave
import (
"github.com/scrtlabs/SecretNetwork/go-cosmwasm/api"

Check failure on line 4 in x/registration/internal/keeper/enclave/enclave.go

GitHub Actions / lint

could not import github.com/scrtlabs/SecretNetwork/go-cosmwasm/api (-: # github.com/scrtlabs/SecretNetwork/go-cosmwasm/api
)
type Api struct{}