diff --git a/.dockerignore b/.dockerignore
index 73443be25..db2a49bbc 100644
--- a/.dockerignore
+++ b/.dockerignore
@@ -4,4 +4,8 @@ clib/
data/
scripts/
testnets/
-two-chains/
\ No newline at end of file
+two-chains/
+examples/
+*.md
+LICENSE
+.github
diff --git a/.github/scripts/IBC-Integration b/.github/scripts/IBC-Integration
new file mode 160000
index 000000000..1f59cf9a9
--- /dev/null
+++ b/.github/scripts/IBC-Integration
@@ -0,0 +1 @@
+Subproject commit 1f59cf9a9411075a5825e74ef229dfdc37ee4c2a
diff --git a/.github/scripts/archway b/.github/scripts/archway
new file mode 160000
index 000000000..fd95e42dd
--- /dev/null
+++ b/.github/scripts/archway
@@ -0,0 +1 @@
+Subproject commit fd95e42dd02d96feab9d3c02c12558962ab9cf95
diff --git a/.github/scripts/gochain-btp b/.github/scripts/gochain-btp
new file mode 160000
index 000000000..4c7d229c4
--- /dev/null
+++ b/.github/scripts/gochain-btp
@@ -0,0 +1 @@
+Subproject commit 4c7d229c4ec366d04d1c70b4dd09d70b901f06ef
diff --git a/.github/scripts/icon-ibc b/.github/scripts/icon-ibc
new file mode 160000
index 000000000..3886faa20
--- /dev/null
+++ b/.github/scripts/icon-ibc
@@ -0,0 +1 @@
+Subproject commit 3886faa20bff076f4b2652050280614afa9ad2f9
diff --git a/.github/scripts/start_relay.sh b/.github/scripts/start_relay.sh
new file mode 100755
index 000000000..34e636616
--- /dev/null
+++ b/.github/scripts/start_relay.sh
@@ -0,0 +1,188 @@
+#!/bin/bash
+
+SCRIPT=$(readlink -f $0)
+SUBMODULE_DIR=$(dirname $SCRIPT)
+
+GPG_FINGERPRINT="C787AB518A0C08B7AE1E1ADA2809A1A84E32159A"
+
+ARCHWAY_CONTAINER='archway-node-1'
+
+cd $SUBMODULE_DIR
+
+echo $PWD
+
+# Correct path
+search_strings=(
+ "export IBC_RELAY="
+ "export IBC_INTEGRATION="
+ "export ICON_DOCKER_PATH="
+ "export WASM_DOCKER_PATH="
+)
+
+replacement="\$GITHUB_WORKSPACE\/.github\/scripts"
+for search_string in "${search_strings[@]}"; do
+ sed -i "/$search_string/ s/\$HOME/$replacement/g" ./icon-ibc/const.sh
+done
+
+sed -i 's/export WASM_WALLET=godWallet/export WASM_WALLET=default/' ./icon-ibc/const.sh
+sed -i 's/\(export WASM_EXTRA=\)"\([^"]*\)"\(.*\)/\1"--keyring-backend test"\3/' ./icon-ibc/const.sh
+
+# Use below lines until there is version fix on wasm file
+sed -i 's/\.wasm/_\.wasm/g' ./icon-ibc/const.sh
+sed -i 's/cw_xcall_.wasm/cw_xcall_0.1.0.wasm/g' ./icon-ibc/const.sh
+sed -i 's/cw_mock_dapp_multi_.wasm/cw_mock_dapp_multi_0.1.0.wasm/g' ./icon-ibc/const.sh
+
+cat ./icon-ibc/const.sh
+
+# sed -i 's/ARCHWAY_NETWORK=localnet/ARCHWAY_NETWORK=docker/' consts.sh
+mkdir -p ~/.relayer/config
+mkdir -p ~/keystore
+cp ./gochain-btp/data/godWallet.json ~/keystore/godWallet.json
+# Import fd account
+pass init $GPG_FINGERPRINT
+
+echo "### Create default wallet"
+wallet=$(archwayd keys add default --keyring-backend test | awk -F\: '/address/ {print $2}' | tr -d '[:space:]')
+echo $wallet
+
+relay_wallet=$(archwayd keys add relayWallet --keyring-backend test | awk -F\: '/address/ {print $2}' | tr -d '[:space:]')
+
+archwayd keys list --keyring-backend test
+
+
+
+
+cd ${SUBMODULE_DIR}/archway
+
+echo "## Before update .."
+cat contrib/localnet/localnet.sh
+# sed -i '/^archwayd add-genesis-account.*/a archwayd add-genesis-account "'"$wallet"'" 100000000000stake --keyring-backend=test' contrib/localnet/localnet.sh
+
+sed -i '/archwayd add-genesis-account "\$addr" 1000000000000stake --keyring-backend=test/{p; a\
+archwayd add-genesis-account "'"$wallet"'" 100000000000stake --keyring-backend=test\
+archwayd add-genesis-account "'"$relay_wallet"'" 100000000000stake --keyring-backend=test
+}' contrib/localnet/localnet.sh
+
+awk '!seen[$0]++' contrib/localnet/localnet.sh > contrib/localnet/localnet_new.sh
+mv contrib/localnet/localnet_new.sh contrib/localnet/localnet.sh
+sed -i 's/latest/v0.4.0/' docker-compose.yaml
+
+echo "### Check archwayd keys list on local"
+archwayd keys list --keyring-backend os
+
+echo "### Check archwayd start script content"
+cat contrib/localnet/localnet.sh
+
+
+cd $SUBMODULE_DIR/icon-ibc
+
+
+
+
+# make nodes
+bash -x ./nodes.sh start-all
+
+sleep 30
+echo "### Get fd wallet address"
+fdwallet=$(docker exec $ARCHWAY_CONTAINER archwayd keys list --keyring-backend test | awk -F\: '/address/ {print $2}' | tr -d '[:space:]')
+
+echo "### Check archwayd genesis file"
+docker exec $ARCHWAY_CONTAINER cat /root/.archway/config/genesis.json
+
+echo "### Check archwayd keys list on node"
+docker exec $ARCHWAY_CONTAINER archwayd keys list
+
+echo "### Check archwayd keys list on local"
+archwayd keys list --keyring-backend os
+archwayd keys list --keyring-backend test
+
+echo "default:"
+archwayd query bank balances $wallet
+echo "fd:"
+docker exec $ARCHWAY_CONTAINER archwayd query bank balances $fdwallet
+
+
+echo "default: $wallet"
+echo "fd: $fdwallet"
+
+echo "### Checking docker logs"
+docker logs $ARCHWAY_CONTAINER
+echo "### Query balance of account"
+echo "default:"
+archwayd query bank balances $wallet
+echo "fd:"
+docker exec $ARCHWAY_CONTAINER archwayd query bank balances $fdwallet
+
+echo -e "\nCopy default key to relayer keyring ======"
+mkdir -p /home/runner/.relayer/keys/localnet/keyring-test
+cp ~/.archway/keyring-test/default.info ~/.relayer/keys/localnet/keyring-test/default.info
+cp ~/.archway/keyring-test/relayWallet.info ~/.relayer/keys/localnet/keyring-test/relayWallet.info
+ls ~/.archway/keyring-test/*
+ls ~/.relayer/keys/localnet/keyring-test/*
+
+# make contracts
+echo
+echo "++++ Setting up icon"
+bash -x ./icon.sh --setup
+
+echo
+echo "++++ Setting up archway"
+bash -x ./wasm.sh --setup
+echo
+echo "++++ Deploying xcall on icon"
+bash -x ./icon.sh --deploy-dapp
+echo
+echo "++++ Deploying xcall on archway"
+bash -x ./wasm.sh --deploy-dapp
+bash -x ./cfg.sh
+
+## Check Score Address
+echo "Checking Score Address..."
+grep . $SUBMODULE_DIR/icon-ibc/env/archway/.*
+grep . $SUBMODULE_DIR/icon-ibc/env/icon/.*
+
+echo
+echo "++++ Starting handshake ..."
+# make handshake
+rly tx clients icon-archway --client-tp "10000000m"
+rly tx conn icon-archway
+
+echo
+echo "+++ Icon - Configure Connection"
+bash -x ./icon.sh -c
+echo
+echo "+++ Archway - Configure Connection"
+bash -x ./wasm.sh -c
+echo
+echo "+++ Create Channel"
+rly tx chan icon-archway --src-port=xcall --dst-port=xcall
+
+echo "Checking containers..."
+docker ps -a
+# cat ~/.relayer/config/config.yaml
+
+
+
+
+echo "### all archwayd keys:"
+archwayd keys list
+echo "### keyring: os"
+archwayd keys list --keyring-backend os
+echo "### keyring: test"
+archwayd keys list --keyring-backend test
+
+echo "### Checking keys inside archway docker node:"
+docker exec $ARCHWAY_CONTAINER archwayd keys list --keyring-backend os
+docker exec $ARCHWAY_CONTAINER archwayd keys list --keyring-backend test
+
+
+echo "+++++++++++++++++++++"
+echo
+echo
+docker ps
+echo "### Checking relay config"
+find ./ -type f -name config.yaml
+cat ~/.relayer/config/config.yaml
+echo "==> Starting relayer..."
+rly start icon-archway & sleep 60s; echo "* Stopping relay ..."; kill $!
+
diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml
index 82d1f9f0d..d6948baa1 100644
--- a/.github/workflows/build.yml
+++ b/.github/workflows/build.yml
@@ -4,7 +4,7 @@ on:
pull_request:
push:
branches:
- - master
+ - main
jobs:
build:
@@ -12,10 +12,10 @@ jobs:
runs-on: ubuntu-latest
steps:
# Install and setup go
- - name: Set up Go 1.19
- uses: actions/setup-go@v2
+ - name: Set up Go 1.20
+ uses: actions/setup-go@v4
with:
- go-version: 1.19
+ go-version: '1.20'
# setup gopath
- name: Set PATH
@@ -25,19 +25,13 @@ jobs:
# checkout relayer
- name: checkout relayer
- uses: actions/checkout@v2
-
- # setup cache
- - uses: actions/cache@v1
- with:
- path: ~/go/pkg/mod
- key: ${{ runner.os }}-go-${{ hashFiles('**/go.sum') }}
- restore-keys: |
- ${{ runner.os }}-go-
+ uses: actions/checkout@v3
# unit tests
- name: run unit tests
run: make test
+
+
# build binary
- name: build binary and move to upload location
run: make build
@@ -47,4 +41,4 @@ jobs:
uses: actions/upload-artifact@v1
with:
name: rly
- path: ./build/rly
\ No newline at end of file
+ path: ./build/rly
diff --git a/.github/workflows/docker-publish.yaml b/.github/workflows/docker-publish.yaml
index 6c6cd8164..a220d3147 100644
--- a/.github/workflows/docker-publish.yaml
+++ b/.github/workflows/docker-publish.yaml
@@ -5,19 +5,12 @@ on:
tags:
- '**'
branches:
- - '**'
-
-env:
- REGISTRY: ghcr.io
- IMAGE_NAME: ${{ github.repository }}
+ - 'main'
+ - '82-run-relay-node-locally-on-pr-merge-to-main'
jobs:
build-and-push-image:
runs-on: ubuntu-latest
- permissions:
- contents: read
- packages: write
-
steps:
- name: Checkout repository
uses: actions/checkout@v2
@@ -28,27 +21,14 @@ jobs:
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v1
- - name: Log in to the Container registry
- uses: docker/login-action@v1
- with:
- registry: ${{ env.REGISTRY }}
- username: ${{ github.actor }}
- password: ${{ secrets.GITHUB_TOKEN }}
-
- - name: Extract metadata (tags, labels) for Docker
- id: meta
- uses: docker/metadata-action@v3
+ - name: Login to Docker Hub
+ uses: docker/login-action@v2
with:
- images: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}
+ username: ${{ secrets.DOCKERHUB_USERNAME }}
+ password: ${{ secrets.DOCKERHUB_TOKEN }}
- name: Build and push Docker image
- uses: docker/build-push-action@v2.7.0
+ uses: docker/build-push-action@v3
with:
- context: .
- platforms: linux/amd64,linux/arm64
- file: Dockerfile
- push: true
- tags: ${{ steps.meta.outputs.tags }}
- labels: ${{ steps.meta.outputs.labels }}
- cache-from: type=gha
- cache-to: type=gha,mode=max
+ repository: ${{ secrets.DOCKERHUB_USERNAME }}/relay-node
+ tag: latest
diff --git a/.github/workflows/interchaintest.yml b/.github/workflows/interchaintest.yml
index ed599544a..e702cc21c 100644
--- a/.github/workflows/interchaintest.yml
+++ b/.github/workflows/interchaintest.yml
@@ -1,7 +1,6 @@
name: TESTING - interchaintest
on:
- pull_request:
push:
branches:
- master
@@ -10,10 +9,10 @@ jobs:
events:
runs-on: self-hosted
steps:
- - name: Set up Go 1.19
+ - name: Set up Go 1.20
uses: actions/setup-go@v1
with:
- go-version: 1.19
+ go-version: 1.20
id: go
- name: checkout relayer
@@ -32,10 +31,10 @@ jobs:
legacy:
runs-on: self-hosted
steps:
- - name: Set up Go 1.19
+ - name: Set up Go 1.20
uses: actions/setup-go@v1
with:
- go-version: 1.19
+ go-version: 1.20
id: go
- name: checkout relayer
@@ -54,10 +53,10 @@ jobs:
multiple-paths:
runs-on: ubuntu-latest
steps:
- - name: Set up Go 1.19
+ - name: Set up Go 1.20
uses: actions/setup-go@v1
with:
- go-version: 1.19
+ go-version: 1.20
id: go
- name: checkout relayer
@@ -73,13 +72,76 @@ jobs:
- name: interchaintest
run: make interchaintest-multiple
+ misbehaviour:
+ runs-on: ubuntu-latest
+ steps:
+ - name: Set up Go 1.20
+ uses: actions/setup-go@v4
+ with:
+ go-version: '1.20'
+
+ - name: checkout relayer
+ uses: actions/checkout@v2
+
+ - uses: actions/cache@v1
+ with:
+ path: ~/go/pkg/mod
+ key: ${{ runner.os }}-go-${{ hashFiles('**/go.sum') }}
+ restore-keys: |
+ ${{ runner.os }}-go-
+
+ - name: interchaintest
+ run: make interchaintest-misbehaviour
+
+ fee-middleware:
+ runs-on: ubuntu-latest
+ steps:
+ - name: Set up Go 1.20
+ uses: actions/setup-go@v4
+ with:
+ go-version: '1.20'
+
+ - name: checkout relayer
+ uses: actions/checkout@v2
+
+ - uses: actions/cache@v1
+ with:
+ path: ~/go/pkg/mod
+ key: ${{ runner.os }}-go-${{ hashFiles('**/go.sum') }}
+ restore-keys: |
+ ${{ runner.os }}-go-
+
+ - name: interchaintest
+ run: make interchaintest-fee-middleware
+
+ fee-grant:
+ runs-on: ubuntu-latest
+ steps:
+ - name: Set up Go 1.20
+ uses: actions/setup-go@v4
+ with:
+ go-version: '1.20'
+
+ - name: checkout relayer
+ uses: actions/checkout@v2
+
+ - uses: actions/cache@v1
+ with:
+ path: ~/go/pkg/mod
+ key: ${{ runner.os }}-go-${{ hashFiles('**/go.sum') }}
+ restore-keys: |
+ ${{ runner.os }}-go-
+
+ - name: interchaintest
+ run: make interchaintest-fee-grant
+
scenarios:
runs-on: ubuntu-latest
steps:
- - name: Set up Go 1.19
+ - name: Set up Go 1.20
uses: actions/setup-go@v1
with:
- go-version: 1.19
+ go-version: 1.20
id: go
- name: checkout relayer
@@ -93,4 +155,4 @@ jobs:
${{ runner.os }}-go-
- name: interchaintest
- run: make interchaintest-scenario
\ No newline at end of file
+ run: make interchaintest-scenario
diff --git a/.github/workflows/lint-pr.yaml b/.github/workflows/lint-pr.yaml
new file mode 100644
index 000000000..dca39a43e
--- /dev/null
+++ b/.github/workflows/lint-pr.yaml
@@ -0,0 +1,18 @@
+name: Lint PR
+on:
+ pull_request_target:
+ types:
+ - opened
+ - edited
+ - synchronize
+jobs:
+ main:
+ name: Validate PR title
+ runs-on: ubuntu-latest
+ steps:
+ - uses: amannn/action-semantic-pull-request@v5.1.0
+ env:
+ GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
+ with:
+ validateSingleCommit: true
+ validateSingleCommitMatchesPrTitle: true
diff --git a/.github/workflows/relay-codecov.yml b/.github/workflows/relay-codecov.yml
new file mode 100644
index 000000000..15f4d4ba8
--- /dev/null
+++ b/.github/workflows/relay-codecov.yml
@@ -0,0 +1,50 @@
+name: Test and coverage
+
+on:
+ push:
+ tags:
+ - '**'
+ # branches:
+ # - '**'
+ pull_request:
+ branches:
+ - main
+
+jobs:
+ coverage:
+ name: coverage
+ runs-on: ubuntu-latest
+ steps:
+ # Install and setup go
+ - name: Set up Go 1.19
+ uses: actions/setup-go@v2
+ with:
+ go-version: 1.19
+
+ # setup gopath
+ - name: Set PATH
+ run: |
+ echo "$(go env GOPATH)/bin" >> $GITHUB_PATH
+ shell: bash
+
+ # checkout relayer
+ - name: checkout relayer
+ uses: actions/checkout@v2
+
+ # setup cache
+ - uses: actions/cache@v1
+ with:
+ path: ~/go/pkg/mod
+ key: ${{ runner.os }}-go-${{ hashFiles('**/go.sum') }}
+ restore-keys: |
+ ${{ runner.os }}-go-
+
+ # unit tests
+ - name: run unit tests
+ run: make test
+ continue-on-error: true
+ - name: Upload coverage to Codecov
+ uses: codecov/codecov-action@v3
+ with:
+ token: ${{ secrets.CODECOV_TOKEN }}
+ files: ./coverage.out
diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml
index 620472251..88f086c1d 100644
--- a/.github/workflows/release.yml
+++ b/.github/workflows/release.yml
@@ -3,7 +3,7 @@ name: "Release"
on:
push:
tags:
- - '*' # Run release on any tag. Will be marked as draft by default anyway.
+ - 'v*.*.*-alpha.*' # Run release on any tag. Will be marked as draft by default anyway.
jobs:
goreleaser:
@@ -15,11 +15,17 @@ jobs:
fetch-depth: 0
- name: Set up Go
- uses: actions/setup-go@v2
+ uses: actions/setup-go@v4
with:
go-version: 1.19
- - run: echo https://github.com/cosmos/relayer/blob/${GITHUB_REF#refs/tags/}/CHANGELOG.md#${GITHUB_REF#refs/tags/} > ../release_notes.md
+ # setup gopath
+ - name: Set PATH
+ run: |
+ echo "$(go env GOPATH)/bin" >> $GITHUB_PATH
+ shell: bash
+
+ - run: echo https://github.com/icon-project/ibc-relay/blob/${GITHUB_REF#refs/tags/}/CHANGELOG.md#${GITHUB_REF#refs/tags/} > ../release_notes.md
- name: setup release environment
run: |-
diff --git a/.github/workflows/test-relay.yaml b/.github/workflows/test-relay.yaml
new file mode 100644
index 000000000..771e6abe9
--- /dev/null
+++ b/.github/workflows/test-relay.yaml
@@ -0,0 +1,156 @@
+name: Deploy Relayer Locally
+
+on:
+ push:
+ branches:
+ - "main"
+
+jobs:
+ relay-local-deployment:
+ runs-on: ubuntu-latest
+
+ steps:
+ - name: Checkout
+ uses: actions/checkout@v2
+ with:
+ submodules: true
+
+ - name: Pull & update submodules recursively
+ run: |
+ git submodule update --init --recursive
+ git submodule update --recursive --remote
+
+ # Install and setup go
+ - name: Set up Go 1.19
+ uses: actions/setup-go@v2
+ with:
+ go-version: 1.19
+
+ # setup gopath
+ - name: Set PATH
+ run: |
+ echo "$(go env GOPATH)/bin" >> $GITHUB_PATH
+ shell: bash
+
+ # Install rust toolchain
+ # - name: Install rust stable toolchain
+ # uses: actions-rs/toolchain@v1
+ # with:
+ # toolchain: 1.69.0
+ # target: wasm32-unknown-unknown
+ # override: true
+ # profile: minimal
+
+ # - name: Cache Rust dependencies
+ # uses: Swatinem/rust-cache@v2
+
+ # Build relay
+ - name: Build relayer
+ run: make install
+
+ # Install goloop
+ - name: Install goloop
+ run: go install github.com/icon-project/goloop/cmd/goloop@latest
+
+ # Build archwayd
+ - name: Build archwayd
+ working-directory: .github/scripts/archway
+ run: |
+ echo $PWD
+ echo $GITHUB_WORKSPACE
+ make install
+
+ # Build comsmwasm
+ # - name: Compile WASM
+ # working-directory: .github/scripts/IBC-Integration
+ # run: |
+ # rustup component add rustfmt --toolchain 1.69.0-x86_64-unknown-linux-gnu
+ # rustup component add clippy --toolchain 1.69.0-x86_64-unknown-linux-gnu
+ # bash ./optimize_build.sh
+
+ # - name: Build javascore
+ # working-directory: .github/scripts/IBC-Integration/contracts/javascore
+ # run: |
+ # ./gradlew clean build
+ # ./gradlew optimizedJar
+
+ - name: Fetch Latest IBC-Integration Tag
+ id: fetch_ibc_tag
+ run: |
+ TAG_IBC=$(curl -s "https://api.github.com/repos/icon-project/IBC-Integration/tags" | jq -r '.[0].name')
+ echo "TAG_IBC=$TAG_IBC" >> $GITHUB_ENV
+
+ - name: Fetch Latest XCALL Tag
+ id: fetch_xcall_tag
+ run: |
+ TAG_XCALL=$(curl -s "https://api.github.com/repos/icon-project/xCall/tags" | jq -r '.[0].name')
+ echo "TAG_XCALL=$TAG_XCALL" >> $GITHUB_ENV
+
+ - name: Get Latest tag - IBC-Integration
+ id: ibc_tag
+ run: echo "tag=$(curl -s "https://api.github.com/repos/icon-project/IBC-Integration/tags" | jq -r '.[0].name')" >> $GITHUB_OUTPUT
+
+ - name: Get Latest tag - xCall
+ id: xcall_tag
+ run: echo "tag=$(curl -s "https://api.github.com/repos/icon-project/xCall/tags" | jq -r '.[0].name')" >> $GITHUB_OUTPUT
+
+
+ - name: Download IBC Core Javascore Contracts
+ uses: robinraju/release-downloader@v1.8
+ with:
+ repository: "icon-project/IBC-Integration"
+ tag: "${{ steps.ibc_tag.outputs.tag }}"
+ # latest: true
+ fileName: "*.jar"
+ out-file-path: "./.github/scripts/IBC-Integration/artifacts/icon"
+
+
+ - name: Download IBC Core Cosmwasm Contracts
+ uses: robinraju/release-downloader@v1.8
+ with:
+ repository: "icon-project/IBC-Integration"
+ tag: "${{ steps.ibc_tag.outputs.tag }}"
+ # latest: true
+ fileName: "*.wasm"
+ out-file-path: "./.github/scripts/IBC-Integration/artifacts/archway"
+
+ - name: Download xCall Javascore Contracts
+ uses: robinraju/release-downloader@v1.8
+ with:
+ repository: "icon-project/xCall"
+ tag: "${{ steps.xcall_tag.outputs.tag }}"
+ # latest: true
+ fileName: "*.jar"
+ out-file-path: "./.github/scripts/IBC-Integration/artifacts/icon"
+
+ - name: Download xCall Cosmwasm Contracts
+ uses: robinraju/release-downloader@v1.8
+ with:
+ repository: "icon-project/xCall"
+ tag: "${{ steps.xcall_tag.outputs.tag }}"
+ # latest: true
+ fileName: "*.wasm"
+ out-file-path: "./.github/scripts/IBC-Integration/artifacts/archway"
+
+ - name: List Download Files
+ run: |
+ ls -l ${GITHUB_WORKSPACE}/.github/scripts/IBC-Integration/artifacts/icon
+ ls -l ${GITHUB_WORKSPACE}/.github/scripts/IBC-Integration/artifacts/archway
+ echo $HOME
+ echo $PWD
+ echo $GITHUB_WORKSPACE
+ echo "${GITHUB_REF##*/}"
+
+ - name: Import GPG key
+ uses: crazy-max/ghaction-import-gpg@v5
+ with:
+ gpg_private_key: ${{ secrets.GPG_PRIVATE_KEY }}
+ fingerprint: "C787AB518A0C08B7AE1E1ADA2809A1A84E32159A"
+ trust_level: 5
+
+
+ - name: start relay
+ working-directory: .github/scripts
+ run: bash ./start_relay.sh
+
+
diff --git a/.gitignore b/.gitignore
index 835dd0cc9..19bf09d6a 100644
--- a/.gitignore
+++ b/.gitignore
@@ -19,5 +19,10 @@ _test/keys/
dist/
.release-env
+**/log*.txt
+**/debug_wasm_msg_data.json
+
# Don't commit the vendor directory if anyone runs 'go mod vendor'.
/vendor
+
+go.work.sum
diff --git a/.gitmodules b/.gitmodules
new file mode 100644
index 000000000..034f7b2ec
--- /dev/null
+++ b/.gitmodules
@@ -0,0 +1,20 @@
+[submodule "contracts/javascore/gochain-btp"]
+ path = contracts/javascore/gochain-btp
+ url = https://github.com/izyak/gochain-btp.git
+
+[submodule "contracts/cosmwasm-vm/archway"]
+ path = contracts/cosmwasm-vm/archway
+ url = https://github.com/archway-network/archway.git
+
+[submodule ".github/scripts/IBC-Integration"]
+ path = .github/scripts/IBC-Integration
+ url = https://github.com/icon-project/IBC-Integration.git
+[submodule ".github/scripts/archway"]
+ path = .github/scripts/archway
+ url = https://github.com/archway-network/archway.git
+[submodule ".github/scripts/gochain-btp"]
+ path = .github/scripts/gochain-btp
+ url = https://github.com/izyak/gochain-btp.git
+[submodule ".github/scripts/icon-ibc"]
+ path = .github/scripts/icon-ibc
+ url = https://github.com/izyak/icon-ibc.git
diff --git a/.gitpod.yml b/.gitpod.yml
new file mode 100644
index 000000000..764d2dd6e
--- /dev/null
+++ b/.gitpod.yml
@@ -0,0 +1,3 @@
+tasks:
+ - name: Install dependencies
+ command: make install
diff --git a/.goreleaser.yaml b/.goreleaser.yaml
index f976a7dd0..a965ce851 100644
--- a/.goreleaser.yaml
+++ b/.goreleaser.yaml
@@ -1,5 +1,4 @@
-project_name: Cosmos Relayer
-
+project_name: ibc-relay
builds:
- id: darwin-amd64
main: ./main.go
@@ -14,7 +13,7 @@ builds:
flags:
- -mod=readonly
ldflags:
- - -s -w -X github.com/cosmos/relayer/v2/cmd.Version={{ .Tag }}
+ - -s -w -X github.com/icon-project/ibc-relay/v2/cmd.Version={{ .Tag }}
- id: darwin-arm64
main: ./main.go
binary: rly
@@ -28,7 +27,7 @@ builds:
flags:
- -mod=readonly
ldflags:
- - -s -w -X github.com/cosmos/relayer/v2/cmd.Version={{ .Tag }}
+ - -s -w -X github.com/icon-project/ibc-relay/v2/cmd.Version={{ .Tag }}
- id: linux-amd64
main: ./main.go
binary: rly
@@ -42,7 +41,7 @@ builds:
flags:
- -mod=readonly
ldflags:
- - -s -w -X github.com/cosmos/relayer/v2/cmd.Version={{ .Tag }}
+ - -s -w -X github.com/icon-project/ibc-relay/v2/cmd.Version={{ .Tag }}
- id: linux-arm64
main: ./main.go
binary: rly
diff --git a/CHANGELOG.md b/CHANGELOG.md
index 315deb42d..93f9f9358 100644
--- a/CHANGELOG.md
+++ b/CHANGELOG.md
@@ -13,6 +13,15 @@
* [\#466](https://github.com/cosmos/relayer/pull/466) Docs cleanup.
* [\#506](https://github.com/cosmos/relayer/pull/506) Fix Timeout Handling on Relayer restart
* [\#940](https://github.com/cosmos/relayer/pull/940) Add min-gas-amount parameter for chain configs, to workaround gas estimation failure.
+* [\#1177](https://github.com/cosmos/relayer/pull/1177) Avoid panic due to nil map when add new path and ensure path get written to config.
+* [\#1178](https://github.com/cosmos/relayer/pull/1178) Add max-gas-amount parameter in chain configs.
+* [\#1180](https://github.com/cosmos/relayer/pull/1180) Update SDK from v0.47.0 to v0.47.2.
+* [\#1205](https://github.com/cosmos/relayer/pull/1205) Update ibc-go to v7.0.1.
+* [\#1179](https://github.com/cosmos/relayer/pull/1179) Add extension-options parameter in chain configs and update SDK to v0.47.3.
+* [\#1208](https://github.com/cosmos/relayer/pull/1208) Replace gogo/protobuf to cosmos/gogoproto.
+* [\#1221](https://github.com/cosmos/relayer/pull/1221) Update cometbft to v0.37.2 and ibc-go to v7.2.0.
+* [\#1226](https://github.com/cosmos/relayer/pull/1226) Avoid invalid Bech32 prefix error in parallel tests when sdk Config get overwritten by each other in single process.
+* [\#1231](https://github.com/cosmos/relayer/pull/1231) Reduce get bech32 prefix when get signer.
## v0.9.3
diff --git a/Dockerfile b/Dockerfile
index ad850f566..5721a5afa 100644
--- a/Dockerfile
+++ b/Dockerfile
@@ -1,33 +1,26 @@
-FROM --platform=$BUILDPLATFORM golang:1.19-alpine3.16 AS build-env
+FROM --platform=$BUILDPLATFORM golang:alpine AS build-env
-RUN apk add --update --no-cache curl make git libc-dev bash gcc linux-headers eudev-dev
+RUN apk add --update --no-cache make git musl-dev gcc binutils-gold cargo
-ARG TARGETARCH
-ARG BUILDARCH
+ARG BUILDPLATFORM=arm64
+ARG TARGETPLATFORM=arm64
+ARG COSMWASM_VERSION=1.2.3
-RUN if [ "${TARGETARCH}" = "arm64" ] && [ "${BUILDARCH}" != "arm64" ]; then \
- wget -c https://musl.cc/aarch64-linux-musl-cross.tgz -O - | tar -xzvv --strip-components 1 -C /usr; \
- elif [ "${TARGETARCH}" = "amd64" ] && [ "${BUILDARCH}" != "amd64" ]; then \
- wget -c https://musl.cc/x86_64-linux-musl-cross.tgz -O - | tar -xzvv --strip-components 1 -C /usr; \
- fi
+RUN wget https://github.com/CosmWasm/wasmvm/releases/download/v${COSMWASM_VERSION}/libwasmvm_muslc.aarch64.a -O /usr/lib/libwasmvm.aarch64.a && \
+ wget https://github.com/CosmWasm/wasmvm/releases/download/v${COSMWASM_VERSION}/libwasmvm_muslc.x86_64.a -O /usr/lib/libwasmvm.x86_64.a
-ADD . .
+COPY . .
-RUN if [ "${TARGETARCH}" = "arm64" ] && [ "${BUILDARCH}" != "arm64" ]; then \
- export CC=aarch64-linux-musl-gcc CXX=aarch64-linux-musl-g++;\
- elif [ "${TARGETARCH}" = "amd64" ] && [ "${BUILDARCH}" != "amd64" ]; then \
- export CC=x86_64-linux-musl-gcc CXX=x86_64-linux-musl-g++; \
- fi; \
- GOOS=linux GOARCH=$TARGETARCH CGO_ENABLED=1 LDFLAGS='-linkmode external -extldflags "-static"' make install
+RUN LDFLAGS='-linkmode external -extldflags "-static"' make install
-RUN if [ -d "/go/bin/linux_${TARGETARCH}" ]; then mv /go/bin/linux_${TARGETARCH}/* /go/bin/; fi
+RUN if [ -d "/go/bin/linux_${TARGETPLATFORM}" ]; then mv /go/bin/linux_${TARGETPLATFORM}/* /go/bin/; fi
# Use minimal busybox from infra-toolkit image for final scratch image
-FROM ghcr.io/strangelove-ventures/infra-toolkit:v0.0.6 AS busybox-min
+FROM --platform=$BUILDPLATFORM ghcr.io/strangelove-ventures/infra-toolkit:v0.0.6 AS busybox-min
RUN addgroup --gid 1000 -S relayer && adduser --uid 100 -S relayer -G relayer
# Use ln and rm from full featured busybox for assembling final image
-FROM busybox:1.34.1-musl AS busybox-full
+FROM --platform=$BUILDPLATFORM busybox:musl AS busybox-full
# Build final image from scratch
FROM scratch
@@ -66,5 +59,10 @@ COPY --from=busybox-min /etc/ssl/cert.pem /etc/ssl/cert.pem
COPY --from=busybox-min /etc/passwd /etc/passwd
COPY --from=busybox-min --chown=100:1000 /home/relayer /home/relayer
-WORKDIR /home/relayer
USER relayer
+
+WORKDIR /home/relayer
+
+COPY ./env/ibc-icon/godWallet.json ./keys/godwallet.json
+
+CMD ["/bin/rly"]
diff --git a/Makefile b/Makefile
index 6afd617c8..90050d788 100644
--- a/Makefile
+++ b/Makefile
@@ -31,7 +31,7 @@ ifeq ($(OS),Windows_NT)
@go build -mod=readonly $(BUILD_FLAGS) -o build/rly.exe main.go
else
@echo "building rly binary..."
- @go build -mod=readonly $(BUILD_FLAGS) -o build/rly main.go
+ @go build $(BUILD_FLAGS) -o build/rly main.go
endif
build-zip: go.sum
@@ -59,8 +59,8 @@ build-osmosis-docker:
###############################################################################
test:
- @go test -mod=readonly -race ./...
-
+# @go test -mod=readonly -race ./...
+ @go test -mod=readonly -race -coverprofile=coverage.out -covermode=atomic ./...
interchaintest:
cd interchaintest && go test -race -v -run TestRelayerInProcess .
@@ -82,10 +82,21 @@ interchaintest-legacy:
interchaintest-multiple:
cd interchaintest && go test -race -v -run TestRelayerMultiplePathsSingleProcess .
+interchaintest-misbehaviour:
+ cd interchaintest && go test -race -v -run TestRelayerMisbehaviourDetection .
+
+interchaintest-fee-middleware:
+ cd interchaintest && go test -race -v -run TestRelayerFeeMiddleware .
+
+interchaintest-fee-grant:
+ cd interchaintest && go test -race -v -run TestRelayerFeeGrant .
+
interchaintest-scenario: ## Scenario tests are suitable for simple networks of 1 validator and no full nodes. They test specific functionality.
- cd interchaintest && go test -timeout 15m -race -v -run TestScenario ./...
+ cd interchaintest && go test -timeout 30m -race -v -run TestScenario ./...
coverage:
+ @echo "Generating coverage report..."
+ @go test -race -coverprofile=coverage.txt -covermode=atomic
@echo "viewing test coverage..."
@go tool cover --html=coverage.out
diff --git a/README.md b/README.md
index 2f267b396..e244e5465 100644
--- a/README.md
+++ b/README.md
@@ -4,14 +4,23 @@
data:image/s3,"s3://crabby-images/bcdb1/bcdb17aa837d05423239c335890ec736ee4d98be" alt="banner"
[data:image/s3,"s3://crabby-images/a7451/a7451d72f5315c7d89a1cc74a8329d8862edff06" alt="Project Status: Initial Release"](https://www.repostatus.org/#active)
-data:image/s3,"s3://crabby-images/f3b1e/f3b1ef0d303567c31417fd148e2443303a9773a6" alt="GitHub Workflow Status"
+data:image/s3,"s3://crabby-images/f31e7/f31e740444f296fadef430053f07f3fcf9c8453e" alt="GitHub Workflow Status"
[data:image/s3,"s3://crabby-images/85dba/85dba84206309678e5b2f24826463d5c2eeb03a7" alt="GoDoc"](https://godoc.org/github.com/cosmos/relayer)
-[data:image/s3,"s3://crabby-images/58c37/58c37280e962925d41fdd4094607314439ba1cb8" alt="Go Report Card"](https://goreportcard.com/report/github.com/cosmos/relayer)
-[data:image/s3,"s3://crabby-images/d75df/d75dfac2b08ac30591388091a0794e23bacba927" alt="License: Apache-2.0"](https://github.com/cosmos/relayer/blob/main/LICENSE)
-[data:image/s3,"s3://crabby-images/874ad/874adab0588bb0ec1cf68f5e7309180af24041c3" alt="Lines Of Code"](https://github.com/cosmos/relayer)
-[data:image/s3,"s3://crabby-images/19f63/19f63bcc7892f935f1bdd0e8bbc59b15c4e63f16" alt="Version"](https://github.com/cosmos/relayer/latest)
+[data:image/s3,"s3://crabby-images/13301/13301cff607592f605f4def26ea2805d61272444" alt="Go Report Card"](https://goreportcard.com/report/github.com/icon-project/ibc-relay)
+[data:image/s3,"s3://crabby-images/e9349/e9349304540945db18b5fca8d256bad1fdc991f8" alt="License: Apache-2.0"](https://github.com/icon-project/ibc-relay/blob/main/LICENSE)
+[data:image/s3,"s3://crabby-images/60037/60037bf1b02266c073d0a9943ede62cdf320bc50" alt="Lines Of Code"](https://github.com/icon-project/ibc-relay)
+[data:image/s3,"s3://crabby-images/824bb/824bb92c64a46af2df125abd354324741b630304" alt="Version"](https://github.com/icon-project/ibc-relay/latest)
+[data:image/s3,"s3://crabby-images/e7cb6/e7cb6a062fbd3d10e5cc6c96f24deeb2c9228ae3" alt="codecov"](https://codecov.io/gh/icon-project/ibc-relay)
+---
+
+This repo is a fork of cosmos [relayer](https://github.com/cosmos/relayer). The goal of this project is to relay packets between ICON and Wasm chains by following the IBC Specs.
+1. [What is ICON-IBC Integration](https://github.com/icon-project/IBC-Integration)
+2. [Deviations from Cosmos Relayer](./docs/deviations_from_ibc.md)
+---
+
+
In IBC, blockchains do not directly pass messages to each other over the network. This is where `relayer` comes in.
A relayer process monitors for updates on opens paths between sets of [IBC](https://ibcprotocol.org/) enabled chains.
The relayer submits these updates in the form of specific message types to the counterparty chain. Clients are then used to
@@ -23,8 +32,13 @@ Additional information on how IBC works can be found [here](https://ibc.cosmos.n
---
+## Demo
+- The easiest way would be to follow the guide in [this repo](https://github.com/izyak/icon-ibc/tree/master) to setup relay for icon ibc integration. It has all the relevant scripts setup, and you can start the relay using a single command.
+- There is E2E tests demo for icon ibc integration [here](https://github.com/icon-project/IBC-Integration/blob/main/docs/e2e_test_setup.md)
+---
+
## Table Of Contents
-- [Basic Usage - Relaying Across Chains](#Basic-Usage---Relaying-Packets-Across-Chains)
+- [Basic Usage - Relaying Across Chains](#basic-usage---relaying-packets-across-chains)
- [Create Path Across Chains](./docs/create-path-across-chain.md)
- [Advanced Usage](./docs/advanced_usage.md)
- [Troubleshooting](./docs/troubleshooting.md)
@@ -32,7 +46,7 @@ Additional information on how IBC works can be found [here](https://ibc.cosmos.n
- [Relayer Terminology](./docs/terminology.md)
- [New Chain Implementation](./docs/chain_implementation.md)
- [Recommended Pruning Settings](./docs/node_pruning.md)
-- [Demo/Dev-Environmnet](./examples/README.md)
+- [Running Relayer Locally](https://github.com/izyak/icon-ibc/blob/master/README.md)
---
## Basic Usage - Relaying Packets Across Chains
@@ -47,7 +61,7 @@ Additional information on how IBC works can be found [here](https://ibc.cosmos.n
```shell
$ git clone https://github.com/cosmos/relayer.git
- $ cd relayer && git checkout v2.0.0-rc3
+ $ cd relayer
$ make install
```
@@ -58,7 +72,7 @@ Additional information on how IBC works can be found [here](https://ibc.cosmos.n
```
**Default config file location:** `~/.relayer/config/config.yaml`
- By default, transactions will be relayed with a memo of `rly(VERSION)` e.g. `rly(v2.0.0)`.
+ By default, transactions will be relayed with a memo of `rly(VERSION)` e.g. `rly(v2.4.0)`.
To customize the memo for all relaying, use the `--memo` flag when initializing the configuration.
@@ -66,64 +80,70 @@ Additional information on how IBC works can be found [here](https://ibc.cosmos.n
$ rly config init --memo "My custom memo"
```
- Custom memos will have `rly(VERSION)` appended. For example, a memo of `My custom memo` running on relayer version `v2.0.0` would result in a transaction memo of `My custom memo | rly(v2.0.0)`.
+ Custom memos will have `rly(VERSION)` appended. For example, a memo of `My custom memo` running on relayer version `v2.4.0` would result in a transaction memo of `My custom memo | rly(v2.4.0)`.
The `--memo` flag is also available for other `rly` commands also that involve sending transactions such as `rly tx link` and `rly start`. It can be passed there to override the `config.yaml` value if desired.
To omit the memo entirely, including the default value of `rly(VERSION)`, use `-` for the memo.
3. **Configure the chains you want to relay between.**
-
- In our example, we will configure the relayer to operate on the canonical path between the Cosmos Hub and Osmosis.
- The `rly chains add` command fetches chain meta-data from the [chain-registry](https://github.com/cosmos/chain-registry) and adds it to your config file.
+ In out example, we will configure the relayer to operate between ICON and Archway.
+
+ To add the chain config files manually, example config files have been included [here](./examples/demo/configs/chains/) Modify the config file as per your requirements and run the following command:
```shell
- $ rly chains add cosmoshub osmosis
- ```
-
- Adding chains from the chain-registry randomly selects an RPC address from the registry entry.
- If you are running your own node, manually go into the config and adjust the `rpc-addr` setting.
-
- > NOTE: `rly chains add` will check the liveliness of the available RPC endpoints for that chain in the chain-registry.
- > It is possible that the command will fail if none of these RPC endpoints are available. In this case, you will want to manually add the chain config.
-
- To add the chain config files manually, example config files have been included [here](https://github.com/cosmos/relayer/tree/main/docs/example-configs/)
- ```shell
- $ rly chains add --url https://raw.githubusercontent.com/cosmos/relayer/main/docs/example-configs/cosmoshub-4.json cosmoshub
- $ rly chains add --url https://raw.githubusercontent.com/cosmos/relayer/main/docs/example-configs/osmosis-1.json osmosis
+ $ rly chains add icon --file _path_to_/examples/demo/configs/chains/ibc-icon.json
+ $ rly chains add archway --file _path_to_/examples/demo/configs/chains/ibc-archway.json
```
4. **Import OR create new keys for the relayer to use when signing and relaying transactions.**
+
+ - For Cosmos chains:
- >`key-name` is an identifier of your choosing.
+ >`key-name` is an identifier of your choosing.
- If you need to generate a new private key you can use the `add` subcommand.
+ If you need to generate a new private key you can use the `add` subcommand.
- ```shell
- $ rly keys add cosmoshub [key-name]
- $ rly keys add osmosis [key-name]
- ```
-
- If you already have a private key and want to restore it from your mnemonic you can use the `restore` subcommand.
+ ```shell
+ $ rly keys add archway [key-name]
+ ```
+
+ If you already have a private key and want to restore it from your mnemonic you can use the `restore` subcommand.
- ```shell
- $ rly keys restore cosmoshub [key-name] "mnemonic words here"
- $ rly keys restore osmosis [key-name] "mnemonic words here"
- ```
+ ```shell
+ $ rly keys restore archway [key-name] "mnemonic words here"
+ ```
+ - For Icon chain
+ To generate a new wallet for icon, you can use `add` subcommmand with password flag. If you do not supply `--password` flag, the default password is `x`
+ ```shell
+ $ rly keys add icon [key-name] --password "password"
+ ```
-5. **Edit the relayer's `key` values in the config file to match the `key-name`'s chosen above.**
- >This step is necessary if you chose a `key-name` other than "default"
+5. **Edit the relayer's `key` values in the config file to match the `key-name`'s chosen above.**
+ - *For Archway*
+ >This step is necessary if you chose a `key-name` other than "default"
- Example:
+ Example:
+
```yaml
- - type: cosmos
- value:
- key: YOUR-KEY-NAME-HERE
- chain-id: cosmoshub-4
- rpc-addr: http://localhost:26657
+ - type: wasm
+ value:
+ key: YOUR-KEY-NAME-HERE
+ chain-id: localnet
+ rpc-addr: http://localhost:26657
```
+ - *For Icon*
+
+ ```yaml
+ - type: icon
+ value:
+ keystore: YOUR-KEY-NAME-HERE
+ password: YOUR-KEY-PASSWORD-HERE
+ chain-id: ibc-icon
+ ```
+
6. **Ensure the keys associated with the configured chains are funded.**
@@ -133,8 +153,8 @@ Additional information on how IBC works can be found [here](https://ibc.cosmos.n
You can query the balance of each configured key by running:
```shell
- $ rly q balance cosmoshub
- $ rly q balance osmosis
+ $ rly q balance icon [key-name]
+ $ rly q balance archway [key-name]
```
7. **Configure path meta-data in config file.**
@@ -142,17 +162,36 @@ Additional information on how IBC works can be found [here](https://ibc.cosmos.n
We have the chain meta-data configured, now we need path meta-data. For more info on `path` terminology visit [here](docs/troubleshooting.md).
>NOTE: Thinking of chains in the config as "source" and "destination" can be confusing. Be aware that most path are bi-directional.
+ To add the chain config files manually, example config files have been included [here](./examples/demo/configs/paths/icon-archway.json) . Modify this file as per your requirements and run the following command.
+
+
+ ```shell
+ $ rly paths add [chain-id-1] [chain-id-2] [path-name] --file _path_to/ibc-relay/examples/demo/configs/paths/icon-archway.json
+ ```
+8. **Client Creation and Handshaking [Optional]**
+
+ If you want to create your own client, channels and connection to relay between chains, run the following command:
- `rly paths fetch` will check for IBC path meta data from the [chain-registry](https://github.com/cosmos/chain-registry/tree/master/_IBC) and add these paths to your config file.
+ To create clients between chains
+ > Ensure that [btp-height] is a valid bto block height. This height will be used to create client for icon's counterparty chain .
+ ```shell
+ rly tx clients [path-name] --client-tp "10000000m" --btp-block-height [btp-height]
+ ```
- ```shell
- $ rly paths fetch
- ```
- > **NOTE:** Don't see the path metadata for paths you want to relay on?
- > Please open a PR to add this metadata to the GitHub repo!
+ To create connection
+ ```shell
+ rly tx conn [path-name]
+ ```
+
+ To create channels
+ ```sh
+ rly tx chan [path-name] --src-port=[src-port] --dst-port=[dst-port]
+ ```
-8. #### **Configure the channel filter.**
+ This step can entirely be skipped if connection and channel exists between 2 chains you want to relay. Ensure that client-id and connection-id are provided in the paths for this.
+
+9. #### **Configure the channel filter [Optional]**
By default, the relayer will relay packets over all channels on a given connection.
@@ -168,18 +207,18 @@ Additional information on how IBC works can be found [here](https://ibc.cosmos.n
Example:
```yaml
- hubosmo:
+ icon-archway:
src:
- chain-id: cosmoshub-4
- client-id: 07-tendermint-259
- connection-id: connection-257
+ chain-id: ibc-icon
+ client-id: 07-tendermint-0
+ connection-id: connection-0
dst:
- chain-id: osmosis-1
- client-id: 07-tendermint-1
- connection-id: connection-1
+ chain-id: localnet
+ client-id: iconclient-0
+ connection-id: connection-0
src-channel-filter:
- rule: allowlist
- channel-list: [channel-141]
+ rule: allowlist
+ channel-list: []
```
>Because two channels between chains are tightly coupled, there is no need to specify the dst channels.
@@ -202,10 +241,16 @@ Additional information on how IBC works can be found [here](https://ibc.cosmos.n
[[TROUBLESHOOTING](docs/troubleshooting.md)]
---
+## Build Docker Image of Relayer
+To build the docker image of the relayer, use the following command:
+```sh
+docker build -t relayer .
+```
+
## Security Notice
If you would like to report a security critical bug related to the relayer repo,
-please reach out @jackzampolin or @Ethereal0ne on telegram.
+please reach out @applexxx or @astra#2705 on discord.
## Code of Conduct
diff --git a/buf.work.yaml b/buf.work.yaml
deleted file mode 100644
index 494296bfa..000000000
--- a/buf.work.yaml
+++ /dev/null
@@ -1,4 +0,0 @@
-version: v1
-directories:
- - proto
- - third_party/proto
diff --git a/cmd/appstate.go b/cmd/appstate.go
index 11861e954..7f26557f3 100644
--- a/cmd/appstate.go
+++ b/cmd/appstate.go
@@ -11,7 +11,6 @@ import (
"github.com/cosmos/relayer/v2/relayer"
"github.com/gofrs/flock"
- "github.com/spf13/cobra"
"github.com/spf13/viper"
"go.uber.org/zap"
"gopkg.in/yaml.v3"
@@ -22,18 +21,61 @@ type appState struct {
// Log is the root logger of the application.
// Consumers are expected to store and use local copies of the logger
// after modifying with the .With method.
- Log *zap.Logger
+ log *zap.Logger
- Viper *viper.Viper
+ viper *viper.Viper
- HomePath string
- Debug bool
- Config *Config
+ homePath string
+ debug bool
+ config *Config
}
-// AddPathFromFile modifies a.config.Paths to include the content stored in the given file.
+func (a *appState) configPath() string {
+ return path.Join(a.homePath, "config", "config.yaml")
+}
+
+// loadConfigFile reads config file into a.Config if file is present.
+func (a *appState) loadConfigFile(ctx context.Context) error {
+ cfgPath := a.configPath()
+
+ if _, err := os.Stat(cfgPath); err != nil {
+ // don't return error if file doesn't exist
+ return nil
+ }
+
+ // read the config file bytes
+ file, err := os.ReadFile(cfgPath)
+ if err != nil {
+ return fmt.Errorf("error reading file: %w", err)
+ }
+
+ // unmarshall them into the wrapper struct
+ cfgWrapper := &ConfigInputWrapper{}
+ err = yaml.Unmarshal(file, cfgWrapper)
+ if err != nil {
+ return fmt.Errorf("error unmarshalling config: %w", err)
+ }
+
+ // retrieve the runtime configuration from the disk configuration.
+ newCfg, err := cfgWrapper.RuntimeConfig(ctx, a)
+ if err != nil {
+ return err
+ }
+
+ // validate runtime configuration
+ if err := newCfg.validateConfig(); err != nil {
+ return fmt.Errorf("error parsing chain config: %w", err)
+ }
+
+ // save runtime configuration in app state
+ a.config = newCfg
+
+ return nil
+}
+
+// addPathFromFile modifies a.config.Paths to include the content stored in the given file.
// If a non-nil error is returned, a.config.Paths is not modified.
-func (a *appState) AddPathFromFile(ctx context.Context, stderr io.Writer, file, name string) error {
+func (a *appState) addPathFromFile(ctx context.Context, stderr io.Writer, file, name string) error {
if _, err := os.Stat(file); err != nil {
return err
}
@@ -48,17 +90,22 @@ func (a *appState) AddPathFromFile(ctx context.Context, stderr io.Writer, file,
return err
}
- if err = a.Config.ValidatePath(ctx, stderr, p); err != nil {
+ if err = a.config.ValidatePath(ctx, stderr, p); err != nil {
return err
}
- return a.Config.Paths.Add(name, p)
+ return a.config.AddPath(name, p)
}
-// AddPathFromUserInput manually prompts the user to specify all the path details.
+// addPathFromUserInput manually prompts the user to specify all the path details.
// It returns any input or validation errors.
// If the path was successfully added, it returns nil.
-func (a *appState) AddPathFromUserInput(ctx context.Context, stdin io.Reader, stderr io.Writer, src, dst, name string) error {
+func (a *appState) addPathFromUserInput(
+ ctx context.Context,
+ stdin io.Reader,
+ stderr io.Writer,
+ src, dst, name string,
+) error {
// TODO: confirm name is available before going through input.
var (
@@ -118,65 +165,15 @@ func (a *appState) AddPathFromUserInput(ctx context.Context, stdin io.Reader, st
return err
}
- if err := a.Config.ValidatePath(ctx, stderr, path); err != nil {
- return err
- }
-
- return a.Config.Paths.Add(name, path)
-}
-
-// OverwriteConfig overwrites the config files on disk with the serialization of cfg,
-// and it replaces a.Config with cfg.
-//
-// It is possible to use a brand new Config argument,
-// but typically the argument is a.Config.
-func (a *appState) OverwriteConfig(cfg *Config) error {
- cfgPath := path.Join(a.HomePath, "config", "config.yaml")
- if _, err := os.Stat(cfgPath); err != nil {
- return fmt.Errorf("failed to check existence of config file at %s: %w", cfgPath, err)
- }
-
- a.Viper.SetConfigFile(cfgPath)
- if err := a.Viper.ReadInConfig(); err != nil {
- // TODO: if we failed to read in the new config, should we restore the old config?
- return fmt.Errorf("failed to read config file at %s: %w", cfgPath, err)
- }
-
- // ensure validateConfig runs properly
- if err := validateConfig(cfg); err != nil {
- return fmt.Errorf("failed to validate config at %s: %w", cfgPath, err)
- }
-
- // marshal the new config
- out, err := yaml.Marshal(cfg.Wrapped())
- if err != nil {
+ if err := a.config.ValidatePath(ctx, stderr, path); err != nil {
return err
}
- // Overwrite the config file.
- if err := os.WriteFile(a.Viper.ConfigFileUsed(), out, 0600); err != nil {
- return fmt.Errorf("failed to write config file at %s: %w", cfgPath, err)
- }
-
- // Write the config back into the app state.
- a.Config = cfg
- return nil
+ return a.config.AddPath(name, path)
}
-// OverwriteConfigOnTheFly overwrites the config file concurrently,
-// locking to read, modify, then write the config.
-func (a *appState) OverwriteConfigOnTheFly(
- cmd *cobra.Command,
- pathName string,
- clientSrc, clientDst string,
- connectionSrc, connectionDst string,
-) error {
- if pathName == "" {
- return errors.New("empty path name not allowed")
- }
-
- // use lock file to guard concurrent access to config.yaml
- lockFilePath := path.Join(a.HomePath, "config", "config.lock")
+func (a *appState) performConfigLockingOperation(ctx context.Context, operation func() error) error {
+ lockFilePath := path.Join(a.homePath, "config", "config.lock")
fileLock := flock.New(lockFilePath)
_, err := fileLock.TryLock()
if err != nil {
@@ -184,7 +181,7 @@ func (a *appState) OverwriteConfigOnTheFly(
}
defer func() {
if err := fileLock.Unlock(); err != nil {
- a.Log.Error("error unlocking config file lock, please manually delete",
+ a.log.Error("error unlocking config file lock, please manually delete",
zap.String("filepath", lockFilePath),
)
}
@@ -192,34 +189,27 @@ func (a *appState) OverwriteConfigOnTheFly(
// load config from file and validate it. don't want to miss
// any changes that may have been made while unlocked.
- if err := initConfig(cmd, a); err != nil {
+ if err := a.loadConfigFile(ctx); err != nil {
return fmt.Errorf("failed to initialize config from file: %w", err)
}
- path, ok := a.Config.Paths[pathName]
- if !ok {
- return fmt.Errorf("config does not exist for that path: %s", pathName)
- }
- if clientSrc != "" {
- path.Src.ClientID = clientSrc
- }
- if clientDst != "" {
- path.Dst.ClientID = clientDst
- }
- if connectionSrc != "" {
- path.Src.ConnectionID = connectionSrc
+ // perform the operation that requires config flock.
+ if err := operation(); err != nil {
+ return err
}
- if connectionDst != "" {
- path.Dst.ConnectionID = connectionDst
+
+ // validate config after changes have been made.
+ if err := a.config.validateConfig(); err != nil {
+ return fmt.Errorf("error parsing chain config: %w", err)
}
// marshal the new config
- out, err := yaml.Marshal(a.Config.Wrapped())
+ out, err := yaml.Marshal(a.config.Wrapped())
if err != nil {
return err
}
- cfgPath := a.Viper.ConfigFileUsed()
+ cfgPath := a.configPath()
// Overwrite the config file.
if err := os.WriteFile(cfgPath, out, 0600); err != nil {
@@ -228,3 +218,175 @@ func (a *appState) OverwriteConfigOnTheFly(
return nil
}
+
+func (a *appState) GetConfigProviderNameFromChainId(chainId string) (string, error) {
+
+ chains := a.config.Chains
+ for k, v := range chains {
+ if v.ChainID() == chainId {
+ return k, nil
+ }
+ }
+
+ return "", errors.New(fmt.Sprintf("Missing provider with chain Id: %s", chainId))
+}
+
+func (a *appState) CheckIfProviderType(providerName string, providerType string) bool {
+ providers := a.config.Wrapped()
+ for p, v := range providers.ProviderConfigs {
+ if p == providerName && v.Type == providerType {
+ return true
+ }
+ }
+ return false
+}
+
+// func (a *appState) UpdateConfigsIfContainIcon(cmd *cobra.Command, src *relayer.Chain, dst *relayer.Chain) error {
+
+// ctx := context.Background()
+// eg, egCtx := errgroup.WithContext(ctx)
+
+// eg.Go(func() error {
+// var err error
+// err = a.UpdateProviderIfIcon(cmd, egCtx, src)
+// if err != nil {
+// return err
+// }
+
+// return nil
+
+// })
+// eg.Go(func() error {
+// var err error
+// err = a.UpdateProviderIfIcon(cmd, egCtx, dst)
+// if err != nil {
+// return err
+// }
+// return nil
+
+// })
+
+// if err := eg.Wait(); err != nil {
+// return err
+// }
+
+// return nil
+
+// }
+
+// func (a *appState) UpdateProviderIfIcon(cmd *cobra.Command, ctx context.Context, chain *relayer.Chain) error {
+
+// providerName, err := a.GetConfigProviderNameFromChainId(chain.ChainID())
+// if err != nil {
+// return err
+// }
+
+// if !a.CheckIfProviderType(providerName, "icon") {
+// return nil
+// }
+// // height, err := chain.ChainProvider.QueryLatestHeight(ctx)
+// // if err != nil {
+// // return errors.New(fmt.Sprintf("Error fetching chain latest height %s ", chain.ChainID()))
+// // }
+
+// // err = a.OverwriteChainConfig(cmd, providerName, "btpHeight", height)
+// // if err != nil {
+// // return errors.New(fmt.Sprintf("Error updating BTPHeight of config of chain %s ", chain.ChainID()))
+// // }
+// return nil
+// }
+
+// func (a *appState) OverwriteChainConfig(
+// cmd *cobra.Command,
+// providerName string,
+// fieldName string,
+// fieldValue interface{},
+// ) error {
+
+// // use lock file to guard concurrent access to config.yaml
+// lockFilePath := path.Join(a.homePath, "config", "config.lock")
+// fileLock := flock.New(lockFilePath)
+// err := fileLock.Lock()
+// if err != nil {
+// return fmt.Errorf("failed to acquire config lock: %w", err)
+// }
+// defer func() {
+// if err := fileLock.Unlock(); err != nil {
+// a.Log.Error("error unlocking config file lock, please manually delete",
+// zap.String("filepath", lockFilePath),
+// )
+// }
+// }()
+
+// if err := initConfig(cmd, a); err != nil {
+// return fmt.Errorf("failed to initialize config from file: %w", err)
+// }
+
+// wrappedConfig := a.config.Wrapped()
+// err = setProviderConfigField(wrappedConfig, providerName, fieldName, fieldValue)
+// if err != nil {
+// return err
+// }
+
+// out, err := yaml.Marshal(wrappedConfig)
+// if err != nil {
+// return err
+// }
+
+// cfgPath := a.viper.ConfigFileUsed()
+
+// // Overwrite the config file.
+// if err := os.WriteFile(cfgPath, out, 0600); err != nil {
+// return fmt.Errorf("failed to write config file at %s: %w", cfgPath, err)
+// }
+
+// return nil
+// }
+
+// func setProviderConfigField(cfg *ConfigOutputWrapper, providerName string, fieldToChange string, newValue interface{}) error {
+// providerConfigs := cfg.ProviderConfigs
+// providerConfigWrapper, ok := providerConfigs[providerName]
+// if !ok {
+// return fmt.Errorf("ProviderConfigWrapper %s not found", providerName)
+// }
+// providerConfigValue := providerConfigWrapper.Value
+// if err := providerConfigValue.Set(fieldToChange, newValue); err != nil {
+// return err
+// }
+// providerConfigWrapper.Value = providerConfigValue
+
+// return nil
+// }
+
+// updatePathConfig overwrites the config file concurrently,
+// locking to read, modify, then write the config.
+func (a *appState) updatePathConfig(
+ ctx context.Context,
+ pathName string,
+ clientSrc, clientDst string,
+ connectionSrc, connectionDst string,
+) error {
+ if pathName == "" {
+ return errors.New("empty path name not allowed")
+ }
+
+ return a.performConfigLockingOperation(ctx, func() error {
+ path, ok := a.config.Paths[pathName]
+ if !ok {
+ return fmt.Errorf("config does not exist for that path: %s", pathName)
+ }
+ if clientSrc != "" {
+ path.Src.ClientID = clientSrc
+ }
+ if clientDst != "" {
+ path.Dst.ClientID = clientDst
+ }
+ if connectionSrc != "" {
+ path.Src.ConnectionID = connectionSrc
+ }
+ if connectionDst != "" {
+ path.Dst.ConnectionID = connectionDst
+ }
+ return nil
+ })
+}
diff --git a/cmd/chains.go b/cmd/chains.go
index 6cf3117e9..7e471ae00 100644
--- a/cmd/chains.go
+++ b/cmd/chains.go
@@ -39,6 +39,7 @@ func chainsCmd(a *appState) *cobra.Command {
chainsShowCmd(a),
chainsAddrCmd(a),
chainsAddDirCmd(a),
+ cmdChainsConfigure(a),
)
return cmd
@@ -54,7 +55,7 @@ func chainsAddrCmd(a *appState) *cobra.Command {
$ %s chains address ibc-0
$ %s ch addr ibc-0`, appName, appName)),
RunE: func(cmd *cobra.Command, args []string) error {
- chain, ok := a.Config.Chains[args[0]]
+ chain, ok := a.config.Chains[args[0]]
if !ok {
return errChainNotFound(args[0])
}
@@ -83,7 +84,7 @@ $ %s chains show ibc-0 --yaml
$ %s ch s ibc-0 --json
$ %s ch s ibc-0 --yaml`, appName, appName, appName, appName)),
RunE: func(cmd *cobra.Command, args []string) error {
- c, ok := a.Config.Chains[args[0]]
+ c, ok := a.config.Chains[args[0]]
if !ok {
return errChainNotFound(args[0])
}
@@ -117,7 +118,7 @@ $ %s ch s ibc-0 --yaml`, appName, appName, appName, appName)),
}
},
}
- return jsonFlag(a.Viper, cmd)
+ return jsonFlag(a.viper, cmd)
}
func chainsDeleteCmd(a *appState) *cobra.Command {
@@ -130,17 +131,33 @@ func chainsDeleteCmd(a *appState) *cobra.Command {
$ %s chains delete ibc-0
$ %s ch d ibc-0`, appName, appName)),
RunE: func(cmd *cobra.Command, args []string) error {
- _, ok := a.Config.Chains[args[0]]
- if !ok {
- return errChainNotFound(args[0])
- }
- a.Config.DeleteChain(args[0])
- return a.OverwriteConfig(a.Config)
+ chain := args[0]
+ return a.performConfigLockingOperation(cmd.Context(), func() error {
+ _, ok := a.config.Chains[chain]
+ if !ok {
+ return errChainNotFound(chain)
+ }
+ a.config.DeleteChain(chain)
+ return nil
+ })
},
}
return cmd
}
+func cmdChainsConfigure(a *appState) *cobra.Command {
+ cmd := &cobra.Command{
+ Use: "configure",
+ Short: "manage local chain configurations",
+ }
+
+ cmd.AddCommand(
+ feegrantConfigureBaseCmd(a),
+ )
+
+ return cmd
+}
+
func chainsRegistryList(a *appState) *cobra.Command {
cmd := &cobra.Command{
Use: "registry-list",
@@ -158,7 +175,7 @@ func chainsRegistryList(a *appState) *cobra.Command {
return err
}
- chains, err := cregistry.DefaultChainRegistry(a.Log).ListChains(cmd.Context())
+ chains, err := cregistry.DefaultChainRegistry(a.log).ListChains(cmd.Context())
if err != nil {
return err
}
@@ -188,7 +205,7 @@ func chainsRegistryList(a *appState) *cobra.Command {
return nil
},
}
- return yamlFlag(a.Viper, jsonFlag(a.Viper, cmd))
+ return yamlFlag(a.viper, jsonFlag(a.viper, cmd))
}
func chainsListCmd(a *appState) *cobra.Command {
@@ -211,7 +228,7 @@ $ %s ch l`, appName, appName)),
return err
}
- configs := a.Config.Wrapped().ProviderConfigs
+ configs := a.config.Wrapped().ProviderConfigs
if len(configs) == 0 {
fmt.Fprintln(cmd.ErrOrStderr(), "warning: no chains found (do you need to run 'rly chains add'?)")
}
@@ -235,7 +252,7 @@ $ %s ch l`, appName, appName)),
return nil
default:
i := 0
- for _, c := range a.Config.Chains {
+ for _, c := range a.config.Chains {
var (
key = xIcon
p = xIcon
@@ -251,7 +268,7 @@ $ %s ch l`, appName, appName)),
bal = check
}
- for _, pth := range a.Config.Paths {
+ for _, pth := range a.config.Paths {
if pth.Src.ChainID == c.ChainProvider.ChainId() || pth.Dst.ChainID == c.ChainID() {
p = check
}
@@ -263,7 +280,7 @@ $ %s ch l`, appName, appName)),
}
},
}
- return yamlFlag(a.Viper, jsonFlag(a.Viper, cmd))
+ return yamlFlag(a.viper, jsonFlag(a.viper, cmd))
}
func chainsAddCmd(a *appState) *cobra.Command {
@@ -274,57 +291,55 @@ func chainsAddCmd(a *appState) *cobra.Command {
" the chain-registry or passing a file (-f) or url (-u)",
Args: withUsage(cobra.MinimumNArgs(0)),
Example: fmt.Sprintf(` $ %s chains add cosmoshub
+ $ %s chains add testnets/cosmoshubtestnet
$ %s chains add cosmoshub osmosis
$ %s chains add --file chains/ibc0.json ibc0
- $ %s chains add --url https://relayer.com/ibc0.json ibc0`, appName, appName, appName, appName),
+ $ %s chains add --url https://relayer.com/ibc0.json ibc0`, appName, appName, appName, appName, appName),
RunE: func(cmd *cobra.Command, args []string) error {
file, url, err := getAddInputs(cmd)
if err != nil {
return err
}
- if ok := a.Config; ok == nil {
+ if ok := a.config; ok == nil {
return fmt.Errorf("config not initialized, consider running `rly config init`")
}
- // default behavior fetch from chain registry
- // still allow for adding config from url or file
- switch {
- case file != "":
- var chainName string
- switch len(args) {
- case 0:
- chainName = strings.Split(filepath.Base(file), ".")[0]
- case 1:
- chainName = args[0]
+ return a.performConfigLockingOperation(cmd.Context(), func() error {
+ // default behavior fetch from chain registry
+ // still allow for adding config from url or file
+ switch {
+ case file != "":
+ var chainName string
+ switch len(args) {
+ case 0:
+ chainName = strings.Split(filepath.Base(file), ".")[0]
+ case 1:
+ chainName = args[0]
+ default:
+ return errors.New("one chain name is required")
+ }
+ if err := addChainFromFile(a, chainName, file); err != nil {
+ return err
+ }
+ case url != "":
+ if len(args) != 1 {
+ return errors.New("one chain name is required")
+ }
+ if err := addChainFromURL(a, args[0], url); err != nil {
+ return err
+ }
default:
- return errors.New("one chain name is required")
- }
- if err := addChainFromFile(a, chainName, file); err != nil {
- return err
- }
- case url != "":
- if len(args) != 1 {
- return errors.New("one chain name is required")
- }
- if err := addChainFromURL(a, args[0], url); err != nil {
- return err
- }
- default:
- if err := addChainsFromRegistry(cmd.Context(), a, args); err != nil {
- return err
+ if err := addChainsFromRegistry(cmd.Context(), a, args); err != nil {
+ return err
+ }
}
- }
-
- if err := validateConfig(a.Config); err != nil {
- return err
- }
-
- return a.OverwriteConfig(a.Config)
+ return nil
+ })
},
}
- return chainsAddFlags(a.Viper, cmd)
+ return chainsAddFlags(a.viper, cmd)
}
func chainsAddDirCmd(a *appState) *cobra.Command {
@@ -340,10 +355,7 @@ func chainsAddDirCmd(a *appState) *cobra.Command {
$ %s chains add-dir configs/demo/chains
$ %s ch ad testnet/chains/`, appName, appName)),
RunE: func(cmd *cobra.Command, args []string) (err error) {
- if err := addChainsFromDirectory(cmd.ErrOrStderr(), a, args[0]); err != nil {
- return err
- }
- return a.OverwriteConfig(a.Config)
+ return addChainsFromDirectory(cmd.Context(), cmd.ErrOrStderr(), a, args[0])
},
}
@@ -369,15 +381,15 @@ func addChainFromFile(a *appState, chainName string, file string) error {
}
prov, err := pcw.Value.NewProvider(
- a.Log.With(zap.String("provider_type", pcw.Type)),
- a.HomePath, a.Debug, chainName,
+ a.log.With(zap.String("provider_type", pcw.Type)),
+ a.homePath, a.debug, chainName,
)
if err != nil {
return fmt.Errorf("failed to build ChainProvider for %s: %w", file, err)
}
- c := relayer.NewChain(a.Log, prov, a.Debug)
- if err = a.Config.AddChain(c); err != nil {
+ c := relayer.NewChain(a.log, prov, a.debug)
+ if err = a.config.AddChain(c); err != nil {
return err
}
@@ -409,28 +421,28 @@ func addChainFromURL(a *appState, chainName string, rawurl string) error {
// build the ChainProvider before initializing the chain
prov, err := pcw.Value.NewProvider(
- a.Log.With(zap.String("provider_type", pcw.Type)),
- a.HomePath, a.Debug, chainName,
+ a.log.With(zap.String("provider_type", pcw.Type)),
+ a.homePath, a.debug, chainName,
)
if err != nil {
return fmt.Errorf("failed to build ChainProvider for %s: %w", rawurl, err)
}
- c := relayer.NewChain(a.Log, prov, a.Debug)
- if err := a.Config.AddChain(c); err != nil {
+ c := relayer.NewChain(a.log, prov, a.debug)
+ if err := a.config.AddChain(c); err != nil {
return err
}
return nil
}
func addChainsFromRegistry(ctx context.Context, a *appState, chains []string) error {
- chainRegistry := cregistry.DefaultChainRegistry(a.Log)
+ chainRegistry := cregistry.DefaultChainRegistry(a.log)
var existed, failed, added []string
for _, chain := range chains {
- if _, ok := a.Config.Chains[chain]; ok {
- a.Log.Warn(
+ if _, ok := a.config.Chains[chain]; ok {
+ a.log.Warn(
"Chain already exists",
zap.String("chain", chain),
zap.String("source_link", chainRegistry.SourceLink()),
@@ -441,7 +453,7 @@ func addChainsFromRegistry(ctx context.Context, a *appState, chains []string) er
chainInfo, err := chainRegistry.GetChain(ctx, chain)
if err != nil {
- a.Log.Warn(
+ a.log.Warn(
"Error retrieving chain",
zap.String("chain", chain),
zap.Error(err),
@@ -450,9 +462,9 @@ func addChainsFromRegistry(ctx context.Context, a *appState, chains []string) er
continue
}
- chainConfig, err := chainInfo.GetChainConfig(ctx)
+ chainConfig, err := chainInfo.GetChainConfig(ctx, chain)
if err != nil {
- a.Log.Warn(
+ a.log.Warn(
"Error generating chain config",
zap.String("chain", chain),
zap.Error(err),
@@ -465,11 +477,11 @@ func addChainsFromRegistry(ctx context.Context, a *appState, chains []string) er
// build the ChainProvider
prov, err := chainConfig.NewProvider(
- a.Log.With(zap.String("provider_type", "cosmos")),
- a.HomePath, a.Debug, chainInfo.ChainName,
+ a.log.With(zap.String("provider_type", "cosmos")),
+ a.homePath, a.debug, chainInfo.ChainName,
)
if err != nil {
- a.Log.Warn(
+ a.log.Warn(
"Failed to build ChainProvider",
zap.String("chain_id", chainConfig.ChainID),
zap.Error(err),
@@ -479,9 +491,9 @@ func addChainsFromRegistry(ctx context.Context, a *appState, chains []string) er
}
// add to config
- c := relayer.NewChain(a.Log, prov, a.Debug)
- if err = a.Config.AddChain(c); err != nil {
- a.Log.Warn(
+ c := relayer.NewChain(a.log, prov, a.debug)
+ if err = a.config.AddChain(c); err != nil {
+ a.log.Warn(
"Failed to add chain to config",
zap.String("chain", chain),
zap.Error(err),
@@ -494,7 +506,7 @@ func addChainsFromRegistry(ctx context.Context, a *appState, chains []string) er
// found the correct chain so move on to next chain in chains
}
- a.Log.Info("Config update status",
+ a.log.Info("Config update status",
zap.Any("added", added),
zap.Any("failed", failed),
zap.Any("already existed", existed),
diff --git a/cmd/config.go b/cmd/config.go
index 1faf6b1bb..54fa542e4 100644
--- a/cmd/config.go
+++ b/cmd/config.go
@@ -19,6 +19,7 @@ package cmd
import (
"context"
"encoding/json"
+ "errors"
"fmt"
"io"
"io/ioutil"
@@ -31,6 +32,9 @@ import (
"github.com/cosmos/relayer/v2/relayer"
"github.com/cosmos/relayer/v2/relayer/chains/cosmos"
+ "github.com/cosmos/relayer/v2/relayer/chains/icon"
+ "github.com/cosmos/relayer/v2/relayer/chains/penumbra"
+ "github.com/cosmos/relayer/v2/relayer/chains/wasm"
"github.com/cosmos/relayer/v2/relayer/provider"
"github.com/spf13/cobra"
"go.uber.org/zap"
@@ -87,14 +91,14 @@ $ %s cfg list`, appName, defaultHome, appName)),
case yml && jsn:
return fmt.Errorf("can't pass both --json and --yaml, must pick one")
case jsn:
- out, err := json.Marshal(a.Config.Wrapped())
+ out, err := json.Marshal(a.config.Wrapped())
if err != nil {
return err
}
fmt.Fprintln(cmd.OutOrStdout(), string(out))
return nil
default:
- out, err := yaml.Marshal(a.Config.Wrapped())
+ out, err := yaml.Marshal(a.config.Wrapped())
if err != nil {
return err
}
@@ -104,7 +108,7 @@ $ %s cfg list`, appName, defaultHome, appName)),
},
}
- return yamlFlag(a.Viper, jsonFlag(a.Viper, cmd))
+ return yamlFlag(a.viper, jsonFlag(a.viper, cmd))
}
// Command for initializing an empty config at the --home location
@@ -165,7 +169,7 @@ $ %s cfg i`, appName, defaultHome, appName)),
return fmt.Errorf("config already exists: %s", cfgPath)
},
}
- cmd = memoFlag(a.Viper, cmd)
+ cmd = memoFlag(a.viper, cmd)
return cmd
}
@@ -175,48 +179,51 @@ $ %s cfg i`, appName, defaultHome, appName)),
// If any files fail to parse or otherwise are not able to be added to a's chains,
// the error is logged.
// An error is only returned if the directory cannot be read at all.
-func addChainsFromDirectory(stderr io.Writer, a *appState, dir string) error {
+func addChainsFromDirectory(ctx context.Context, stderr io.Writer, a *appState, dir string) error {
dir = path.Clean(dir)
files, err := ioutil.ReadDir(dir)
if err != nil {
return err
}
- for _, f := range files {
- pth := filepath.Join(dir, f.Name())
- if f.IsDir() {
- fmt.Fprintf(stderr, "directory at %s, skipping...\n", pth)
- continue
- }
- byt, err := os.ReadFile(pth)
- if err != nil {
- fmt.Fprintf(stderr, "failed to read file %s. Err: %v skipping...\n", pth, err)
- continue
- }
+ return a.performConfigLockingOperation(ctx, func() error {
+ for _, f := range files {
+ pth := filepath.Join(dir, f.Name())
+ if f.IsDir() {
+ fmt.Fprintf(stderr, "directory at %s, skipping...\n", pth)
+ continue
+ }
- var pcw ProviderConfigWrapper
- if err = json.Unmarshal(byt, &pcw); err != nil {
- fmt.Fprintf(stderr, "failed to unmarshal file %s. Err: %v skipping...\n", pth, err)
- continue
- }
- chainName := strings.Split(f.Name(), ".")[0]
- prov, err := pcw.Value.NewProvider(
- a.Log.With(zap.String("provider_type", pcw.Type)),
- a.HomePath, a.Debug, chainName,
- )
- if err != nil {
- fmt.Fprintf(stderr, "failed to build ChainProvider for %s. Err: %v \n", pth, err)
- continue
- }
+ byt, err := os.ReadFile(pth)
+ if err != nil {
+ fmt.Fprintf(stderr, "failed to read file %s. Err: %v skipping...\n", pth, err)
+ continue
+ }
- c := relayer.NewChain(a.Log, prov, a.Debug)
- if err = a.Config.AddChain(c); err != nil {
- fmt.Fprintf(stderr, "failed to add chain %s: %v \n", pth, err)
- continue
+ var pcw ProviderConfigWrapper
+ if err = json.Unmarshal(byt, &pcw); err != nil {
+ fmt.Fprintf(stderr, "failed to unmarshal file %s. Err: %v skipping...\n", pth, err)
+ continue
+ }
+ chainName := strings.Split(f.Name(), ".")[0]
+ prov, err := pcw.Value.NewProvider(
+ a.log.With(zap.String("provider_type", pcw.Type)),
+ a.homePath, a.debug, chainName,
+ )
+ if err != nil {
+ fmt.Fprintf(stderr, "failed to build ChainProvider for %s. Err: %v \n", pth, err)
+ continue
+ }
+
+ c := relayer.NewChain(a.log, prov, a.debug)
+ if err = a.config.AddChain(c); err != nil {
+ fmt.Fprintf(stderr, "failed to add chain %s: %v \n", pth, err)
+ continue
+ }
+ fmt.Fprintf(stderr, "added chain %s...\n", c.ChainProvider.ChainId())
}
- fmt.Fprintf(stderr, "added chain %s...\n", c.ChainProvider.ChainId())
- }
- return nil
+ return nil
+ })
}
// addPathsFromDirectory parses all the files containing JSON-encoded paths in dir,
@@ -230,36 +237,38 @@ func addPathsFromDirectory(ctx context.Context, stderr io.Writer, a *appState, d
if err != nil {
return err
}
- for _, f := range files {
- pth := filepath.Join(dir, f.Name())
- if f.IsDir() {
- fmt.Fprintf(stderr, "directory at %s, skipping...\n", pth)
- continue
- }
+ return a.performConfigLockingOperation(ctx, func() error {
+ for _, f := range files {
+ pth := filepath.Join(dir, f.Name())
+ if f.IsDir() {
+ fmt.Fprintf(stderr, "directory at %s, skipping...\n", pth)
+ continue
+ }
- byt, err := os.ReadFile(pth)
- if err != nil {
- return fmt.Errorf("failed to read file %s: %w", pth, err)
- }
+ byt, err := os.ReadFile(pth)
+ if err != nil {
+ return fmt.Errorf("failed to read file %s: %w", pth, err)
+ }
- p := &relayer.Path{}
- if err = json.Unmarshal(byt, p); err != nil {
- return fmt.Errorf("failed to unmarshal file %s: %w", pth, err)
- }
+ p := &relayer.Path{}
+ if err = json.Unmarshal(byt, p); err != nil {
+ return fmt.Errorf("failed to unmarshal file %s: %w", pth, err)
+ }
- pthName := strings.Split(f.Name(), ".")[0]
- if err := a.Config.ValidatePath(ctx, stderr, p); err != nil {
- return fmt.Errorf("failed to validate path %s: %w", pth, err)
- }
+ pthName := strings.Split(f.Name(), ".")[0]
+ if err := a.config.ValidatePath(ctx, stderr, p); err != nil {
+ return fmt.Errorf("failed to validate path %s: %w", pth, err)
+ }
- if err := a.Config.AddPath(pthName, p); err != nil {
- return fmt.Errorf("failed to add path %s: %w", pth, err)
- }
+ if err := a.config.AddPath(pthName, p); err != nil {
+ return fmt.Errorf("failed to add path %s: %w", pth, err)
+ }
- fmt.Fprintf(stderr, "added path %s...\n\n", pthName)
- }
+ fmt.Fprintf(stderr, "added path %s...\n\n", pthName)
+ }
- return nil
+ return nil
+ })
}
// Wrapped converts the Config struct into a ConfigOutputWrapper struct
@@ -276,8 +285,8 @@ func (c *Config) Wrapped() *ConfigOutputWrapper {
}
// rlyMemo returns a formatted message memo string
-// that includes "rly" and the version, e.g. "rly(v2.0.0)"
-// or "My custom memo | rly(v2.0.0)"
+// that includes "rly" and the version, e.g. "rly(v2.3.0)"
+// or "My custom memo | rly(v2.3.0)"
func rlyMemo(memo string) string {
if memo == "-" {
// omit memo entirely
@@ -322,6 +331,34 @@ type ConfigInputWrapper struct {
Paths relayer.Paths `yaml:"paths"`
}
+// RuntimeConfig converts the input disk config into the relayer runtime config.
+func (c *ConfigInputWrapper) RuntimeConfig(ctx context.Context, a *appState) (*Config, error) {
+ // build providers for each chain
+ chains := make(relayer.Chains)
+ for chainName, pcfg := range c.ProviderConfigs {
+ prov, err := pcfg.Value.(provider.ProviderConfig).NewProvider(
+ a.log.With(zap.String("provider_type", pcfg.Type)),
+ a.homePath, a.debug, chainName,
+ )
+ if err != nil {
+ return nil, fmt.Errorf("failed to build ChainProviders: %w", err)
+ }
+
+ if err := prov.Init(ctx); err != nil {
+ return nil, fmt.Errorf("failed to initialize provider: %w", err)
+ }
+
+ chain := relayer.NewChain(a.log, prov, a.debug)
+ chains[chainName] = chain
+ }
+
+ return &Config{
+ Global: c.Global,
+ Chains: chains,
+ Paths: c.Paths,
+ }, nil
+}
+
type ProviderConfigs map[string]*ProviderConfigWrapper
// ProviderConfigWrapper is an intermediary type for parsing arbitrary ProviderConfigs from json files and writing to json/yaml files
@@ -340,7 +377,10 @@ type ProviderConfigYAMLWrapper struct {
// NOTE: Add new ProviderConfig types in the map here with the key set equal to the type of ChainProvider (e.g. cosmos, substrate, etc.)
func (pcw *ProviderConfigWrapper) UnmarshalJSON(data []byte) error {
customTypes := map[string]reflect.Type{
- "cosmos": reflect.TypeOf(cosmos.CosmosProviderConfig{}),
+ "icon": reflect.TypeOf(icon.IconProviderConfig{}),
+ "cosmos": reflect.TypeOf(cosmos.CosmosProviderConfig{}),
+ "wasm": reflect.TypeOf(wasm.WasmProviderConfig{}),
+ "penumbra": reflect.TypeOf(penumbra.PenumbraProviderConfig{}),
}
val, err := UnmarshalJSONProviderConfig(data, customTypes)
if err != nil {
@@ -358,7 +398,11 @@ func UnmarshalJSONProviderConfig(data []byte, customTypes map[string]reflect.Typ
return nil, err
}
- typeName := m["type"].(string)
+ typeName, ok := m["type"].(string)
+ if !ok {
+ return nil, errors.New("cannot find type")
+ }
+
var provCfg provider.ProviderConfig
if ty, found := customTypes[typeName]; found {
provCfg = reflect.New(ty).Interface().(provider.ProviderConfig)
@@ -393,6 +437,12 @@ func (iw *ProviderConfigYAMLWrapper) UnmarshalYAML(n *yaml.Node) error {
switch iw.Type {
case "cosmos":
iw.Value = new(cosmos.CosmosProviderConfig)
+ case "icon":
+ iw.Value = new(icon.IconProviderConfig)
+ case "wasm":
+ iw.Value = new(wasm.WasmProviderConfig)
+ case "penumbra":
+ iw.Value = new(penumbra.PenumbraProviderConfig)
default:
return fmt.Errorf("%s is an invalid chain type, check your config file", iw.Type)
}
@@ -508,6 +558,10 @@ func checkPathEndConflict(pathID, direction string, oldPe, newPe *relayer.PathEn
// AddPath adds an additional path to the config
func (c *Config) AddPath(name string, path *relayer.Path) (err error) {
+ // Ensure path is initialized.
+ if c.Paths == nil {
+ c.Paths = make(relayer.Paths)
+ }
// Check if the path does not yet exist.
oldPath, err := c.Paths.Get(name)
if err != nil {
@@ -531,87 +585,19 @@ func (c *Config) DeleteChain(chain string) {
}
// validateConfig is used to validate the GlobalConfig values
-func validateConfig(c *Config) error {
+func (c *Config) validateConfig() error {
_, err := time.ParseDuration(c.Global.Timeout)
if err != nil {
return fmt.Errorf("did you remember to run 'rly config init' error:%w", err)
}
- return nil
-}
-
-// initConfig reads config file into a.Config if file is present.
-func initConfig(cmd *cobra.Command, a *appState) error {
- if a.HomePath == "" {
- var err error
- a.HomePath, err = cmd.PersistentFlags().GetString(flagHome)
- if err != nil {
- return err
- }
- }
-
- cfgPath := path.Join(a.HomePath, "config", "config.yaml")
- if _, err := os.Stat(cfgPath); err != nil {
- // don't return error if file doesn't exist
- return nil
- }
- a.Viper.SetConfigFile(cfgPath)
- if err := a.Viper.ReadInConfig(); err != nil {
- return err
- }
- // read the config file bytes
- file, err := os.ReadFile(a.Viper.ConfigFileUsed())
- if err != nil {
- fmt.Fprintln(cmd.ErrOrStderr(), "Error reading file:", err)
- return err
- }
-
- // unmarshall them into the wrapper struct
- cfgWrapper := &ConfigInputWrapper{}
- err = yaml.Unmarshal(file, cfgWrapper)
- if err != nil {
- fmt.Fprintln(cmd.ErrOrStderr(), "Error unmarshalling config:", err)
- return err
- }
-
// verify that the channel filter rule is valid for every path in the config
- for _, p := range cfgWrapper.Paths {
+ for _, p := range c.Paths {
if err := p.ValidateChannelFilterRule(); err != nil {
return fmt.Errorf("error initializing the relayer config for path %s: %w", p.String(), err)
}
}
- // build the config struct
- chains := make(relayer.Chains)
- for chainName, pcfg := range cfgWrapper.ProviderConfigs {
- prov, err := pcfg.Value.(provider.ProviderConfig).NewProvider(
- a.Log.With(zap.String("provider_type", pcfg.Type)),
- a.HomePath, a.Debug, chainName,
- )
- if err != nil {
- return fmt.Errorf("failed to build ChainProviders: %w", err)
- }
-
- if err := prov.Init(cmd.Context()); err != nil {
- return fmt.Errorf("failed to initialize provider: %w", err)
- }
-
- chain := relayer.NewChain(a.Log, prov, a.Debug)
- chains[chainName] = chain
- }
-
- a.Config = &Config{
- Global: cfgWrapper.Global,
- Chains: chains,
- Paths: cfgWrapper.Paths,
- }
-
- // ensure config has []*relayer.Chain used for all chain operations
- if err := validateConfig(a.Config); err != nil {
- fmt.Fprintln(cmd.ErrOrStderr(), "Error parsing chain config:", err)
- return err
- }
-
return nil
}
diff --git a/cmd/feegrant.go b/cmd/feegrant.go
new file mode 100644
index 000000000..edb66d800
--- /dev/null
+++ b/cmd/feegrant.go
@@ -0,0 +1,213 @@
+package cmd
+
+import (
+ "errors"
+ "fmt"
+
+ "github.com/cosmos/relayer/v2/relayer/chains/cosmos"
+ "github.com/spf13/cobra"
+)
+
+// feegrantConfigureCmd returns the fee grant configuration commands for this module
+func feegrantConfigureBaseCmd(a *appState) *cobra.Command {
+ cmd := &cobra.Command{
+ Use: "feegrant",
+ Short: "Configure the client to use round-robin feegranted accounts when sending TXs",
+ Long: "Use round-robin feegranted accounts when sending TXs. Useful for relayers and applications where sequencing is important",
+ }
+
+ cmd.AddCommand(
+ feegrantConfigureBasicCmd(a),
+ )
+
+ return cmd
+}
+
+func feegrantConfigureBasicCmd(a *appState) *cobra.Command {
+ var numGrantees int
+ var update bool
+ var delete bool
+ var updateGrantees bool
+ var grantees []string
+
+ cmd := &cobra.Command{
+ Use: "basicallowance [chain-name] [granter] --num-grantees [int] --overwrite-granter --overwrite-grantees",
+ Short: "feegrants for the given chain and granter (if granter is unspecified, use the default key)",
+ Long: "feegrants for the given chain. 10 grantees by default, all with an unrestricted BasicAllowance.",
+ Args: cobra.MinimumNArgs(1),
+ RunE: func(cmd *cobra.Command, args []string) error {
+ chain := args[0]
+ cosmosChain, ok := a.config.Chains[chain]
+ if !ok {
+ return errChainNotFound(args[0])
+ }
+
+ prov, ok := cosmosChain.ChainProvider.(*cosmos.CosmosProvider)
+ if !ok {
+ return errors.New("only CosmosProvider can be feegranted")
+ }
+
+ granterKeyOrAddr := ""
+
+ if len(args) > 1 {
+ granterKeyOrAddr = args[1]
+ } else if prov.PCfg.FeeGrants != nil {
+ granterKeyOrAddr = prov.PCfg.FeeGrants.GranterKey
+ } else {
+ granterKeyOrAddr = prov.PCfg.Key
+ }
+
+ granterKey, err := prov.KeyFromKeyOrAddress(granterKeyOrAddr)
+ if err != nil {
+ return fmt.Errorf("could not get granter key from '%s'", granterKeyOrAddr)
+ }
+
+ if delete {
+ fmt.Printf("Deleting %s feegrant configuration\n", chain)
+
+ cfgErr := a.performConfigLockingOperation(cmd.Context(), func() error {
+ chain := a.config.Chains[chain]
+ oldProv := chain.ChainProvider.(*cosmos.CosmosProvider)
+ oldProv.PCfg.FeeGrants = nil
+ return nil
+ })
+ cobra.CheckErr(cfgErr)
+ return nil
+ }
+
+ if prov.PCfg.FeeGrants != nil && granterKey != prov.PCfg.FeeGrants.GranterKey && !update {
+ return fmt.Errorf("you specified granter '%s' which is different than configured feegranter '%s', but you did not specify the --overwrite-granter flag", granterKeyOrAddr, prov.PCfg.FeeGrants.GranterKey)
+ } else if prov.PCfg.FeeGrants != nil && granterKey != prov.PCfg.FeeGrants.GranterKey && update {
+ cfgErr := a.performConfigLockingOperation(cmd.Context(), func() error {
+ prov.PCfg.FeeGrants.GranterKey = granterKey
+ return nil
+ })
+ cobra.CheckErr(cfgErr)
+ }
+
+ if prov.PCfg.FeeGrants == nil || updateGrantees || len(grantees) > 0 {
+ var feegrantErr error
+
+ //No list of grantees was provided, so we will use the default naming convention "grantee1, ... granteeN"
+ if grantees == nil {
+ feegrantErr = prov.ConfigureFeegrants(numGrantees, granterKey)
+ } else {
+ feegrantErr = prov.ConfigureWithGrantees(grantees, granterKey)
+ }
+
+ if feegrantErr != nil {
+ return feegrantErr
+ }
+
+ cfgErr := a.performConfigLockingOperation(cmd.Context(), func() error {
+ chain := a.config.Chains[chain]
+ oldProv := chain.ChainProvider.(*cosmos.CosmosProvider)
+ oldProv.PCfg.FeeGrants = prov.PCfg.FeeGrants
+ return nil
+ })
+ cobra.CheckErr(cfgErr)
+ }
+
+ memo, err := cmd.Flags().GetString(flagMemo)
+ if err != nil {
+ return err
+ }
+
+ ctx := cmd.Context()
+ _, err = prov.EnsureBasicGrants(ctx, memo)
+ if err != nil {
+ return fmt.Errorf("error writing grants on chain: '%s'", err.Error())
+ }
+
+ //Get latest height from the chain, mark feegrant configuration as verified up to that height.
+ //This means we've verified feegranting is enabled on-chain and TXs can be sent with a feegranter.
+ if prov.PCfg.FeeGrants != nil {
+ fmt.Printf("Querying latest chain height to mark FeeGrant height... \n")
+ h, err := prov.QueryLatestHeight(ctx)
+ cobra.CheckErr(err)
+
+ cfgErr := a.performConfigLockingOperation(cmd.Context(), func() error {
+ chain := a.config.Chains[chain]
+ oldProv := chain.ChainProvider.(*cosmos.CosmosProvider)
+ oldProv.PCfg.FeeGrants = prov.PCfg.FeeGrants
+ oldProv.PCfg.FeeGrants.BlockHeightVerified = h
+ fmt.Printf("Feegrant chain height marked: %d\n", h)
+ return nil
+ })
+ cobra.CheckErr(cfgErr)
+ }
+
+ return nil
+ },
+ }
+
+ cmd.Flags().BoolVar(&delete, "delete", false, "delete the feegrant configuration")
+ cmd.Flags().BoolVar(&update, "overwrite-granter", false, "allow overwriting the existing granter")
+ cmd.Flags().BoolVar(&updateGrantees, "overwrite-grantees", false, "allow overwriting existing grantees")
+ cmd.Flags().IntVar(&numGrantees, "num-grantees", 10, "number of grantees that will be feegranted with basic allowances")
+ cmd.Flags().StringSliceVar(&grantees, "grantees", nil, "comma separated list of grantee key names (keys are created if they do not exist)")
+ cmd.MarkFlagsMutuallyExclusive("num-grantees", "grantees", "delete")
+
+ memoFlag(a.viper, cmd)
+ return cmd
+}
+
+func feegrantBasicGrantsCmd(a *appState) *cobra.Command {
+ cmd := &cobra.Command{
+ Use: "basic chain-name [granter]",
+ Short: "query the grants for an account (if none is specified, the default account is returned)",
+ Args: cobra.RangeArgs(1, 2),
+ RunE: func(cmd *cobra.Command, args []string) error {
+ chain := args[0]
+ cosmosChain, ok := a.config.Chains[chain]
+ if !ok {
+ return errChainNotFound(args[0])
+ }
+
+ prov, ok := cosmosChain.ChainProvider.(*cosmos.CosmosProvider)
+ if !ok {
+ return errors.New("only CosmosProvider can be feegranted")
+ }
+
+ // TODO fix pagination
+ // pageReq, err := client.ReadPageRequest(cmd.Flags())
+ // if err != nil {
+ // return err
+ // }
+
+ //TODO fix height
+ // height, err := lensCmd.ReadHeight(cmd.Flags())
+ // if err != nil {
+ // return err
+ // }
+
+ keyNameOrAddress := ""
+ if len(args) == 0 {
+ keyNameOrAddress = prov.PCfg.Key
+ } else {
+ keyNameOrAddress = args[0]
+ }
+
+ granterAcc, err := prov.AccountFromKeyOrAddress(keyNameOrAddress)
+ if err != nil {
+ fmt.Printf("Error retrieving account from key '%s'\n", keyNameOrAddress)
+ return err
+ }
+ granterAddr := prov.MustEncodeAccAddr(granterAcc)
+
+ res, err := prov.QueryFeegrantsByGranter(granterAddr, nil)
+ if err != nil {
+ return err
+ }
+
+ for _, grant := range res {
+ allowance, e := prov.Sprint(grant.Allowance)
+ cobra.CheckErr(e)
+ fmt.Printf("Granter: %s, Grantee: %s, Allowance: %s\n", grant.Granter, grant.Grantee, allowance)
+ }
+
+ return nil
+ },
+ }
+ return paginationFlags(a.viper, cmd, "feegrant")
+}
diff --git a/cmd/flags.go b/cmd/flags.go
index 427f12d52..1f8396899 100644
--- a/cmd/flags.go
+++ b/cmd/flags.go
@@ -54,6 +54,7 @@ const (
flagDstClientID = "dst-client-id"
flagSrcConnID = "src-connection-id"
flagDstConnID = "dst-connection-id"
+ flagBtpBlockHeight = "btp-block-height"
)
const (
@@ -80,6 +81,14 @@ func heightFlag(v *viper.Viper, cmd *cobra.Command) *cobra.Command {
return cmd
}
+func btpBlockHeightFlag(v *viper.Viper, cmd *cobra.Command) *cobra.Command {
+ cmd.Flags().Int64(flagBtpBlockHeight, 0, "Icon Start Height to register client")
+ if err := v.BindPFlag(flagBtpBlockHeight, cmd.Flags().Lookup(flagBtpBlockHeight)); err != nil {
+ panic(err)
+ }
+ return cmd
+}
+
func paginationFlags(v *viper.Viper, cmd *cobra.Command, query string) *cobra.Command {
cmd.Flags().Uint64(flagPage, 1, fmt.Sprintf("pagination page of %s to query for. This sets offset to a multiple of limit", query))
cmd.Flags().String(flagPageKey, "", fmt.Sprintf("pagination page-key of %s to query for", query))
@@ -225,11 +234,12 @@ func urlFlag(v *viper.Viper, cmd *cobra.Command) *cobra.Command {
}
func strategyFlag(v *viper.Viper, cmd *cobra.Command) *cobra.Command {
- cmd.Flags().StringP(flagMaxTxSize, "s", "2", "strategy of path to generate of the messages in a relay transaction")
- cmd.Flags().StringP(flagMaxMsgLength, "l", "5", "maximum number of messages in a relay transaction")
- if err := v.BindPFlag(flagMaxTxSize, cmd.Flags().Lookup(flagMaxTxSize)); err != nil {
- panic(err)
- }
+ cmd.Flags().Uint64P(
+ flagMaxMsgLength,
+ "l",
+ relayer.DefaultMaxMsgLength,
+ "maximum number of messages per transaction",
+ )
if err := v.BindPFlag(flagMaxMsgLength, cmd.Flags().Lookup(flagMaxMsgLength)); err != nil {
panic(err)
}
@@ -349,7 +359,7 @@ func processorFlag(v *viper.Viper, cmd *cobra.Command) *cobra.Command {
}
func initBlockFlag(v *viper.Viper, cmd *cobra.Command) *cobra.Command {
- cmd.Flags().Uint64P(flagInitialBlockHistory, "b", 20, "initial block history to query when using 'events' as the processor for relaying")
+ cmd.Flags().Uint64P(flagInitialBlockHistory, "b", 0, "initial block history to query when using 'events' as the processor for relaying")
if err := v.BindPFlag(flagInitialBlockHistory, cmd.Flags().Lookup(flagInitialBlockHistory)); err != nil {
panic(err)
}
diff --git a/cmd/keys.go b/cmd/keys.go
index 36072d405..3f7380141 100644
--- a/cmd/keys.go
+++ b/cmd/keys.go
@@ -22,6 +22,7 @@ import (
"io"
"strings"
+ "github.com/cosmos/cosmos-sdk/crypto/hd"
sdk "github.com/cosmos/cosmos-sdk/types"
"github.com/cosmos/relayer/v2/relayer/chains/cosmos"
"github.com/spf13/cobra"
@@ -30,6 +31,8 @@ import (
const (
flagCoinType = "coin-type"
+ flagAlgo = "signing-algorithm"
+ flagPassword = "password"
defaultCoinType uint32 = sdk.CoinType
)
@@ -46,8 +49,8 @@ func keysCmd(a *appState) *cobra.Command {
keysRestoreCmd(a),
keysDeleteCmd(a),
keysListCmd(a),
- keysShowCmd(a),
keysExportCmd(a),
+ keysShowCmd(a),
)
return cmd
@@ -65,7 +68,7 @@ $ %s keys add ibc-0
$ %s keys add ibc-1 key2
$ %s k a cosmoshub testkey`, appName, appName, appName)),
RunE: func(cmd *cobra.Command, args []string) error {
- chain, ok := a.Config.Chains[args[0]]
+ chain, ok := a.config.Chains[args[0]]
if !ok {
return errChainNotFound(args[0])
}
@@ -75,20 +78,40 @@ $ %s k a cosmoshub testkey`, appName, appName, appName)),
return errKeyExists(keyName)
}
- coinType, err := cmd.Flags().GetInt32(flagCoinType)
+ cmdFlags := cmd.Flags()
+
+ coinType, err := cmdFlags.GetInt32(flagCoinType)
if err != nil {
return err
}
if coinType < 0 {
- if ccp, ok := chain.ChainProvider.(*cosmos.CosmosProvider); ok {
- coinType = int32(ccp.PCfg.Slip44)
+ if ccp, ok := chain.ChainProvider.(*cosmos.CosmosProvider); ok && ccp.PCfg.Slip44 != nil {
+ coinType = int32(*ccp.PCfg.Slip44)
} else {
coinType = int32(defaultCoinType)
}
}
- ko, err := chain.ChainProvider.AddKey(keyName, uint32(coinType))
+ algo, err := cmdFlags.GetString(flagAlgo)
+ if err != nil {
+ return err
+ }
+
+ password, err := cmdFlags.GetString(flagPassword)
+ if err != nil {
+ return err
+ }
+
+ if algo == "" {
+ if ccp, ok := chain.ChainProvider.(*cosmos.CosmosProvider); ok {
+ algo = ccp.PCfg.SigningAlgorithm
+ } else {
+ algo = string(hd.Secp256k1Type)
+ }
+ }
+
+ ko, err := chain.ChainProvider.AddKey(keyName, uint32(coinType), algo, password)
if err != nil {
return fmt.Errorf("failed to add key: %w", err)
}
@@ -103,6 +126,8 @@ $ %s k a cosmoshub testkey`, appName, appName, appName)),
},
}
cmd.Flags().Int32(flagCoinType, -1, "coin type number for HD derivation")
+ cmd.Flags().String(flagAlgo, "", "signing algorithm for key (secp256k1, sr25519)")
+ cmd.Flags().String(flagPassword, "x", "icon keystore password")
return cmd
}
@@ -120,7 +145,7 @@ $ %s k r cosmoshub faucet-key "[mnemonic-words]"`, appName, appName)),
RunE: func(cmd *cobra.Command, args []string) error {
keyName := args[1]
- chain, ok := a.Config.Chains[args[0]]
+ chain, ok := a.config.Chains[args[0]]
if !ok {
return errChainNotFound(args[0])
}
@@ -129,20 +154,35 @@ $ %s k r cosmoshub faucet-key "[mnemonic-words]"`, appName, appName)),
return errKeyExists(keyName)
}
- coinType, err := cmd.Flags().GetInt32(flagCoinType)
+ cmdFlags := cmd.Flags()
+
+ coinType, err := cmdFlags.GetInt32(flagCoinType)
if err != nil {
return err
}
if coinType < 0 {
- if ccp, ok := chain.ChainProvider.(*cosmos.CosmosProvider); ok {
- coinType = int32(ccp.PCfg.Slip44)
+ if ccp, ok := chain.ChainProvider.(*cosmos.CosmosProvider); ok && ccp.PCfg.Slip44 != nil {
+ coinType = int32(*ccp.PCfg.Slip44)
} else {
coinType = int32(defaultCoinType)
}
}
- address, err := chain.ChainProvider.RestoreKey(keyName, args[2], uint32(coinType))
+ algo, err := cmdFlags.GetString(flagAlgo)
+ if err != nil {
+ return err
+ }
+
+ if algo == "" {
+ if ccp, ok := chain.ChainProvider.(*cosmos.CosmosProvider); ok {
+ algo = ccp.PCfg.SigningAlgorithm
+ } else {
+ algo = string(hd.Secp256k1Type)
+ }
+ }
+
+ address, err := chain.ChainProvider.RestoreKey(keyName, args[2], uint32(coinType), algo)
if err != nil {
return err
}
@@ -152,6 +192,7 @@ $ %s k r cosmoshub faucet-key "[mnemonic-words]"`, appName, appName)),
},
}
cmd.Flags().Int32(flagCoinType, -1, "coin type number for HD derivation")
+ cmd.Flags().String(flagAlgo, "", "signing algorithm for key (secp256k1, sr25519)")
return cmd
}
@@ -168,7 +209,7 @@ $ %s keys delete ibc-0 -y
$ %s keys delete ibc-1 key2 -y
$ %s k d cosmoshub default`, appName, appName, appName)),
RunE: func(cmd *cobra.Command, args []string) error {
- chain, ok := a.Config.Chains[args[0]]
+ chain, ok := a.config.Chains[args[0]]
if !ok {
return errChainNotFound(args[0])
}
@@ -195,7 +236,7 @@ $ %s k d cosmoshub default`, appName, appName, appName)),
},
}
- return skipConfirm(a.Viper, cmd)
+ return skipConfirm(a.viper, cmd)
}
func askForConfirmation(a *appState, stdin io.Reader, stderr io.Writer) bool {
@@ -203,7 +244,7 @@ func askForConfirmation(a *appState, stdin io.Reader, stderr io.Writer) bool {
_, err := fmt.Fscanln(stdin, &response)
if err != nil {
- a.Log.Fatal("Failed to read input", zap.Error(err))
+ a.log.Fatal("Failed to read input", zap.Error(err))
}
switch strings.ToLower(response) {
@@ -230,7 +271,7 @@ $ %s k l ibc-1`, appName, appName)),
RunE: func(cmd *cobra.Command, args []string) error {
chainName := args[0]
- chain, ok := a.Config.Chains[chainName]
+ chain, ok := a.config.Chains[chainName]
if !ok {
return errChainNotFound(chainName)
}
@@ -255,47 +296,6 @@ $ %s k l ibc-1`, appName, appName)),
return cmd
}
-// keysShowCmd respresents the `keys show` command
-func keysShowCmd(a *appState) *cobra.Command {
- cmd := &cobra.Command{
- Use: "show chain_name [key_name]",
- Aliases: []string{"s"},
- Short: "Shows a key from the keychain associated with a particular chain",
- Args: withUsage(cobra.RangeArgs(1, 2)),
- Example: strings.TrimSpace(fmt.Sprintf(`
-$ %s keys show ibc-0
-$ %s keys show ibc-1 key2
-$ %s k s ibc-2 testkey`, appName, appName, appName)),
- RunE: func(cmd *cobra.Command, args []string) error {
- chain, ok := a.Config.Chains[args[0]]
- if !ok {
- return errChainNotFound(args[0])
- }
-
- var keyName string
- if len(args) == 2 {
- keyName = args[1]
- } else {
- keyName = chain.ChainProvider.Key()
- }
-
- if !chain.ChainProvider.KeyExists(keyName) {
- return errKeyDoesntExist(keyName)
- }
-
- address, err := chain.ChainProvider.ShowAddress(keyName)
- if err != nil {
- return err
- }
-
- fmt.Fprintln(cmd.OutOrStdout(), address)
- return nil
- },
- }
-
- return cmd
-}
-
// keysExportCmd respresents the `keys export` command
func keysExportCmd(a *appState) *cobra.Command {
cmd := &cobra.Command{
@@ -308,7 +308,7 @@ $ %s keys export ibc-0 testkey
$ %s k e cosmoshub testkey`, appName, appName)),
RunE: func(cmd *cobra.Command, args []string) error {
keyName := args[1]
- chain, ok := a.Config.Chains[args[0]]
+ chain, ok := a.config.Chains[args[0]]
if !ok {
return errChainNotFound(args[0])
}
@@ -329,3 +329,64 @@ $ %s k e cosmoshub testkey`, appName, appName)),
return cmd
}
+
+// ShowAddressByChainAndKey represents the logic for showing relayer address by chain_name and key_name
+func (a *appState) showAddressByChainAndKey(cmd *cobra.Command, args []string) error {
+ chain, ok := a.config.Chains[args[0]]
+ if !ok {
+ return errChainNotFound(args[0])
+ }
+
+ var keyName string
+ if len(args) == 2 {
+ keyName = args[1]
+ } else {
+ keyName = chain.ChainProvider.Key()
+ }
+
+ if !chain.ChainProvider.KeyExists(keyName) {
+ return errKeyDoesntExist(keyName)
+ }
+
+ address, err := chain.ChainProvider.ShowAddress(keyName)
+ if err != nil {
+ return err
+ }
+
+ fmt.Fprintln(cmd.OutOrStdout(), address)
+ return nil
+}
+
+// keysShowCmd respresents the `keys show` command
+func keysShowCmd(a *appState) *cobra.Command {
+ cmd := &cobra.Command{
+ Use: "show chain_name [key_name]",
+ Aliases: []string{"s"},
+ Short: "Shows a key from the keychain associated with a particular chain",
+ Args: withUsage(cobra.RangeArgs(1, 2)),
+ Example: strings.TrimSpace(fmt.Sprintf(`
+$ %s keys show ibc-0
+$ %s keys show ibc-1 key2
+$ %s k s ibc-2 testkey`, appName, appName, appName)),
+ RunE: a.showAddressByChainAndKey,
+ }
+
+ return cmd
+}
+
+// addressCmd represents the address of a relayer
+func addressCmd(a *appState) *cobra.Command {
+ cmd := &cobra.Command{
+ Use: "address chain_name [key_name]",
+ Aliases: []string{"a"},
+ Short: "Shows the address of a relayer",
+ Args: withUsage(cobra.RangeArgs(1, 2)),
+ Example: strings.TrimSpace(fmt.Sprintf(`
+$ %s address ibc-0
+$ %s address ibc-1 key2
+$ %s a ibc-2 testkey`, appName, appName, appName)),
+ RunE: a.showAddressByChainAndKey,
+ }
+
+ return cmd
+}
diff --git a/cmd/keys_test.go b/cmd/keys_test.go
index 6a302fd1c..df51f8924 100644
--- a/cmd/keys_test.go
+++ b/cmd/keys_test.go
@@ -42,6 +42,8 @@ func TestKeysRestore_Delete(t *testing.T) {
_ = sys.MustRun(t, "config", "init")
+ slip44 := 118
+
sys.MustAddChain(t, "testChain", cmd.ProviderConfigWrapper{
Type: "cosmos",
Value: cosmos.CosmosProviderConfig{
@@ -49,7 +51,7 @@ func TestKeysRestore_Delete(t *testing.T) {
ChainID: "testcosmos",
KeyringBackend: "test",
Timeout: "10s",
- Slip44: 118,
+ Slip44: &slip44,
},
})
@@ -82,6 +84,8 @@ func TestKeysExport(t *testing.T) {
_ = sys.MustRun(t, "config", "init")
+ slip44 := 118
+
sys.MustAddChain(t, "testChain", cmd.ProviderConfigWrapper{
Type: "cosmos",
Value: cosmos.CosmosProviderConfig{
@@ -89,7 +93,7 @@ func TestKeysExport(t *testing.T) {
ChainID: "testcosmos",
KeyringBackend: "test",
Timeout: "10s",
- Slip44: 118,
+ Slip44: &slip44,
},
})
@@ -113,3 +117,68 @@ func TestKeysExport(t *testing.T) {
// TODO: confirm the imported address matches?
}
+
+func TestKeysDefaultCoinType(t *testing.T) {
+ t.Parallel()
+
+ sys := relayertest.NewSystem(t)
+
+ _ = sys.MustRun(t, "config", "init")
+
+ slip44 := 118
+
+ sys.MustAddChain(t, "testChain", cmd.ProviderConfigWrapper{
+ Type: "cosmos",
+ Value: cosmos.CosmosProviderConfig{
+ AccountPrefix: "cosmos",
+ ChainID: "testcosmos-1",
+ KeyringBackend: "test",
+ Timeout: "10s",
+ Slip44: &slip44,
+ },
+ })
+
+ sys.MustAddChain(t, "testChain2", cmd.ProviderConfigWrapper{
+ Type: "cosmos",
+ Value: cosmos.CosmosProviderConfig{
+ AccountPrefix: "cosmos",
+ ChainID: "testcosmos-2",
+ KeyringBackend: "test",
+ Timeout: "10s",
+ },
+ })
+
+ // Restore a key with mnemonic to the chain.
+ res := sys.MustRun(t, "keys", "restore", "testChain", "default", relayertest.ZeroMnemonic)
+ require.Equal(t, res.Stdout.String(), relayertest.ZeroCosmosAddr+"\n")
+ require.Empty(t, res.Stderr.String())
+
+ // Restore a key with mnemonic to the chain.
+ res = sys.MustRun(t, "keys", "restore", "testChain2", "default", relayertest.ZeroMnemonic)
+ require.Equal(t, res.Stdout.String(), relayertest.ZeroCosmosAddr+"\n")
+ require.Empty(t, res.Stderr.String())
+
+ // Export the key.
+ res = sys.MustRun(t, "keys", "export", "testChain", "default")
+ armorOut := res.Stdout.String()
+ require.Contains(t, armorOut, "BEGIN TENDERMINT PRIVATE KEY")
+ require.Empty(t, res.Stderr.String())
+
+ // Export the key.
+ res = sys.MustRun(t, "keys", "export", "testChain2", "default")
+ armorOut2 := res.Stdout.String()
+ require.Contains(t, armorOut, "BEGIN TENDERMINT PRIVATE KEY")
+ require.Empty(t, res.Stderr.String())
+
+ // Import the key to a temporary keyring.
+ registry := codectypes.NewInterfaceRegistry()
+ cryptocodec.RegisterInterfaces(registry)
+ cdc := codec.NewProtoCodec(registry)
+ kr := keyring.NewInMemory(cdc)
+ require.NoError(t, kr.ImportPrivKey("temp", armorOut, keys.DefaultKeyPass))
+
+ // This should fail due to same key
+ err := kr.ImportPrivKey("temp", armorOut2, keys.DefaultKeyPass)
+ require.Error(t, err, "same key was able to be imported twice")
+ require.Contains(t, err.Error(), "cannot overwrite key")
+}
diff --git a/cmd/paths.go b/cmd/paths.go
index 46fc5aec8..640414fa5 100644
--- a/cmd/paths.go
+++ b/cmd/paths.go
@@ -49,11 +49,13 @@ func pathsDeleteCmd(a *appState) *cobra.Command {
$ %s paths delete demo-path
$ %s pth d path-name`, appName, appName)),
RunE: func(cmd *cobra.Command, args []string) error {
- if _, err := a.Config.Paths.Get(args[0]); err != nil {
- return err
- }
- delete(a.Config.Paths, args[0])
- return a.OverwriteConfig(a.Config)
+ return a.performConfigLockingOperation(cmd.Context(), func() error {
+ if _, err := a.config.Paths.Get(args[0]); err != nil {
+ return err
+ }
+ delete(a.config.Paths, args[0])
+ return nil
+ })
},
}
return cmd
@@ -76,14 +78,14 @@ $ %s pth l`, appName, appName, appName)),
case yml && jsn:
return fmt.Errorf("can't pass both --json and --yaml, must pick one")
case yml:
- out, err := yaml.Marshal(a.Config.Paths)
+ out, err := yaml.Marshal(a.config.Paths)
if err != nil {
return err
}
fmt.Fprintln(cmd.OutOrStdout(), string(out))
return nil
case jsn:
- out, err := json.Marshal(a.Config.Paths)
+ out, err := json.Marshal(a.config.Paths)
if err != nil {
return err
}
@@ -91,8 +93,8 @@ $ %s pth l`, appName, appName, appName)),
return nil
default:
i := 0
- for k, pth := range a.Config.Paths {
- chains, err := a.Config.Chains.Gets(pth.Src.ChainID, pth.Dst.ChainID)
+ for k, pth := range a.config.Paths {
+ chains, err := a.config.Chains.Gets(pth.Src.ChainID, pth.Dst.ChainID)
if err != nil {
return err
}
@@ -107,7 +109,7 @@ $ %s pth l`, appName, appName, appName)),
}
},
}
- return yamlFlag(a.Viper, jsonFlag(a.Viper, cmd))
+ return yamlFlag(a.viper, jsonFlag(a.viper, cmd))
}
func printPath(stdout io.Writer, i int, k string, pth *relayer.Path, chains, clients, connection string) {
@@ -133,11 +135,11 @@ $ %s paths show demo-path --yaml
$ %s paths show demo-path --json
$ %s pth s path-name`, appName, appName, appName)),
RunE: func(cmd *cobra.Command, args []string) error {
- p, err := a.Config.Paths.Get(args[0])
+ p, err := a.config.Paths.Get(args[0])
if err != nil {
return err
}
- chains, err := a.Config.Chains.Gets(p.Src.ChainID, p.Dst.ChainID)
+ chains, err := a.config.Chains.Gets(p.Src.ChainID, p.Dst.ChainID)
if err != nil {
return err
}
@@ -168,7 +170,7 @@ $ %s pth s path-name`, appName, appName, appName)),
return nil
},
}
- return yamlFlag(a.Viper, jsonFlag(a.Viper, cmd))
+ return yamlFlag(a.viper, jsonFlag(a.viper, cmd))
}
func pathsAddCmd(a *appState) *cobra.Command {
@@ -183,30 +185,32 @@ $ %s paths add ibc-0 ibc-1 demo-path --file paths/demo.json
$ %s pth a ibc-0 ibc-1 demo-path`, appName, appName, appName)),
RunE: func(cmd *cobra.Command, args []string) error {
src, dst := args[0], args[1]
- _, err := a.Config.Chains.Gets(src, dst)
- if err != nil {
- return fmt.Errorf("chains need to be configured before paths to them can be added: %w", err)
- }
-
- file, err := cmd.Flags().GetString(flagFile)
- if err != nil {
- return err
- }
- if file != "" {
- if err := a.AddPathFromFile(cmd.Context(), cmd.ErrOrStderr(), file, args[2]); err != nil {
- return err
+ return a.performConfigLockingOperation(cmd.Context(), func() error {
+ _, err := a.config.Chains.Gets(src, dst)
+ if err != nil {
+ return fmt.Errorf("chains need to be configured before paths to them can be added: %w", err)
}
- } else {
- if err := a.AddPathFromUserInput(cmd.Context(), cmd.InOrStdin(), cmd.ErrOrStderr(), src, dst, args[2]); err != nil {
+
+ file, err := cmd.Flags().GetString(flagFile)
+ if err != nil {
return err
}
- }
- return a.OverwriteConfig(a.Config)
+ if file != "" {
+ if err := a.addPathFromFile(cmd.Context(), cmd.ErrOrStderr(), file, args[2]); err != nil {
+ return err
+ }
+ } else {
+ if err := a.addPathFromUserInput(cmd.Context(), cmd.InOrStdin(), cmd.ErrOrStderr(), src, dst, args[2]); err != nil {
+ return err
+ }
+ }
+ return nil
+ })
},
}
- return fileFlag(a.Viper, cmd)
+ return fileFlag(a.viper, cmd)
}
func pathsAddDirCmd(a *appState) *cobra.Command {
@@ -220,10 +224,7 @@ func pathsAddDirCmd(a *appState) *cobra.Command {
Example: strings.TrimSpace(fmt.Sprintf(`
$ %s config add-paths examples/demo/configs/paths`, appName)),
RunE: func(cmd *cobra.Command, args []string) (err error) {
- if err := addPathsFromDirectory(cmd.Context(), cmd.ErrOrStderr(), a, args[0]); err != nil {
- return err
- }
- return a.OverwriteConfig(a.Config)
+ return addPathsFromDirectory(cmd.Context(), cmd.ErrOrStderr(), a, args[0])
},
}
@@ -241,25 +242,27 @@ $ %s paths new ibc-0 ibc-1 demo-path
$ %s pth n ibc-0 ibc-1 demo-path`, appName, appName)),
RunE: func(cmd *cobra.Command, args []string) error {
src, dst := args[0], args[1]
- _, err := a.Config.Chains.Gets(src, dst)
- if err != nil {
- return fmt.Errorf("chains need to be configured before paths to them can be added: %w", err)
- }
- p := &relayer.Path{
- Src: &relayer.PathEnd{ChainID: src},
- Dst: &relayer.PathEnd{ChainID: dst},
- }
+ return a.performConfigLockingOperation(cmd.Context(), func() error {
+ _, err := a.config.Chains.Gets(src, dst)
+ if err != nil {
+ return fmt.Errorf("chains need to be configured before paths to them can be added: %w", err)
+ }
- name := args[2]
- if err = a.Config.Paths.Add(name, p); err != nil {
- return err
- }
+ p := &relayer.Path{
+ Src: &relayer.PathEnd{ChainID: src},
+ Dst: &relayer.PathEnd{ChainID: dst},
+ }
- return a.OverwriteConfig(a.Config)
+ name := args[2]
+ if err = a.config.AddPath(name, p); err != nil {
+ return err
+ }
+ return nil
+ })
},
}
- return channelParameterFlags(a.Viper, cmd)
+ return channelParameterFlags(a.viper, cmd)
}
func pathsUpdateCmd(a *appState) *cobra.Command {
@@ -280,77 +283,79 @@ $ %s paths update demo-path --src-connection-id connection-02 --dst-connection-i
flags := cmd.Flags()
- p := a.Config.Paths.MustGet(name)
+ return a.performConfigLockingOperation(cmd.Context(), func() error {
+ p := a.config.Paths.MustGet(name)
- actionTaken := false
+ actionTaken := false
- filterRule, _ := flags.GetString(flagFilterRule)
- if filterRule != blankValue {
- if filterRule != "" && filterRule != processor.RuleAllowList && filterRule != processor.RuleDenyList {
- return fmt.Errorf(
- `invalid filter rule : "%s". valid rules: ("", "%s", "%s")`,
- filterRule, processor.RuleAllowList, processor.RuleDenyList)
+ filterRule, _ := flags.GetString(flagFilterRule)
+ if filterRule != blankValue {
+ if filterRule != "" && filterRule != processor.RuleAllowList && filterRule != processor.RuleDenyList {
+ return fmt.Errorf(
+ `invalid filter rule : "%s". valid rules: ("", "%s", "%s")`,
+ filterRule, processor.RuleAllowList, processor.RuleDenyList)
+ }
+ p.Filter.Rule = filterRule
+ actionTaken = true
}
- p.Filter.Rule = filterRule
- actionTaken = true
- }
- filterChannels, _ := flags.GetString(flagFilterChannels)
- if filterChannels != blankValue {
- var channelList []string
+ filterChannels, _ := flags.GetString(flagFilterChannels)
+ if filterChannels != blankValue {
+ var channelList []string
- if filterChannels != "" {
- channelList = strings.Split(filterChannels, ",")
- }
+ if filterChannels != "" {
+ channelList = strings.Split(filterChannels, ",")
+ }
- p.Filter.ChannelList = channelList
- actionTaken = true
- }
+ p.Filter.ChannelList = channelList
+ actionTaken = true
+ }
- srcChainID, _ := flags.GetString(flagSrcChainID)
- if srcChainID != "" {
- p.Src.ChainID = srcChainID
- actionTaken = true
- }
+ srcChainID, _ := flags.GetString(flagSrcChainID)
+ if srcChainID != "" {
+ p.Src.ChainID = srcChainID
+ actionTaken = true
+ }
- dstChainID, _ := flags.GetString(flagDstChainID)
- if dstChainID != "" {
- p.Dst.ChainID = dstChainID
- actionTaken = true
- }
+ dstChainID, _ := flags.GetString(flagDstChainID)
+ if dstChainID != "" {
+ p.Dst.ChainID = dstChainID
+ actionTaken = true
+ }
- srcClientID, _ := flags.GetString(flagSrcClientID)
- if srcClientID != "" {
- p.Src.ClientID = srcClientID
- actionTaken = true
- }
+ srcClientID, _ := flags.GetString(flagSrcClientID)
+ if srcClientID != "" {
+ p.Src.ClientID = srcClientID
+ actionTaken = true
+ }
- dstClientID, _ := flags.GetString(flagDstClientID)
- if dstClientID != "" {
- p.Dst.ClientID = dstClientID
- actionTaken = true
- }
+ dstClientID, _ := flags.GetString(flagDstClientID)
+ if dstClientID != "" {
+ p.Dst.ClientID = dstClientID
+ actionTaken = true
+ }
- srcConnID, _ := flags.GetString(flagSrcConnID)
- if srcConnID != "" {
- p.Src.ConnectionID = srcConnID
- actionTaken = true
- }
+ srcConnID, _ := flags.GetString(flagSrcConnID)
+ if srcConnID != "" {
+ p.Src.ConnectionID = srcConnID
+ actionTaken = true
+ }
- dstConnID, _ := flags.GetString(flagDstConnID)
- if dstConnID != "" {
- p.Dst.ConnectionID = dstConnID
- actionTaken = true
- }
+ dstConnID, _ := flags.GetString(flagDstConnID)
+ if dstConnID != "" {
+ p.Dst.ConnectionID = dstConnID
+ actionTaken = true
+ }
- if !actionTaken {
- return fmt.Errorf("at least one flag must be provided")
- }
+ if !actionTaken {
+ return fmt.Errorf("at least one flag must be provided")
+ }
- return a.OverwriteConfig(a.Config)
+ return nil
+ })
},
}
- cmd = pathFilterFlags(a.Viper, cmd)
+ cmd = pathFilterFlags(a.viper, cmd)
return cmd
}
@@ -367,91 +372,88 @@ $ %s pth fch`, appName, defaultHome, appName)),
RunE: func(cmd *cobra.Command, args []string) error {
overwrite, _ := cmd.Flags().GetBool(flagOverwriteConfig)
- chains := []string{}
- for chainName := range a.Config.Chains {
- chains = append(chains, chainName)
- }
+ return a.performConfigLockingOperation(cmd.Context(), func() error {
+ chains := []string{}
+ for chainName := range a.config.Chains {
+ chains = append(chains, chainName)
+ }
- // find all combinations of paths for configured chains
- chainCombinations := make(map[string]bool)
- for _, chainA := range chains {
- for _, chainB := range chains {
- if chainA == chainB {
- continue
+ // find all combinations of paths for configured chains
+ chainCombinations := make(map[string]bool)
+ for _, chainA := range chains {
+ for _, chainB := range chains {
+ if chainA == chainB {
+ continue
+ }
+
+ pair := chainA + "-" + chainB
+ if chainB < chainA {
+ pair = chainB + "-" + chainA
+ }
+ chainCombinations[pair] = true
}
+ }
- pair := chainA + "-" + chainB
- if chainB < chainA {
- pair = chainB + "-" + chainA
+ client := github.NewClient(nil)
+ for pthName := range chainCombinations {
+ _, exist := a.config.Paths[pthName]
+ if exist && !overwrite {
+ fmt.Fprintf(cmd.ErrOrStderr(), "skipping: %s already exists in config, use -o to overwrite (clears filters)\n", pthName)
+ continue
}
- chainCombinations[pair] = true
- }
- }
- client := github.NewClient(nil)
- for pthName := range chainCombinations {
- _, exist := a.Config.Paths[pthName]
- if exist && !overwrite {
- fmt.Fprintf(cmd.ErrOrStderr(), "skipping: %s already exists in config, use -o to overwrite (clears filters)\n", pthName)
- continue
- }
+ // TODO: Don't use github api. Potentially use: https://github.com/eco-stake/cosmos-directory once they integrate IBC data into restAPI. This will avoid rate limits.
+ fileName := pthName + ".json"
+ regPath := path.Join("_IBC", fileName)
+ client, _, err := client.Repositories.DownloadContents(cmd.Context(), "cosmos", "chain-registry", regPath, nil)
+ if err != nil {
+ if errors.As(err, new(*github.RateLimitError)) {
+ fmt.Println("some paths failed: ", err)
+ break
+ }
+ fmt.Fprintf(cmd.ErrOrStderr(), "failure retrieving: %s: consider adding to cosmos/chain-registry: ERR: %v\n", pthName, err)
+ continue
+ }
+ defer client.Close()
- // TODO: Don't use github api. Potentially use: https://github.com/eco-stake/cosmos-directory once they integrate IBC data into restAPI. This will avoid rate limits.
- fileName := pthName + ".json"
- regPath := path.Join("_IBC", fileName)
- client, _, err := client.Repositories.DownloadContents(cmd.Context(), "cosmos", "chain-registry", regPath, nil)
- if err != nil {
- if errors.As(err, new(*github.RateLimitError)) {
- fmt.Println("some paths failed: ", err)
- break
+ b, err := io.ReadAll(client)
+ if err != nil {
+ return fmt.Errorf("error reading response body: %w", err)
}
- fmt.Fprintf(cmd.ErrOrStderr(), "failure retrieving: %s: consider adding to cosmos/chain-registry: ERR: %v\n", pthName, err)
- continue
- }
- defer client.Close()
- b, err := io.ReadAll(client)
- if err != nil {
- return fmt.Errorf("error reading response body: %w", err)
- }
+ ibc := &relayer.IBCdata{}
+ if err = json.Unmarshal(b, &ibc); err != nil {
+ return fmt.Errorf("failed to unmarshal: %w ", err)
+ }
- ibc := &relayer.IBCdata{}
- if err = json.Unmarshal(b, &ibc); err != nil {
- return fmt.Errorf("failed to unmarshal: %w ", err)
- }
+ srcChainName := ibc.Chain1.ChainName
+ dstChainName := ibc.Chain2.ChainName
- srcChainName := ibc.Chain1.ChainName
- dstChainName := ibc.Chain2.ChainName
+ srcPathEnd := &relayer.PathEnd{
+ ChainID: a.config.Chains[srcChainName].ChainID(),
+ ClientID: ibc.Chain1.ClientID,
+ ConnectionID: ibc.Chain1.ConnectionID,
+ }
+ dstPathEnd := &relayer.PathEnd{
+ ChainID: a.config.Chains[dstChainName].ChainID(),
+ ClientID: ibc.Chain2.ClientID,
+ ConnectionID: ibc.Chain2.ConnectionID,
+ }
+ newPath := &relayer.Path{
+ Src: srcPathEnd,
+ Dst: dstPathEnd,
+ }
+ client.Close()
- srcPathEnd := &relayer.PathEnd{
- ChainID: a.Config.Chains[srcChainName].ChainID(),
- ClientID: ibc.Chain1.ClientID,
- ConnectionID: ibc.Chain1.ConnectionID,
- }
- dstPathEnd := &relayer.PathEnd{
- ChainID: a.Config.Chains[dstChainName].ChainID(),
- ClientID: ibc.Chain2.ClientID,
- ConnectionID: ibc.Chain2.ConnectionID,
- }
- newPath := &relayer.Path{
- Src: srcPathEnd,
- Dst: dstPathEnd,
- }
- client.Close()
+ if err = a.config.AddPath(pthName, newPath); err != nil {
+ return fmt.Errorf("failed to add path %s: %w", pthName, err)
+ }
+ fmt.Fprintf(cmd.ErrOrStderr(), "added: %s\n", pthName)
- if err = a.Config.AddPath(pthName, newPath); err != nil {
- return fmt.Errorf("failed to add path %s: %w", pthName, err)
}
- fmt.Fprintf(cmd.ErrOrStderr(), "added: %s\n", pthName)
-
- }
-
- if err := a.OverwriteConfig(a.Config); err != nil {
- return err
- }
- return nil
-
+ return nil
+ })
},
}
- return OverwriteConfigFlag(a.Viper, cmd)
+ return OverwriteConfigFlag(a.viper, cmd)
}
diff --git a/cmd/query.go b/cmd/query.go
index 9e74aa395..15ccd743a 100644
--- a/cmd/query.go
+++ b/cmd/query.go
@@ -47,6 +47,21 @@ func queryCmd(a *appState) *cobra.Command {
lineBreakCommand(),
queryIBCDenoms(a),
queryBaseDenomFromIBCDenom(a),
+ feegrantQueryCmd(a),
+ )
+
+ return cmd
+}
+
+// feegrantQueryCmd returns the fee grant query commands for this module
+func feegrantQueryCmd(a *appState) *cobra.Command {
+ cmd := &cobra.Command{
+ Use: "feegrant",
+ Short: "Querying commands for the feegrant module [currently BasicAllowance only]",
+ }
+
+ cmd.AddCommand(
+ feegrantBasicGrantsCmd(a),
)
return cmd
@@ -63,7 +78,7 @@ $ %s q ibc-denoms ibc-0`,
appName, appName,
)),
RunE: func(cmd *cobra.Command, args []string) error {
- chain, ok := a.Config.Chains[args[0]]
+ chain, ok := a.config.Chains[args[0]]
if !ok {
return errChainNotFound(args[0])
}
@@ -99,7 +114,7 @@ $ %s q denom-trace osmosis 9BBA9A1C257E971E38C1422780CE6F0B0686F0A3085E2D61118D9
appName, appName,
)),
RunE: func(cmd *cobra.Command, args []string) error {
- c, ok := a.Config.Chains[args[0]]
+ c, ok := a.config.Chains[args[0]]
if !ok {
return errChainNotFound(args[0])
}
@@ -127,7 +142,7 @@ $ %s q tx ibc-0 A5DF8D272F1C451CFF92BA6C41942C4D29B5CF180279439ED6AB038282F956BE
appName, appName,
)),
RunE: func(cmd *cobra.Command, args []string) error {
- chain, ok := a.Config.Chains[args[0]]
+ chain, ok := a.config.Chains[args[0]]
if !ok {
return errChainNotFound(args[0])
}
@@ -168,7 +183,7 @@ $ %s q txs ibc-0 "message.action=transfer"`,
appName, appName,
)),
RunE: func(cmd *cobra.Command, args []string) error {
- chain, ok := a.Config.Chains[args[0]]
+ chain, ok := a.config.Chains[args[0]]
if !ok {
return errChainNotFound(args[0])
}
@@ -198,7 +213,7 @@ $ %s q txs ibc-0 "message.action=transfer"`,
},
}
- return paginationFlags(a.Viper, cmd, "txs")
+ return paginationFlags(a.viper, cmd, "txs")
}
func queryBalanceCmd(a *appState) *cobra.Command {
@@ -213,7 +228,7 @@ $ %s query balance ibc-0 testkey`,
appName, appName,
)),
RunE: func(cmd *cobra.Command, args []string) error {
- chain, ok := a.Config.Chains[args[0]]
+ chain, ok := a.config.Chains[args[0]]
if !ok {
return errChainNotFound(args[0])
}
@@ -247,7 +262,7 @@ $ %s query balance ibc-0 testkey`,
},
}
- return ibcDenomFlags(a.Viper, cmd)
+ return ibcDenomFlags(a.viper, cmd)
}
func queryHeaderCmd(a *appState) *cobra.Command {
@@ -261,7 +276,7 @@ $ %s query header ibc-0 1400`,
appName, appName,
)),
RunE: func(cmd *cobra.Command, args []string) error {
- chain, ok := a.Config.Chains[args[0]]
+ chain, ok := a.config.Chains[args[0]]
if !ok {
return errChainNotFound(args[0])
}
@@ -315,7 +330,7 @@ $ %s q node-state ibc-1`,
appName, appName,
)),
RunE: func(cmd *cobra.Command, args []string) error {
- chain, ok := a.Config.Chains[args[0]]
+ chain, ok := a.config.Chains[args[0]]
if !ok {
return errChainNotFound(args[0])
}
@@ -355,7 +370,7 @@ $ %s query client ibc-0 ibczeroclient --height 1205`,
appName, appName,
)),
RunE: func(cmd *cobra.Command, args []string) error {
- chain, ok := a.Config.Chains[args[0]]
+ chain, ok := a.config.Chains[args[0]]
if !ok {
return errChainNotFound(args[0])
}
@@ -392,7 +407,7 @@ $ %s query client ibc-0 ibczeroclient --height 1205`,
},
}
- return heightFlag(a.Viper, cmd)
+ return heightFlag(a.viper, cmd)
}
func queryClientsCmd(a *appState) *cobra.Command {
@@ -407,7 +422,7 @@ $ %s query clients ibc-2 --offset 2 --limit 30`,
appName, appName,
)),
RunE: func(cmd *cobra.Command, args []string) error {
- chain, ok := a.Config.Chains[args[0]]
+ chain, ok := a.config.Chains[args[0]]
if !ok {
return errChainNotFound(args[0])
}
@@ -437,7 +452,7 @@ $ %s query clients ibc-2 --offset 2 --limit 30`,
},
}
- return paginationFlags(a.Viper, cmd, "client states")
+ return paginationFlags(a.viper, cmd, "client states")
}
func queryConnections(a *appState) *cobra.Command {
@@ -453,7 +468,7 @@ $ %s q conns ibc-1`,
appName, appName, appName,
)),
RunE: func(cmd *cobra.Command, args []string) error {
- chain, ok := a.Config.Chains[args[0]]
+ chain, ok := a.config.Chains[args[0]]
if !ok {
return errChainNotFound(args[0])
}
@@ -483,7 +498,7 @@ $ %s q conns ibc-1`,
},
}
- return paginationFlags(a.Viper, cmd, "connections on a network")
+ return paginationFlags(a.viper, cmd, "connections on a network")
}
func queryConnectionsUsingClient(a *appState) *cobra.Command {
@@ -499,7 +514,7 @@ $ %s query client-connections ibc-0 ibczeroclient --height 1205`,
RunE: func(cmd *cobra.Command, args []string) error {
//TODO - Add pagination
- chain, ok := a.Config.Chains[args[0]]
+ chain, ok := a.config.Chains[args[0]]
if !ok {
return errChainNotFound(args[0])
}
@@ -536,7 +551,7 @@ $ %s query client-connections ibc-0 ibczeroclient --height 1205`,
},
}
- return heightFlag(a.Viper, cmd)
+ return heightFlag(a.viper, cmd)
}
func queryConnection(a *appState) *cobra.Command {
@@ -551,7 +566,7 @@ $ %s q conn ibc-1 ibconeconn`,
appName, appName,
)),
RunE: func(cmd *cobra.Command, args []string) error {
- chain, ok := a.Config.Chains[args[0]]
+ chain, ok := a.config.Chains[args[0]]
if !ok {
return errChainNotFound(args[0])
}
@@ -595,7 +610,7 @@ $ %s query connection-channels ibc-2 ibcconnection2 --offset 2 --limit 30`,
appName, appName,
)),
RunE: func(cmd *cobra.Command, args []string) error {
- chain, ok := a.Config.Chains[args[0]]
+ chain, ok := a.config.Chains[args[0]]
if !ok {
return errChainNotFound(args[0])
}
@@ -629,7 +644,7 @@ $ %s query connection-channels ibc-2 ibcconnection2 --offset 2 --limit 30`,
},
}
- return paginationFlags(a.Viper, cmd, "channels associated with a connection")
+ return paginationFlags(a.viper, cmd, "channels associated with a connection")
}
func queryChannel(a *appState) *cobra.Command {
@@ -643,7 +658,7 @@ $ %s query channel ibc-2 ibctwochannel transfer --height 1205`,
appName, appName,
)),
RunE: func(cmd *cobra.Command, args []string) error {
- chain, ok := a.Config.Chains[args[0]]
+ chain, ok := a.config.Chains[args[0]]
if !ok {
return errChainNotFound(args[0])
}
@@ -682,7 +697,7 @@ $ %s query channel ibc-2 ibctwochannel transfer --height 1205`,
},
}
- return heightFlag(a.Viper, cmd)
+ return heightFlag(a.viper, cmd)
}
// chanExtendedInfo is an intermediate type for holding additional useful
@@ -880,13 +895,13 @@ $ %s query channels ibc-0 ibc-2`,
appName, appName, appName,
)),
RunE: func(cmd *cobra.Command, args []string) error {
- chain, ok := a.Config.Chains[args[0]]
+ chain, ok := a.config.Chains[args[0]]
if !ok {
return errChainNotFound(args[0])
}
if len(args) > 1 {
- dstChain, ok := a.Config.Chains[args[1]]
+ dstChain, ok := a.config.Chains[args[1]]
if !ok {
return errChainNotFound(args[1])
}
@@ -902,7 +917,7 @@ $ %s query channels ibc-0 ibc-2`,
},
}
- return paginationFlags(a.Viper, cmd, "channels on a network")
+ return paginationFlags(a.viper, cmd, "channels on a network")
}
func queryPacketCommitment(a *appState) *cobra.Command {
@@ -916,7 +931,7 @@ $ %s q packet-commit ibc-1 ibconechannel transfer 31`,
appName, appName,
)),
RunE: func(cmd *cobra.Command, args []string) error {
- chain, ok := a.Config.Chains[args[0]]
+ chain, ok := a.config.Chains[args[0]]
if !ok {
return errChainNotFound(args[0])
}
@@ -961,14 +976,14 @@ $ %s query unrelayed-pkts demo-path channel-0`,
appName, appName, appName,
)),
RunE: func(cmd *cobra.Command, args []string) error {
- path, err := a.Config.Paths.Get(args[0])
+ path, err := a.config.Paths.Get(args[0])
if err != nil {
return err
}
src, dst := path.Src.ChainID, path.Dst.ChainID
- c, err := a.Config.Chains.Gets(src, dst)
+ c, err := a.config.Chains.Gets(src, dst)
if err != nil {
return err
}
@@ -1014,13 +1029,13 @@ $ %s query unrelayed-acks demo-path channel-0`,
appName, appName, appName,
)),
RunE: func(cmd *cobra.Command, args []string) error {
- path, err := a.Config.Paths.Get(args[0])
+ path, err := a.config.Paths.Get(args[0])
if err != nil {
return err
}
src, dst := path.Src.ChainID, path.Dst.ChainID
- c, err := a.Config.Chains.Gets(src, dst)
+ c, err := a.config.Chains.Gets(src, dst)
if err != nil {
return err
}
@@ -1055,20 +1070,21 @@ $ %s query unrelayed-acks demo-path channel-0`,
func queryClientsExpiration(a *appState) *cobra.Command {
cmd := &cobra.Command{
- Use: "clients-expiration path",
- Short: "query for light clients expiration date",
- Args: withUsage(cobra.ExactArgs(1)),
+ Use: "clients-expiration path",
+ Aliases: []string{"ce"},
+ Short: "query for light clients expiration date",
+ Args: withUsage(cobra.ExactArgs(1)),
Example: strings.TrimSpace(fmt.Sprintf(`
$ %s query clients-expiration demo-path`,
appName,
)),
RunE: func(cmd *cobra.Command, args []string) error {
- path, err := a.Config.Paths.Get(args[0])
+ path, err := a.config.Paths.Get(args[0])
if err != nil {
return err
}
src, dst := path.Src.ChainID, path.Dst.ChainID
- c, err := a.Config.Chains.Gets(src, dst)
+ c, err := a.config.Chains.Gets(src, dst)
if err != nil {
return err
}
@@ -1080,17 +1096,29 @@ $ %s query clients-expiration demo-path`,
return err
}
- srcExpiration, err := relayer.QueryClientExpiration(cmd.Context(), c[src], c[dst])
- if err != nil {
- return err
+ srcExpiration, srcClientInfo, errSrc := relayer.QueryClientExpiration(cmd.Context(), c[src], c[dst])
+ if errSrc != nil && !strings.Contains(errSrc.Error(), "light client not found") {
+ return errSrc
}
- dstExpiration, err := relayer.QueryClientExpiration(cmd.Context(), c[dst], c[src])
- if err != nil {
- return err
+ dstExpiration, dstClientInfo, errDst := relayer.QueryClientExpiration(cmd.Context(), c[dst], c[src])
+ if errDst != nil && !strings.Contains(errDst.Error(), "light client not found") {
+ return errDst
+ }
+
+ // if only the src light client is found, just print info for source light client
+ if errSrc == nil && errDst != nil {
+ fmt.Fprintln(cmd.OutOrStdout(), relayer.SPrintClientExpiration(c[src], srcExpiration, srcClientInfo))
+ return nil
+ }
+
+ // if only the dst light client is found, just print info for destination light client
+ if errDst == nil && errSrc != nil {
+ fmt.Fprintln(cmd.OutOrStdout(), relayer.SPrintClientExpiration(c[dst], dstExpiration, dstClientInfo))
+ return nil
}
- fmt.Fprintf(cmd.OutOrStdout(), relayer.SPrintClientExpiration(c[src], srcExpiration))
- fmt.Fprintf(cmd.OutOrStdout(), relayer.SPrintClientExpiration(c[dst], dstExpiration))
+ fmt.Fprintln(cmd.OutOrStdout(), relayer.SPrintClientExpiration(c[src], srcExpiration, srcClientInfo))
+ fmt.Fprintln(cmd.OutOrStdout(), relayer.SPrintClientExpiration(c[dst], dstExpiration, dstClientInfo))
return nil
},
diff --git a/cmd/root.go b/cmd/root.go
index a819397d5..fc940377f 100644
--- a/cmd/root.go
+++ b/cmd/root.go
@@ -22,8 +22,10 @@ import (
"errors"
"fmt"
"io"
+ "net/url"
"os"
"os/signal"
+ "path"
"path/filepath"
"runtime/debug"
"strings"
@@ -34,13 +36,10 @@ import (
"github.com/spf13/viper"
"go.uber.org/zap"
"go.uber.org/zap/zapcore"
- "golang.org/x/term"
+ "gopkg.in/natefinch/lumberjack.v2"
)
-const (
- MB = 1024 * 1024 // in bytes
- appName = "rly"
-)
+const appName = "rly"
var defaultHome = filepath.Join(os.Getenv("HOME"), ".relayer")
@@ -57,9 +56,9 @@ func NewRootCmd(log *zap.Logger) *cobra.Command {
// Use a local app state instance scoped to the new root command,
// so that tests don't concurrently access the state.
a := &appState{
- Viper: viper.New(),
+ viper: viper.New(),
- Log: log,
+ log: log,
}
// RootCmd represents the base command when called without any subcommands
@@ -78,37 +77,37 @@ func NewRootCmd(log *zap.Logger) *cobra.Command {
rootCmd.PersistentPreRunE = func(cmd *cobra.Command, _ []string) error {
// Inside persistent pre-run because this takes effect after flags are parsed.
if log == nil {
- log, err := newRootLogger(a.Viper.GetString("log-format"), a.Viper.GetBool("debug"))
+ log, err := newRootLogger(a.viper.GetString("log-format"), a.viper.GetBool("debug"))
if err != nil {
return err
}
- a.Log = log
+ a.log = log
}
// reads `homeDir/config/config.yaml` into `a.Config`
- return initConfig(rootCmd, a)
+ return a.loadConfigFile(rootCmd.Context())
}
rootCmd.PersistentPostRun = func(cmd *cobra.Command, _ []string) {
// Force syncing the logs before exit, if anything is buffered.
- a.Log.Sync()
+ _ = a.log.Sync()
}
// Register --home flag
- rootCmd.PersistentFlags().StringVar(&a.HomePath, flagHome, defaultHome, "set home directory")
- if err := a.Viper.BindPFlag(flagHome, rootCmd.PersistentFlags().Lookup(flagHome)); err != nil {
+ rootCmd.PersistentFlags().StringVar(&a.homePath, flagHome, defaultHome, "set home directory")
+ if err := a.viper.BindPFlag(flagHome, rootCmd.PersistentFlags().Lookup(flagHome)); err != nil {
panic(err)
}
// Register --debug flag
- rootCmd.PersistentFlags().BoolVarP(&a.Debug, "debug", "d", false, "debug output")
- if err := a.Viper.BindPFlag("debug", rootCmd.PersistentFlags().Lookup("debug")); err != nil {
+ rootCmd.PersistentFlags().BoolVarP(&a.debug, "debug", "d", false, "debug output")
+ if err := a.viper.BindPFlag("debug", rootCmd.PersistentFlags().Lookup("debug")); err != nil {
panic(err)
}
rootCmd.PersistentFlags().String("log-format", "auto", "log output format (auto, logfmt, json, or console)")
- if err := a.Viper.BindPFlag("log-format", rootCmd.PersistentFlags().Lookup("log-format")); err != nil {
+ if err := a.viper.BindPFlag("log-format", rootCmd.PersistentFlags().Lookup("log-format")); err != nil {
panic(err)
}
@@ -124,6 +123,7 @@ func NewRootCmd(log *zap.Logger) *cobra.Command {
startCmd(a),
lineBreakCommand(),
getVersionCmd(a),
+ addressCmd(a),
)
return rootCmd
@@ -174,6 +174,12 @@ func Execute() {
}
}
+type lumberjackSink struct {
+ *lumberjack.Logger
+}
+
+func (lumberjackSink) Sync() error { return nil }
+
func newRootLogger(format string, debug bool) (*zap.Logger, error) {
config := zap.NewProductionEncoderConfig()
config.EncodeTime = func(ts time.Time, encoder zapcore.PrimitiveArrayEncoder) {
@@ -181,22 +187,27 @@ func newRootLogger(format string, debug bool) (*zap.Logger, error) {
}
config.LevelKey = "lvl"
+ ll := lumberjack.Logger{
+ Filename: path.Join(defaultHome, "relay.log"),
+ MaxSize: 10, //MB
+ MaxBackups: 30,
+ MaxAge: 28, //days
+ Compress: false,
+ }
+ zap.RegisterSink("lumberjack", func(*url.URL) (zap.Sink, error) {
+ return lumberjackSink{
+ Logger: &ll,
+ }, nil
+ })
+
var enc zapcore.Encoder
switch format {
case "json":
enc = zapcore.NewJSONEncoder(config)
- case "console":
+ case "auto", "console":
enc = zapcore.NewConsoleEncoder(config)
case "logfmt":
enc = zaplogfmt.NewEncoder(config)
- case "auto":
- if term.IsTerminal(int(os.Stderr.Fd())) {
- // When a user runs relayer in the foreground, use easier to read output.
- enc = zapcore.NewConsoleEncoder(config)
- } else {
- // Otherwise, use consistent logfmt format for simplistic machine processing.
- enc = zaplogfmt.NewEncoder(config)
- }
default:
return nil, fmt.Errorf("unrecognized log format %q", format)
}
@@ -205,11 +216,15 @@ func newRootLogger(format string, debug bool) (*zap.Logger, error) {
if debug {
level = zap.DebugLevel
}
- return zap.New(zapcore.NewCore(
- enc,
- os.Stderr,
- level,
- )), nil
+
+ w := zapcore.AddSync(&ll)
+
+ core := zapcore.NewTee(
+ zapcore.NewCore(enc, w, level),
+ zapcore.NewCore(enc, os.Stderr, level),
+ )
+
+ return zap.New(core), nil
}
// readLine reads one line from the given reader.
diff --git a/cmd/start.go b/cmd/start.go
index bc8143865..c2cdf9406 100644
--- a/cmd/start.go
+++ b/cmd/start.go
@@ -21,7 +21,6 @@ import (
"errors"
"fmt"
"net"
- "strconv"
"strings"
"github.com/cosmos/relayer/v2/internal/relaydebug"
@@ -50,7 +49,7 @@ $ %s start demo-path2 --max-tx-size 10`, appName, appName, appName, appName)),
if len(args) > 0 {
for i, pathName := range args {
- path := a.Config.Paths.MustGet(pathName)
+ path := a.config.Paths.MustGet(pathName)
paths[i] = relayer.NamedPath{
Name: pathName,
Path: path,
@@ -61,7 +60,7 @@ $ %s start demo-path2 --max-tx-size 10`, appName, appName, appName, appName)),
chains[path.Dst.ChainID] = nil
}
} else {
- for n, path := range a.Config.Paths {
+ for n, path := range a.config.Paths {
paths = append(paths, relayer.NamedPath{
Name: n,
Path: path,
@@ -79,7 +78,7 @@ $ %s start demo-path2 --max-tx-size 10`, appName, appName, appName, appName)),
}
// get chain configurations
- chains, err := a.Config.Chains.Gets(chainIDs...)
+ chains, err := a.config.Chains.Gets(chainIDs...)
if err != nil {
return err
}
@@ -88,14 +87,14 @@ $ %s start demo-path2 --max-tx-size 10`, appName, appName, appName, appName)),
return err
}
- maxTxSize, maxMsgLength, err := GetStartOptions(cmd)
+ maxMsgLength, err := cmd.Flags().GetUint64(flagMaxMsgLength)
if err != nil {
return err
}
var prometheusMetrics *processor.PrometheusMetrics
- debugAddr := a.Config.Global.APIListenPort
+ debugAddr := a.config.Global.APIListenPort
debugAddrFlag, err := cmd.Flags().GetString(flagDebugAddr)
if err != nil {
@@ -107,14 +106,14 @@ $ %s start demo-path2 --max-tx-size 10`, appName, appName, appName, appName)),
}
if debugAddr == "" {
- a.Log.Info("Skipping debug server due to empty debug address flag")
+ a.log.Info("Skipping debug server due to empty debug address flag")
} else {
ln, err := net.Listen("tcp", debugAddr)
if err != nil {
- a.Log.Error("Failed to listen on debug address. If you have another relayer process open, use --" + flagDebugAddr + " to pick a different address.")
+ a.log.Error("Failed to listen on debug address. If you have another relayer process open, use --" + flagDebugAddr + " to pick a different address.")
return fmt.Errorf("failed to listen on debug address %q: %w", debugAddr, err)
}
- log := a.Log.With(zap.String("sys", "debughttp"))
+ log := a.log.With(zap.String("sys", "debughttp"))
log.Info("Debug server listening", zap.String("addr", debugAddr))
prometheusMetrics = processor.NewPrometheusMetrics()
relaydebug.StartDebugServer(cmd.Context(), log, ln, prometheusMetrics.Registry)
@@ -146,11 +145,11 @@ $ %s start demo-path2 --max-tx-size 10`, appName, appName, appName, appName)),
rlyErrCh := relayer.StartRelayer(
cmd.Context(),
- a.Log,
+ a.log,
chains,
paths,
- maxTxSize, maxMsgLength,
- a.Config.memo(cmd),
+ maxMsgLength,
+ a.config.memo(cmd),
clientUpdateThresholdTime,
flushInterval,
nil,
@@ -164,7 +163,7 @@ $ %s start demo-path2 --max-tx-size 10`, appName, appName, appName, appName)),
// so we don't want to separately monitor the ctx.Done channel,
// because we would risk returning before the relayer cleans up.
if err := <-rlyErrCh; err != nil && !errors.Is(err, context.Canceled) {
- a.Log.Warn(
+ a.log.Warn(
"Relayer start error",
zap.Error(err),
)
@@ -173,37 +172,12 @@ $ %s start demo-path2 --max-tx-size 10`, appName, appName, appName, appName)),
return nil
},
}
- cmd = updateTimeFlags(a.Viper, cmd)
- cmd = strategyFlag(a.Viper, cmd)
- cmd = debugServerFlags(a.Viper, cmd)
- cmd = processorFlag(a.Viper, cmd)
- cmd = initBlockFlag(a.Viper, cmd)
- cmd = flushIntervalFlag(a.Viper, cmd)
- cmd = memoFlag(a.Viper, cmd)
+ cmd = updateTimeFlags(a.viper, cmd)
+ cmd = strategyFlag(a.viper, cmd)
+ cmd = debugServerFlags(a.viper, cmd)
+ cmd = processorFlag(a.viper, cmd)
+ cmd = initBlockFlag(a.viper, cmd)
+ cmd = flushIntervalFlag(a.viper, cmd)
+ cmd = memoFlag(a.viper, cmd)
return cmd
}
-
-// GetStartOptions sets strategy specific fields.
-func GetStartOptions(cmd *cobra.Command) (uint64, uint64, error) {
- maxTxSize, err := cmd.Flags().GetString(flagMaxTxSize)
- if err != nil {
- return 0, 0, err
- }
-
- txSize, err := strconv.ParseUint(maxTxSize, 10, 64)
- if err != nil {
- return 0, 0, err
- }
-
- maxMsgLength, err := cmd.Flags().GetString(flagMaxMsgLength)
- if err != nil {
- return txSize * MB, 0, err
- }
-
- msgLen, err := strconv.ParseUint(maxMsgLength, 10, 64)
- if err != nil {
- return txSize * MB, 0, err
- }
-
- return txSize * MB, msgLen, nil
-}
diff --git a/cmd/tx.go b/cmd/tx.go
index 437edbc05..4ea063dd9 100644
--- a/cmd/tx.go
+++ b/cmd/tx.go
@@ -11,6 +11,7 @@ import (
sdk "github.com/cosmos/cosmos-sdk/types"
chantypes "github.com/cosmos/ibc-go/v7/modules/core/04-channel/types"
"github.com/cosmos/relayer/v2/relayer"
+ "github.com/cosmos/relayer/v2/relayer/common"
"github.com/cosmos/relayer/v2/relayer/processor"
"github.com/cosmos/relayer/v2/relayer/provider"
"github.com/spf13/cobra"
@@ -49,6 +50,7 @@ Most of these commands take a [path] argument. Make sure:
createChannelCmd(a),
closeChannelCmd(a),
lineBreakCommand(),
+ registerCounterpartyCmd(a),
)
return cmd
@@ -78,6 +80,11 @@ func createClientsCmd(a *appState) *cobra.Command {
return err
}
+ iconStartHeight, err := cmd.Flags().GetInt64(flagBtpBlockHeight)
+ if err != nil {
+ return err
+ }
+
override, err := cmd.Flags().GetBool(flagOverride)
if err != nil {
return err
@@ -85,7 +92,7 @@ func createClientsCmd(a *appState) *cobra.Command {
path := args[0]
- c, src, dst, err := a.Config.ChainsFromPath(path)
+ c, src, dst, err := a.config.ChainsFromPath(path)
if err != nil {
return err
}
@@ -98,23 +105,31 @@ func createClientsCmd(a *appState) *cobra.Command {
return fmt.Errorf("key %s not found on dst chain %s", c[dst].ChainProvider.Key(), c[dst].ChainID())
}
- clientSrc, clientDst, err := c[src].CreateClients(cmd.Context(), c[dst], allowUpdateAfterExpiry, allowUpdateAfterMisbehaviour, override, customClientTrustingPeriod, a.Config.memo(cmd))
+ // TODO: make iconStartHeight compulsory
+ // if iconStartHeight is not given it can create confusion as starting relay at any time could miss number of btp block update_client
+ clientSrc, clientDst, err := c[src].CreateClients(cmd.Context(), c[dst], allowUpdateAfterExpiry, allowUpdateAfterMisbehaviour, override, customClientTrustingPeriod, a.config.memo(cmd), iconStartHeight)
if err != nil {
return err
}
+
if clientSrc != "" || clientDst != "" {
- if err := a.OverwriteConfigOnTheFly(cmd, path, clientSrc, clientDst, "", ""); err != nil {
+ if err := a.updatePathConfig(cmd.Context(), path, clientSrc, clientDst, "", ""); err != nil {
return err
}
+
+ // if err := a.UpdateConfigsIfContainIcon(cmd, c[src], c[dst]); err != nil {
+ // return err
+ // }
}
return nil
},
}
- cmd = clientParameterFlags(a.Viper, cmd)
- cmd = overrideFlag(a.Viper, cmd)
- cmd = memoFlag(a.Viper, cmd)
+ cmd = clientParameterFlags(a.viper, cmd)
+ cmd = overrideFlag(a.viper, cmd)
+ cmd = memoFlag(a.viper, cmd)
+ cmd = btpBlockHeightFlag(a.viper, cmd)
return cmd
}
@@ -147,17 +162,17 @@ func createClientCmd(a *appState) *cobra.Command {
return err
}
- src, ok := a.Config.Chains[args[0]]
+ src, ok := a.config.Chains[args[0]]
if !ok {
return errChainNotFound(args[0])
}
- dst, ok := a.Config.Chains[args[1]]
+ dst, ok := a.config.Chains[args[1]]
if !ok {
return errChainNotFound(args[1])
}
pathName := args[2]
- path, err := a.Config.Paths.Get(pathName)
+ path, err := a.config.Paths.Get(pathName)
if err != nil {
return err
}
@@ -185,6 +200,20 @@ func createClientCmd(a *appState) *cobra.Command {
return err
}
+ iconStartHeight, err := cmd.Flags().GetInt64(flagBtpBlockHeight)
+ if err != nil {
+ return err
+ }
+
+ if iconStartHeight != 0 {
+ if src.ChainProvider.Type() == common.IconModule {
+ srch = iconStartHeight
+ }
+ if dst.ChainProvider.Type() == common.IconModule {
+ dsth = iconStartHeight
+ }
+ }
+
// Query the light signed headers for src & dst at the heights srch & dsth, retry if the query fails
var srcUpdateHeader, dstUpdateHeader provider.IBCHeader
if err = retry.Do(func() error {
@@ -194,7 +223,7 @@ func createClientCmd(a *appState) *cobra.Command {
}
return nil
}, retry.Context(cmd.Context()), relayer.RtyAtt, relayer.RtyDel, relayer.RtyErr, retry.OnRetry(func(n uint, err error) {
- a.Log.Info(
+ a.log.Info(
"Failed to get light signed header",
zap.String("src_chain_id", src.ChainID()),
zap.Int64("src_height", srch),
@@ -209,7 +238,7 @@ func createClientCmd(a *appState) *cobra.Command {
return err
}
- clientID, err := relayer.CreateClient(cmd.Context(), src, dst, srcUpdateHeader, dstUpdateHeader, allowUpdateAfterExpiry, allowUpdateAfterMisbehaviour, override, customClientTrustingPeriod, a.Config.memo(cmd))
+ clientID, err := relayer.CreateClient(cmd.Context(), src, dst, srcUpdateHeader, dstUpdateHeader, allowUpdateAfterExpiry, allowUpdateAfterMisbehaviour, override, customClientTrustingPeriod, a.config.memo(cmd), iconStartHeight)
if err != nil {
return err
}
@@ -220,7 +249,7 @@ func createClientCmd(a *appState) *cobra.Command {
clientDst = clientID
}
if clientID != "" {
- if err = a.OverwriteConfigOnTheFly(cmd, pathName, clientSrc, clientDst, "", ""); err != nil {
+ if err = a.updatePathConfig(cmd.Context(), pathName, clientSrc, clientDst, "", ""); err != nil {
return err
}
}
@@ -229,9 +258,10 @@ func createClientCmd(a *appState) *cobra.Command {
},
}
- cmd = clientParameterFlags(a.Viper, cmd)
- cmd = overrideFlag(a.Viper, cmd)
- cmd = memoFlag(a.Viper, cmd)
+ cmd = clientParameterFlags(a.viper, cmd)
+ cmd = overrideFlag(a.viper, cmd)
+ cmd = memoFlag(a.viper, cmd)
+ cmd = btpBlockHeightFlag(a.viper, cmd)
return cmd
}
@@ -245,7 +275,7 @@ corresponding update-client messages.`,
Args: withUsage(cobra.ExactArgs(1)),
Example: strings.TrimSpace(fmt.Sprintf(`$ %s transact update-clients demo-path`, appName)),
RunE: func(cmd *cobra.Command, args []string) error {
- c, src, dst, err := a.Config.ChainsFromPath(args[0])
+ c, src, dst, err := a.config.ChainsFromPath(args[0])
if err != nil {
return err
}
@@ -258,11 +288,11 @@ corresponding update-client messages.`,
return fmt.Errorf("key %s not found on dst chain %s", c[dst].ChainProvider.Key(), c[dst].ChainID())
}
- return relayer.UpdateClients(cmd.Context(), c[src], c[dst], a.Config.memo(cmd))
+ return relayer.UpdateClients(cmd.Context(), c[src], c[dst], a.config.memo(cmd))
},
}
- return memoFlag(a.Viper, cmd)
+ return memoFlag(a.viper, cmd)
}
func upgradeClientsCmd(a *appState) *cobra.Command {
@@ -271,7 +301,7 @@ func upgradeClientsCmd(a *appState) *cobra.Command {
Short: "upgrades IBC clients between two configured chains with a configured path and chain-id",
Args: withUsage(cobra.ExactArgs(2)),
RunE: func(cmd *cobra.Command, args []string) error {
- c, src, dst, err := a.Config.ChainsFromPath(args[0])
+ c, src, dst, err := a.config.ChainsFromPath(args[0])
if err != nil {
return err
}
@@ -291,7 +321,7 @@ func upgradeClientsCmd(a *appState) *cobra.Command {
targetChainID := args[1]
- memo := a.Config.memo(cmd)
+ memo := a.config.memo(cmd)
// send the upgrade message on the targetChainID
if src == targetChainID {
@@ -302,11 +332,12 @@ func upgradeClientsCmd(a *appState) *cobra.Command {
},
}
- cmd = heightFlag(a.Viper, cmd)
- cmd = memoFlag(a.Viper, cmd)
+ cmd = heightFlag(a.viper, cmd)
+ cmd = memoFlag(a.viper, cmd)
return cmd
}
+// TODO: method has side_effect
func createConnectionCmd(a *appState) *cobra.Command {
cmd := &cobra.Command{
Use: "connection path_name",
@@ -339,7 +370,7 @@ $ %s tx conn demo-path --timeout 5s`,
pathName := args[0]
- c, src, dst, err := a.Config.ChainsFromPath(pathName)
+ c, src, dst, err := a.config.ChainsFromPath(pathName)
if err != nil {
return err
}
@@ -367,22 +398,30 @@ $ %s tx conn demo-path --timeout 5s`,
return fmt.Errorf("key %s not found on dst chain %s", c[dst].ChainProvider.Key(), c[dst].ChainID())
}
- memo := a.Config.memo(cmd)
+ memo := a.config.memo(cmd)
initialBlockHistory, err := cmd.Flags().GetUint64(flagInitialBlockHistory)
if err != nil {
return err
}
+ iconStartHeight, err := cmd.Flags().GetInt64(flagBtpBlockHeight)
+ if err != nil {
+ return err
+ }
+
// ensure that the clients exist
- clientSrc, clientDst, err := c[src].CreateClients(cmd.Context(), c[dst], allowUpdateAfterExpiry, allowUpdateAfterMisbehaviour, override, customClientTrustingPeriod, memo)
+ clientSrc, clientDst, err := c[src].CreateClients(cmd.Context(), c[dst], allowUpdateAfterExpiry, allowUpdateAfterMisbehaviour, override, customClientTrustingPeriod, memo, iconStartHeight)
if err != nil {
return err
}
if clientSrc != "" || clientDst != "" {
- if err := a.OverwriteConfigOnTheFly(cmd, pathName, clientSrc, clientDst, "", ""); err != nil {
+ if err := a.updatePathConfig(cmd.Context(), pathName, clientSrc, clientDst, "", ""); err != nil {
return err
}
+ // if err := a.UpdateConfigsIfContainIcon(cmd, c[src], c[dst]); err != nil {
+ // return err
+ // }
}
connectionSrc, connectionDst, err := c[src].CreateOpenConnections(cmd.Context(), c[dst], retries, to, memo, initialBlockHistory, pathName)
@@ -390,21 +429,27 @@ $ %s tx conn demo-path --timeout 5s`,
return err
}
if connectionSrc != "" || connectionDst != "" {
- if err := a.OverwriteConfigOnTheFly(cmd, pathName, "", "", connectionSrc, connectionDst); err != nil {
+ if err := a.updatePathConfig(cmd.Context(), pathName, "", "", connectionSrc, connectionDst); err != nil {
return err
}
+
+ // if err := a.UpdateConfigsIfContainIcon(cmd, c[src], c[dst]); err != nil {
+ // return err
+ // }
+
}
return nil
},
}
- cmd = timeoutFlag(a.Viper, cmd)
- cmd = retryFlag(a.Viper, cmd)
- cmd = clientParameterFlags(a.Viper, cmd)
- cmd = overrideFlag(a.Viper, cmd)
- cmd = memoFlag(a.Viper, cmd)
- cmd = initBlockFlag(a.Viper, cmd)
+ cmd = timeoutFlag(a.viper, cmd)
+ cmd = retryFlag(a.viper, cmd)
+ cmd = clientParameterFlags(a.viper, cmd)
+ cmd = overrideFlag(a.viper, cmd)
+ cmd = memoFlag(a.viper, cmd)
+ cmd = initBlockFlag(a.viper, cmd)
+ cmd = btpBlockHeightFlag(a.viper, cmd)
return cmd
}
@@ -426,7 +471,7 @@ $ %s tx chan demo-path --timeout 5s --max-retries 10`,
pathName := args[0]
- c, src, dst, err := a.Config.ChainsFromPath(pathName)
+ c, src, dst, err := a.config.ChainsFromPath(pathName)
if err != nil {
return err
}
@@ -475,15 +520,15 @@ $ %s tx chan demo-path --timeout 5s --max-retries 10`,
}
// create channel if it isn't already created
- return c[src].CreateOpenChannels(cmd.Context(), c[dst], retries, to, srcPort, dstPort, order, version, override, a.Config.memo(cmd), pathName)
+ return c[src].CreateOpenChannels(cmd.Context(), c[dst], retries, to, srcPort, dstPort, order, version, override, a.config.memo(cmd), pathName)
},
}
- cmd = timeoutFlag(a.Viper, cmd)
- cmd = retryFlag(a.Viper, cmd)
- cmd = overrideFlag(a.Viper, cmd)
- cmd = channelParameterFlags(a.Viper, cmd)
- cmd = memoFlag(a.Viper, cmd)
+ cmd = timeoutFlag(a.viper, cmd)
+ cmd = retryFlag(a.viper, cmd)
+ cmd = overrideFlag(a.viper, cmd)
+ cmd = channelParameterFlags(a.viper, cmd)
+ cmd = memoFlag(a.viper, cmd)
return cmd
}
@@ -502,7 +547,7 @@ $ %s tx channel-close demo-path channel-0 transfer -o 3s`,
RunE: func(cmd *cobra.Command, args []string) error {
pathName := args[0]
- c, src, dst, err := a.Config.ChainsFromPath(pathName)
+ c, src, dst, err := a.config.ChainsFromPath(pathName)
if err != nil {
return err
}
@@ -538,13 +583,13 @@ $ %s tx channel-close demo-path channel-0 transfer -o 3s`,
return err
}
- return c[src].CloseChannel(cmd.Context(), c[dst], retries, to, channelID, portID, a.Config.memo(cmd), pathName)
+ return c[src].CloseChannel(cmd.Context(), c[dst], retries, to, channelID, portID, a.config.memo(cmd), pathName)
},
}
- cmd = timeoutFlag(a.Viper, cmd)
- cmd = retryFlag(a.Viper, cmd)
- cmd = memoFlag(a.Viper, cmd)
+ cmd = timeoutFlag(a.viper, cmd)
+ cmd = retryFlag(a.viper, cmd)
+ cmd = memoFlag(a.viper, cmd)
return cmd
}
@@ -560,7 +605,7 @@ to creating a connection and a channel between the two networks on a configured
Example: strings.TrimSpace(fmt.Sprintf(`
$ %s transact link demo-path --src-port transfer --dst-port transfer
$ %s tx link demo-path
-$ %s tx connect demo-path --src-port transfer --dst-port transfer --order unordered --version ics20-1`,
+$ %s tx connect demo-path --src-port mock --dst-port mock --order unordered --version ics20-1`,
appName, appName, appName,
)),
RunE: func(cmd *cobra.Command, args []string) error {
@@ -581,13 +626,13 @@ $ %s tx connect demo-path --src-port transfer --dst-port transfer --order unorde
pathName := args[0]
- pth, err := a.Config.Paths.Get(pathName)
+ pth, err := a.config.Paths.Get(pathName)
if err != nil {
return err
}
src, dst := pth.Src.ChainID, pth.Dst.ChainID
- c, err := a.Config.Chains.Gets(src, dst)
+ c, err := a.config.Chains.Gets(src, dst)
if err != nil {
return err
}
@@ -638,20 +683,25 @@ $ %s tx connect demo-path --src-port transfer --dst-port transfer --order unorde
return fmt.Errorf("key %s not found on dst chain %s", c[dst].ChainProvider.Key(), c[dst].ChainID())
}
- memo := a.Config.memo(cmd)
+ memo := a.config.memo(cmd)
initialBlockHistory, err := cmd.Flags().GetUint64(flagInitialBlockHistory)
if err != nil {
return err
}
+ iconStartHeight, err := cmd.Flags().GetInt64(flagBtpBlockHeight)
+ if err != nil {
+ return err
+ }
+
// create clients if they aren't already created
- clientSrc, clientDst, err := c[src].CreateClients(cmd.Context(), c[dst], allowUpdateAfterExpiry, allowUpdateAfterMisbehaviour, override, customClientTrustingPeriod, memo)
+ clientSrc, clientDst, err := c[src].CreateClients(cmd.Context(), c[dst], allowUpdateAfterExpiry, allowUpdateAfterMisbehaviour, override, customClientTrustingPeriod, memo, iconStartHeight)
if err != nil {
return fmt.Errorf("error creating clients: %w", err)
}
if clientSrc != "" || clientDst != "" {
- if err := a.OverwriteConfigOnTheFly(cmd, pathName, clientSrc, clientDst, "", ""); err != nil {
+ if err := a.updatePathConfig(cmd.Context(), pathName, clientSrc, clientDst, "", ""); err != nil {
return err
}
}
@@ -662,7 +712,7 @@ $ %s tx connect demo-path --src-port transfer --dst-port transfer --order unorde
return fmt.Errorf("error creating connections: %w", err)
}
if connectionSrc != "" || connectionDst != "" {
- if err := a.OverwriteConfigOnTheFly(cmd, pathName, "", "", connectionSrc, connectionDst); err != nil {
+ if err := a.updatePathConfig(cmd.Context(), pathName, "", "", connectionSrc, connectionDst); err != nil {
return err
}
}
@@ -671,13 +721,14 @@ $ %s tx connect demo-path --src-port transfer --dst-port transfer --order unorde
return c[src].CreateOpenChannels(cmd.Context(), c[dst], retries, to, srcPort, dstPort, order, version, override, memo, pathName)
},
}
- cmd = timeoutFlag(a.Viper, cmd)
- cmd = retryFlag(a.Viper, cmd)
- cmd = clientParameterFlags(a.Viper, cmd)
- cmd = channelParameterFlags(a.Viper, cmd)
- cmd = overrideFlag(a.Viper, cmd)
- cmd = memoFlag(a.Viper, cmd)
- cmd = initBlockFlag(a.Viper, cmd)
+ cmd = timeoutFlag(a.viper, cmd)
+ cmd = retryFlag(a.viper, cmd)
+ cmd = clientParameterFlags(a.viper, cmd)
+ cmd = channelParameterFlags(a.viper, cmd)
+ cmd = overrideFlag(a.viper, cmd)
+ cmd = memoFlag(a.viper, cmd)
+ cmd = initBlockFlag(a.viper, cmd)
+ cmd = btpBlockHeightFlag(a.viper, cmd)
return cmd
}
@@ -697,7 +748,7 @@ $ %s tx link-then-start demo-path --timeout 5s`, appName, appName)),
lCmd := linkCmd(a)
for err := lCmd.RunE(cmd, args); err != nil; err = lCmd.RunE(cmd, args) {
- a.Log.Info("Error running link; retrying", zap.Error(err))
+ a.log.Info("Error running link; retrying", zap.Error(err))
select {
case <-time.After(time.Second):
// Keep going.
@@ -711,17 +762,18 @@ $ %s tx link-then-start demo-path --timeout 5s`, appName, appName)),
},
}
- cmd = timeoutFlag(a.Viper, cmd)
- cmd = retryFlag(a.Viper, cmd)
- cmd = strategyFlag(a.Viper, cmd)
- cmd = clientParameterFlags(a.Viper, cmd)
- cmd = channelParameterFlags(a.Viper, cmd)
- cmd = overrideFlag(a.Viper, cmd)
- cmd = memoFlag(a.Viper, cmd)
- cmd = debugServerFlags(a.Viper, cmd)
- cmd = initBlockFlag(a.Viper, cmd)
- cmd = processorFlag(a.Viper, cmd)
- cmd = updateTimeFlags(a.Viper, cmd)
+ cmd = timeoutFlag(a.viper, cmd)
+ cmd = retryFlag(a.viper, cmd)
+ cmd = strategyFlag(a.viper, cmd)
+ cmd = clientParameterFlags(a.viper, cmd)
+ cmd = channelParameterFlags(a.viper, cmd)
+ cmd = overrideFlag(a.viper, cmd)
+ cmd = memoFlag(a.viper, cmd)
+ cmd = debugServerFlags(a.viper, cmd)
+ cmd = initBlockFlag(a.viper, cmd)
+ cmd = processorFlag(a.viper, cmd)
+ cmd = updateTimeFlags(a.viper, cmd)
+ cmd = flushIntervalFlag(a.viper, cmd)
return cmd
}
@@ -743,7 +795,7 @@ $ %s tx flush demo-path channel-0`,
if len(args) > 0 {
pathName := args[0]
- path := a.Config.Paths.MustGet(pathName)
+ path := a.config.Paths.MustGet(pathName)
paths = append(paths, relayer.NamedPath{
Name: pathName,
Path: path,
@@ -753,7 +805,7 @@ $ %s tx flush demo-path channel-0`,
chains[path.Src.ChainID] = nil
chains[path.Dst.ChainID] = nil
} else {
- for n, path := range a.Config.Paths {
+ for n, path := range a.config.Paths {
paths = append(paths, relayer.NamedPath{
Name: n,
Path: path,
@@ -771,7 +823,7 @@ $ %s tx flush demo-path channel-0`,
}
// get chain configurations
- chains, err := a.Config.Chains.Gets(chainIDs...)
+ chains, err := a.config.Chains.Gets(chainIDs...)
if err != nil {
return err
}
@@ -780,7 +832,7 @@ $ %s tx flush demo-path channel-0`,
return err
}
- maxTxSize, maxMsgLength, err := GetStartOptions(cmd)
+ maxMsgLength, err := cmd.Flags().GetUint64(flagMaxMsgLength)
if err != nil {
return err
}
@@ -798,11 +850,11 @@ $ %s tx flush demo-path channel-0`,
rlyErrCh := relayer.StartRelayer(
ctx,
- a.Log,
+ a.log,
chains,
paths,
- maxTxSize, maxMsgLength,
- a.Config.memo(cmd),
+ maxMsgLength,
+ a.config.memo(cmd),
0,
0,
&processor.FlushLifecycle{},
@@ -816,7 +868,7 @@ $ %s tx flush demo-path channel-0`,
// so we don't want to separately monitor the ctx.Done channel,
// because we would risk returning before the relayer cleans up.
if err := <-rlyErrCh; err != nil && !errors.Is(err, context.Canceled) {
- a.Log.Warn(
+ a.log.Warn(
"Relayer start error",
zap.Error(err),
)
@@ -826,8 +878,8 @@ $ %s tx flush demo-path channel-0`,
},
}
- cmd = strategyFlag(a.Viper, cmd)
- cmd = memoFlag(a.Viper, cmd)
+ cmd = strategyFlag(a.viper, cmd)
+ cmd = memoFlag(a.viper, cmd)
return cmd
}
@@ -843,13 +895,13 @@ $ %s tx relay-pkts demo-path channel-0`,
appName, appName,
)),
RunE: func(cmd *cobra.Command, args []string) error {
- a.Log.Warn("This command is deprecated. Please use 'tx flush' command instead")
+ a.log.Warn("This command is deprecated. Please use 'tx flush' command instead")
return flushCmd(a).RunE(cmd, args)
},
}
- cmd = strategyFlag(a.Viper, cmd)
- cmd = memoFlag(a.Viper, cmd)
+ cmd = strategyFlag(a.viper, cmd)
+ cmd = memoFlag(a.viper, cmd)
return cmd
}
@@ -865,13 +917,13 @@ $ %s tx relay-acks demo-path channel-0 -l 3 -s 6`,
appName, appName,
)),
RunE: func(cmd *cobra.Command, args []string) error {
- a.Log.Warn("This command is deprecated. Please use 'tx flush' command instead")
+ a.log.Warn("This command is deprecated. Please use 'tx flush' command instead")
return flushCmd(a).RunE(cmd, args)
},
}
- cmd = strategyFlag(a.Viper, cmd)
- cmd = memoFlag(a.Viper, cmd)
+ cmd = strategyFlag(a.viper, cmd)
+ cmd = memoFlag(a.viper, cmd)
return cmd
}
@@ -889,11 +941,11 @@ $ %s tx transfer ibc-0 ibc-1 100000stake raw:non-bech32-address channel-0 --path
$ %s tx raw send ibc-0 ibc-1 100000stake cosmos1skjwj5whet0lpe65qaq4rpq03hjxlwd9nf39lk channel-0 --path demo -c 5
`, appName, appName, appName, appName)),
RunE: func(cmd *cobra.Command, args []string) error {
- src, ok := a.Config.Chains[args[0]]
+ src, ok := a.config.Chains[args[0]]
if !ok {
return errChainNotFound(args[0])
}
- dst, ok := a.Config.Chains[args[1]]
+ dst, ok := a.config.Chains[args[1]]
if !ok {
return errChainNotFound(args[1])
}
@@ -979,16 +1031,16 @@ $ %s tx raw send ibc-0 ibc-1 100000stake cosmos1skjwj5whet0lpe65qaq4rpq03hjxlwd9
dstAddr = rawDstAddr
}
- return src.SendTransferMsg(cmd.Context(), a.Log, dst, amount, dstAddr, toHeightOffset, toTimeOffset, srcChannel)
+ return src.SendTransferMsg(cmd.Context(), a.log, dst, amount, dstAddr, toHeightOffset, toTimeOffset, srcChannel)
},
}
- return timeoutFlags(a.Viper, pathFlag(a.Viper, cmd))
+ return timeoutFlags(a.viper, pathFlag(a.viper, cmd))
}
func setPathsFromArgs(a *appState, src, dst *relayer.Chain, name string) (*relayer.Path, error) {
// find any configured paths between the chains
- paths, err := a.Config.Paths.PathsFromChains(src.ChainID(), dst.ChainID())
+ paths, err := a.config.Paths.PathsFromChains(src.ChainID(), dst.ChainID())
if err != nil {
return nil, err
}
@@ -1037,3 +1089,39 @@ func ensureKeysExist(chains map[string]*relayer.Chain) error {
return nil
}
+
+// MsgRegisterCounterpartyPayee registers the counterparty_payee
+func registerCounterpartyCmd(a *appState) *cobra.Command {
+ cmd := &cobra.Command{
+ Use: "register-counterparty chain_name channel_id port_id relay_addr counterparty_payee",
+ Aliases: []string{"reg-cpt"},
+ Short: "register the counterparty relayer address for ics-29 fee middleware",
+ Args: withUsage(cobra.MatchAll(cobra.ExactArgs(5))),
+ Example: strings.TrimSpace(fmt.Sprintf(`
+$ %s register-counterparty channel-1 transfer cosmos1skjwj5whet0lpe65qaq4rpq03hjxlwd9nf39lk juno1g0ny488ws4064mjjxk4keenwfjrthn503ngjxd
+$ %s reg-cpt channel-1 cosmos1skjwj5whet0lpe65qaq4rpq03hjxlwd9nf39lk juno1g0ny488ws4064mjjxk4keenwfjrthn503ngjxd`,
+ appName, appName)),
+ RunE: func(cmd *cobra.Command, args []string) error {
+
+ chain, ok := a.config.Chains[args[0]]
+ if !ok {
+ return errChainNotFound(args[0])
+ }
+
+ channelID := args[1]
+ portID := args[2]
+
+ relayerAddr := args[3]
+ counterpartyPayee := args[4]
+
+ msg, err := chain.ChainProvider.MsgRegisterCounterpartyPayee(portID, channelID, relayerAddr, counterpartyPayee)
+ if err != nil {
+ return err
+ }
+ res, success, err := chain.ChainProvider.SendMessage(cmd.Context(), msg, "")
+ fmt.Println(res, success, err)
+ return nil
+ },
+ }
+ return cmd
+}
diff --git a/cmd/version.go b/cmd/version.go
index 2079685de..7f18c6519 100644
--- a/cmd/version.go
+++ b/cmd/version.go
@@ -76,5 +76,5 @@ $ %s v`,
},
}
- return jsonFlag(a.Viper, versionCmd)
+ return jsonFlag(a.viper, versionCmd)
}
diff --git a/codecov.yaml b/codecov.yaml
new file mode 100644
index 000000000..1a83c9d79
--- /dev/null
+++ b/codecov.yaml
@@ -0,0 +1,28 @@
+codecov:
+ require_ci_to_pass: false
+comment:
+ behavior: default
+ layout: "reach, diff, flags, files"
+
+ignore:
+ - "**/test_*"
+ - "**/*_test.*"
+ - "**/mocks/*"
+ - "**/mock/*"
+
+coverage:
+ precision: 2
+ range:
+ - 50.0
+ - 100.0
+ round: down
+ status:
+ project: no
+ patch: # patch status only measures lines adjusted in the pull request or single commit
+ default:
+ target: 80% # target of an exact coverage number such as 75% or 100%
+ threshold: 2% # Allow the coverage to drop by X%, and posting a success status.
+ base: auto
+ changes: no # Codecov will detect changes in coverage that are NOT included in the commit/pull diff
+github_checks:
+ annotations: true
\ No newline at end of file
diff --git a/cregistry/chain_info.go b/cregistry/chain_info.go
index 7cea1cb5a..7309296e2 100644
--- a/cregistry/chain_info.go
+++ b/cregistry/chain_info.go
@@ -12,6 +12,7 @@ import (
"time"
"github.com/cosmos/relayer/v2/relayer/chains/cosmos"
+ "github.com/cosmos/relayer/v2/relayer/provider"
"github.com/spf13/viper"
"go.uber.org/zap"
"golang.org/x/sync/errgroup"
@@ -55,8 +56,9 @@ type ChainInfo struct {
Genesis struct {
GenesisURL string `json:"genesis_url"`
} `json:"genesis"`
- Slip44 int `json:"slip44"`
- Codebase struct {
+ Slip44 *int `json:"slip44"`
+ SigningAlgorithm string `json:"signing-algorithm"`
+ Codebase struct {
GitRepo string `json:"git_repo"`
RecommendedVersion string `json:"recommended_version"`
CompatibleVersions []string `json:"compatible_versions"`
@@ -82,6 +84,9 @@ type ChainInfo struct {
Provider string `json:"provider"`
} `json:"rest"`
} `json:"apis"`
+ MaxGasAmount uint64 `json:"max_gas_amount"`
+ ExtraCodecs []string `json:"extra_codecs"`
+ ExtensionOptions []provider.ExtensionOption `json:"extension_options"`
}
// NewChainInfo returns a ChainInfo that is uninitialized other than the provided zap.Logger.
@@ -201,8 +206,8 @@ func (c ChainInfo) GetRandomRPCEndpoint(ctx context.Context) (string, error) {
}
// GetAssetList returns the asset metadata from the cosmos chain registry for this particular chain.
-func (c ChainInfo) GetAssetList(ctx context.Context) (AssetList, error) {
- chainRegURL := fmt.Sprintf("https://raw.githubusercontent.com/cosmos/chain-registry/master/%s/assetlist.json", c.ChainName)
+func (c ChainInfo) GetAssetList(ctx context.Context, name string) (AssetList, error) {
+ chainRegURL := fmt.Sprintf("https://raw.githubusercontent.com/cosmos/chain-registry/master/%s/assetlist.json", name)
res, err := http.Get(chainRegURL)
if err != nil {
@@ -231,11 +236,11 @@ func (c ChainInfo) GetAssetList(ctx context.Context) (AssetList, error) {
// GetChainConfig returns a CosmosProviderConfig composed from the details found in the cosmos chain registry for
// this particular chain.
-func (c ChainInfo) GetChainConfig(ctx context.Context) (*cosmos.CosmosProviderConfig, error) {
+func (c ChainInfo) GetChainConfig(ctx context.Context, name string) (*cosmos.CosmosProviderConfig, error) {
debug := viper.GetBool("debug")
home := viper.GetString("home")
- assetList, err := c.GetAssetList(ctx)
+ assetList, err := c.GetAssetList(ctx, name)
if err != nil {
return nil, err
}
@@ -251,18 +256,22 @@ func (c ChainInfo) GetChainConfig(ctx context.Context) (*cosmos.CosmosProviderCo
}
return &cosmos.CosmosProviderConfig{
- Key: "default",
- ChainID: c.ChainID,
- RPCAddr: rpc,
- AccountPrefix: c.Bech32Prefix,
- KeyringBackend: "test",
- GasAdjustment: 1.2,
- GasPrices: gasPrices,
- KeyDirectory: home,
- Debug: debug,
- Timeout: "20s",
- OutputFormat: "json",
- SignModeStr: "direct",
- Slip44: c.Slip44,
+ Key: "default",
+ ChainID: c.ChainID,
+ RPCAddr: rpc,
+ AccountPrefix: c.Bech32Prefix,
+ KeyringBackend: "test",
+ GasAdjustment: 1.2,
+ GasPrices: gasPrices,
+ KeyDirectory: home,
+ Debug: debug,
+ Timeout: "20s",
+ OutputFormat: "json",
+ SignModeStr: "direct",
+ Slip44: c.Slip44,
+ SigningAlgorithm: c.SigningAlgorithm,
+ ExtraCodecs: c.ExtraCodecs,
+ MaxGasAmount: c.MaxGasAmount,
+ ExtensionOptions: c.ExtensionOptions,
}, nil
}
diff --git a/docker-compose.yaml b/docker-compose.yaml
new file mode 100644
index 000000000..5f4dadcaa
--- /dev/null
+++ b/docker-compose.yaml
@@ -0,0 +1,15 @@
+version: "3.7"
+services:
+ ibc-relayer:
+ container_name: relayer01
+ image: docker.io/18cr314y/relay-node:latest
+ environment:
+ - PATH_NAME="icon-archway"
+ entrypoint:
+ - sh
+ - /opt/start-relay.sh
+ volumes:
+ - ~/.relayer:/home/relayer/.relayer:rw
+ - ./scripts:/opt
+ ports:
+ - "5183:5183"
diff --git a/docs/advanced_usage.md b/docs/advanced_usage.md
index a95d8d51e..bcfd1d2ac 100644
--- a/docs/advanced_usage.md
+++ b/docs/advanced_usage.md
@@ -5,27 +5,24 @@
**Prometheus exporter**
If you started `rly` with the default `--debug-addr` argument,
-you can use `http://$IP:7597/relayer/metrics` as a target for your prometheus scraper.
-
-**Example metrics**
-
-```
-go_goroutines 29
-...
-go_threads 39
-...
-observed_packets{chain="cosmoshub-4",channel="channel-141",path="hubosmo",port="transfer",type="acknowledge_packet"} 57
-observed_packets{chain="cosmoshub-4",channel="channel-141",path="hubosmo",port="transfer",type="recv_packet"} 103
-observed_packets{chain="cosmoshub-4",channel="channel-141",path="hubosmo",port="transfer",type="send_packet"} 58
-observed_packets{chain="osmosis-1",channel="channel-0",path="hubosmo",port="transfer",type="acknowledge_packet"} 107
-observed_packets{chain="osmosis-1",channel="channel-0",path="hubosmo",port="transfer",type="recv_packet"} 60
-observed_packets{chain="osmosis-1",channel="channel-0",path="hubosmo",port="transfer",type="send_packet"} 102
-...
-relayed_packets{chain="cosmoshub-4",channel="channel-141",path="hubosmo",port="transfer",type="acknowledge_packet"} 31
-relayed_packets{chain="cosmoshub-4",channel="channel-141",path="hubosmo",port="transfer",type="recv_packet"} 65
-relayed_packets{chain="osmosis-1",channel="channel-0",path="hubosmo",port="transfer",type="acknowledge_packet"} 36
-relayed_packets{chain="osmosis-1",channel="channel-0",path="hubosmo",port="transfer",type="recv_packet"} 35
-```
+you can use `http://$IP:5183/relayer/metrics` as a target for your prometheus scraper.
+
+
+Exported metrics:
+
+| **Exported Metric** | **Description** | **Type** |
+|:---------------------------------------------: |:----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------: |:--------: |
+| cosmos_relayer_observed_packets | The total number of observed packets | Counter |
+| cosmos_relayer_relayed_packets | The total number of relayed packets | Counter |
+| cosmos_relayer_chain_latest_height | The current height of the chain | Gauge |
+| cosmos_relayer_wallet_balance | The current balance for the relayer's wallet | Gauge |
+| cosmos_relayer_fees_spent | The amount of fees spent from the relayer's wallet | Gauge |
+| cosmos_relayer_tx_failure |
The total number of tx failures broken up into categories:
- "packet messages are redundant"
- "insufficient funds"
- "invalid coins"
- "out of gas"
"Tx Failure" is the the catch all bucket | Counter |
+| cosmos_relayer_block_query_errors_total | The total number of block query failures. The failures are separated into two categories:
- "RPC Client"
- "IBC Header" | Counter |
+| cosmos_relayer_client_expiration_seconds | Seconds until the client expires | Gauge |
+| cosmos_relayer_client_trusting_period_seconds | The trusting period (in seconds) of the client | Gauge |
+
+
---
@@ -38,19 +35,49 @@ By default, the Relayer will automatically update clients (`MsgUpdateClient`) if
> This auto-update functionality is specifically useful on low trafficked paths where messages aren't regularly being relayed.
-You can choose to update clients more regularly by using the `--time-threshold` flag when running the `rly start` command.
+Alternitavely, you can choose to update clients more frequently by using the `--time-threshold` flag when running the `rly start` command.
Example:
-- You are relaying on a path that has a client trusting period of 9 minutes.
+- Say... You are relaying on a path that has a client trusting period of 9 minutes.
- If no messages are sent for 6 minutes and the client is 3 minutes (1/3) to expiration, the relayer will automatically update the client.
- If you wish to update the client more frequently, say anytime two minutes have passed without a `MsgUpdateClient` being sent, use flag: `--time-threshold 2m`
Selecting a time-threshold that is greater than 2/3 of the client trusting period will deem itself useless.
+Use cases for configuring the `--time-threshold` flag:
+- The underlying chain node that the relayer is using as an endpoint has restrictive pruning. Client updates are needed more frequently since states 2/3 trusting period ago would not be available due to pruning.
+- Mitiage relayer operational errors allowing more frequent updates incase a relayer node goes down for > the client trusting period.
+
\* It is not mandatory for relayers to include the `MsgUpdateClient` when relaying packets, however most, if not all relayers currently do.
----
+## Feegrants
+
+Feegrant configurations can be applied to each chain in the relayer. Note that Osmosis does not support Feegrants.
+
+ - When feegrants are enabled, TXs will be signed in round robin by the grantees.
+ - Feegrants reduce sequencing error rates by using many signing addresses instead of a single signer, especially when broadcast-mode is set to single.
+ - Feegrants are especially useful when relaying on multiple paths with the same wallet.
+ - Funds are held on a single address, the "granter".
+
+For example, configure feegrants for Kujira:
+- `rly chains configure feegrant basicallowance kujira default --num-grantees 10`
+- Note: above, `default` is the key that will need to contain funds (the granter)
+- 10 grantees will be configured, so those 10 address will sign TXs in round robin order.
+You may also choose to specify the exact names of your grantees:
+- `rly chains configure feegrant basicallowance kujira default --grantees "kuji1,kuji2,kuji3"`
+
+Rerunning the feegrant command will simply confirm your configuration is correct, e.g. "Valid grant found for granter `addr` and grantee `addr2`" but will not create additional TXs on chain. Rerunning the feegrant command can therefore be a good way to check what addresses exist.
+
+
+To remove the feegrant configuration:
+- `rly chains configure feegrant basicallowance kujira --delete`
+
+
+
+
+---
+
[<-- Create Path Across Chains](create-path-across-chain.md) - [Troubleshooting -->](./troubleshooting.md)
diff --git a/docs/deviations_from_ibc.md b/docs/deviations_from_ibc.md
new file mode 100644
index 000000000..dd4f9a971
--- /dev/null
+++ b/docs/deviations_from_ibc.md
@@ -0,0 +1,71 @@
+# Deviations from IBC Relay
+
+This relayer was meant to be used for [ICON-IBC Integration](https://github.com/icon-project/IBC-Integration). So, it is made to accomodate all the changes made on IBC Integration such that IBC can be established between ICON and Cosmos based chains.
+
+All the deviations that the ICON-IBC Integrations can be found [here]().
+
+## Changes
+The major changes in the relayer include:
+- [ICON Module](#icon-module)
+- [Wasm Module](#wasm-module)
+- [Relayer Internal](#relayer-internal)
+- [Cmd](#cmd)
+- [Config](#config)
+
+## Icon Module
+- Icon Chain Module has been added to support ICON Chain.
+- We use [BTP Blocks](https://icon.community/glossary/btp-blocks/) provided by ICON chain significantly.
+- Icon provides a websocket api which we can use to stream all blocks of mainnet. We do use this websockets instead of polling each height as done on cosmos chain processor.
+- The relayer interfaces with IBC contract deployed on ICON and calls methods of the contract via ICON Provider.
+- To update counterparty light client, we use information obtained BTP Blocks rather than actual main ICON chain.
+- We query if the block is a BTP Block, and if yes, it initiates messages that'll be sent to counterparty contract. So, for each BTP Block produced, light client is updated.
+
+## Wasm Module
+- Wasm Module has been added to support CosmWasm contracts.
+- Like cosmos chain processor, polling is done for each height of the chain.
+- Wasm Provider provides methods to interface with the IBC Wasm contract deployed on respective cosmos chain.
+
+## Relayer Internal
+- Minimal changes has had to be added on the internal logic of the relayer to support for BTP Blocks.
+- Since ICON cannot produce non membership proofs via BTP Blocks, a method called `requestTimeout` was introduced on ICON contract for when packet is to be timed out on wasm contracts. Logic for this has been added on relayer internal.
+- Update client and the message to be sent after, has been sent on different transaction. [Reason for this decision]()
+
+## Cmd
+- Relevant methods for ICON has been added accordingly.
+- When a BTP client is to be created on WASM contract, we need to specify a BTP height for the relayer. By default, it takes the first BTP height for this network. If we are to give a custom height, a flag `btp-block-height` has been added. The height should be a BTP Block for given BTP network type and BTP Network Id.
+ ```sh
+ rly tx clients icon-path-name --client-tp "1000000m" --btp-block-height 11313986
+ ```
+
+## Config
+- Example Config for ICON-IBC Integration
+ - [Here](../examples/config_IBC_ICON.yaml)
+
+
+
+## Wasm Config
+Other parameters are same as in cosmos chains. The specifications for added fields in config are
+- IBC Handler Address
+ - WASM Contract Address of IBC Handler
+- First Retry Block After:
+ - For first retry transaction, wait for this number of blocks (default set to 3)
+- Start Height:
+ - Custom height to start chain processor from
+- Block Interval:
+ - Block Interval of cosmos chain
+
+## Icon Config
+- keystore and password
+ - Keystore and password is used to generate a wallet for relay
+- Icon Network ID
+ - Network ID for ICON chain (varies for testnet, localnet and mainnet)
+- BTP Network ID, BTP Network Type ID
+ - BTP Specific IDs required
+- Start Height:
+ - Height to start ICON chain processor from
+- IBC Handler Address:
+ - Address of IBC java contract
+- Block Interval:
+ - Block Interval of ICON chain
+- First Retry Block After:
+ - For first retry transaction, wait for this number of blocks (default set to 8)
diff --git a/docs/troubleshooting.md b/docs/troubleshooting.md
index dbfac01dc..75f46195e 100644
--- a/docs/troubleshooting.md
+++ b/docs/troubleshooting.md
@@ -53,6 +53,17 @@ it will be helpful to provide the output from `http://localhost:7597/debug/pprof
---
+**Error querying blockdata**
+
+The relayer looks back in time at historical transactions and needs to have an index of them.
+
+Specifically check `~/./config/config.toml` has the following fields set:
+```toml
+indexer = "kv"
+index_all_tags = true
+```
+---
+
**Error building or broadcasting transaction**
When preparing a transaction for relaying, the amount of gas that the transaction will consume is unknown. To compute how much gas the transaction will need, the transaction is prepared with 0 gas and delivered as a `/cosmos.tx.v1beta1.Service/Simulate` query to the RPC endpoint. Recently chains have been creating AnteHandlers in which 0 gas triggers an error case:
diff --git a/env/archway/keys/constantine-2/keyring-test/07d2687af11bd5395e9825a5db2a79fd2b701e15.address b/env/archway/keys/constantine-2/keyring-test/07d2687af11bd5395e9825a5db2a79fd2b701e15.address
new file mode 100644
index 000000000..c39c03642
--- /dev/null
+++ b/env/archway/keys/constantine-2/keyring-test/07d2687af11bd5395e9825a5db2a79fd2b701e15.address
@@ -0,0 +1 @@
+eyJhbGciOiJQQkVTMi1IUzI1NitBMTI4S1ciLCJjcmVhdGVkIjoiMjAyMy0wNS0wNSAwNzozMTowNi43MzAzMjI1MTkgKzA1NDUgKzA1NDUgbT0rMC4wNTYzNzExOTciLCJlbmMiOiJBMjU2R0NNIiwicDJjIjo4MTkyLCJwMnMiOiJMcnNiQmNlbVR1SGlGcmswIn0.7hHBTJ9-ckG8JAJii7_EYyRgaHd6k49E8wrCVxHX7d6p7MpoTTwiXA.wTF4cbPE6zcvTn9f.3-khIHDMI8qgUYD41_wWVMh6ARoRDBV4NunAhpSVB2q_uiRBPsq4tonMSxv3XKJCy_wvLPcX5teZA1op7n-HrieemrKxWnyNho11eGadfkrAibEF4pGunumktfLlJNFGCtwFTw1ptPCC9Qqu3vKbL3Mn2VilSABYo0eTsQUT8_L7Y77OKiNczeO0C7NqIVxFpF0Kl4-0gBfGrU0FDCGhSDubPOcPbG3WsF-wxa-jY6ziq84q5hi99yQV.kRxbQv_ncCI2T9BitYqBYg
\ No newline at end of file
diff --git a/env/archway/keys/constantine-2/keyring-test/testWallet.info b/env/archway/keys/constantine-2/keyring-test/testWallet.info
new file mode 100644
index 000000000..26a03c8c3
--- /dev/null
+++ b/env/archway/keys/constantine-2/keyring-test/testWallet.info
@@ -0,0 +1 @@
+eyJhbGciOiJQQkVTMi1IUzI1NitBMTI4S1ciLCJjcmVhdGVkIjoiMjAyMy0wNS0wNSAwNzozMTowNi43MjUwMTQzNjEgKzA1NDUgKzA1NDUgbT0rMC4wNTEwNjMwMzkiLCJlbmMiOiJBMjU2R0NNIiwicDJjIjo4MTkyLCJwMnMiOiJtdEpJYm0wVjBsbDVPaEN3In0.H0oXPjMmYwkc40g5y6qcdEXZFq7y3kd4jGna3rd5LHi8C95-H91zBQ.7Fb4ECO4L6syg_UF.EfQ8j_vX_vKLC8f1gcqzMF-hv2RhRtwYzBI359HXu4HKXKBtv9AY_OsP3h9iilkLL6nRJiBMKnD4MfqZ1SB6itdwitKulYck7H_C8GU9XY9FBdTyPXHBOmfGAVqkQE4-qQbE7HiAOv3ZTk7xgznEtzuTUxqfGLUZxyw8AJf8az-EpgQDxzbjnnwhv4krYyC5QOIB811I0KGjGXGKYIurMcf0n_5XaUFPQiY3sFV1DBy7TGYepJ7Nm2gmmdmWbzBVa-bKWcrmR97LmdM78BJgIi8UoLyCqgrE2v1wC3BXHWJGcKeViS-acnZBS5WXmWsTxrDcqohpgbTjWe49NtXQrj_1Xdh8nsEk69cyA7yKtjddXXFAIwzmtlZ2TEKj1le7wVfEeDReYUXrxuDuBmTbyDVPTXwjv7V6F0nXoNzsy1xgybucC8ISmqUcM8zdp0QurWiRYOxMDaY9.a4p8dtUP5XUeJUL4LuIIoA
\ No newline at end of file
diff --git a/env/archway/keys/constantine-3/keyring-test/905b8459ccf3b6ee831af918d3a9aebd8c64b03f.address b/env/archway/keys/constantine-3/keyring-test/905b8459ccf3b6ee831af918d3a9aebd8c64b03f.address
new file mode 100644
index 000000000..adc06adff
--- /dev/null
+++ b/env/archway/keys/constantine-3/keyring-test/905b8459ccf3b6ee831af918d3a9aebd8c64b03f.address
@@ -0,0 +1 @@
+eyJhbGciOiJQQkVTMi1IUzI1NitBMTI4S1ciLCJjcmVhdGVkIjoiMjAyMy0wNi0wNyAwODo1Njo1Ni4wMDMyOTUgKzA1NDUgKzA1NDUgbT0rMi4wNDE5MzY1NDMiLCJlbmMiOiJBMjU2R0NNIiwicDJjIjo4MTkyLCJwMnMiOiI0MzRfTmVERVVuWDVCVU1SIn0.r7lv-yGNVvND8NJIVdR_Ti3MLLpbEYzjmWMw3LA0ArHDMzMQZfXwLQ.dvcqHGmIHHaBx34z.pIIZitK5ocyC5tUQd15Nn5m5f0eynjZuM9ughJ2jvtEgzp44EhXvOYgCjVoorNog3Im0M6DIftP_7Tnc_hEprWR7rxlMgl-U8UMZkDVJXfBjLmM0iaUN3V3i-dBF7Rvo2CR9cOmYan4LmVQfj8jLT67vyPs4f9uj_efjVMVcNNB93gGbWC3Ihs-qv4jPV1pZslVgE8M6NyxOUrUtBVdsHudDQBv8C4wpw2L7VcAKmNDT-MpqtcLUctiL.pPU6EwtZFVIZE6qnitVuNA
\ No newline at end of file
diff --git a/env/archway/keys/constantine-3/keyring-test/testWallet.info b/env/archway/keys/constantine-3/keyring-test/testWallet.info
new file mode 100644
index 000000000..4d2f9471c
--- /dev/null
+++ b/env/archway/keys/constantine-3/keyring-test/testWallet.info
@@ -0,0 +1 @@
+eyJhbGciOiJQQkVTMi1IUzI1NitBMTI4S1ciLCJjcmVhdGVkIjoiMjAyMy0wNi0wNyAwODo1Njo1Ni4wMDEwMTkgKzA1NDUgKzA1NDUgbT0rMi4wMzk2NjA4MzQiLCJlbmMiOiJBMjU2R0NNIiwicDJjIjo4MTkyLCJwMnMiOiJJZ0JIdFQxZWNreFVFanhwIn0.YmDzG_pwW-49GJi4i_eEgzS_up6PEEG7py2RPCMacm7r2DdRo-izCQ.JP7Vb2qyvqFD3F18.Y2X7upGeUoCH6FlnuiDV2nkKKoNs_cMy2on_1-C3LH3GH5xMk2yO7mmlSL6et4hMwWZPpl1TapBOIBWEppKpfQioHQki4HCPBwiclNW8Kb1siDtlrYFytykO31n5pcNf6XZdTVrh4MTDVy8LVpKFHi1Eboq7kmz9CWk5wzBJTD-Qctj07xKPot6rHgAmSznO3rWIUup6GxY_28PzJbDsrx0d0Rp4SIrMn1KXsobakAemqTwJhGwzJasTypU733wNi6YxhehI369Hgewf2dvCjMPNb3zFDGfoCkTqEG6nbBlfblhJWaJmyFBXhBfnTTn2Q7wHRbg0YF6U2REMc03BThE-0-m0Kh3SLxZIkHIixsxNz2-DftB8G-vfJnbmUJhzJgBQphkVX_AsstP8b5fofl63CitCYYXeHA0v-3xqCssF5ULuXN1_E79UPLh3zDmLQNdvY1ZcmuhJ.RRzqfURo53kRJ1zIMuR-8A
\ No newline at end of file
diff --git a/env/archway/keys/localnet/keyring-test/69884312e40d2f6123f11bad24db0ea3e2f563be.address b/env/archway/keys/localnet/keyring-test/69884312e40d2f6123f11bad24db0ea3e2f563be.address
new file mode 100644
index 000000000..b21e4d4d4
--- /dev/null
+++ b/env/archway/keys/localnet/keyring-test/69884312e40d2f6123f11bad24db0ea3e2f563be.address
@@ -0,0 +1 @@
+eyJhbGciOiJQQkVTMi1IUzI1NitBMTI4S1ciLCJjcmVhdGVkIjoiMjAyMy0wNS0xOCAxMToyMDoyNi4zNzg3ODggKzA1NDUgKzA1NDUgbT0rMC4xNTg0MDAzMzUiLCJlbmMiOiJBMjU2R0NNIiwicDJjIjo4MTkyLCJwMnMiOiJVS3VmLVlwWUYtejJXTGVYIn0.t54pg3dTQr91YShB2R3pWVbCHlkrW7EQF6-5HSRJ8eOygqv-MOI7bw.nYBWAV54DCHIfAkV.Y8ywjCjk_dsSa4U9T9nZ7U4dtLYqKCZtUxv3cgEGUOYyPfsT10Q_rFFDrqmZwQoIUKwPNrRDdt1gYPaObeNt8AUkFPRe5MvHme0Ur0WBHsy0sL0huGwQD_gh2-jStmDIgWaZm6IIc2yq9SNYqds4DoyYuBJtpoOj3BU0GNIIxyLcRnBWvw8dT_Y4QaV0_ykJTJobSIe-dmGyaPMIJbYeM9X2rHQC0l0ONg-lTSXx5DwPIowzrRw.weJEefxDS5ymcfwsNE5lAw
\ No newline at end of file
diff --git a/env/archway/keys/localnet/keyring-test/77983c27b7d199e369dce01ec9465c3cf3e53dab.address b/env/archway/keys/localnet/keyring-test/77983c27b7d199e369dce01ec9465c3cf3e53dab.address
new file mode 100644
index 000000000..566159d0f
--- /dev/null
+++ b/env/archway/keys/localnet/keyring-test/77983c27b7d199e369dce01ec9465c3cf3e53dab.address
@@ -0,0 +1 @@
+eyJhbGciOiJQQkVTMi1IUzI1NitBMTI4S1ciLCJjcmVhdGVkIjoiMjAyMy0wNS0yMiAwNzo1MzoxMC40NzMzOTIgKzA1NDUgKzA1NDUgbT0rMC4wNDk0NDYyOTMiLCJlbmMiOiJBMjU2R0NNIiwicDJjIjo4MTkyLCJwMnMiOiJoRG42Ym5RNm84YWFJcEVxIn0.fDM0MseEJEku1BXOpliz3NV0shnt12C41A2ICiX1IynJs54sbLNx9A.RnrDJ2AgQ919i9FQ.90sMOtcQV04JPnSiXnmYJMDD3bYth-Ca4h0ea6LW0A6Vr2v56wRj0jrQtN6xOHc9SqSMmkupta_pCfB5CMpTwpwAjtjoDDeOyTrK_-1XpQQI4Gfs0S86r4bsdhtJp7JS4oefclLQaIEeTkS-pMtLFJMrFCKaulKGfnJshcjaZIRlrR2t0bnrX74bPcTd8hn2h8jKcVO3aRUmq7THLdEI7AxjII0W9o1OgY5OFne-S_h24CvXCzihtXpR.CQduuKMpXiSpgYqfOxzmFQ
\ No newline at end of file
diff --git a/env/archway/keys/localnet/keyring-test/default.info b/env/archway/keys/localnet/keyring-test/default.info
new file mode 100644
index 000000000..7c5c14a32
--- /dev/null
+++ b/env/archway/keys/localnet/keyring-test/default.info
@@ -0,0 +1 @@
+eyJhbGciOiJQQkVTMi1IUzI1NitBMTI4S1ciLCJjcmVhdGVkIjoiMjAyMy0wNS0xOCAxMToyMDoyNi4zNzczNDggKzA1NDUgKzA1NDUgbT0rMC4xNTY5NjA3MTAiLCJlbmMiOiJBMjU2R0NNIiwicDJjIjo4MTkyLCJwMnMiOiJsOGFBQ1U3WHJIdFhfX19JIn0.D-2spknCPMAcOKswbbUfouVacZlekDAPTyuvdNH-5Guz4NmUFckNlw.ldALTGAhQuaqsKqH.YdWdtuxvCy426CpG4sIIxVsNIqmlrglKURzjGKZ0GTJ9Ny00zRVj61mjCYVKUIs0irdwNUsJ9MpalTDET7hxJDqGAgBMdBvp7rjh8508BQhZnwjYlOjUt7zamGm8NYL5hGRbbK5blfubFRvzrOWrYZbXpUwQk7__lVYFspEwSz4pCLPS7y4VYPxj9P7SVZBdW5EoYU_dnieDOhngHsteEHMvBKfme-LgsGEUgEuXgdevIelCC7ml_GEct_IfvNu350Z71d2wCd-U9xKSyr4YvwLM3n3m9gTcMstHaPWWTdcAaT8XpIN5w-rQt-0Byn2EAOknkPLwvfVW8-6ztluNNt1HPfqHSUka8tQ-qDMsK_PGOZQFwzae60djnVtN4XAZST1Q9Vw4GNDBEgRu3kGQONjFCW6dteSdV5sYv8k3e-u74AiJ4wv9A-6_e2MnfyYa88I.uD74oxn1VOcIjP7PyuXtlQ
\ No newline at end of file
diff --git a/env/archway/keys/localnet/keyring-test/testWallet.info b/env/archway/keys/localnet/keyring-test/testWallet.info
new file mode 100644
index 000000000..d7e307d59
--- /dev/null
+++ b/env/archway/keys/localnet/keyring-test/testWallet.info
@@ -0,0 +1 @@
+eyJhbGciOiJQQkVTMi1IUzI1NitBMTI4S1ciLCJjcmVhdGVkIjoiMjAyMy0wNS0yMiAwNzo1MzoxMC40NzE3NzUgKzA1NDUgKzA1NDUgbT0rMC4wNDc4Mjg3NTEiLCJlbmMiOiJBMjU2R0NNIiwicDJjIjo4MTkyLCJwMnMiOiJMNEZnSk9GbGdRejFTR3BRIn0.ANqHjDpwMPAy6ySLuR-Bah8Id9INrvRWnR_j7KVUVwbcEMj8AtlcQA.GzYUDAjk8568c_LY.oqaficyo5OaSnfPrY3-uoU78SOv-hBUZz7WezzY-QkTo7mRodHiV3ifNzpdoIM36P5DxBjAaA0GjOLL0A5msaMkjYJaRsQQ03G5LlJOWBlio29KovGf3tHhRlJbK_aHe4c4qr12IZGaJ6Kj7cujI4bHZjy7WoYZAKT_nG3czO4zRX7EKkpv0bVMp6CXlUWwha6-TourVXo-Sj2cm7U6zYUA7aeBGfdOpcsjef1ApTp1Ote8xOHW0vcsZES0CKqGwjiSj-TDzZzh3kb1fdp-djl46pKYMVPXSCtjR2GXkPZbLf5nXeiN4EAyg5dgyVlk4ogodcC_CH0czv5GcB2N6Yc53C8E4GkPQPsJBhNPdrXoXdviBoCamd4EwBxQ4NMK8ojLU6QieM-VSjdYvwsXjfdU24Pd-rg2hRMbVPIwKKxerapqcVB4w1SpG8hZH7zy5MIE94OzkJGDF.FAr8naGG324ClezNrdoveQ
\ No newline at end of file
diff --git a/env/ibc-icon/godWallet.json b/env/ibc-icon/godWallet.json
new file mode 100644
index 000000000..c77c10216
--- /dev/null
+++ b/env/ibc-icon/godWallet.json
@@ -0,0 +1,23 @@
+{
+ "address": "hxb6b5791be0b5ef67063b3c10b840fb81514db2fd",
+ "id": "87323a66-289a-4ce2-88e4-00278deb5b84",
+ "version": 3,
+ "coinType": "icx",
+ "crypto": {
+ "cipher": "aes-128-ctr",
+ "cipherparams": {
+ "iv": "069e46aaefae8f1c1f840d6b09144999"
+ },
+ "ciphertext": "f35ff7cf4f5759cb0878088d0887574a896f7f0fc2a73898d88be1fe52977dbd",
+ "kdf": "scrypt",
+ "kdfparams": {
+ "dklen": 32,
+ "n": 65536,
+ "r": 8,
+ "p": 1,
+ "salt": "0fc9c3b24cdb8175"
+ },
+ "mac": "1ef4ff51fdee8d4de9cf59e160da049eb0099eb691510994f5eca492f56c817a"
+ }
+}
+
diff --git a/examples/config_IBC_ICON.yaml b/examples/config_IBC_ICON.yaml
new file mode 100644
index 000000000..d0f69c19b
--- /dev/null
+++ b/examples/config_IBC_ICON.yaml
@@ -0,0 +1,59 @@
+global:
+ api-listen-addr: :5183
+ timeout: 10s
+ memo: ""
+ light-cache-size: 20
+chains:
+ archway:
+ type: wasm
+ value:
+ key-directory: /home/user/.relayer/keys
+ key: relayWallet
+ chain-id: localnet
+ rpc-addr: http://localhost:26657
+ account-prefix: archway
+ keyring-backend: test
+ gas-adjustment: 1.5
+ gas-prices: 0.025stake
+ min-gas-amount: 1000000
+ debug: true
+ timeout: 20s
+ block-timeout: ""
+ output-format: json
+ sign-mode: direct
+ extra-codecs: []
+ coin-type: 0
+ broadcast-mode: batch
+ ibc-handler-address: archway1pvrwmjuusn9wh34j7y520g8gumuy9xtl3gvprlljfdpwju3x7ucszwhc7n
+ first-retry-block-after: 0
+ start-height: 0
+ block-interval: 3000
+ icon:
+ type: icon
+ value:
+ key-directory: /home/user/.relayer/keys
+ chain-id: ibc-icon
+ rpc-addr: http://localhost:9082/api/v3/
+ timeout: 30s
+ keystore: godWallet
+ password: gochain
+ icon-network-id: 3
+ btp-network-id: 1
+ btp-network-type-id: 1
+ start-height: 0
+ ibc-handler-address: cxbeb5929616e0dbd2fec1e6e950ab09e45e6fb25a
+ first-retry-block-after: 0
+ block-interval: 2000
+paths:
+ icon-archway:
+ src:
+ chain-id: ibc-icon
+ client-id: 07-tendermint-0
+ connection-id: connection-0
+ dst:
+ chain-id: localnet
+ client-id: iconclient-0
+ connection-id: connection-0
+ src-channel-filter:
+ rule: ""
+ channel-list: []
diff --git a/examples/demo/configs/chains/ibc-0.json b/examples/demo/configs/chains/ibc-0.json
deleted file mode 100644
index 9acc0c04e..000000000
--- a/examples/demo/configs/chains/ibc-0.json
+++ /dev/null
@@ -1,18 +0,0 @@
-{
- "type": "cosmos",
- "value": {
- "key": "testkey",
- "chain-id": "ibc-0",
- "rpc-addr": "http://localhost:26657",
- "grpc-addr": "",
- "account-prefix": "cosmos",
- "keyring-backend": "test",
- "gas-adjustment": 1.5,
- "gas-prices": "0.025stake",
- "debug": true,
- "timeout": "10s",
- "output-format": "json",
- "sign-mode": "direct"
- }
-}
-
diff --git a/examples/demo/configs/chains/ibc-1.json b/examples/demo/configs/chains/ibc-1.json
deleted file mode 100644
index 56ad3c370..000000000
--- a/examples/demo/configs/chains/ibc-1.json
+++ /dev/null
@@ -1,18 +0,0 @@
-{
- "type": "cosmos",
- "value": {
- "key": "testkey",
- "chain-id": "ibc-1",
- "rpc-addr": "http://localhost:26557",
- "grpc-addr": "",
- "account-prefix": "cosmos",
- "keyring-backend": "test",
- "gas-adjustment": 1.5,
- "gas-prices": "0.025rice",
- "debug": true,
- "timeout": "10s",
- "output-format": "json",
- "sign-mode": "direct"
- }
-}
-
diff --git a/examples/demo/configs/chains/ibc-icon.json b/examples/demo/configs/chains/ibc-icon.json
new file mode 100644
index 000000000..466f153ee
--- /dev/null
+++ b/examples/demo/configs/chains/ibc-icon.json
@@ -0,0 +1,18 @@
+{
+ "type": "icon",
+ "value": {
+ "key-directory": "/home/user/.relayer/keys",
+ "chain-id": "ibc-icon",
+ "rpc-addr": "http://localhost:9082/api/v3/",
+ "timeout": "30s",
+ "keystore": "relayerWallet",
+ "password": "gochain",
+ "icon-network-id": 3,
+ "btp-network-id": 2,
+ "btp-network-type-id": 1,
+ "start-height": 0,
+ "ibc-handler-address": "cxbeb5929616e0dbd2fec1e6e950ab09e45e6fb25a",
+ "first-retry-block-after": 0,
+ "block-interval": 2000
+ }
+}
\ No newline at end of file
diff --git a/examples/demo/configs/chains/ibc-wasm.json b/examples/demo/configs/chains/ibc-wasm.json
new file mode 100644
index 000000000..d0f6bbe3a
--- /dev/null
+++ b/examples/demo/configs/chains/ibc-wasm.json
@@ -0,0 +1,26 @@
+{
+ "type": "wasm",
+ "value": {
+ "key-directory": "/home/user/.relayer/keys",
+ "key": "relayWallet",
+ "chain-id": "localnet",
+ "rpc-addr": "http://localhost:26657",
+ "account-prefix": "archway",
+ "keyring-backend": "test",
+ "gas-adjustment": 1.5,
+ "gas-prices": "0.025stake",
+ "min-gas-amount": 1000000,
+ "debug": true,
+ "timeout": "20s",
+ "block-timeout": "",
+ "output-format": "json",
+ "sign-mode": "direct",
+ "extra-codecs": [],
+ "coin-type": 0,
+ "broadcast-mode": "batch",
+ "ibc-handler-address": "archway1pvrwmjuusn9wh34j7y520g8gumuy9xtl3gvprlljfdpwju3x7ucszwhc7n",
+ "first-retry-block-after": 0,
+ "start-height": 0,
+ "block-interval": 3000
+ }
+}
\ No newline at end of file
diff --git a/examples/demo/configs/paths/demo.json b/examples/demo/configs/paths/icon-archway.json
similarity index 66%
rename from examples/demo/configs/paths/demo.json
rename to examples/demo/configs/paths/icon-archway.json
index 14175cedb..9a12e583a 100644
--- a/examples/demo/configs/paths/demo.json
+++ b/examples/demo/configs/paths/icon-archway.json
@@ -1,9 +1,9 @@
{
"src": {
- "chain-id": "ibc-0"
+ "chain-id": "ibc-icon"
},
"dst": {
- "chain-id": "ibc-1"
+ "chain-id": "localnet"
},
"src-channel-filter": {
"rule": null,
diff --git a/go.mod b/go.mod
index d6b2f0eb1..6912007dc 100644
--- a/go.mod
+++ b/go.mod
@@ -4,72 +4,87 @@ go 1.19
require (
cosmossdk.io/api v0.3.1
- cosmossdk.io/errors v1.0.0-beta.7
- cosmossdk.io/math v1.0.0-beta.6.0.20230216172121-959ce49135e4
- github.com/avast/retry-go/v4 v4.3.2
- github.com/btcsuite/btcd v0.22.2
- github.com/btcsuite/btcutil v1.0.3-0.20201208143702-a53e38424cce
- github.com/cometbft/cometbft v0.37.0
+ cosmossdk.io/errors v1.0.0
+ cosmossdk.io/math v1.1.2
+ github.com/CosmWasm/wasmd v0.0.0-00010101000000-000000000000
+ github.com/avast/retry-go/v4 v4.3.3
+ github.com/btcsuite/btcd v0.23.4
+ github.com/btcsuite/btcd/btcutil v1.1.3
+ github.com/cometbft/cometbft v0.37.2
github.com/cosmos/cosmos-proto v1.0.0-beta.2
- github.com/cosmos/cosmos-sdk v0.47.0-rc3
+ github.com/cosmos/cosmos-sdk v0.47.5
github.com/cosmos/go-bip39 v1.0.0
- github.com/cosmos/gogoproto v1.4.6
- github.com/cosmos/ibc-go/v7 v7.0.0-rc1
+ github.com/cosmos/gogoproto v1.4.10
+ github.com/cosmos/ibc-go/modules/capability v1.0.0-rc1
+ github.com/cosmos/ibc-go/v7 v7.3.0
+ github.com/cosmos/ics23/go v0.10.0
github.com/ethereum/go-ethereum v1.10.26
github.com/gofrs/flock v0.8.1
- github.com/gogo/protobuf v1.3.2
+ github.com/gogo/protobuf v1.3.3
github.com/google/go-cmp v0.5.9
github.com/google/go-github/v43 v43.0.0
+ github.com/gorilla/websocket v1.5.0
github.com/grpc-ecosystem/grpc-gateway v1.16.0
+ github.com/icon-project/IBC-Integration v0.0.0-20230416064536-48d70570734d
+ github.com/icon-project/goloop v1.3.4
github.com/jsternberg/zap-logfmt v1.3.0
- github.com/prometheus/client_golang v1.14.0
- github.com/spf13/cobra v1.6.1
- github.com/spf13/viper v1.15.0
- github.com/stretchr/testify v1.8.2
+ github.com/pkg/errors v0.9.1
+ github.com/prometheus/client_golang v1.15.0
+ github.com/spf13/cobra v1.7.0
+ github.com/spf13/viper v1.16.0
+ github.com/stretchr/testify v1.8.4
github.com/tyler-smith/go-bip39 v1.1.0
go.uber.org/multierr v1.8.0
go.uber.org/zap v1.24.0
- golang.org/x/mod v0.8.0
- golang.org/x/sync v0.1.0
- golang.org/x/term v0.5.0
- golang.org/x/text v0.7.0
- google.golang.org/grpc v1.53.0
+ golang.org/x/crypto v0.11.0
+ golang.org/x/mod v0.11.0
+ golang.org/x/sync v0.2.0
+ golang.org/x/text v0.12.0
+ google.golang.org/grpc v1.56.2
+ gopkg.in/natefinch/lumberjack.v2 v2.0.0
gopkg.in/yaml.v2 v2.4.0
gopkg.in/yaml.v3 v3.0.1
)
require (
- cloud.google.com/go v0.110.0 // indirect
- cloud.google.com/go/compute v1.18.0 // indirect
+ cloud.google.com/go v0.110.4 // indirect
+ cloud.google.com/go/compute v1.20.1 // indirect
cloud.google.com/go/compute/metadata v0.2.3 // indirect
- cloud.google.com/go/iam v0.12.0 // indirect
- cloud.google.com/go/storage v1.29.0 // indirect
+ cloud.google.com/go/iam v1.1.0 // indirect
+ cloud.google.com/go/storage v1.30.1 // indirect
+ contrib.go.opencensus.io/exporter/prometheus v0.4.2 // indirect
cosmossdk.io/core v0.5.1 // indirect
- cosmossdk.io/depinject v1.0.0-alpha.3 // indirect
+ cosmossdk.io/depinject v1.0.0-alpha.4 // indirect
+ cosmossdk.io/log v1.2.1 // indirect
cosmossdk.io/tools/rosetta v0.2.1 // indirect
filippo.io/edwards25519 v1.0.0 // indirect
github.com/99designs/go-keychain v0.0.0-20191008050251-8e49817e8af4 // indirect
- github.com/99designs/keyring v1.2.1 // indirect
- github.com/ChainSafe/go-schnorrkel v0.0.0-20200405005733-88cbf1b4c40d // indirect
+ github.com/99designs/keyring v1.2.2 // indirect
+ github.com/ChainSafe/go-schnorrkel v1.0.0 // indirect
+ github.com/CosmWasm/wasmvm v1.2.3 // indirect
github.com/armon/go-metrics v0.4.1 // indirect
github.com/aws/aws-sdk-go v1.44.203 // indirect
github.com/benbjohnson/clock v1.3.0 // indirect
github.com/beorn7/perks v1.0.1 // indirect
github.com/bgentry/go-netrc v0.0.0-20140422174119-9fd32a8b3d3d // indirect
github.com/bgentry/speakeasy v0.1.1-0.20220910012023-760eaf8b6816 // indirect
+ github.com/bshuster-repo/logrus-logstash-hook v0.4.1 // indirect
github.com/btcsuite/btcd/btcec/v2 v2.3.2 // indirect
github.com/btcsuite/btcd/chaincfg/chainhash v1.0.1 // indirect
github.com/cenkalti/backoff/v4 v4.1.3 // indirect
github.com/cespare/xxhash v1.1.0 // indirect
github.com/cespare/xxhash/v2 v2.2.0 // indirect
github.com/chzyer/readline v1.5.1 // indirect
+ github.com/cockroachdb/apd/v2 v2.0.2 // indirect
+ github.com/cockroachdb/errors v1.10.0 // indirect
+ github.com/cockroachdb/logtags v0.0.0-20230118201751-21c54148d20b // indirect
+ github.com/cockroachdb/redact v1.1.5 // indirect
github.com/coinbase/rosetta-sdk-go/types v1.0.0 // indirect
- github.com/cometbft/cometbft-db v0.7.0 // indirect
+ github.com/cometbft/cometbft-db v0.8.0 // indirect
github.com/confio/ics23/go v0.9.0 // indirect
github.com/cosmos/btcutil v1.0.5 // indirect
github.com/cosmos/gogogateway v1.2.0 // indirect
- github.com/cosmos/iavl v0.20.0-alpha4 // indirect
- github.com/cosmos/ics23/go v0.9.1-0.20221207100636-b1abd8678aab // indirect
+ github.com/cosmos/iavl v0.20.0 // indirect
github.com/cosmos/ledger-cosmos-go v0.12.2 // indirect
github.com/cosmos/rosetta-sdk-go v0.10.0 // indirect
github.com/creachadair/taskgroup v0.4.2 // indirect
@@ -80,36 +95,45 @@ require (
github.com/dgraph-io/badger/v2 v2.2007.4 // indirect
github.com/dgraph-io/ristretto v0.1.1 // indirect
github.com/dgryski/go-farm v0.0.0-20200201041132-a6ae2369ad13 // indirect
+ github.com/docker/distribution v2.8.1+incompatible // indirect
github.com/dustin/go-humanize v1.0.1 // indirect
github.com/dvsekhvalnov/jose2go v1.5.0 // indirect
+ github.com/evalphobia/logrus_fluent v0.5.4 // indirect
github.com/felixge/httpsnoop v1.0.2 // indirect
+ github.com/fluent/fluent-logger-golang v1.4.0 // indirect
github.com/fsnotify/fsnotify v1.6.0 // indirect
+ github.com/getsentry/sentry-go v0.23.0 // indirect
github.com/go-kit/kit v0.12.0 // indirect
github.com/go-kit/log v0.2.1 // indirect
github.com/go-logfmt/logfmt v0.6.0 // indirect
- github.com/go-stack/stack v1.8.0 // indirect
+ github.com/go-playground/locales v0.14.0 // indirect
+ github.com/go-playground/universal-translator v0.18.0 // indirect
+ github.com/go-stack/stack v1.8.1 // indirect
github.com/godbus/dbus v0.0.0-20190726142602-4481cbc300e2 // indirect
+ github.com/gofrs/uuid v4.3.0+incompatible // indirect
github.com/gogo/googleapis v1.4.1 // indirect
- github.com/golang/glog v1.0.0 // indirect
+ github.com/golang-jwt/jwt v3.2.2+incompatible // indirect
+ github.com/golang/glog v1.1.0 // indirect
github.com/golang/groupcache v0.0.0-20210331224755-41bb18bfe9da // indirect
github.com/golang/mock v1.6.0 // indirect
- github.com/golang/protobuf v1.5.2 // indirect
+ github.com/golang/protobuf v1.5.3 // indirect
github.com/golang/snappy v0.0.4 // indirect
github.com/google/btree v1.1.2 // indirect
github.com/google/go-querystring v1.1.0 // indirect
+ github.com/google/gofuzz v1.2.0 // indirect
github.com/google/orderedcode v0.0.1 // indirect
+ github.com/google/s2a-go v0.1.4 // indirect
github.com/google/uuid v1.3.0 // indirect
github.com/googleapis/enterprise-certificate-proxy v0.2.3 // indirect
- github.com/googleapis/gax-go/v2 v2.7.0 // indirect
+ github.com/googleapis/gax-go/v2 v2.11.0 // indirect
github.com/gorilla/handlers v1.5.1 // indirect
github.com/gorilla/mux v1.8.0 // indirect
- github.com/gorilla/websocket v1.5.0 // indirect
github.com/grpc-ecosystem/go-grpc-middleware v1.3.0 // indirect
github.com/gsterjov/go-libsecret v0.0.0-20161001094733-a6f4afe4910c // indirect
github.com/gtank/merlin v0.1.1 // indirect
github.com/gtank/ristretto255 v0.1.2 // indirect
github.com/hashicorp/go-cleanhttp v0.5.2 // indirect
- github.com/hashicorp/go-getter v1.7.0 // indirect
+ github.com/hashicorp/go-getter v1.7.1 // indirect
github.com/hashicorp/go-immutable-radix v1.3.1 // indirect
github.com/hashicorp/go-safetemp v1.0.0 // indirect
github.com/hashicorp/go-version v1.6.0 // indirect
@@ -122,62 +146,85 @@ require (
github.com/inconshreveable/mousetrap v1.1.0 // indirect
github.com/jmespath/go-jmespath v0.4.0 // indirect
github.com/jmhodges/levigo v1.0.0 // indirect
- github.com/json-iterator/go v1.1.12 // indirect
- github.com/klauspost/compress v1.15.15 // indirect
+ github.com/klauspost/compress v1.16.3 // indirect
+ github.com/kr/pretty v0.3.1 // indirect
+ github.com/kr/text v0.2.0 // indirect
+ github.com/labstack/echo/v4 v4.10.0 // indirect
+ github.com/labstack/gommon v0.4.0 // indirect
+ github.com/leodido/go-urn v1.2.1 // indirect
github.com/lib/pq v1.10.7 // indirect
github.com/libp2p/go-buffer-pool v0.1.0 // indirect
+ github.com/linxGnu/grocksdb v1.7.16 // indirect
github.com/magiconair/properties v1.8.7 // indirect
github.com/manifoldco/promptui v0.9.0 // indirect
- github.com/mattn/go-isatty v0.0.17 // indirect
- github.com/mattn/go-runewidth v0.0.13 // indirect
+ github.com/mattn/go-colorable v0.1.13 // indirect
+ github.com/mattn/go-isatty v0.0.19 // indirect
github.com/matttproud/golang_protobuf_extensions v1.0.4 // indirect
- github.com/mimoo/StrobeGo v0.0.0-20210601165009-122bf33a46e0 // indirect
+ github.com/mimoo/StrobeGo v0.0.0-20220103164710-9a04d6ca976b // indirect
github.com/minio/highwayhash v1.0.2 // indirect
github.com/mitchellh/go-homedir v1.1.0 // indirect
github.com/mitchellh/go-testing-interface v1.14.1 // indirect
github.com/mitchellh/mapstructure v1.5.0 // indirect
- github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd // indirect
- github.com/modern-go/reflect2 v1.0.2 // indirect
github.com/mtibben/percent v0.2.1 // indirect
- github.com/pelletier/go-toml/v2 v2.0.6 // indirect
- github.com/petermattis/goid v0.0.0-20221215004737-a150e88a970d // indirect
- github.com/pkg/errors v0.9.1 // indirect
+ github.com/opencontainers/go-digest v1.0.0 // indirect
+ github.com/pelletier/go-toml/v2 v2.0.8 // indirect
+ github.com/petermattis/goid v0.0.0-20230317030725-371a4b8eda08 // indirect
+ github.com/philhofer/fwd v1.0.0 // indirect
github.com/pmezard/go-difflib v1.0.0 // indirect
github.com/prometheus/client_model v0.3.0 // indirect
- github.com/prometheus/common v0.40.0 // indirect
+ github.com/prometheus/common v0.42.0 // indirect
github.com/prometheus/procfs v0.9.0 // indirect
+ github.com/prometheus/statsd_exporter v0.22.7 // indirect
github.com/rakyll/statik v0.1.7 // indirect
github.com/rcrowley/go-metrics v0.0.0-20201227073835-cf1acfcdf475 // indirect
+ github.com/rogpeppe/go-internal v1.11.0 // indirect
github.com/rs/cors v1.8.3 // indirect
+ github.com/rs/zerolog v1.30.0 // indirect
github.com/sasha-s/go-deadlock v0.3.1 // indirect
- github.com/spf13/afero v1.9.3 // indirect
- github.com/spf13/cast v1.5.0 // indirect
+ github.com/sirupsen/logrus v1.9.0 // indirect
+ github.com/spf13/afero v1.9.5 // indirect
+ github.com/spf13/cast v1.5.1 // indirect
github.com/spf13/jwalterweatherman v1.1.0 // indirect
github.com/spf13/pflag v1.0.5 // indirect
github.com/subosito/gotenv v1.4.2 // indirect
github.com/syndtr/goleveldb v1.0.1-0.20220721030215-126854af5e6d // indirect
- github.com/tecbot/gorocksdb v0.0.0-20191217155057-f0fad39f321c // indirect
github.com/tendermint/go-amino v0.16.0 // indirect
github.com/tidwall/btree v1.6.0 // indirect
+ github.com/tinylib/msgp v1.1.2 // indirect
github.com/tklauser/numcpus v0.4.0 // indirect
github.com/ulikunitz/xz v0.5.11 // indirect
+ github.com/valyala/bytebufferpool v1.0.0 // indirect
+ github.com/valyala/fasttemplate v1.2.2 // indirect
+ github.com/vmihailenco/msgpack/v4 v4.3.11 // indirect
+ github.com/vmihailenco/tagparser v0.1.1 // indirect
github.com/zondax/hid v0.9.1 // indirect
github.com/zondax/ledger-go v0.14.1 // indirect
- go.etcd.io/bbolt v1.3.6 // indirect
+ go.etcd.io/bbolt v1.3.7 // indirect
go.opencensus.io v0.24.0 // indirect
go.uber.org/atomic v1.10.0 // indirect
- golang.org/x/crypto v0.6.0 // indirect
- golang.org/x/exp v0.0.0-20230213192124-5e25df0256eb // indirect
- golang.org/x/net v0.7.0 // indirect
- golang.org/x/oauth2 v0.5.0 // indirect
- golang.org/x/sys v0.5.0 // indirect
+ golang.org/x/exp v0.0.0-20230711153332-06a737ee72cb // indirect
+ golang.org/x/net v0.12.0 // indirect
+ golang.org/x/oauth2 v0.8.0 // indirect
+ golang.org/x/sys v0.11.0 // indirect
+ golang.org/x/term v0.10.0 // indirect
+ golang.org/x/time v0.3.0 // indirect
golang.org/x/xerrors v0.0.0-20220907171357-04be3eba64a2 // indirect
- google.golang.org/api v0.110.0 // indirect
+ google.golang.org/api v0.126.0 // indirect
google.golang.org/appengine v1.6.7 // indirect
- google.golang.org/genproto v0.0.0-20230216225411-c8e22ba71e44 // indirect
- google.golang.org/protobuf v1.28.2-0.20230208135220-49eaa78c6c9c // indirect
+ google.golang.org/genproto v0.0.0-20230706204954-ccb25ca9f130 // indirect
+ google.golang.org/genproto/googleapis/api v0.0.0-20230629202037-9506855d4529 // indirect
+ google.golang.org/genproto/googleapis/rpc v0.0.0-20230711160842-782d3b101e98 // indirect
+ google.golang.org/protobuf v1.31.0 // indirect
+ gopkg.in/go-playground/validator.v9 v9.28.0 // indirect
gopkg.in/ini.v1 v1.67.0 // indirect
nhooyr.io/websocket v1.8.6 // indirect
pgregory.net/rapid v0.5.5 // indirect
sigs.k8s.io/yaml v1.3.0 // indirect
)
+
+replace (
+ // github.com/ChainSafe/go-schnorrkel => github.com/ChainSafe/go-schnorrkel v0.0.0-20200405005733-88cbf1b4c40d
+ github.com/CosmWasm/wasmd => github.com/cosmwasm/wasmd v0.40.0-rc.1.0.20230424144037-55647a1fd1f9
+ github.com/gogo/protobuf => github.com/regen-network/protobuf v1.3.3-alpha.regen.1
+ github.com/icon-project/IBC-Integration => github.com/icon-project/ibc-integration v0.0.0-20230717083940-67949d73b622
+)
diff --git a/go.sum b/go.sum
index 44a1947fa..be15eebfa 100644
--- a/go.sum
+++ b/go.sum
@@ -32,8 +32,8 @@ cloud.google.com/go v0.100.2/go.mod h1:4Xra9TjzAeYHrl5+oeLlzbM2k3mjVhZh4UqTZ//w9
cloud.google.com/go v0.102.0/go.mod h1:oWcCzKlqJ5zgHQt9YsaeTY9KzIvjyy0ArmiBUgpQ+nc=
cloud.google.com/go v0.102.1/go.mod h1:XZ77E9qnTEnrgEOvr4xzfdX5TRo7fB4T2F4O6+34hIU=
cloud.google.com/go v0.104.0/go.mod h1:OO6xxXdJyvuJPcEPBLN9BJPD+jep5G1+2U5B5gkRYtA=
-cloud.google.com/go v0.110.0 h1:Zc8gqp3+a9/Eyph2KDmcGaPtbKRIoqq4YTlL4NMD0Ys=
-cloud.google.com/go v0.110.0/go.mod h1:SJnCLqQ0FCFGSZMUNUf84MV3Aia54kn7pi8st7tMzaY=
+cloud.google.com/go v0.110.4 h1:1JYyxKMN9hd5dR2MYTPWkGUgcoxVVhg0LKNKEo0qvmk=
+cloud.google.com/go v0.110.4/go.mod h1:+EYjdK8e5RME/VY/qLCAtuyALQ9q67dvuum8i+H5xsI=
cloud.google.com/go/aiplatform v1.22.0/go.mod h1:ig5Nct50bZlzV6NvKaTwmplLLddFx0YReh9WfTO5jKw=
cloud.google.com/go/aiplatform v1.24.0/go.mod h1:67UUvRBKG6GTayHKV8DBv2RtR1t93YRu5B1P3x99mYY=
cloud.google.com/go/analytics v0.11.0/go.mod h1:DjEWCu41bVbYcKyvlws9Er60YE4a//bK6mnhWvQeFNI=
@@ -70,8 +70,8 @@ cloud.google.com/go/compute v1.6.0/go.mod h1:T29tfhtVbq1wvAPo0E3+7vhgmkOYeXjhFvz
cloud.google.com/go/compute v1.6.1/go.mod h1:g85FgpzFvNULZ+S8AYq87axRKuf2Kh7deLqV/jJ3thU=
cloud.google.com/go/compute v1.7.0/go.mod h1:435lt8av5oL9P3fv1OEzSbSUe+ybHXGMPQHHZWZxy9U=
cloud.google.com/go/compute v1.10.0/go.mod h1:ER5CLbMxl90o2jtNbGSbtfOpQKR0t15FOtRsugnLrlU=
-cloud.google.com/go/compute v1.18.0 h1:FEigFqoDbys2cvFkZ9Fjq4gnHBP55anJ0yQyau2f9oY=
-cloud.google.com/go/compute v1.18.0/go.mod h1:1X7yHxec2Ga+Ss6jPyjxRxpu2uu7PLgsOVXvgU0yacs=
+cloud.google.com/go/compute v1.20.1 h1:6aKEtlUiwEpJzM001l0yFkpXmUVXaN8W+fbkb2AZNbg=
+cloud.google.com/go/compute v1.20.1/go.mod h1:4tCnrn48xsqlwSAiLf1HXMQk8CONslYbdiEZc9FEIbM=
cloud.google.com/go/compute/metadata v0.2.3 h1:mg4jlk7mCAj6xXp9UJ4fjI9VUI5rubuGBW5aJ7UnBMY=
cloud.google.com/go/compute/metadata v0.2.3/go.mod h1:VAV5nSsACxMJvgaAuX6Pk2AawlZn8kiOGuCv6gTkwuA=
cloud.google.com/go/containeranalysis v0.5.1/go.mod h1:1D92jd8gRR/c0fGMlymRgxWD3Qw9C1ff6/T7mLgVL8I=
@@ -111,13 +111,12 @@ cloud.google.com/go/gkehub v0.10.0/go.mod h1:UIPwxI0DsrpsVoWpLB0stwKCP+WFVG9+y97
cloud.google.com/go/grafeas v0.2.0/go.mod h1:KhxgtF2hb0P191HlY5besjYm6MqTSTj3LSI+M+ByZHc=
cloud.google.com/go/iam v0.3.0/go.mod h1:XzJPvDayI+9zsASAFO68Hk07u3z+f+JrT2xXNdp4bnY=
cloud.google.com/go/iam v0.5.0/go.mod h1:wPU9Vt0P4UmCux7mqtRu6jcpPAb74cP1fh50J3QpkUc=
-cloud.google.com/go/iam v0.12.0 h1:DRtTY29b75ciH6Ov1PHb4/iat2CLCvrOm40Q0a6DFpE=
-cloud.google.com/go/iam v0.12.0/go.mod h1:knyHGviacl11zrtZUoDuYpDgLjvr28sLQaG0YB2GYAY=
+cloud.google.com/go/iam v1.1.0 h1:67gSqaPukx7O8WLLHMa0PNs3EBGd2eE4d+psbO/CO94=
+cloud.google.com/go/iam v1.1.0/go.mod h1:nxdHjaKfCr7fNYx/HJMM8LgiMugmveWlkatear5gVyk=
cloud.google.com/go/language v1.4.0/go.mod h1:F9dRpNFQmJbkaop6g0JhSBXCNlO90e1KWx5iDdxbWic=
cloud.google.com/go/language v1.6.0/go.mod h1:6dJ8t3B+lUYfStgls25GusK04NLh3eDLQnWM3mdEbhI=
cloud.google.com/go/lifesciences v0.5.0/go.mod h1:3oIKy8ycWGPUyZDR/8RNnTOYevhaMLqh5vLUXs9zvT8=
cloud.google.com/go/lifesciences v0.6.0/go.mod h1:ddj6tSX/7BOnhxCSd3ZcETvtNr8NZ6t/iPhY2Tyfu08=
-cloud.google.com/go/longrunning v0.3.0 h1:NjljC+FYPV3uh5/OwWT6pVU+doBqMg2x/rZlE+CamDs=
cloud.google.com/go/mediatranslation v0.5.0/go.mod h1:jGPUhGTybqsPQn91pNXw0xVHfuJ3leR1wj37oU3y1f4=
cloud.google.com/go/mediatranslation v0.6.0/go.mod h1:hHdBCTYNigsBxshbznuIMFNe5QXEowAuNmmC7h8pu5w=
cloud.google.com/go/memcache v1.4.0/go.mod h1:rTOfiGZtJX1AaFUrOgsMHX5kAzaTQ8azHiuDoTPzNsE=
@@ -175,8 +174,8 @@ cloud.google.com/go/storage v1.14.0/go.mod h1:GrKmX003DSIwi9o29oFT7YDnHYwZoctc3f
cloud.google.com/go/storage v1.22.1/go.mod h1:S8N1cAStu7BOeFfE8KAQzmyyLkK8p/vmRq6kuBTW58Y=
cloud.google.com/go/storage v1.23.0/go.mod h1:vOEEDNFnciUMhBeT6hsJIn3ieU5cFRmzeLgDvXzfIXc=
cloud.google.com/go/storage v1.27.0/go.mod h1:x9DOL8TK/ygDUMieqwfhdpQryTeEkhGKMi80i/iqR2s=
-cloud.google.com/go/storage v1.29.0 h1:6weCgzRvMg7lzuUurI4697AqIRPU1SvzHhynwpW31jI=
-cloud.google.com/go/storage v1.29.0/go.mod h1:4puEjyTKnku6gfKoTfNOU/W+a9JyuVNxjpS5GBrB8h4=
+cloud.google.com/go/storage v1.30.1 h1:uOdMxAs8HExqBlnLtnQyP0YkvbiDpdGShGKtx6U/oNM=
+cloud.google.com/go/storage v1.30.1/go.mod h1:NfxhC0UJE1aXSx7CIIbCf7y9HKT7BiccwkR7+P7gN8E=
cloud.google.com/go/talent v1.1.0/go.mod h1:Vl4pt9jiHKvOgF9KoZo6Kob9oV4lwd/ZD5Cto54zDRw=
cloud.google.com/go/talent v1.2.0/go.mod h1:MoNF9bhFQbiJ6eFD3uSsg0uBALw4n4gaCaEjBw9zo8g=
cloud.google.com/go/videointelligence v1.6.0/go.mod h1:w0DIDlVRKtwPCn/C4iwZIJdvC69yInhW0cfi+p546uU=
@@ -188,16 +187,20 @@ cloud.google.com/go/webrisk v1.4.0/go.mod h1:Hn8X6Zr+ziE2aNd8SliSDWpEnSS1u4R9+xX
cloud.google.com/go/webrisk v1.5.0/go.mod h1:iPG6fr52Tv7sGk0H6qUFzmL3HHZev1htXuWDEEsqMTg=
cloud.google.com/go/workflows v1.6.0/go.mod h1:6t9F5h/unJz41YqfBmqSASJSXccBLtD1Vwf+KmJENM0=
cloud.google.com/go/workflows v1.7.0/go.mod h1:JhSrZuVZWuiDfKEFxU0/F1PQjmpnpcoISEXH2bcHC3M=
+contrib.go.opencensus.io/exporter/prometheus v0.4.2 h1:sqfsYl5GIY/L570iT+l93ehxaWJs2/OwXtiWwew3oAg=
+contrib.go.opencensus.io/exporter/prometheus v0.4.2/go.mod h1:dvEHbiKmgvbr5pjaF9fpw1KeYcjrnC1J8B+JKjsZyRQ=
cosmossdk.io/api v0.3.1 h1:NNiOclKRR0AOlO4KIqeaG6PS6kswOMhHD0ir0SscNXE=
cosmossdk.io/api v0.3.1/go.mod h1:DfHfMkiNA2Uhy8fj0JJlOCYOBp4eWUUJ1te5zBGNyIw=
cosmossdk.io/core v0.5.1 h1:vQVtFrIYOQJDV3f7rw4pjjVqc1id4+mE0L9hHP66pyI=
cosmossdk.io/core v0.5.1/go.mod h1:KZtwHCLjcFuo0nmDc24Xy6CRNEL9Vl/MeimQ2aC7NLE=
-cosmossdk.io/depinject v1.0.0-alpha.3 h1:6evFIgj//Y3w09bqOUOzEpFj5tsxBqdc5CfkO7z+zfw=
-cosmossdk.io/depinject v1.0.0-alpha.3/go.mod h1:eRbcdQ7MRpIPEM5YUJh8k97nxHpYbc3sMUnEtt8HPWU=
-cosmossdk.io/errors v1.0.0-beta.7 h1:gypHW76pTQGVnHKo6QBkb4yFOJjC+sUGRc5Al3Odj1w=
-cosmossdk.io/errors v1.0.0-beta.7/go.mod h1:mz6FQMJRku4bY7aqS/Gwfcmr/ue91roMEKAmDUDpBfE=
-cosmossdk.io/math v1.0.0-beta.6.0.20230216172121-959ce49135e4 h1:/jnzJ9zFsL7qkV8LCQ1JH3dYHh2EsKZ3k8Mr6AqqiOA=
-cosmossdk.io/math v1.0.0-beta.6.0.20230216172121-959ce49135e4/go.mod h1:gUVtWwIzfSXqcOT+lBVz2jyjfua8DoBdzRsIyaUAT/8=
+cosmossdk.io/depinject v1.0.0-alpha.4 h1:PLNp8ZYAMPTUKyG9IK2hsbciDWqna2z1Wsl98okJopc=
+cosmossdk.io/depinject v1.0.0-alpha.4/go.mod h1:HeDk7IkR5ckZ3lMGs/o91AVUc7E596vMaOmslGFM3yU=
+cosmossdk.io/errors v1.0.0 h1:nxF07lmlBbB8NKQhtJ+sJm6ef5uV1XkvPXG2bUntb04=
+cosmossdk.io/errors v1.0.0/go.mod h1:+hJZLuhdDE0pYN8HkOrVNwrIOYvUGnn6+4fjnJs/oV0=
+cosmossdk.io/log v1.2.1 h1:Xc1GgTCicniwmMiKwDxUjO4eLhPxoVdI9vtMW8Ti/uk=
+cosmossdk.io/log v1.2.1/go.mod h1:GNSCc/6+DhFIj1aLn/j7Id7PaO8DzNylUZoOYBL9+I4=
+cosmossdk.io/math v1.1.2 h1:ORZetZCTyWkI5GlZ6CZS28fMHi83ZYf+A2vVnHNzZBM=
+cosmossdk.io/math v1.1.2/go.mod h1:l2Gnda87F0su8a/7FEKJfFdJrM0JZRXQaohlgJeyQh0=
cosmossdk.io/tools/rosetta v0.2.1 h1:ddOMatOH+pbxWbrGJKRAawdBkPYLfKXutK9IETnjYxw=
cosmossdk.io/tools/rosetta v0.2.1/go.mod h1:Pqdc1FdvkNV3LcNIkYWt2RQY6IP1ge6YWZk8MhhO9Hw=
dmitri.shuralyov.com/gpu/mtl v0.0.0-20190408044501-666a987793e9/go.mod h1:H6x//7gZCb22OMCxBHrMx7a5I7Hp++hsVxbQ4BYO7hU=
@@ -205,13 +208,16 @@ filippo.io/edwards25519 v1.0.0 h1:0wAIcmJUqRdI8IJ/3eGi5/HwXZWPujYXXlkrQogz0Ek=
filippo.io/edwards25519 v1.0.0/go.mod h1:N1IkdkCkiLB6tki+MYJoSx2JTY9NUlxZE7eHn5EwJns=
github.com/99designs/go-keychain v0.0.0-20191008050251-8e49817e8af4 h1:/vQbFIOMbk2FiG/kXiLl8BRyzTWDw7gX/Hz7Dd5eDMs=
github.com/99designs/go-keychain v0.0.0-20191008050251-8e49817e8af4/go.mod h1:hN7oaIRCjzsZ2dE+yG5k+rsdt3qcwykqK6HVGcKwsw4=
-github.com/99designs/keyring v1.2.1 h1:tYLp1ULvO7i3fI5vE21ReQuj99QFSs7lGm0xWyJo87o=
-github.com/99designs/keyring v1.2.1/go.mod h1:fc+wB5KTk9wQ9sDx0kFXB3A0MaeGHM9AwRStKOQ5vOA=
+github.com/99designs/keyring v1.2.2 h1:pZd3neh/EmUzWONb35LxQfvuY7kiSXAq3HQd97+XBn0=
+github.com/99designs/keyring v1.2.2/go.mod h1:wes/FrByc8j7lFOAGLGSNEg8f/PaI3cgTBqhFkHUrPk=
github.com/Azure/go-ansiterm v0.0.0-20210617225240-d185dfc1b5a1 h1:UQHMgLO+TxOElx5B5HZ4hJQsoJ/PvUvKRhJHDQXO8P8=
github.com/BurntSushi/toml v0.3.1/go.mod h1:xHWCNGjB5oqiDr8zfno3MHue2Ht5sIBksp03qcyfWMU=
+github.com/BurntSushi/toml v1.2.1 h1:9F2/+DoOYIOksmaJFPw1tGFy1eDnIJXg+UHjuD8lTak=
github.com/BurntSushi/xgb v0.0.0-20160522181843-27f122750802/go.mod h1:IVnqGOEym/WlBOVXweHU+Q+/VP0lqqI8lqeDx9IjBqo=
-github.com/ChainSafe/go-schnorrkel v0.0.0-20200405005733-88cbf1b4c40d h1:nalkkPQcITbvhmL4+C4cKA87NW0tfm3Kl9VXRoPywFg=
-github.com/ChainSafe/go-schnorrkel v0.0.0-20200405005733-88cbf1b4c40d/go.mod h1:URdX5+vg25ts3aCh8H5IFZybJYKWhJHYMTnf+ULtoC4=
+github.com/ChainSafe/go-schnorrkel v1.0.0 h1:3aDA67lAykLaG1y3AOjs88dMxC88PgUuHRrLeDnvGIM=
+github.com/ChainSafe/go-schnorrkel v1.0.0/go.mod h1:dpzHYVxLZcp8pjlV+O+UR8K0Hp/z7vcchBSbMBEhCw4=
+github.com/CosmWasm/wasmvm v1.2.3 h1:OKYlobwmVGbl0eSn0mXoAAjE5hIuXnQCLPjbNd91sVY=
+github.com/CosmWasm/wasmvm v1.2.3/go.mod h1:vW/E3h8j9xBQs9bCoijDuawKo9kCtxOaS8N8J7KFtkc=
github.com/DataDog/datadog-go v3.2.0+incompatible/go.mod h1:LButxg5PwREeZtORoXG3tL4fMGNddJ+vMq1mwgfaqoQ=
github.com/Knetic/govaluate v3.0.1-0.20171022003610-9aa49832a739+incompatible/go.mod h1:r7JcOSlj0wfOMncg0iLm8Leh48TZaKVeNIfJntJ2wa0=
github.com/Microsoft/go-winio v0.6.0 h1:slsWYD/zyx7lCXoZVlvQrj0hPTM1HI4+v1sIda2yDvg=
@@ -227,12 +233,12 @@ github.com/VividCortex/gohistogram v1.0.0/go.mod h1:Pf5mBqqDxYaXu3hDrrU+w6nw50o/
github.com/adlio/schema v1.3.3 h1:oBJn8I02PyTB466pZO1UZEn1TV5XLlifBSyMrmHl/1I=
github.com/aead/siphash v1.0.1/go.mod h1:Nywa3cDsYNNK3gaciGTWPwHt0wlpNV15vwmswBAUSII=
github.com/afex/hystrix-go v0.0.0-20180502004556-fa1af6a1f4f5/go.mod h1:SkGFH1ia65gfNATL8TAiHDNxPzPdmEL5uirI2Uyuz6c=
-github.com/alecthomas/participle/v2 v2.0.0-alpha7 h1:cK4vjj0VSgb3lN1nuKA5F7dw+1s1pWBe5bx7nNCnN+c=
github.com/alecthomas/template v0.0.0-20160405071501-a0175ee3bccc/go.mod h1:LOuyumcjzFXgccqObfd/Ljyb9UuFJ6TxHnclSeseNhc=
github.com/alecthomas/template v0.0.0-20190718012654-fb15b899a751/go.mod h1:LOuyumcjzFXgccqObfd/Ljyb9UuFJ6TxHnclSeseNhc=
github.com/alecthomas/units v0.0.0-20151022065526-2efee857e7cf/go.mod h1:ybxpYRFXyAe+OPACYpWeL0wqObRcbAqCMya13uyzqw0=
github.com/alecthomas/units v0.0.0-20190717042225-c3de453c63f4/go.mod h1:ybxpYRFXyAe+OPACYpWeL0wqObRcbAqCMya13uyzqw0=
github.com/alecthomas/units v0.0.0-20190924025748-f65c72e2690d/go.mod h1:rBZYJk541a8SKzHPHnH3zbiI+7dagKZ0cgpgrD7Fyho=
+github.com/alecthomas/units v0.0.0-20211218093645-b94a6e3cc137/go.mod h1:OMCwj8VM1Kc9e19TLln2VL61YJF0x1XFtfdL4JdbSyE=
github.com/antihax/optional v1.0.0/go.mod h1:uupD/76wgC+ih3iEmQUL+0Ugr19nfwCT1kdvxnR2qWY=
github.com/apache/thrift v0.12.0/go.mod h1:cp2SuWMxlEZw2r+iP2GNCdIi4C1qmUzdZFSVb+bacwQ=
github.com/apache/thrift v0.13.0/go.mod h1:cp2SuWMxlEZw2r+iP2GNCdIi4C1qmUzdZFSVb+bacwQ=
@@ -243,8 +249,8 @@ github.com/armon/go-metrics v0.4.1 h1:hR91U9KYmb6bLBYLQjyM+3j+rcd/UhE+G78SFnF8gJ
github.com/armon/go-metrics v0.4.1/go.mod h1:E6amYzXo6aW1tqzoZGT755KkbgrJsSdpwZ+3JqfkOG4=
github.com/armon/go-radix v0.0.0-20180808171621-7fddfc383310/go.mod h1:ufUuZ+zHj4x4TnLV4JWEpy2hxWSpsRywHrMgIH9cCH8=
github.com/aryann/difflib v0.0.0-20170710044230-e206f873d14a/go.mod h1:DAHtR1m6lCRdSC2Tm3DSWRPvIPr6xNKyeHdqDQSQT+A=
-github.com/avast/retry-go/v4 v4.3.2 h1:x4sTEu3jSwr7zNjya8NTdIN+U88u/jtO/q3OupBoDtM=
-github.com/avast/retry-go/v4 v4.3.2/go.mod h1:rg6XFaiuFYII0Xu3RDbZQkxCofFwruZKW8oEF1jpWiU=
+github.com/avast/retry-go/v4 v4.3.3 h1:G56Bp6mU0b5HE1SkaoVjscZjlQb0oy4mezwY/cGH19w=
+github.com/avast/retry-go/v4 v4.3.3/go.mod h1:rg6XFaiuFYII0Xu3RDbZQkxCofFwruZKW8oEF1jpWiU=
github.com/aws/aws-lambda-go v1.13.3/go.mod h1:4UKl9IzQMoD+QF79YdCuzCwp8VbmG4VAQwij/eHl5CU=
github.com/aws/aws-sdk-go v1.27.0/go.mod h1:KmX6BPdI08NWTb3/sm4ZGu5ShLoqVDhKgpiN924inxo=
github.com/aws/aws-sdk-go v1.44.122/go.mod h1:y4AeaBuwd2Lk+GepC1E9v0qOiTws0MIWAX4oIKwKHZo=
@@ -262,23 +268,35 @@ github.com/bgentry/go-netrc v0.0.0-20140422174119-9fd32a8b3d3d/go.mod h1:6QX/PXZ
github.com/bgentry/speakeasy v0.1.0/go.mod h1:+zsyZBPWlz7T6j88CTgSN5bM796AkVf0kBD4zp0CCIs=
github.com/bgentry/speakeasy v0.1.1-0.20220910012023-760eaf8b6816 h1:41iFGWnSlI2gVpmOtVTJZNodLdLQLn/KsJqFvXwnd/s=
github.com/bgentry/speakeasy v0.1.1-0.20220910012023-760eaf8b6816/go.mod h1:+zsyZBPWlz7T6j88CTgSN5bM796AkVf0kBD4zp0CCIs=
+github.com/bmizerany/assert v0.0.0-20160611221934-b7ed37b82869 h1:DDGfHa7BWjL4YnC6+E63dPcxHo2sUxDIu8g3QgEJdRY=
+github.com/bshuster-repo/logrus-logstash-hook v0.4.1 h1:pgAtgj+A31JBVtEHu2uHuEx0n+2ukqUJnS2vVe5pQNA=
+github.com/bshuster-repo/logrus-logstash-hook v0.4.1/go.mod h1:zsTqEiSzDgAa/8GZR7E1qaXrhYNDKBYy5/dWPTIflbk=
github.com/btcsuite/btcd v0.20.1-beta/go.mod h1:wVuoA8VJLEcwgqHBwHmzLRazpKxTv13Px/pDuV7OomQ=
-github.com/btcsuite/btcd v0.22.2 h1:vBZ+lGGd1XubpOWO67ITJpAEsICWhA0YzqkcpkgNBfo=
-github.com/btcsuite/btcd v0.22.2/go.mod h1:wqgTSL29+50LRkmOVknEdmt8ZojIzhuWvgu/iptuN7Y=
+github.com/btcsuite/btcd v0.22.0-beta.0.20220111032746-97732e52810c/go.mod h1:tjmYdS6MLJ5/s0Fj4DbLgSbDHbEqLJrtnHecBFkdz5M=
+github.com/btcsuite/btcd v0.23.0/go.mod h1:0QJIIN1wwIXF/3G/m87gIwGniDMDQqjVn4SZgnFpsYY=
+github.com/btcsuite/btcd v0.23.4 h1:IzV6qqkfwbItOS/sg/aDfPDsjPP8twrCOE2R93hxMlQ=
+github.com/btcsuite/btcd v0.23.4/go.mod h1:0QJIIN1wwIXF/3G/m87gIwGniDMDQqjVn4SZgnFpsYY=
+github.com/btcsuite/btcd/btcec/v2 v2.1.0/go.mod h1:2VzYrv4Gm4apmbVVsSq5bqf1Ec8v56E48Vt0Y/umPgA=
+github.com/btcsuite/btcd/btcec/v2 v2.1.3/go.mod h1:ctjw4H1kknNJmRN4iP1R7bTQ+v3GJkZBd6mui8ZsAZE=
github.com/btcsuite/btcd/btcec/v2 v2.3.2 h1:5n0X6hX0Zk+6omWcihdYvdAlGf2DfasC0GMf7DClJ3U=
github.com/btcsuite/btcd/btcec/v2 v2.3.2/go.mod h1:zYzJ8etWJQIv1Ogk7OzpWjowwOdXY1W/17j2MW85J04=
-github.com/btcsuite/btcd/btcutil v1.1.2 h1:XLMbX8JQEiwMcYft2EGi8zPUkoa0abKIU6/BJSRsjzQ=
+github.com/btcsuite/btcd/btcutil v1.0.0/go.mod h1:Uoxwv0pqYWhD//tfTiipkxNfdhG9UrLwaeswfjfdF0A=
+github.com/btcsuite/btcd/btcutil v1.1.0/go.mod h1:5OapHB7A2hBBWLm48mmw4MOHNJCcUBTwmWH/0Jn8VHE=
+github.com/btcsuite/btcd/btcutil v1.1.3 h1:xfbtw8lwpp0G6NwSHb+UE67ryTFHJAiNuipusjXSohQ=
+github.com/btcsuite/btcd/btcutil v1.1.3/go.mod h1:UR7dsSJzJUfMmFiiLlIrMq1lS9jh9EdCV7FStZSnpi0=
+github.com/btcsuite/btcd/chaincfg/chainhash v1.0.0/go.mod h1:7SFka0XMvUgj3hfZtydOrQY2mwhPclbT2snogU7SQQc=
github.com/btcsuite/btcd/chaincfg/chainhash v1.0.1 h1:q0rUy8C/TYNBQS1+CGKw68tLOFYSNEs0TFnxxnS9+4U=
github.com/btcsuite/btcd/chaincfg/chainhash v1.0.1/go.mod h1:7SFka0XMvUgj3hfZtydOrQY2mwhPclbT2snogU7SQQc=
github.com/btcsuite/btclog v0.0.0-20170628155309-84c8d2346e9f/go.mod h1:TdznJufoqS23FtqVCzL0ZqgP5MqXbb4fg/WgDys70nA=
github.com/btcsuite/btcutil v0.0.0-20190425235716-9e5f4b9a998d/go.mod h1:+5NJ2+qvTyV9exUAL/rxXi3DcLg2Ts+ymUAY5y4NvMg=
-github.com/btcsuite/btcutil v1.0.3-0.20201208143702-a53e38424cce h1:YtWJF7RHm2pYCvA5t0RPmAaLUhREsKuKd+SLhxFbFeQ=
-github.com/btcsuite/btcutil v1.0.3-0.20201208143702-a53e38424cce/go.mod h1:0DVlHczLPewLcPGEIeUEzfOJhqGPQ0mJJRDBtD307+o=
github.com/btcsuite/go-socks v0.0.0-20170105172521-4720035b7bfd/go.mod h1:HHNXQzUsZCxOoE+CPiyCTO6x34Zs86zZUiwtpXoGdtg=
github.com/btcsuite/goleveldb v0.0.0-20160330041536-7834afc9e8cd/go.mod h1:F+uVaaLLH7j4eDXPRvw78tMflu7Ie2bzYOH4Y8rRKBY=
+github.com/btcsuite/goleveldb v1.0.0/go.mod h1:QiK9vBlgftBg6rWQIj6wFzbPfRjiykIEhBH4obrXJ/I=
github.com/btcsuite/snappy-go v0.0.0-20151229074030-0bdef8d06723/go.mod h1:8woku9dyThutzjeg+3xrA5iCpBRH8XEEg3lh6TiUghc=
+github.com/btcsuite/snappy-go v1.0.0/go.mod h1:8woku9dyThutzjeg+3xrA5iCpBRH8XEEg3lh6TiUghc=
github.com/btcsuite/websocket v0.0.0-20150119174127-31079b680792/go.mod h1:ghJtEyQwv5/p4Mg4C0fgbePVuGr935/5ddU9Z3TmDRY=
github.com/btcsuite/winsvc v1.0.0/go.mod h1:jsenWakMcC0zFBFurPLEAyrnc/teJEM1O46fmI40EZs=
+github.com/bufbuild/protocompile v0.4.0 h1:LbFKd2XowZvQ/kajzguUp2DC9UEIQhIq77fZZlaQsNA=
github.com/casbin/casbin/v2 v2.1.2/go.mod h1:YcPU1XXisHhLzuxH9coDNf2FbKpjGlbCg3n9yuLkIJQ=
github.com/cenkalti/backoff v2.2.1+incompatible h1:tNowT99t7UNflLxfYYSlKYsBpXdEet03Pg2g16Swow4=
github.com/cenkalti/backoff v2.2.1+incompatible/go.mod h1:90ReRw6GdpyfrHakVjL/QHaoyV4aDUVVkXQJJJ3NXXM=
@@ -289,6 +307,7 @@ github.com/census-instrumentation/opencensus-proto v0.2.1/go.mod h1:f6KPmirojxKA
github.com/cespare/xxhash v1.1.0 h1:a6HrQnmkObjyL+Gs60czilIUGqrzKutQD6XZog3p+ko=
github.com/cespare/xxhash v1.1.0/go.mod h1:XrSqR1VqqWfGrhpAt58auRo0WTKS1nRRg3ghfAqPWnc=
github.com/cespare/xxhash/v2 v2.1.1/go.mod h1:VGX0DQ3Q6kWi7AoAeZDth3/j3BFtOZR5XLFGgcrjCOs=
+github.com/cespare/xxhash/v2 v2.1.2/go.mod h1:VGX0DQ3Q6kWi7AoAeZDth3/j3BFtOZR5XLFGgcrjCOs=
github.com/cespare/xxhash/v2 v2.2.0 h1:DC2CZ1Ep5Y4k3ZQ899DldepgrayRUGE6BBZ/cd9Cj44=
github.com/cespare/xxhash/v2 v2.2.0/go.mod h1:VGX0DQ3Q6kWi7AoAeZDth3/j3BFtOZR5XLFGgcrjCOs=
github.com/cheggaaa/pb v1.0.27/go.mod h1:pQciLPpbU0oxA0h+VJYYLxO+XeDQb5pZijXscXHm81s=
@@ -315,15 +334,21 @@ github.com/cncf/xds/go v0.0.0-20210922020428-25de7278fc84/go.mod h1:eXthEFrGJvWH
github.com/cncf/xds/go v0.0.0-20211001041855-01bcc9b48dfe/go.mod h1:eXthEFrGJvWHgFFCl3hGmgk+/aYT6PnTQLykKQRLhEs=
github.com/cncf/xds/go v0.0.0-20211011173535-cb28da3451f1/go.mod h1:eXthEFrGJvWHgFFCl3hGmgk+/aYT6PnTQLykKQRLhEs=
github.com/cockroachdb/apd/v2 v2.0.2 h1:weh8u7Cneje73dDh+2tEVLUvyBc89iwepWCD8b8034E=
-github.com/cockroachdb/apd/v3 v3.1.0 h1:MK3Ow7LH0W8zkd5GMKA1PvS9qG3bWFI95WaVNfyZJ/w=
+github.com/cockroachdb/apd/v2 v2.0.2/go.mod h1:DDxRlzC2lo3/vSlmSoS7JkqbbrARPuFOGr0B9pvN3Gw=
github.com/cockroachdb/datadriven v0.0.0-20190809214429-80d97fb3cbaa/go.mod h1:zn76sxSg3SzpJ0PPJaLDCu+Bu0Lg3sKTORVIj19EIF8=
+github.com/cockroachdb/errors v1.10.0 h1:lfxS8zZz1+OjtV4MtNWgboi/W5tyLEB6VQZBXN+0VUU=
+github.com/cockroachdb/errors v1.10.0/go.mod h1:lknhIsEVQ9Ss/qKDBQS/UqFSvPQjOwNq2qyKAxtHRqE=
+github.com/cockroachdb/logtags v0.0.0-20230118201751-21c54148d20b h1:r6VH0faHjZeQy818SGhaone5OnYfxFR/+AzdY3sf5aE=
+github.com/cockroachdb/logtags v0.0.0-20230118201751-21c54148d20b/go.mod h1:Vz9DsVWQQhf3vs21MhPMZpMGSht7O/2vFW2xusFUVOs=
+github.com/cockroachdb/redact v1.1.5 h1:u1PMllDkdFfPWaNGMyLD1+so+aq3uUItthCFqzwPJ30=
+github.com/cockroachdb/redact v1.1.5/go.mod h1:BVNblN9mBWFyMyqK1k3AAiSxhvhfK2oOZZ2lK+dpvRg=
github.com/codahale/hdrhistogram v0.0.0-20161010025455-3a0bb77429bd/go.mod h1:sE/e/2PUdi/liOCUjSTXgM1o87ZssimdTWN964YiIeI=
github.com/coinbase/rosetta-sdk-go/types v1.0.0 h1:jpVIwLcPoOeCR6o1tU+Xv7r5bMONNbHU7MuEHboiFuA=
github.com/coinbase/rosetta-sdk-go/types v1.0.0/go.mod h1:eq7W2TMRH22GTW0N0beDnN931DW0/WOI1R2sdHNHG4c=
-github.com/cometbft/cometbft v0.37.0 h1:M005vBaSaugvYYmNZwJOopynQSjwLoDTwflnQ/I/eYk=
-github.com/cometbft/cometbft v0.37.0/go.mod h1:Y2MMMN//O5K4YKd8ze4r9jmk4Y7h0ajqILXbH5JQFVs=
-github.com/cometbft/cometbft-db v0.7.0 h1:uBjbrBx4QzU0zOEnU8KxoDl18dMNgDh+zZRUE0ucsbo=
-github.com/cometbft/cometbft-db v0.7.0/go.mod h1:yiKJIm2WKrt6x8Cyxtq9YTEcIMPcEe4XPxhgX59Fzf0=
+github.com/cometbft/cometbft v0.37.2 h1:XB0yyHGT0lwmJlFmM4+rsRnczPlHoAKFX6K8Zgc2/Jc=
+github.com/cometbft/cometbft v0.37.2/go.mod h1:Y2MMMN//O5K4YKd8ze4r9jmk4Y7h0ajqILXbH5JQFVs=
+github.com/cometbft/cometbft-db v0.8.0 h1:vUMDaH3ApkX8m0KZvOFFy9b5DZHBAjsnEuo9AKVZpjo=
+github.com/cometbft/cometbft-db v0.8.0/go.mod h1:6ASCP4pfhmrCBpfk01/9E1SI29nD3HfVHrY4PG8x5c0=
github.com/confio/ics23/go v0.9.0 h1:cWs+wdbS2KRPZezoaaj+qBleXgUk5WOQFMP3CQFGTr4=
github.com/confio/ics23/go v0.9.0/go.mod h1:4LPZ2NYqnYIVRklaozjNR1FScgDJ2s5Xrp+e/mYVRak=
github.com/containerd/continuity v0.3.0 h1:nisirsYROK15TAMVukJOUyGJjz4BNQJBVsNvAXZJ/eg=
@@ -331,39 +356,43 @@ github.com/coreos/etcd v3.3.10+incompatible/go.mod h1:uF7uidLiAD3TWHmW31ZFd/JWoc
github.com/coreos/go-etcd v2.0.0+incompatible/go.mod h1:Jez6KQU2B/sWsbdaef3ED8NzMklzPG4d5KIOhIy30Tk=
github.com/coreos/go-semver v0.2.0/go.mod h1:nnelYz7RCh+5ahJtPPxZlU+153eP4D4r3EedlOD2RNk=
github.com/coreos/go-systemd v0.0.0-20180511133405-39ca1b05acc7/go.mod h1:F5haX7vjVVG0kc13fIWeqUViNPyEJxv/OmvnBo0Yme4=
+github.com/coreos/go-systemd/v22 v22.5.0/go.mod h1:Y58oyj3AT4RCenI/lSvhwexgC+NSVTIJ3seZv2GcEnc=
github.com/coreos/pkg v0.0.0-20160727233714-3ac0863d7acf/go.mod h1:E3G3o1h8I7cfcXa63jLwjI0eiQQMgzzUDFVpN/nH/eA=
github.com/cosmos/btcutil v1.0.5 h1:t+ZFcX77LpKtDBhjucvnOH8C2l2ioGsBNEQ3jef8xFk=
github.com/cosmos/btcutil v1.0.5/go.mod h1:IyB7iuqZMJlthe2tkIFL33xPyzbFYP0XVdS8P5lUPis=
github.com/cosmos/cosmos-proto v1.0.0-beta.2 h1:X3OKvWgK9Gsejo0F1qs5l8Qn6xJV/AzgIWR2wZ8Nua8=
github.com/cosmos/cosmos-proto v1.0.0-beta.2/go.mod h1:+XRCLJ14pr5HFEHIUcn51IKXD1Fy3rkEQqt4WqmN4V0=
-github.com/cosmos/cosmos-sdk v0.47.0-rc3 h1:MMun/+mMpzise9d85csTp+kGkhLCkjJLwLK0urp0Bcs=
-github.com/cosmos/cosmos-sdk v0.47.0-rc3/go.mod h1:GlXjIIIsIZAD5CPqm7FHtr3v5/anE9eXWDjSWdNmznw=
+github.com/cosmos/cosmos-sdk v0.47.5 h1:n1+WjP/VM/gAEOx3TqU2/Ny734rj/MX1kpUnn7zVJP8=
+github.com/cosmos/cosmos-sdk v0.47.5/go.mod h1:EHwCeN9IXonsjKcjpS12MqeStdZvIdxt3VYXhus3G3c=
github.com/cosmos/go-bip39 v0.0.0-20180819234021-555e2067c45d/go.mod h1:tSxLoYXyBmiFeKpvmq4dzayMdCjCnu8uqmCysIGBT2Y=
github.com/cosmos/go-bip39 v1.0.0 h1:pcomnQdrdH22njcAatO0yWojsUnCO3y2tNoV1cb6hHY=
github.com/cosmos/go-bip39 v1.0.0/go.mod h1:RNJv0H/pOIVgxw6KS7QeX2a0Uo0aKUlfhZ4xuwvCdJw=
github.com/cosmos/gogogateway v1.2.0 h1:Ae/OivNhp8DqBi/sh2A8a1D0y638GpL3tkmLQAiKxTE=
github.com/cosmos/gogogateway v1.2.0/go.mod h1:iQpLkGWxYcnCdz5iAdLcRBSw3h7NXeOkZ4GUkT+tbFI=
github.com/cosmos/gogoproto v1.4.2/go.mod h1:cLxOsn1ljAHSV527CHOtaIP91kK6cCrZETRBrkzItWU=
-github.com/cosmos/gogoproto v1.4.6 h1:Ee7z15dWJaGlgM2rWrK8N2IX7PQcuccu8oG68jp5RL4=
-github.com/cosmos/gogoproto v1.4.6/go.mod h1:VS/ASYmPgv6zkPKLjR9EB91lwbLHOzaGCirmKKhncfI=
-github.com/cosmos/iavl v0.20.0-alpha4 h1:49SZoxNwah5nqbVE1da8BAhenC7HMSVOTZ0XKVhZpOE=
-github.com/cosmos/iavl v0.20.0-alpha4/go.mod h1:WO7FyvaZJoH65+HFOsDir7xU9FWk2w9cHXNW1XHcl7A=
-github.com/cosmos/ibc-go/v7 v7.0.0-rc1 h1:+HokO9GDqWNmjKSLGSC1WjcqjOdDIeSmNGuXQFSHMQE=
-github.com/cosmos/ibc-go/v7 v7.0.0-rc1/go.mod h1:wpKGb+lqAnxwThgS3LoCPgDEFNAPVX+1YIQCAJcePcM=
-github.com/cosmos/ics23/go v0.9.1-0.20221207100636-b1abd8678aab h1:I9ialKTQo7248V827Bba4OuKPmk+FPzmTVHsLXaIJWw=
-github.com/cosmos/ics23/go v0.9.1-0.20221207100636-b1abd8678aab/go.mod h1:2CwqasX5dSD7Hbp/9b6lhK6BwoBDCBldx7gPKRukR60=
+github.com/cosmos/gogoproto v1.4.10 h1:QH/yT8X+c0F4ZDacDv3z+xE3WU1P1Z3wQoLMBRJoKuI=
+github.com/cosmos/gogoproto v1.4.10/go.mod h1:3aAZzeRWpAwr+SS/LLkICX2/kDFyaYVzckBDzygIxek=
+github.com/cosmos/iavl v0.20.0 h1:fTVznVlepH0KK8NyKq8w+U7c2L6jofa27aFX6YGlm38=
+github.com/cosmos/iavl v0.20.0/go.mod h1:WO7FyvaZJoH65+HFOsDir7xU9FWk2w9cHXNW1XHcl7A=
+github.com/cosmos/ibc-go/modules/capability v1.0.0-rc1 h1:BvSKnPFKxL+TTSLxGKwJN4x0ndCZj0yfXhSvmsQztSA=
+github.com/cosmos/ibc-go/modules/capability v1.0.0-rc1/go.mod h1:A+CxAQdn2j6ihDTbClpEEBdHthWgAUAcHbRAQPY8sl4=
+github.com/cosmos/ibc-go/v7 v7.3.0 h1:QtGeVMi/3JeLWuvEuC60sBHpAF40Oenx/y+bP8+wRRw=
+github.com/cosmos/ibc-go/v7 v7.3.0/go.mod h1:mUmaHFXpXrEdcxfdXyau+utZf14pGKVUiXwYftRZZfQ=
+github.com/cosmos/ics23/go v0.10.0 h1:iXqLLgp2Lp+EdpIuwXTYIQU+AiHj9mOC2X9ab++bZDM=
+github.com/cosmos/ics23/go v0.10.0/go.mod h1:ZfJSmng/TBNTBkFemHHHj5YY7VAU/MBU980F4VU1NG0=
github.com/cosmos/ledger-cosmos-go v0.12.2 h1:/XYaBlE2BJxtvpkHiBm97gFGSGmYGKunKyF3nNqAXZA=
github.com/cosmos/ledger-cosmos-go v0.12.2/go.mod h1:ZcqYgnfNJ6lAXe4HPtWgarNEY+B74i+2/8MhZw4ziiI=
github.com/cosmos/rosetta-sdk-go v0.10.0 h1:E5RhTruuoA7KTIXUcMicL76cffyeoyvNybzUGSKFTcM=
github.com/cosmos/rosetta-sdk-go v0.10.0/go.mod h1:SImAZkb96YbwvoRkzSMQB6noNJXFgWl/ENIznEoYQI4=
+github.com/cosmwasm/wasmd v0.40.0-rc.1.0.20230424144037-55647a1fd1f9 h1:JCkKi1yHPIlBAKAeKQrBJIWmWAwScA1z9mLd3vVQGX0=
+github.com/cosmwasm/wasmd v0.40.0-rc.1.0.20230424144037-55647a1fd1f9/go.mod h1:uacdue6EGn9JA1TqBNHB3iCe4PCIChuFT23AzIl2VME=
github.com/cpuguy83/go-md2man v1.0.10/go.mod h1:SmD6nW6nTyfqj6ABTjUi3V3JVMnlJmwcJI5acqYI6dE=
github.com/cpuguy83/go-md2man/v2 v2.0.0-20190314233015-f79a8a8ca69d/go.mod h1:maD7wRr/U5Z6m/iR4s+kqSMx2CaBsrgA7czyZG/E6dU=
github.com/cpuguy83/go-md2man/v2 v2.0.2/go.mod h1:tgQtvFlXSQOSOSIRvRPT7W67SCa46tRHOmNcaadrF8o=
github.com/creachadair/taskgroup v0.4.2 h1:jsBLdAJE42asreGss2xZGZ8fJra7WtwnHWeJFxv2Li8=
github.com/creachadair/taskgroup v0.4.2/go.mod h1:qiXUOSrbwAY3u0JPGTzObbE3yf9hcXHDKBZ2ZjpCbgM=
github.com/creack/pty v1.1.7/go.mod h1:lj5s0c3V2DBrqTV7llrYr5NG6My20zk30Fl46Y7DoTY=
-github.com/cucumber/common/gherkin/go/v22 v22.0.0 h1:4K8NqptbvdOrjL9DEea6HFjSpbdT9+Q5kgLpmmsHYl0=
-github.com/cucumber/common/messages/go/v17 v17.1.1 h1:RNqopvIFyLWnKv0LfATh34SWBhXeoFTJnSrgm9cT/Ts=
+github.com/creack/pty v1.1.9/go.mod h1:oKZEueFk5CKHvIhNR5MUki03XCEU+Q6VDXinZuGJ33E=
github.com/danieljoos/wincred v1.1.2 h1:QLdCxFs1/Yl4zduvBdcHB8goaYk9RARS2SgLLRuAyr0=
github.com/danieljoos/wincred v1.1.2/go.mod h1:GijpziifJoIBfYh+S7BbkdUTU4LfM+QnGqR5Vl2tAx0=
github.com/davecgh/go-spew v0.0.0-20171005155431-ecdeabc65495/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
@@ -371,8 +400,11 @@ github.com/davecgh/go-spew v1.1.0/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSs
github.com/davecgh/go-spew v1.1.1 h1:vj9j/u1bqnvCEfJOwUhtlOARqs3+rkHYY13jYWTU97c=
github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
github.com/decred/dcrd/crypto/blake256 v1.0.0 h1:/8DMNYp9SGi5f0w7uCm6d6M4OU2rGFK09Y2A4Xv7EE0=
+github.com/decred/dcrd/crypto/blake256 v1.0.0/go.mod h1:sQl2p6Y26YV+ZOcSTP6thNdn47hh8kt6rqSlvmrXFAc=
+github.com/decred/dcrd/dcrec/secp256k1/v4 v4.0.1/go.mod h1:hyedUtir6IdtD/7lIxGeCxkaw7y45JueMRL4DIyJDKs=
github.com/decred/dcrd/dcrec/secp256k1/v4 v4.1.0 h1:HbphB4TFFXpv7MNrT52FGrrgVXF1owhMVTHFZIlnvd4=
github.com/decred/dcrd/dcrec/secp256k1/v4 v4.1.0/go.mod h1:DZGJHZMqrU4JJqFAWUS2UO1+lbSKsdiOoYi9Zzey7Fc=
+github.com/decred/dcrd/lru v1.0.0/go.mod h1:mxKOwFd7lFjN2GZYsiz/ecgqR6kkYAl+0pz0tEMk218=
github.com/desertbit/timer v0.0.0-20180107155436-c41aec40b27f h1:U5y3Y5UE0w7amNe7Z5G/twsBW0KEalRQXZzf8ufSh9I=
github.com/desertbit/timer v0.0.0-20180107155436-c41aec40b27f/go.mod h1:xH/i4TFMt8koVQZ6WFms69WAsDWr2XsYL3Hkl7jkoLE=
github.com/dgraph-io/badger/v2 v2.2007.4 h1:TRWBQg8UrlUhaFdco01nO2uXwzKS7zd+HVdwV/GHc4o=
@@ -384,6 +416,8 @@ github.com/dgrijalva/jwt-go v3.2.0+incompatible/go.mod h1:E3ru+11k8xSBh+hMPgOLZm
github.com/dgryski/go-farm v0.0.0-20190423205320-6a90982ecee2/go.mod h1:SqUrOPUnsFjfmXRMNPybcSiG0BgUW2AuFH8PAnS2iTw=
github.com/dgryski/go-farm v0.0.0-20200201041132-a6ae2369ad13 h1:fAjc9m62+UWV/WAFKLNi6ZS0675eEUC9y3AlwSbQu1Y=
github.com/dgryski/go-farm v0.0.0-20200201041132-a6ae2369ad13/go.mod h1:SqUrOPUnsFjfmXRMNPybcSiG0BgUW2AuFH8PAnS2iTw=
+github.com/docker/distribution v2.8.1+incompatible h1:Q50tZOPR6T/hjNsyc9g8/syEs6bk8XXApsHjKukMl68=
+github.com/docker/distribution v2.8.1+incompatible/go.mod h1:J2gT2udsDAN96Uj4KfcMRqY0/ypR+oyYUYmja8H+y+w=
github.com/docker/go-connections v0.4.0 h1:El9xVISelRB7BuFusrZozjnkIM5YnzCViNKohAFqRJQ=
github.com/docker/go-units v0.5.0 h1:69rxXcBk27SvSaaxTtLh/8llcHD8vYHT7WSdRZ/jvr4=
github.com/dustin/go-humanize v0.0.0-20171111073723-bb3d318650d4/go.mod h1:HtrtbFcZ19U5GC7JDqmcUSB87Iq5E25KnS6fMYU6eOk=
@@ -409,27 +443,31 @@ github.com/envoyproxy/go-control-plane v0.10.2-0.20220325020618-49ff273808a1/go.
github.com/envoyproxy/protoc-gen-validate v0.1.0/go.mod h1:iSmxcyjqTsJpI2R4NaDN7+kN2VEUnK/pcBlmesArF7c=
github.com/ethereum/go-ethereum v1.10.26 h1:i/7d9RBBwiXCEuyduBQzJw/mKmnvzsN14jqBmytw72s=
github.com/ethereum/go-ethereum v1.10.26/go.mod h1:EYFyF19u3ezGLD4RqOkLq+ZCXzYbLoNDdZlMt7kyKFg=
-github.com/facebookgo/ensure v0.0.0-20200202191622-63f1cf65ac4c h1:8ISkoahWXwZR41ois5lSJBSVw4D0OV19Ht/JSTzvSv0=
-github.com/facebookgo/stack v0.0.0-20160209184415-751773369052 h1:JWuenKqqX8nojtoVVWjGfOF9635RETekkoH6Cc9SX0A=
-github.com/facebookgo/subset v0.0.0-20200203212716-c811ad88dec4 h1:7HZCaLC5+BZpmbhCOZJ293Lz68O7PYrF2EzeiFMwCLk=
+github.com/evalphobia/logrus_fluent v0.5.4 h1:G4BSBTm7+L+oanWfFtA/A5Y3pvL2OMxviczyZPYO5xc=
+github.com/evalphobia/logrus_fluent v0.5.4/go.mod h1:hasyj+CXm3BDP1YhFk/rnTcjlegyqvkokV9A25cQsaA=
github.com/fatih/color v1.7.0/go.mod h1:Zm6kSWBoL9eyXnKyktHP6abPY2pDugNf5KwzbycvMj4=
github.com/felixge/httpsnoop v1.0.1/go.mod h1:m8KPJKqk1gH5J9DgRY2ASl2lWCfGKXixSwevea8zH2U=
github.com/felixge/httpsnoop v1.0.2 h1:+nS9g82KMXccJ/wp0zyRW9ZBHFETmMGtkk+2CTTrW4o=
github.com/felixge/httpsnoop v1.0.2/go.mod h1:m8KPJKqk1gH5J9DgRY2ASl2lWCfGKXixSwevea8zH2U=
+github.com/fluent/fluent-logger-golang v1.4.0 h1:uT1Lzz5yFV16YvDwWbjX6s3AYngnJz8byTCsMTIS0tU=
+github.com/fluent/fluent-logger-golang v1.4.0/go.mod h1:2/HCT/jTy78yGyeNGQLGQsjF3zzzAuy6Xlk6FCMV5eU=
github.com/fortytw2/leaktest v1.3.0 h1:u8491cBMTQ8ft8aeV+adlcytMZylmA5nnwwkRZjI8vw=
github.com/franela/goblin v0.0.0-20200105215937-c9ffbefa60db/go.mod h1:7dvUGVsVBjqR7JHJk0brhHOZYGmfBYOrK0ZhYMEtBr4=
github.com/franela/goreq v0.0.0-20171204163338-bcd34c9993f8/go.mod h1:ZhphrRTfi2rbfLwlschooIH4+wKKDR4Pdxhh+TRoA20=
-github.com/frankban/quicktest v1.14.3 h1:FJKSZTDHjyhriyC81FLQ0LY93eSai0ZyR/ZIkd3ZUKE=
+github.com/frankban/quicktest v1.14.4 h1:g2rn0vABPOOXmZUj+vbmUp0lPoXEMuhTpIluN0XL9UY=
github.com/fsnotify/fsnotify v1.4.7/go.mod h1:jwhsz4b93w/PPRr/qN1Yymfu8t87LnFCMoQvtojpjFo=
github.com/fsnotify/fsnotify v1.4.9/go.mod h1:znqG4EE+3YCdAaPaxE2ZRY/06pZUdp0tY4IgpuI1SZQ=
github.com/fsnotify/fsnotify v1.5.4/go.mod h1:OVB6XrOHzAwXMpEM7uPOzcehqUV2UqJxmVXmkdnm1bU=
github.com/fsnotify/fsnotify v1.6.0 h1:n+5WquG0fcWoWp6xPWfHdbskMCQaFnG6PfBrh1Ky4HY=
github.com/fsnotify/fsnotify v1.6.0/go.mod h1:sl3t1tCWJFWoRz9R8WJCbQihKKwmorjAbSClcnxKAGw=
+github.com/getsentry/sentry-go v0.23.0 h1:dn+QRCeJv4pPt9OjVXiMcGIBIefaTJPw/h0bZWO05nE=
+github.com/getsentry/sentry-go v0.23.0/go.mod h1:lc76E2QywIyW8WuBnwl8Lc4bkmQH4+w1gwTf25trprY=
github.com/ghodss/yaml v1.0.0/go.mod h1:4dBDuWmgqj2HViK6kFavaiC9ZROes6MMH2rRYeMEF04=
github.com/gin-contrib/sse v0.1.0 h1:Y/yl/+YNO8GZSjAhjMsSuLt29uWRFHdHYUb5lYOV9qE=
github.com/gin-contrib/sse v0.1.0/go.mod h1:RHrZQHXnP2xjPF+u1gW/2HnVO7nvIa9PG3Gm+fLHvGI=
github.com/gin-gonic/gin v1.6.3/go.mod h1:75u5sXoLsGZoRN5Sgbi1eraJ4GU3++wFwWzhwvtwp4M=
github.com/gin-gonic/gin v1.8.1 h1:4+fr/el88TOO3ewCmQr8cx/CtZ/umlIRIs5M4NTNjf8=
+github.com/go-errors/errors v1.4.2 h1:J6MZopCL4uSllY1OfXM374weqZFFItUbrImctkmUxIA=
github.com/go-gl/glfw v0.0.0-20190409004039-e6da0acd62b1/go.mod h1:vR7hzQXu2zJy9AVAgeJqvqgH9Q5CA+iKCZ2gyEVpxRU=
github.com/go-gl/glfw/v3.3/glfw v0.0.0-20191125211704-12ad95a8df72/go.mod h1:tQ2UAYgL5IevRw8kRxooKSPJfGvJ9fJQFa0TUsXzTg8=
github.com/go-gl/glfw/v3.3/glfw v0.0.0-20200222043503-6f7a984d4dc4/go.mod h1:tQ2UAYgL5IevRw8kRxooKSPJfGvJ9fJQFa0TUsXzTg8=
@@ -438,24 +476,30 @@ github.com/go-kit/kit v0.9.0/go.mod h1:xBxKIO96dXMWWy0MnWVtmwkA9/13aqxPnvrjFYMA2
github.com/go-kit/kit v0.10.0/go.mod h1:xUsJbQ/Fp4kEt7AFgCuvyX4a71u8h9jB8tj/ORgOZ7o=
github.com/go-kit/kit v0.12.0 h1:e4o3o3IsBfAKQh5Qbbiqyfu97Ku7jrO/JbohvztANh4=
github.com/go-kit/kit v0.12.0/go.mod h1:lHd+EkCZPIwYItmGDDRdhinkzX2A1sj+M9biaEaizzs=
+github.com/go-kit/log v0.1.0/go.mod h1:zbhenjAZHb184qTLMA9ZjW7ThYL0H2mk7Q6pNt4vbaY=
+github.com/go-kit/log v0.2.0/go.mod h1:NwTd00d/i8cPZ3xOwwiv2PO5MOcx78fFErGNcVmBjv0=
github.com/go-kit/log v0.2.1 h1:MRVx0/zhvdseW+Gza6N9rVzU/IVzaeE1SFI4raAhmBU=
github.com/go-kit/log v0.2.1/go.mod h1:NwTd00d/i8cPZ3xOwwiv2PO5MOcx78fFErGNcVmBjv0=
github.com/go-logfmt/logfmt v0.3.0/go.mod h1:Qt1PoO58o5twSAckw1HlFXLmHsOX5/0LbT9GBnD5lWE=
github.com/go-logfmt/logfmt v0.4.0/go.mod h1:3RMwSq7FuexP4Kalkev3ejPJsZTpXXBr9+V4qmtdjCk=
github.com/go-logfmt/logfmt v0.5.0/go.mod h1:wCYkCAKZfumFQihp8CzCvQ3paCTfi41vtzG1KdI/P7A=
+github.com/go-logfmt/logfmt v0.5.1/go.mod h1:WYhtIu8zTZfxdn5+rREduYbwxfcBr/Vr6KEVveWlfTs=
github.com/go-logfmt/logfmt v0.6.0 h1:wGYYu3uicYdqXVgoYbvnkrPVXkuLM1p1ifugDMEdRi4=
github.com/go-logfmt/logfmt v0.6.0/go.mod h1:WYhtIu8zTZfxdn5+rREduYbwxfcBr/Vr6KEVveWlfTs=
-github.com/go-ole/go-ole v1.2.1 h1:2lOsA72HgjxAuMlKpFiCbHTvu44PIVkZ5hqm3RSdI/E=
+github.com/go-ole/go-ole v1.2.6 h1:/Fpf6oFPoeFik9ty7siob0G6Ke8QvQEuVcuChpwXzpY=
github.com/go-playground/assert/v2 v2.0.1/go.mod h1:VDjEfimB/XKnb+ZQfWdccd7VUvScMdVu0Titje2rxJ4=
-github.com/go-playground/locales v0.13.0 h1:HyWk6mgj5qFqCT5fjGBuRArbVDfE4hi8+e8ceBS/t7Q=
github.com/go-playground/locales v0.13.0/go.mod h1:taPMhCMXrRLJO55olJkUXHZBHCxTMfnGwq/HNwmWNS8=
-github.com/go-playground/universal-translator v0.17.0 h1:icxd5fm+REJzpZx7ZfpaD876Lmtgy7VtROAbHHXk8no=
+github.com/go-playground/locales v0.14.0 h1:u50s323jtVGugKlcYeyzC0etD1HifMjqmJqb8WugfUU=
+github.com/go-playground/locales v0.14.0/go.mod h1:sawfccIbzZTqEDETgFXqTho0QybSa7l++s0DH+LDiLs=
github.com/go-playground/universal-translator v0.17.0/go.mod h1:UkSxE5sNxxRwHyU+Scu5vgOQjsIJAF8j9muTVoKLVtA=
+github.com/go-playground/universal-translator v0.18.0 h1:82dyy6p4OuJq4/CByFNOn/jYrnRPArHwAcmLoJZxyho=
+github.com/go-playground/universal-translator v0.18.0/go.mod h1:UvRDBj+xPUEGrFYl+lu/H90nyDXpg0fqeB/AQUGNTVA=
github.com/go-playground/validator/v10 v10.2.0/go.mod h1:uOYAAleCW8F/7oMFd6aG0GOhaH6EGOAJShg8Id5JGkI=
github.com/go-playground/validator/v10 v10.11.1 h1:prmOlTVv+YjZjmRmNSF3VmspqJIxJWXmqUsHwfTRRkQ=
github.com/go-sql-driver/mysql v1.4.0/go.mod h1:zAC/RDZ24gD3HViQzih4MyKcchzm+sOG5ZlKdlhCg5w=
-github.com/go-stack/stack v1.8.0 h1:5SgMzNM5HxrEjV0ww2lTmX6E2Izsfxas4+YHWRs3Lsk=
github.com/go-stack/stack v1.8.0/go.mod h1:v0f6uXyyMGvRgIKkXu+yp6POWl0qKG85gN/melR3HDY=
+github.com/go-stack/stack v1.8.1 h1:ntEHSVwIt7PNXNpgPmVfMrNhLtgjlmnZha2kOpuRiDw=
+github.com/go-stack/stack v1.8.1/go.mod h1:dcoOX6HbPZSZptuspn9bctJ+N/CnF5gGygcUP3XYfe4=
github.com/go-task/slim-sprig v0.0.0-20210107165309-348f09dbbbc0/go.mod h1:fyg7847qk6SyHyPtNmDHnmrv/HOrqktSC+C9fM+CJOE=
github.com/gobwas/httphead v0.0.0-20180130184737-2c6c146eadee h1:s+21KNqlpePfkah2I+gwHF8xmJWRjooY+5248k6m4A0=
github.com/gobwas/httphead v0.0.0-20180130184737-2c6c146eadee/go.mod h1:L0fX3K22YWvt/FAX9NnzrNzcI4wNYi9Yku4O0LKYflo=
@@ -466,22 +510,20 @@ github.com/gobwas/ws v1.0.2/go.mod h1:szmBTxLgaFppYjEmNtny/v3w89xOydFnnZMcgRRu/E
github.com/goccy/go-json v0.9.11 h1:/pAaQDLHEoCq/5FFmSKBswWmK6H0e8g4159Kc/X/nqk=
github.com/godbus/dbus v0.0.0-20190726142602-4481cbc300e2 h1:ZpnhV/YsD2/4cESfV5+Hoeu/iUR3ruzNvZ+yQfO03a0=
github.com/godbus/dbus v0.0.0-20190726142602-4481cbc300e2/go.mod h1:bBOAhwG1umN6/6ZUMtDFBMQR8jRg9O75tm9K00oMsK4=
+github.com/godbus/dbus/v5 v5.0.4/go.mod h1:xhWf0FNVPg57R7Z0UbKHbJfkEywrmjJnf7w5xrFpKfA=
github.com/gofrs/flock v0.8.1 h1:+gYjHKf32LDeiEEFhQaotPbLuUXjY5ZqxKgXy7n59aw=
github.com/gofrs/flock v0.8.1/go.mod h1:F1TvTiK9OcQqauNUHlbJvyl9Qa1QvF/gOUDKA14jxHU=
github.com/gofrs/uuid v4.3.0+incompatible h1:CaSVZxm5B+7o45rtab4jC2G37WGYX1zQfuU2i6DSvnc=
+github.com/gofrs/uuid v4.3.0+incompatible/go.mod h1:b2aQJv3Z4Fp6yNu3cdSllBxTCLRxnplIgP/c0N/04lM=
github.com/gogo/googleapis v1.1.0/go.mod h1:gf4bu3Q80BeJ6H1S1vYPm8/ELATdvryBaNFGgqEef3s=
github.com/gogo/googleapis v1.4.1-0.20201022092350-68b0159b7869/go.mod h1:5YRNX2z1oM5gXdAkurHa942MDgEJyk02w4OecKY87+c=
github.com/gogo/googleapis v1.4.1 h1:1Yx4Myt7BxzvUr5ldGSbwYiZG6t9wGBZ+8/fX3Wvtq0=
github.com/gogo/googleapis v1.4.1/go.mod h1:2lpHqI5OcWCtVElxXnPt+s8oJvMpySlOyM6xDCrzib4=
-github.com/gogo/protobuf v1.1.1/go.mod h1:r8qH/GZQm5c6nD/R0oafs1akxWv10x8SbQlK7atdtwQ=
-github.com/gogo/protobuf v1.2.0/go.mod h1:r8qH/GZQm5c6nD/R0oafs1akxWv10x8SbQlK7atdtwQ=
-github.com/gogo/protobuf v1.2.1/go.mod h1:hp+jE20tsWTFYpLwKvXlhS1hjn+gTNwPg2I6zVXpSg4=
-github.com/gogo/protobuf v1.3.1/go.mod h1:SlYgWuQ5SjCEi6WLHjHCa1yvBfUnHcTbrrZtXPKa29o=
-github.com/gogo/protobuf v1.3.2 h1:Ov1cvc58UF3b5XjBnZv7+opcTcQFZebYjWzi34vdm4Q=
-github.com/gogo/protobuf v1.3.2/go.mod h1:P1XiOD3dCwIKUDQYPy72D8LYyHL2YPYrpS2s69NZV8Q=
+github.com/golang-jwt/jwt v3.2.2+incompatible h1:IfV12K8xAKAnZqdXVzCZ+TOjboZ2keLg81eXfW3O+oY=
+github.com/golang-jwt/jwt v3.2.2+incompatible/go.mod h1:8pz2t5EyA70fFQQSrl6XZXzqecmYZeUEB8OUGHkxJ+I=
github.com/golang/glog v0.0.0-20160126235308-23def4e6c14b/go.mod h1:SBH7ygxi8pfUlaOkMMuAQtPIUF8ecWP5IEl/CR7VP2Q=
-github.com/golang/glog v1.0.0 h1:nfP3RFugxnNRyKgeWd4oI1nYvXpxrx8ck8ZrcizshdQ=
-github.com/golang/glog v1.0.0/go.mod h1:EWib/APOK0SL3dFbYqvxE3UYd8E6s1ouQ7iEp/0LWV4=
+github.com/golang/glog v1.1.0 h1:/d3pCKDPWNnvIWe0vVUpNP32qc8U3PDVxySP/y360qE=
+github.com/golang/glog v1.1.0/go.mod h1:pfYeQZ3JWZoXTV5sFc986z3HTpwQs9At6P4ImfuP3NQ=
github.com/golang/groupcache v0.0.0-20160516000752-02826c3e7903/go.mod h1:cIg4eruTrX1D+g88fzRXU5OdNfaM+9IcxsU14FzY7Hc=
github.com/golang/groupcache v0.0.0-20190702054246-869f871628b6/go.mod h1:cIg4eruTrX1D+g88fzRXU5OdNfaM+9IcxsU14FzY7Hc=
github.com/golang/groupcache v0.0.0-20191227052852-215e87163ea7/go.mod h1:cIg4eruTrX1D+g88fzRXU5OdNfaM+9IcxsU14FzY7Hc=
@@ -515,8 +557,9 @@ github.com/golang/protobuf v1.4.2/go.mod h1:oDoupMAO8OvCJWAcko0GGGIgR6R6ocIYbsSw
github.com/golang/protobuf v1.4.3/go.mod h1:oDoupMAO8OvCJWAcko0GGGIgR6R6ocIYbsSw735rRwI=
github.com/golang/protobuf v1.5.0/go.mod h1:FsONVRAS9T7sI+LIUmWTfcYkHO4aIWwzhcaSAoJOfIk=
github.com/golang/protobuf v1.5.1/go.mod h1:DopwsBzvsk0Fs44TXzsVbJyPhcCPeIwnvohx4u74HPM=
-github.com/golang/protobuf v1.5.2 h1:ROPKBNFfQgOUMifHyP+KYbvpjbdoFNs+aK7DXlji0Tw=
github.com/golang/protobuf v1.5.2/go.mod h1:XVQd3VNwM+JqD3oG2Ue2ip4fOMUkwXdXDdiuN0vRsmY=
+github.com/golang/protobuf v1.5.3 h1:KhyjKVUg7Usr/dYsdSqoFveMYd5ko72D+zANwlG1mmg=
+github.com/golang/protobuf v1.5.3/go.mod h1:XVQd3VNwM+JqD3oG2Ue2ip4fOMUkwXdXDdiuN0vRsmY=
github.com/golang/snappy v0.0.0-20180518054509-2e65f85255db/go.mod h1:/XxbfmMg8lxefKM7IXC3fBNl/7bRcc72aCRzEWrmP2Q=
github.com/golang/snappy v0.0.3/go.mod h1:/XxbfmMg8lxefKM7IXC3fBNl/7bRcc72aCRzEWrmP2Q=
github.com/golang/snappy v0.0.4 h1:yAGX7huGHXlcLOEtBnF4w7FQwA26wojNCwOYAEhLjQM=
@@ -548,6 +591,7 @@ github.com/google/go-querystring v1.1.0/go.mod h1:Kcdr2DB4koayq7X8pmAG4sNG59So17
github.com/google/gofuzz v0.0.0-20170612174753-24818f796faf/go.mod h1:HP5RmnzzSNb993RKQDq4+1A4ia9nllfqcQFTQJedwGI=
github.com/google/gofuzz v1.0.0/go.mod h1:dBl0BpW6vV/+mYPU4Po3pmUjxk6FQPldtuIdl/M65Eg=
github.com/google/gofuzz v1.2.0 h1:xRy4A+RhZaiKjJ1bPfwQ8sedCA+YS2YcCHW6ec7JMi0=
+github.com/google/gofuzz v1.2.0/go.mod h1:dBl0BpW6vV/+mYPU4Po3pmUjxk6FQPldtuIdl/M65Eg=
github.com/google/martian v2.1.0+incompatible h1:/CP5g8u/VJHijgedC/Legn3BAbAaWPgecwXBIDzw5no=
github.com/google/martian v2.1.0+incompatible/go.mod h1:9I4somxYTbIHy5NJKHRl3wXiIaQGbYVAs8BPL6v8lEs=
github.com/google/martian/v3 v3.0.0/go.mod h1:y5Zk1BBys9G+gd6Jrk0W3cC1+ELVxBWuIGO+w/tUAp0=
@@ -573,6 +617,8 @@ github.com/google/pprof v0.0.0-20210601050228-01bbb1931b22/go.mod h1:kpwsk12EmLe
github.com/google/pprof v0.0.0-20210609004039-a478d1d731e9/go.mod h1:kpwsk12EmLew5upagYY7GY0pfYCcupk39gWOCRROcvE=
github.com/google/pprof v0.0.0-20210720184732-4bb14d4b1be1/go.mod h1:kpwsk12EmLew5upagYY7GY0pfYCcupk39gWOCRROcvE=
github.com/google/renameio v0.1.0/go.mod h1:KWCgfxg9yswjAJkECMjeO8J8rahYeXnNhOm40UhjYkI=
+github.com/google/s2a-go v0.1.4 h1:1kZ/sQM3srePvKs3tXAvQzo66XfcReoqFpIpIccE7Oc=
+github.com/google/s2a-go v0.1.4/go.mod h1:Ej+mSEMGRnqRzjc7VtF+jdBwYG5fuJfiZ8ELkjEwM0A=
github.com/google/uuid v1.0.0/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo=
github.com/google/uuid v1.1.2/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo=
github.com/google/uuid v1.3.0 h1:t6JiXgmwXMjEs8VusXIJk2BXHsn+wx8BZdTaoZ5fu7I=
@@ -591,8 +637,8 @@ github.com/googleapis/gax-go/v2 v2.3.0/go.mod h1:b8LNqSzNabLiUpXKkY7HAR5jr6bIT99
github.com/googleapis/gax-go/v2 v2.4.0/go.mod h1:XOTVJ59hdnfJLIP/dh8n5CGryZR2LxK9wbMD5+iXC6c=
github.com/googleapis/gax-go/v2 v2.5.1/go.mod h1:h6B0KMMFNtI2ddbGJn3T3ZbwkeT6yqEF02fYlzkUCyo=
github.com/googleapis/gax-go/v2 v2.6.0/go.mod h1:1mjbznJAPHFpesgE5ucqfYEscaz5kMdcIDwU/6+DDoY=
-github.com/googleapis/gax-go/v2 v2.7.0 h1:IcsPKeInNvYi7eqSaDjiZqDDKu5rsmunY0Y1YupQSSQ=
-github.com/googleapis/gax-go/v2 v2.7.0/go.mod h1:TEop28CZZQ2y+c0VxMUmu1lV+fQx57QpBWsYpwqHJx8=
+github.com/googleapis/gax-go/v2 v2.11.0 h1:9V9PWXEsWnPpQhu/PeQIkS4eGzMlTLGgt80cUUI8Ki4=
+github.com/googleapis/gax-go/v2 v2.11.0/go.mod h1:DxmR61SGKkGLa2xigwuZIQpkCI2S5iydzRfb3peWZJI=
github.com/googleapis/go-type-adapters v1.0.0/go.mod h1:zHW75FOG2aur7gAO2B+MLby+cLsWGBF62rFAi7WjWO4=
github.com/googleapis/google-cloud-go-testing v0.0.0-20200911160855-bcd43fbb19e8/go.mod h1:dvDLG8qkwmyD9a/MJJN3XJcT3xFxOKAvTZGvuZmac9g=
github.com/gopherjs/gopherjs v0.0.0-20181017120253-0766667cb4d1/go.mod h1:wJfORRmW1u3UXTncJ5qlYoELFm8eSnnEO6hX4iZ3EWY=
@@ -629,8 +675,8 @@ github.com/hashicorp/go-cleanhttp v0.5.0/go.mod h1:JpRdi6/HCYpAwUzNwuwqhbovhLtng
github.com/hashicorp/go-cleanhttp v0.5.1/go.mod h1:JpRdi6/HCYpAwUzNwuwqhbovhLtngrth3wmdIIUrZ80=
github.com/hashicorp/go-cleanhttp v0.5.2 h1:035FKYIWjmULyFRBKPs8TBQoi0x6d9G4xc9neXJWAZQ=
github.com/hashicorp/go-cleanhttp v0.5.2/go.mod h1:kO/YDlP8L1346E6Sodw+PrpBSV4/SoxCXGY6BqNFT48=
-github.com/hashicorp/go-getter v1.7.0 h1:bzrYP+qu/gMrL1au7/aDvkoOVGUJpeKBgbqRHACAFDY=
-github.com/hashicorp/go-getter v1.7.0/go.mod h1:W7TalhMmbPmsSMdNjD0ZskARur/9GJ17cfHTRtXV744=
+github.com/hashicorp/go-getter v1.7.1 h1:SWiSWN/42qdpR0MdhaOc/bLR48PLuP1ZQtYLRlM69uY=
+github.com/hashicorp/go-getter v1.7.1/go.mod h1:W7TalhMmbPmsSMdNjD0ZskARur/9GJ17cfHTRtXV744=
github.com/hashicorp/go-immutable-radix v1.0.0/go.mod h1:0y9vanUI8NX6FsYoO3zeMjhV/C5i9g4Q3DwcSNZ4P60=
github.com/hashicorp/go-immutable-radix v1.3.1 h1:DKHmCUm2hRBK510BaiZlwvpD40f8bJFeZnpfm2KLowc=
github.com/hashicorp/go-immutable-radix v1.3.1/go.mod h1:0y9vanUI8NX6FsYoO3zeMjhV/C5i9g4Q3DwcSNZ4P60=
@@ -672,15 +718,19 @@ github.com/huandu/skiplist v1.2.0/go.mod h1:7v3iFjLcSAzO4fN5B8dvebvo/qsfumiLiDXM
github.com/hudl/fargo v1.3.0/go.mod h1:y3CKSmjA+wD2gak7sUSXTAoopbhU08POFhmITJgmKTg=
github.com/ianlancetaylor/demangle v0.0.0-20181102032728-5e5cf60278f6/go.mod h1:aSSvb/t6k1mPoxDqO4vJh6VOCGPwU4O0C2/Eqndh1Sc=
github.com/ianlancetaylor/demangle v0.0.0-20200824232613-28f6c0f3b639/go.mod h1:aSSvb/t6k1mPoxDqO4vJh6VOCGPwU4O0C2/Eqndh1Sc=
+github.com/icon-project/goloop v1.3.4 h1:82x8x+zY2XLVPEuWKHvnTj4bkeC5EYlNaaiePDqdMjk=
+github.com/icon-project/goloop v1.3.4/go.mod h1:9PoWRb5kowidc9jYy0RLuLpay1zT5FXgEKijx7rDQjE=
+github.com/icon-project/ibc-integration v0.0.0-20230717083940-67949d73b622 h1:RHutSdyBRURe7MHx/838gVEw6Iu+tYMF/x2cx9hZSxY=
+github.com/icon-project/ibc-integration v0.0.0-20230717083940-67949d73b622/go.mod h1:lYQTcVqXxpUhhdz/cU2xsX1rPGoIkeWalIAjiEt0K+0=
github.com/improbable-eng/grpc-web v0.15.0 h1:BN+7z6uNXZ1tQGcNAuaU1YjsLTApzkjt2tzCixLaUPQ=
github.com/improbable-eng/grpc-web v0.15.0/go.mod h1:1sy9HKV4Jt9aEs9JSnkWlRJPuPtwNr0l57L4f878wP8=
github.com/inconshreveable/mousetrap v1.0.0/go.mod h1:PxqpIevigyE2G7u3NXJIT2ANytuPF1OarO4DADm73n8=
-github.com/inconshreveable/mousetrap v1.0.1/go.mod h1:vpF70FUmC8bwa3OWnCshd2FqLfsEA9PFc4w1p2J65bw=
github.com/inconshreveable/mousetrap v1.1.0 h1:wN+x4NVGpMsO7ErUn/mUI3vEoE6Jt13X2s0bqwp9tc8=
github.com/inconshreveable/mousetrap v1.1.0/go.mod h1:vpF70FUmC8bwa3OWnCshd2FqLfsEA9PFc4w1p2J65bw=
github.com/influxdata/influxdb1-client v0.0.0-20191209144304-8bf82d3c094d/go.mod h1:qj24IKcXYK6Iy9ceXlo3Tc+vtHo9lIhSX5JddghvEPo=
github.com/jessevdk/go-flags v0.0.0-20141203071132-1679536dcc89/go.mod h1:4FA24M0QyGHXBuZZK/XkWh8h0e1EYbRYJSGM75WSRxI=
-github.com/jhump/protoreflect v1.12.1-0.20220721211354-060cc04fc18b h1:izTof8BKh/nE1wrKOrloNA5q4odOarjf+Xpe+4qow98=
+github.com/jessevdk/go-flags v1.4.0/go.mod h1:4FA24M0QyGHXBuZZK/XkWh8h0e1EYbRYJSGM75WSRxI=
+github.com/jhump/protoreflect v1.15.1 h1:HUMERORf3I3ZdX05WaQ6MIpd/NJ434hTp5YiKgfCL6c=
github.com/jmespath/go-jmespath v0.0.0-20180206201540-c2b33e8439af/go.mod h1:Nht3zPeWKUH0NzdCt2Blrr5ys8VGpn0CEB0cQHVjt7k=
github.com/jmespath/go-jmespath v0.4.0 h1:BEgLn5cpjn8UN1mAw4NjwDrS35OdebyEtFe+9YPoQUg=
github.com/jmespath/go-jmespath v0.4.0/go.mod h1:T8mJZnbsbmF+m6zOOFylbeCJqk5+pHWvzYPziyZiYoo=
@@ -696,6 +746,7 @@ github.com/json-iterator/go v1.1.7/go.mod h1:KdQUCv79m/52Kvf8AW2vK1V8akMuk1QjK/u
github.com/json-iterator/go v1.1.8/go.mod h1:KdQUCv79m/52Kvf8AW2vK1V8akMuk1QjK/uOdHXbAo4=
github.com/json-iterator/go v1.1.9/go.mod h1:KdQUCv79m/52Kvf8AW2vK1V8akMuk1QjK/uOdHXbAo4=
github.com/json-iterator/go v1.1.10/go.mod h1:KdQUCv79m/52Kvf8AW2vK1V8akMuk1QjK/uOdHXbAo4=
+github.com/json-iterator/go v1.1.11/go.mod h1:KdQUCv79m/52Kvf8AW2vK1V8akMuk1QjK/uOdHXbAo4=
github.com/json-iterator/go v1.1.12 h1:PV8peI4a0ysnczrg+LtxykD8LfKY9ML6u2jnxaEnrnM=
github.com/json-iterator/go v1.1.12/go.mod h1:e30LSqwooZae/UwlEbR2852Gd8hjQvJoHmT4TnhNGBo=
github.com/jstemmer/go-junit-report v0.0.0-20190106144839-af01ea7f8024/go.mod h1:6v2b51hI/fHJwM22ozAgKL4VKDeJcHhJFhtBdhmNjmU=
@@ -705,8 +756,6 @@ github.com/jsternberg/zap-logfmt v1.3.0/go.mod h1:N3DENp9WNmCZxvkBD/eReWwz1149BK
github.com/jtolds/gls v4.20.0+incompatible/go.mod h1:QJZ7F/aHp+rZTRtaJ1ow/lLfFfVYBRgL+9YlvaHOwJU=
github.com/julienschmidt/httprouter v1.2.0/go.mod h1:SYymIcj16QtmaHHD7aYtjjsJG7VTCxuUUipMqKk8s4w=
github.com/julienschmidt/httprouter v1.3.0/go.mod h1:JR6WtHb+2LUe8TCKY3cZOxFyyO8IZAc4RVcycCCAKdM=
-github.com/kisielk/errcheck v1.1.0/go.mod h1:EZBBE59ingxPouuu3KfxchcWSUPOHkagtvWXihfKN4Q=
-github.com/kisielk/errcheck v1.2.0/go.mod h1:/BMXB+zMLi60iA8Vv6Ksmxu/1UDYcXs4uQLJ+jE2L00=
github.com/kisielk/errcheck v1.5.0/go.mod h1:pFxgyoBC7bSaBwPgfKdkLd5X25qrDl4LWUI2bnpBCr8=
github.com/kisielk/gotool v1.0.0/go.mod h1:XhKaO+MFFWcvkIS/tQcRk01m1F5IRFswLeQ+oQHNcck=
github.com/kkdai/bstream v0.0.0-20161212061736-f391b8402d23/go.mod h1:J+Gs4SYgM6CZQHDETBtE9HaSEkGmuNXF86RwHhHUvq4=
@@ -714,25 +763,34 @@ github.com/klauspost/compress v1.10.3/go.mod h1:aoV0uJVorq1K+umq18yTdKaF57EivdYs
github.com/klauspost/compress v1.11.7/go.mod h1:aoV0uJVorq1K+umq18yTdKaF57EivdYsUV+/s2qKfXs=
github.com/klauspost/compress v1.12.3/go.mod h1:8dP1Hq4DHOhN9w426knH3Rhby4rFm6D8eO+e+Dq5Gzg=
github.com/klauspost/compress v1.15.11/go.mod h1:QPwzmACJjUTFsnSHH934V6woptycfrDDJnH7hvFVbGM=
-github.com/klauspost/compress v1.15.15 h1:EF27CXIuDsYJ6mmvtBRlEuB2UVOqHG1tAXgZ7yIO+lw=
-github.com/klauspost/compress v1.15.15/go.mod h1:ZcK2JAFqKOpnBlxcLsJzYfrS9X1akm9fHZNnD9+Vo/4=
+github.com/klauspost/compress v1.16.3 h1:XuJt9zzcnaz6a16/OU53ZjWp/v7/42WcR5t2a0PcNQY=
+github.com/klauspost/compress v1.16.3/go.mod h1:ntbaceVETuRiXiv4DpjP66DpAtAGkEQskQzEyD//IeE=
github.com/konsorten/go-windows-terminal-sequences v1.0.1/go.mod h1:T0+1ngSBFLxvqU3pZ+m/2kptfBszLMUkC4ZK/EgS/cQ=
github.com/konsorten/go-windows-terminal-sequences v1.0.3/go.mod h1:T0+1ngSBFLxvqU3pZ+m/2kptfBszLMUkC4ZK/EgS/cQ=
github.com/kr/fs v0.1.0/go.mod h1:FFnZGqtBN9Gxj7eW1uZ42v5BccTP0vu6NEaFoC2HwRg=
github.com/kr/logfmt v0.0.0-20140226030751-b84e30acd515/go.mod h1:+0opPa2QZZtGFBFZlji/RkVcI2GknAs/DXo4wKdlNEc=
github.com/kr/pretty v0.1.0/go.mod h1:dAy3ld7l9f0ibDNOQOHHMYYIIbhfbHSm3C4ZsoJORNo=
github.com/kr/pretty v0.3.1 h1:flRD4NNwYAUpkphVc1HcthR4KEIFJ65n8Mw5qdRn3LE=
+github.com/kr/pretty v0.3.1/go.mod h1:hoEshYVHaxMs3cyo3Yncou5ZscifuDolrwPKZanG3xk=
github.com/kr/pty v1.1.1/go.mod h1:pFQYn66WHrOpPYNljwOMqo10TkYh1fy3cYio2l3bCsQ=
github.com/kr/text v0.1.0/go.mod h1:4Jbv+DJW3UT/LiOwJeYQe1efqtUx/iVham/4vfdArNI=
github.com/kr/text v0.2.0 h1:5Nx0Ya0ZqY2ygV366QzturHI13Jq95ApcVaJBhpS+AY=
-github.com/leodido/go-urn v1.2.0 h1:hpXL4XnriNwQ/ABnpepYM/1vCLWNDfUNts8dX3xTG6Y=
+github.com/kr/text v0.2.0/go.mod h1:eLer722TekiGuMkidMxC/pM04lWEeraHUUmBw8l2grE=
+github.com/labstack/echo/v4 v4.10.0 h1:5CiyngihEO4HXsz3vVsJn7f8xAlWwRr3aY6Ih280ZKA=
+github.com/labstack/echo/v4 v4.10.0/go.mod h1:S/T/5fy/GigaXnHTkh0ZGe4LpkkQysvRjFMSUTkDRNQ=
+github.com/labstack/gommon v0.4.0 h1:y7cvthEAEbU0yHOf4axH8ZG2NH8knB9iNSoTO8dyIk8=
+github.com/labstack/gommon v0.4.0/go.mod h1:uW6kP17uPlLJsD3ijUYn3/M5bAxtlZhMI6m3MFxTMTM=
github.com/leodido/go-urn v1.2.0/go.mod h1:+8+nEpDfqqsY+g338gtMEUOtuK+4dEMhiQEgxpxOKII=
+github.com/leodido/go-urn v1.2.1 h1:BqpAaACuzVSgi/VLzGZIobT2z4v53pjosyNd9Yv6n/w=
+github.com/leodido/go-urn v1.2.1/go.mod h1:zt4jvISO2HfUBqxjfIshjdMTYS56ZS/qv49ictyFfxY=
github.com/lib/pq v1.10.7 h1:p7ZhMD+KsSRozJr34udlUrhboJwWAgCg34+/ZZNvZZw=
github.com/lib/pq v1.10.7/go.mod h1:AlVN5x4E4T544tWzH6hKfbfQvm3HdbOxrmggDNAPY9o=
github.com/libp2p/go-buffer-pool v0.1.0 h1:oK4mSFcQz7cTQIfqbe4MIj9gLW+mnanjyFtc6cdF0Y8=
github.com/libp2p/go-buffer-pool v0.1.0/go.mod h1:N+vh8gMqimBzdKkSMVuydVDq+UV5QTWy5HSiZacSbPg=
github.com/lightstep/lightstep-tracer-common/golang/gogo v0.0.0-20190605223551-bc2310a04743/go.mod h1:qklhhLq1aX+mtWk9cPHPzaBjWImj5ULL6C7HFJtXQMM=
github.com/lightstep/lightstep-tracer-go v0.18.1/go.mod h1:jlF1pusYV4pidLvZ+XD0UBX0ZE6WURAspgAczcDHrL4=
+github.com/linxGnu/grocksdb v1.7.16 h1:Q2co1xrpdkr5Hx3Fp+f+f7fRGhQFQhvi/+226dtLmA8=
+github.com/linxGnu/grocksdb v1.7.16/go.mod h1:JkS7pl5qWpGpuVb3bPqTz8nC12X3YtPZT+Xq7+QfQo4=
github.com/lyft/protoc-gen-validate v0.0.13/go.mod h1:XbGvPuh87YZc5TdIa2/I4pLk0QoUACkjt2znoq26NVQ=
github.com/magiconair/properties v1.8.0/go.mod h1:PppfXfuXeibc/6YijjN8zIbojt8czPbwD3XqdrwzmxQ=
github.com/magiconair/properties v1.8.7 h1:IeQXZAiQcpL9mgcAe1Nu6cX9LLw6ExEHKjN0VQdvPDY=
@@ -740,22 +798,27 @@ github.com/magiconair/properties v1.8.7/go.mod h1:Dhd985XPs7jluiymwWYZ0G4Z61jb3v
github.com/manifoldco/promptui v0.9.0 h1:3V4HzJk1TtXW1MTZMP7mdlwbBpIinw3HztaIlYthEiA=
github.com/manifoldco/promptui v0.9.0/go.mod h1:ka04sppxSGFAtxX0qhlYQjISsg9mR4GWtQEhdbn6Pgg=
github.com/mattn/go-colorable v0.0.9/go.mod h1:9vuHe8Xs5qXnSaW/c/ABM9alt+Vo+STaOChaDxuIBZU=
+github.com/mattn/go-colorable v0.1.11/go.mod h1:u5H1YNBxpqRaxsYJYSkiCWKzEfiAb1Gb520KVy5xxl4=
+github.com/mattn/go-colorable v0.1.12/go.mod h1:u5H1YNBxpqRaxsYJYSkiCWKzEfiAb1Gb520KVy5xxl4=
+github.com/mattn/go-colorable v0.1.13 h1:fFA4WZxdEF4tXPZVKMLwD8oUnCTTo08duU7wxecdEvA=
+github.com/mattn/go-colorable v0.1.13/go.mod h1:7S9/ev0klgBDR4GtXTXX8a3vIGJpMovkB8vQcUbaXHg=
github.com/mattn/go-isatty v0.0.3/go.mod h1:M+lRXTBqGeGNdLjl/ufCoiOlB5xdOkqRJdNxMWT7Zi4=
github.com/mattn/go-isatty v0.0.4/go.mod h1:M+lRXTBqGeGNdLjl/ufCoiOlB5xdOkqRJdNxMWT7Zi4=
github.com/mattn/go-isatty v0.0.12/go.mod h1:cbi8OIDigv2wuxKPP5vlRcQ1OAZbq2CE4Kysco4FUpU=
-github.com/mattn/go-isatty v0.0.17 h1:BTarxUcIeDqL27Mc+vyvdWYSL28zpIhv3RoTdsLMPng=
-github.com/mattn/go-isatty v0.0.17/go.mod h1:kYGgaQfpe5nmfYZH+SKPsOc2e4SrIfOl2e/yFXSvRLM=
+github.com/mattn/go-isatty v0.0.14/go.mod h1:7GGIvUiUoEMVVmxf/4nioHXj79iQHKdU27kJ6hsGG94=
+github.com/mattn/go-isatty v0.0.16/go.mod h1:kYGgaQfpe5nmfYZH+SKPsOc2e4SrIfOl2e/yFXSvRLM=
+github.com/mattn/go-isatty v0.0.19 h1:JITubQf0MOLdlGRuRq+jtsDlekdYPia9ZFsB8h/APPA=
+github.com/mattn/go-isatty v0.0.19/go.mod h1:W+V8PltTTMOvKvAeJH7IuucS94S2C6jfK/D7dTCTo3Y=
github.com/mattn/go-runewidth v0.0.2/go.mod h1:LwmH8dsx7+W8Uxz3IHJYH5QSwggIsqBzpuz5H//U1FU=
github.com/mattn/go-runewidth v0.0.4/go.mod h1:LwmH8dsx7+W8Uxz3IHJYH5QSwggIsqBzpuz5H//U1FU=
-github.com/mattn/go-runewidth v0.0.13 h1:lTGmDsbAYt5DmK6OnoV7EuIF1wEIFAcxld6ypU4OSgU=
-github.com/mattn/go-runewidth v0.0.13/go.mod h1:Jdepj2loyihRzMpdS35Xk/zdY8IAYHsh153qUoGf23w=
+github.com/mattn/go-runewidth v0.0.14 h1:+xnbZSEeDbOIg5/mE6JF0w6n9duR1l3/WmbinWVwUuU=
github.com/matttproud/golang_protobuf_extensions v1.0.1/go.mod h1:D8He9yQNgCq6Z5Ld7szi9bcBfOoFv/3dc6xSMkL2PC0=
github.com/matttproud/golang_protobuf_extensions v1.0.4 h1:mmDVorXM7PCGKw94cs5zkfA9PSy5pEvNWRP0ET0TIVo=
github.com/matttproud/golang_protobuf_extensions v1.0.4/go.mod h1:BSXmuO+STAnVfrANrmjBb36TMTDstsz7MSK+HVaYKv4=
github.com/miekg/dns v1.0.14/go.mod h1:W1PPwlIAgtquWBMBEV9nkV9Cazfe8ScdGz/Lj7v3Nrg=
github.com/mimoo/StrobeGo v0.0.0-20181016162300-f8f6d4d2b643/go.mod h1:43+3pMjjKimDBf5Kr4ZFNGbLql1zKkbImw+fZbw3geM=
-github.com/mimoo/StrobeGo v0.0.0-20210601165009-122bf33a46e0 h1:QRUSJEgZn2Snx0EmT/QLXibWjSUDjKWvXIT19NBVp94=
-github.com/mimoo/StrobeGo v0.0.0-20210601165009-122bf33a46e0/go.mod h1:43+3pMjjKimDBf5Kr4ZFNGbLql1zKkbImw+fZbw3geM=
+github.com/mimoo/StrobeGo v0.0.0-20220103164710-9a04d6ca976b h1:QrHweqAtyJ9EwCaGHBu1fghwxIPiopAHV06JlXrMHjk=
+github.com/mimoo/StrobeGo v0.0.0-20220103164710-9a04d6ca976b/go.mod h1:xxLb2ip6sSUts3g1irPVHyk/DGslwQsNOo9I7smJfNU=
github.com/minio/highwayhash v1.0.2 h1:Aak5U0nElisjDCfPSG79Tgzkn2gl66NxOMspRrKnA/g=
github.com/minio/highwayhash v1.0.2/go.mod h1:BQskDq+xkJ12lmlUUi7U0M5Swg3EWR+dLTk+kldvVxY=
github.com/mitchellh/cli v1.0.0/go.mod h1:hNIlj7HEI86fIcpObd7a0FcrxTWetlwJDGcceTlRvqc=
@@ -802,10 +865,12 @@ github.com/olekukonko/tablewriter v0.0.5 h1:P2Ga83D34wi1o9J6Wh1mRuqd4mF/x/lgBS7N
github.com/onsi/ginkgo v1.6.0/go.mod h1:lLunBs/Ym6LB5Z9jYTR76FiuTmxDTDusOGeTQH+WWjE=
github.com/onsi/ginkgo v1.7.0/go.mod h1:lLunBs/Ym6LB5Z9jYTR76FiuTmxDTDusOGeTQH+WWjE=
github.com/onsi/ginkgo v1.12.1/go.mod h1:zj2OWP4+oCPe1qIXoGWkgMRwljMUYCdkwsT2108oapk=
+github.com/onsi/ginkgo v1.14.0/go.mod h1:iSB4RoI2tjJc9BBv4NKIKWKya62Rps+oPG/Lv9klQyY=
github.com/onsi/ginkgo v1.16.4/go.mod h1:dX+/inL/fNMqNlz0e9LfyB9TswhZpCVdJM/Z6Vvnwo0=
github.com/onsi/ginkgo v1.16.5 h1:8xi0RTUf59SOSfEtZMvwTvXYMzG4gV23XVHOZiXNtnE=
github.com/onsi/ginkgo v1.16.5/go.mod h1:+E8gABHa3K6zRBolWtd+ROzc/U5bkGt0FwiG042wbpU=
github.com/onsi/ginkgo/v2 v2.1.3/go.mod h1:vw5CSIxN1JObi/U8gcbwft7ZxR2dgaR70JSE3/PpL4c=
+github.com/onsi/gomega v1.4.1/go.mod h1:C1qb7wdrVGGVU+Z6iS04AVkA3Q65CEZX59MT0QO5uiA=
github.com/onsi/gomega v1.4.3/go.mod h1:ex+gbHU/CVuBBDIJjb2X0qEXbFg53c61hWP/1CpauHY=
github.com/onsi/gomega v1.7.1/go.mod h1:XdKZgCCFLUoM/7CFJVPcG8C1xQ1AJ0vpAezJrB7JYyY=
github.com/onsi/gomega v1.10.1/go.mod h1:iN09h71vgCQne3DLsj+A5owkum+a2tYe+TOCB1ybHNo=
@@ -814,6 +879,7 @@ github.com/onsi/gomega v1.19.0/go.mod h1:LY+I3pBVzYsTBU1AnDwOSxaYi9WoWiqgwooUqq9
github.com/onsi/gomega v1.20.0 h1:8W0cWlwFkflGPLltQvLRB7ZVD5HuP6ng320w2IS245Q=
github.com/op/go-logging v0.0.0-20160315200505-970db520ece7/go.mod h1:HzydrMdWErDVzsI23lYNej1Htcns9BCg93Dk0bBINWk=
github.com/opencontainers/go-digest v1.0.0 h1:apOUWs51W5PlhuyGyz9FCeeBIOUDA/6nW8Oi/yOhh5U=
+github.com/opencontainers/go-digest v1.0.0/go.mod h1:0JzlMkj0TRzQZfJkVvzbP0HBR3IKzErnv2BNG4W4MAM=
github.com/opencontainers/image-spec v1.1.0-rc2 h1:2zx/Stx4Wc5pIPDvIxHXvXtQFW/7XWJGmnM7r3wg034=
github.com/opencontainers/runc v1.1.3 h1:vIXrkId+0/J2Ymu2m7VjGvbSlAId9XNRPhn2p4b+d8w=
github.com/opentracing-contrib/go-observer v0.0.0-20170622124052-a52f23424492/go.mod h1:Ngi6UdF0k5OKD5t5wlmGhe/EDKPoUM3BXZSSfIuJbis=
@@ -831,14 +897,18 @@ github.com/pascaldekloe/goe v0.1.0 h1:cBOtyMzM9HTpWjXfbbunk26uA6nG3a8n06Wieeh0Mw
github.com/pascaldekloe/goe v0.1.0/go.mod h1:lzWF7FIEvWOWxwDKqyGYQf6ZUaNfKdP144TG7ZOy1lc=
github.com/pborman/uuid v1.2.0/go.mod h1:X/NO0urCmaxf9VXbdlT7C2Yzkj2IKimNn4k+gtPdI/k=
github.com/pelletier/go-toml v1.2.0/go.mod h1:5z9KED0ma1S8pY6P1sdut58dfprrGBbd/94hg7ilaic=
-github.com/pelletier/go-toml/v2 v2.0.6 h1:nrzqCb7j9cDFj2coyLNLaZuJTLjWjlaz6nvTvIwycIU=
-github.com/pelletier/go-toml/v2 v2.0.6/go.mod h1:eumQOmlWiOPt5WriQQqoM5y18pDHwha2N+QD+EUNTek=
+github.com/pelletier/go-toml/v2 v2.0.8 h1:0ctb6s9mE31h0/lhu+J6OPmVeDxJn+kYnJc2jZR9tGQ=
+github.com/pelletier/go-toml/v2 v2.0.8/go.mod h1:vuYfssBdrU2XDZ9bYydBu6t+6a6PYNcZljzZR9VXg+4=
github.com/performancecopilot/speed v3.0.0+incompatible/go.mod h1:/CLtqpZ5gBg1M9iaPbIdPPGyKcA8hKdoy6hAWba7Yac=
github.com/petermattis/goid v0.0.0-20180202154549-b0b1615b78e5/go.mod h1:jvVRKCrJTQWu0XVbaOlby/2lO20uSCHEMzzplHXte1o=
-github.com/petermattis/goid v0.0.0-20221215004737-a150e88a970d h1:htwtWgtQo8YS6JFWWi2DNgY0RwSGJ1ruMoxY6CUUclk=
-github.com/petermattis/goid v0.0.0-20221215004737-a150e88a970d/go.mod h1:pxMtw7cyUw6B2bRH0ZBANSPg+AoSud1I1iyJHI69jH4=
+github.com/petermattis/goid v0.0.0-20230317030725-371a4b8eda08 h1:hDSdbBuw3Lefr6R18ax0tZ2BJeNB3NehB3trOwYBsdU=
+github.com/petermattis/goid v0.0.0-20230317030725-371a4b8eda08/go.mod h1:pxMtw7cyUw6B2bRH0ZBANSPg+AoSud1I1iyJHI69jH4=
+github.com/philhofer/fwd v1.0.0 h1:UbZqGr5Y38ApvM/V/jEljVxwocdweyH+vmYvRPBnbqQ=
+github.com/philhofer/fwd v1.0.0/go.mod h1:gk3iGcWd9+svBvR0sR+KPcfE+RNWozjowpeBVG3ZVNU=
github.com/pierrec/lz4 v1.0.2-0.20190131084431-473cd7ce01a1/go.mod h1:3/3N9NVKO0jef7pBehbT1qWhCMrIgbYNnFAZCqQ5LRc=
github.com/pierrec/lz4 v2.0.5+incompatible/go.mod h1:pdkljMzZIN41W+lC3N2tnIh5sFi+IEE17M5jbnwPHcY=
+github.com/pingcap/errors v0.11.4 h1:lFuQV/oaUMGcD2tqt+01ROSmJs75VG1ToEOkZIZ4nE4=
+github.com/pkg/diff v0.0.0-20210226163009-20ebb0f2a09e/go.mod h1:pJLUxLENpZxwdsKMEsNbx1VGcRFpLqf3715MtcvvzbA=
github.com/pkg/errors v0.8.0/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0=
github.com/pkg/errors v0.8.1/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0=
github.com/pkg/errors v0.9.1 h1:FEBLx1zS214owpjy7qsBeixbURkuhQAwrK5UwLGTwt4=
@@ -854,8 +924,12 @@ github.com/prometheus/client_golang v1.0.0/go.mod h1:db9x61etRT2tGnBNRi70OPL5Fsn
github.com/prometheus/client_golang v1.3.0/go.mod h1:hJaj2vgQTGQmVCsAACORcieXFeDPbaTKGT+JTgUa3og=
github.com/prometheus/client_golang v1.4.0/go.mod h1:e9GMxYsXl05ICDXkRhurwBS4Q3OK1iX/F2sw+iXX5zU=
github.com/prometheus/client_golang v1.7.1/go.mod h1:PY5Wy2awLA44sXw4AOSfFBetzPP4j5+D6mVACh+pe2M=
-github.com/prometheus/client_golang v1.14.0 h1:nJdhIvne2eSX/XRAFV9PcvFFRbrjbcTUj0VP62TMhnw=
-github.com/prometheus/client_golang v1.14.0/go.mod h1:8vpkKitgIVNcqrRBWh1C4TIUQgYNtG/XQE4E/Zae36Y=
+github.com/prometheus/client_golang v1.11.0/go.mod h1:Z6t4BnS23TR94PD6BsDNk8yVqroYurpAkEiz0P2BEV0=
+github.com/prometheus/client_golang v1.12.1/go.mod h1:3Z9XVyYiZYEO+YQWt3RD2R3jrbd179Rt297l4aS6nDY=
+github.com/prometheus/client_golang v1.12.2/go.mod h1:3Z9XVyYiZYEO+YQWt3RD2R3jrbd179Rt297l4aS6nDY=
+github.com/prometheus/client_golang v1.13.0/go.mod h1:vTeo+zgvILHsnnj/39Ou/1fPN5nJFOEMgftOUOmlvYQ=
+github.com/prometheus/client_golang v1.15.0 h1:5fCgGYogn0hFdhyhLbw7hEsWxufKtY9klyvdNfFlFhM=
+github.com/prometheus/client_golang v1.15.0/go.mod h1:e9yaBhRPU2pPNsZwE+JdQl0KEt1N9XgF6zxWmaC0xOk=
github.com/prometheus/client_model v0.0.0-20180712105110-5c3871d89910/go.mod h1:MbSGuTsp3dbXC40dX6PRTWyKYBIrTGTE9sqQNg2J8bo=
github.com/prometheus/client_model v0.0.0-20190115171406-56726106282f/go.mod h1:MbSGuTsp3dbXC40dX6PRTWyKYBIrTGTE9sqQNg2J8bo=
github.com/prometheus/client_model v0.0.0-20190129233127-fd36f4220a90/go.mod h1:xMI15A0UPsDsEKsMN9yxemIoYk6Tm2C1GtYGdfGttqA=
@@ -870,32 +944,46 @@ github.com/prometheus/common v0.7.0/go.mod h1:DjGbpBbp5NYNiECxcL/VnbXCCaQpKd3tt2
github.com/prometheus/common v0.9.1/go.mod h1:yhUN8i9wzaXS3w1O07YhxHEBxD+W35wd8bs7vj7HSQ4=
github.com/prometheus/common v0.10.0/go.mod h1:Tlit/dnDKsSWFlCLTWaA1cyBgKHSMdTB80sz/V91rCo=
github.com/prometheus/common v0.15.0/go.mod h1:U+gB1OBLb1lF3O42bTCL+FK18tX9Oar16Clt/msog/s=
-github.com/prometheus/common v0.40.0 h1:Afz7EVRqGg2Mqqf4JuF9vdvp1pi220m55Pi9T2JnO4Q=
-github.com/prometheus/common v0.40.0/go.mod h1:L65ZJPSmfn/UBWLQIHV7dBrKFidB/wPlF1y5TlSt9OE=
+github.com/prometheus/common v0.26.0/go.mod h1:M7rCNAaPfAosfx8veZJCuw84e35h3Cfd9VFqTh1DIvc=
+github.com/prometheus/common v0.32.1/go.mod h1:vu+V0TpY+O6vW9J44gczi3Ap/oXXR10b+M/gUGO4Hls=
+github.com/prometheus/common v0.35.0/go.mod h1:phzohg0JFMnBEFGxTDbfu3QyL5GI8gTQJFhYO5B3mfA=
+github.com/prometheus/common v0.37.0/go.mod h1:phzohg0JFMnBEFGxTDbfu3QyL5GI8gTQJFhYO5B3mfA=
+github.com/prometheus/common v0.42.0 h1:EKsfXEYo4JpWMHH5cg+KOUWeuJSov1Id8zGR8eeI1YM=
+github.com/prometheus/common v0.42.0/go.mod h1:xBwqVerjNdUDjgODMpudtOMwlOwf2SaTr1yjz4b7Zbc=
github.com/prometheus/procfs v0.0.0-20181005140218-185b4288413d/go.mod h1:c3At6R/oaqEKCNdg8wHV1ftS6bRYblBhIjjI8uT2IGk=
github.com/prometheus/procfs v0.0.0-20190117184657-bf6a532e95b1/go.mod h1:c3At6R/oaqEKCNdg8wHV1ftS6bRYblBhIjjI8uT2IGk=
github.com/prometheus/procfs v0.0.2/go.mod h1:TjEm7ze935MbeOT/UhFTIMYKhuLP4wbCsTZCD3I8kEA=
github.com/prometheus/procfs v0.0.8/go.mod h1:7Qr8sr6344vo1JqZ6HhLceV9o3AJ1Ff+GxbHq6oeK9A=
github.com/prometheus/procfs v0.1.3/go.mod h1:lV6e/gmhEcM9IjHGsFOCxxuZ+z1YqCvr4OA4YeYWdaU=
github.com/prometheus/procfs v0.3.0/go.mod h1:lV6e/gmhEcM9IjHGsFOCxxuZ+z1YqCvr4OA4YeYWdaU=
+github.com/prometheus/procfs v0.6.0/go.mod h1:cz+aTbrPOrUb4q7XlbU9ygM+/jj0fzG6c1xBZuNvfVA=
+github.com/prometheus/procfs v0.7.3/go.mod h1:cz+aTbrPOrUb4q7XlbU9ygM+/jj0fzG6c1xBZuNvfVA=
+github.com/prometheus/procfs v0.8.0/go.mod h1:z7EfXMXOkbkqb9IINtpCn86r/to3BnA0uaxHdg830/4=
github.com/prometheus/procfs v0.9.0 h1:wzCHvIvM5SxWqYvwgVL7yJY8Lz3PKn49KQtpgMYJfhI=
github.com/prometheus/procfs v0.9.0/go.mod h1:+pB4zwohETzFnmlpe6yd2lSc+0/46IYZRB/chUwxUZY=
+github.com/prometheus/statsd_exporter v0.22.7 h1:7Pji/i2GuhK6Lu7DHrtTkFmNBCudCPT1pX2CziuyQR0=
+github.com/prometheus/statsd_exporter v0.22.7/go.mod h1:N/TevpjkIh9ccs6nuzY3jQn9dFqnUakOjnEuMPJJJnI=
github.com/prometheus/tsdb v0.7.1 h1:YZcsG11NqnK4czYLrWd9mpEuAJIHVQLwdrleYfszMAA=
github.com/rakyll/statik v0.1.7 h1:OF3QCZUuyPxuGEP7B4ypUa7sB/iHtqOTDYZXGM8KOdQ=
github.com/rakyll/statik v0.1.7/go.mod h1:AlZONWzMtEnMs7W4e/1LURLiI49pIMmp6V9Unghqrcc=
github.com/rcrowley/go-metrics v0.0.0-20181016184325-3113b8401b8a/go.mod h1:bCqnVzQkZxMG4s8nGwiZ5l3QUCyqpo9Y+/ZMZ9VjZe4=
github.com/rcrowley/go-metrics v0.0.0-20201227073835-cf1acfcdf475 h1:N/ElC8H3+5XpJzTSTfLsJV/mx9Q9g7kxmchpfZyxgzM=
github.com/rcrowley/go-metrics v0.0.0-20201227073835-cf1acfcdf475/go.mod h1:bCqnVzQkZxMG4s8nGwiZ5l3QUCyqpo9Y+/ZMZ9VjZe4=
-github.com/regen-network/gocuke v0.6.2 h1:pHviZ0kKAq2U2hN2q3smKNxct6hS0mGByFMHGnWA97M=
-github.com/rivo/uniseg v0.2.0 h1:S1pD9weZBuJdFmowNwbpi7BJ8TNftyUImj/0WQi72jY=
-github.com/rivo/uniseg v0.2.0/go.mod h1:J6wj4VEh+S6ZtnVlnTBMWIodfgj8LQOQFoIToxlJtxc=
+github.com/regen-network/protobuf v1.3.3-alpha.regen.1 h1:OHEc+q5iIAXpqiqFKeLpu5NwTIkVXUs48vFMwzqpqY4=
+github.com/regen-network/protobuf v1.3.3-alpha.regen.1/go.mod h1:2DjTFR1HhMQhiWC5sZ4OhQ3+NtdbZ6oBDKQwq5Ou+FI=
+github.com/rivo/uniseg v0.4.3 h1:utMvzDsuh3suAEnhH0RdHmoPbU648o6CvXxTx4SBMOw=
github.com/rogpeppe/fastuuid v0.0.0-20150106093220-6724a57986af/go.mod h1:XWv6SoW27p1b0cqNHllgS5HIMJraePCO15w5zCzIWYg=
github.com/rogpeppe/fastuuid v1.2.0/go.mod h1:jVj6XXZzXRy/MSR5jhDC/2q6DgLz+nrA6LYCDYWNEvQ=
github.com/rogpeppe/go-internal v1.3.0/go.mod h1:M8bDsm7K2OlrFYOpmOWEs/qY81heoFRclV5y23lUDJ4=
-github.com/rogpeppe/go-internal v1.9.0 h1:73kH8U+JUqXU8lRuOHeVHaa/SZPifC7BkcraZVejAe8=
+github.com/rogpeppe/go-internal v1.9.0/go.mod h1:WtVeX8xhTBvf0smdhujwtBcq4Qrzq/fJaraNFVN+nFs=
+github.com/rogpeppe/go-internal v1.11.0 h1:cWPaGQEPrBb5/AsnsZesgZZ9yb1OQ+GOISoDNXVBh4M=
+github.com/rogpeppe/go-internal v1.11.0/go.mod h1:ddIwULY96R17DhadqLgMfk9H9tvdUzkipdSkR5nkCZA=
github.com/rs/cors v1.7.0/go.mod h1:gFx+x8UowdsKA9AchylcLynDq+nNFfI8FkUZdN/jGCU=
github.com/rs/cors v1.8.3 h1:O+qNyWn7Z+F9M0ILBHgMVPuB1xTOucVd5gtaYyXBpRo=
github.com/rs/cors v1.8.3/go.mod h1:XyqrcTp5zjWr1wsJ8PIRZssZ8b/WMcMf71DJnit4EMU=
+github.com/rs/xid v1.5.0/go.mod h1:trrq9SKmegXys3aeAKXMUTdJsYXVwGY3RLcfgqegfbg=
+github.com/rs/zerolog v1.30.0 h1:SymVODrcRsaRaSInD9yQtKbtWqwsfoPcRff/oRXLj4c=
+github.com/rs/zerolog v1.30.0/go.mod h1:/tk+P47gFdPXq4QYjvCmT5/Gsug2nagsFWBWhAiSi1w=
github.com/russross/blackfriday v1.5.2/go.mod h1:JO/DiYxRf+HjHt06OyowR9PTA263kcR/rfWxYHBV53g=
github.com/russross/blackfriday/v2 v2.0.1/go.mod h1:+Rmxgy9KzJVeS9/2gXHxylqXiyQDYRxCVz55jmeOWTM=
github.com/russross/blackfriday/v2 v2.1.0/go.mod h1:+Rmxgy9KzJVeS9/2gXHxylqXiyQDYRxCVz55jmeOWTM=
@@ -911,6 +999,7 @@ github.com/sirupsen/logrus v1.4.2/go.mod h1:tLMulIdttU9McNUspp0xgXVQah82FyeX6Mwd
github.com/sirupsen/logrus v1.6.0/go.mod h1:7uNnSEd1DgxDLC74fIahvMZmmYsHGZGEOFrfsX/uA88=
github.com/sirupsen/logrus v1.7.0/go.mod h1:yWOB1SBYBC5VeMP7gHvWumXLIWorT60ONWic61uBYv0=
github.com/sirupsen/logrus v1.9.0 h1:trlNQbNUG3OdDrDil03MCb1H2o9nJ1x4/5LYw7byDE0=
+github.com/sirupsen/logrus v1.9.0/go.mod h1:naHLuLoDiP4jHNo9R0sCBMtWGeIprob74mVsIT4qYEQ=
github.com/smartystreets/assertions v0.0.0-20180927180507-b2de0cb4f26d/go.mod h1:OnSkiWE9lh6wB0YB77sQom3nweQdgAjqCqsofrRNTgc=
github.com/smartystreets/goconvey v1.6.4/go.mod h1:syvi0/a8iFYH4r/RixwvyeAJjdLS9QV7WQ/tjFTllLA=
github.com/soheilhy/cmux v0.1.4/go.mod h1:IM3LyeVVIOuxMH7sFAkER9+bJ4dT7Ms6E4xg4kGIyLM=
@@ -919,15 +1008,15 @@ github.com/spaolacci/murmur3 v0.0.0-20180118202830-f09979ecbc72/go.mod h1:JwIasO
github.com/spaolacci/murmur3 v1.1.0 h1:7c1g84S4BPRrfL5Xrdp6fOJ206sU9y293DDHaoy0bLI=
github.com/spaolacci/murmur3 v1.1.0/go.mod h1:JwIasOWyU6f++ZhiEuf87xNszmSA2myDM2Kzu9HwQUA=
github.com/spf13/afero v1.1.2/go.mod h1:j4pytiNVoe2o6bmDsKpLACNPDBIoEAkihy7loJ1B0CQ=
-github.com/spf13/afero v1.9.3 h1:41FoI0fD7OR7mGcKE/aOiLkGreyf8ifIOQmJANWogMk=
-github.com/spf13/afero v1.9.3/go.mod h1:iUV7ddyEEZPO5gA3zD4fJt6iStLlL+Lg4m2cihcDf8Y=
+github.com/spf13/afero v1.9.5 h1:stMpOSZFs//0Lv29HduCmli3GUfpFoF3Y1Q/aXj/wVM=
+github.com/spf13/afero v1.9.5/go.mod h1:UBogFpq8E9Hx+xc5CNTTEpTnuHVmXDwZcZcE1eb/UhQ=
github.com/spf13/cast v1.3.0/go.mod h1:Qx5cxh0v+4UWYiBimWS+eyWzqEqokIECu5etghLkUJE=
-github.com/spf13/cast v1.5.0 h1:rj3WzYc11XZaIZMPKmwP96zkFEnnAmV8s6XbB2aY32w=
-github.com/spf13/cast v1.5.0/go.mod h1:SpXXQ5YoyJw6s3/6cMTQuxvgRl3PCJiyaX9p6b155UU=
+github.com/spf13/cast v1.5.1 h1:R+kOtfhWQE6TVQzY+4D7wJLBgkdVasCEFxSUBYBYIlA=
+github.com/spf13/cast v1.5.1/go.mod h1:b9PdjNptOpzXr7Rq1q9gJML/2cdGQAo69NKzQ10KN48=
github.com/spf13/cobra v0.0.3/go.mod h1:1l0Ry5zgKvJasoi3XT1TypsSe7PqH0Sj9dhYf7v3XqQ=
github.com/spf13/cobra v0.0.5/go.mod h1:3K3wKZymM7VvHMDS9+Akkh4K60UwM26emMESw8tLCHU=
-github.com/spf13/cobra v1.6.1 h1:o94oiPyS4KD1mPy2fmcYYHHfCxLqYjJOhGsCHFZtEzA=
-github.com/spf13/cobra v1.6.1/go.mod h1:IOw/AERYS7UzyrGinqmz6HLUo219MORXGxhbaJUqzrY=
+github.com/spf13/cobra v1.7.0 h1:hyqWnYt1ZQShIddO5kBpj3vu05/++x6tJ6dg8EC572I=
+github.com/spf13/cobra v1.7.0/go.mod h1:uLxZILRyS/50WlhOIKD7W6V5bgeIt+4sICxh6uRMrb0=
github.com/spf13/jwalterweatherman v1.0.0/go.mod h1:cQK4TGJAtQXfYWX+Ddv3mKDzgVb68N+wFjFa4jdeBTo=
github.com/spf13/jwalterweatherman v1.1.0 h1:ue6voC5bR5F8YxI5S67j9i582FU4Qvo2bmqnqMYADFk=
github.com/spf13/jwalterweatherman v1.1.0/go.mod h1:aNWZUN0dPAAO/Ljvb5BEdw96iTZ0EXowPYD95IqWIGo=
@@ -936,8 +1025,8 @@ github.com/spf13/pflag v1.0.3/go.mod h1:DYY7MBk1bdzusC3SYhjObp+wFpr4gzcvqqNjLnIn
github.com/spf13/pflag v1.0.5 h1:iy+VFUOCP1a+8yFto/drg2CJ5u0yRoB7fZw3DKv/JXA=
github.com/spf13/pflag v1.0.5/go.mod h1:McXfInJRrz4CZXVZOBLb0bTZqETkiAhM9Iw0y3An2Bg=
github.com/spf13/viper v1.3.2/go.mod h1:ZiWeW+zYFKm7srdB9IoDzzZXaJaI5eL9QjNiN/DMA2s=
-github.com/spf13/viper v1.15.0 h1:js3yy885G8xwJa6iOISGFwd+qlUo5AvyXb7CiihdtiU=
-github.com/spf13/viper v1.15.0/go.mod h1:fFcTBJxvhhzSJiZy8n+PeW6t8l+KeT/uTARa0jHOQLA=
+github.com/spf13/viper v1.16.0 h1:rGGH0XDZhdUOryiDWjmIvUSWpbNqisK8Wk0Vyefw8hc=
+github.com/spf13/viper v1.16.0/go.mod h1:yg78JgCJcbrQOvV9YLXgkLaZqUidkY9K+Dd1FofRzQg=
github.com/streadway/amqp v0.0.0-20190404075320-75d898a42a94/go.mod h1:AZpEONHx3DKn8O/DFsRAY58/XVQiIPMTMB1SddzLXVw=
github.com/streadway/amqp v0.0.0-20190827072141-edfb9018d271/go.mod h1:AZpEONHx3DKn8O/DFsRAY58/XVQiIPMTMB1SddzLXVw=
github.com/streadway/handy v0.0.0-20190108123426-d5acb3125c2a/go.mod h1:qNTQ5P5JnDBl6z3cMAg/SywNDC5ABu5ApDIw6lUbRmI=
@@ -956,19 +1045,22 @@ github.com/stretchr/testify v1.7.1/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/
github.com/stretchr/testify v1.7.2/go.mod h1:R6va5+xMeoiuVRoj+gSkQ7d3FALtqAAGI1FQKckRals=
github.com/stretchr/testify v1.8.0/go.mod h1:yNjHg4UonilssWZ8iaSj1OCr/vHnekPRkoO+kdMU+MU=
github.com/stretchr/testify v1.8.1/go.mod h1:w2LPCIKwWwSfY2zedu0+kehJoqGctiVI29o6fzry7u4=
-github.com/stretchr/testify v1.8.2 h1:+h33VjcLVPDHtOdpUCuF+7gSuG3yGIftsP1YvFihtJ8=
-github.com/stretchr/testify v1.8.2/go.mod h1:w2LPCIKwWwSfY2zedu0+kehJoqGctiVI29o6fzry7u4=
+github.com/stretchr/testify v1.8.3/go.mod h1:sz/lmYIOXD/1dqDmKjjqLyZ2RngseejIcXlSw2iwfAo=
+github.com/stretchr/testify v1.8.4 h1:CcVxjf3Q8PM0mHUKJCdn+eZZtm5yQwehR5yeSVQQcUk=
+github.com/stretchr/testify v1.8.4/go.mod h1:sz/lmYIOXD/1dqDmKjjqLyZ2RngseejIcXlSw2iwfAo=
+github.com/stvp/go-udp-testing v0.0.0-20201019212854-469649b16807/go.mod h1:7jxmlfBCDBXRzr0eAQJ48XC1hBu1np4CS5+cHEYfwpc=
github.com/subosito/gotenv v1.4.2 h1:X1TuBLAMDFbaTAChgCBLu3DU3UPyELpnF2jjJ2cz/S8=
github.com/subosito/gotenv v1.4.2/go.mod h1:ayKnFf/c6rvx/2iiLrJUk1e6plDbT3edrFNGqEflhK0=
+github.com/syndtr/goleveldb v1.0.1-0.20210819022825-2ae1ddf74ef7/go.mod h1:q4W45IWZaF22tdD+VEXcAWRA037jwmWEB5VWYORlTpc=
github.com/syndtr/goleveldb v1.0.1-0.20220721030215-126854af5e6d h1:vfofYNRScrDdvS342BElfbETmL1Aiz3i2t0zfRj16Hs=
github.com/syndtr/goleveldb v1.0.1-0.20220721030215-126854af5e6d/go.mod h1:RRCYJbIwD5jmqPI9XoAFR0OcDxqUctll6zUj/+B4S48=
-github.com/tecbot/gorocksdb v0.0.0-20191217155057-f0fad39f321c h1:g+WoO5jjkqGAzHWCjJB1zZfXPIAaDpzXIEJ0eS6B5Ok=
-github.com/tecbot/gorocksdb v0.0.0-20191217155057-f0fad39f321c/go.mod h1:ahpPrc7HpcfEWDQRZEmnXMzHY03mLDYMCxeDzy46i+8=
github.com/tendermint/go-amino v0.16.0 h1:GyhmgQKvqF82e2oZeuMSp9JTN0N09emoSZlb2lyGa2E=
github.com/tendermint/go-amino v0.16.0/go.mod h1:TQU0M1i/ImAo+tYpZi73AU3V/dKeCoMC9Sphe2ZwGME=
github.com/tidwall/btree v1.6.0 h1:LDZfKfQIBHGHWSwckhXI0RPSXzlo+KYdjK7FWSqOzzg=
github.com/tidwall/btree v1.6.0/go.mod h1:twD9XRA5jj9VUQGELzDO4HPQTNJsoWWfYEL+EUQ2cKY=
-github.com/tklauser/go-sysconf v0.3.5 h1:uu3Xl4nkLzQfXNsWn15rPc/HQCJKObbt1dKJeWp3vU4=
+github.com/tinylib/msgp v1.1.2 h1:gWmO7n0Ys2RBEb7GPYB9Ujq8Mk5p2U08lRnmMcGy6BQ=
+github.com/tinylib/msgp v1.1.2/go.mod h1:+d+yLhGm8mzTaHzB+wgMYrodPfmZrzkirds8fDWklFE=
+github.com/tklauser/go-sysconf v0.3.10 h1:IJ1AZGZRWbY8T5Vfk04D9WOA5WSejdflXxP03OUqALw=
github.com/tklauser/numcpus v0.4.0 h1:E53Dm1HjH1/R2/aoCtXtPgzmElmn51aOkhCFSuZq//o=
github.com/tklauser/numcpus v0.4.0/go.mod h1:1+UI3pD8NW14VMwdgJNJ1ESk2UnwhAnz5hMwiKKqXCQ=
github.com/tmc/grpc-websocket-proxy v0.0.0-20170815181823-89b8d40f7ca8/go.mod h1:ncp9v5uamzpCO7NfCPTXjqaC+bZgJeR0sMTm6dMHP7U=
@@ -978,13 +1070,22 @@ github.com/tyler-smith/go-bip39 v1.1.0/go.mod h1:gUYDtqQw1JS3ZJ8UWVcGTGqqr6YIN3C
github.com/ugorji/go v1.1.7 h1:/68gy2h+1mWMrwZFeD1kQialdSzAb432dtpeJ42ovdo=
github.com/ugorji/go v1.1.7/go.mod h1:kZn38zHttfInRq0xu/PH0az30d+z6vm202qpg1oXVMw=
github.com/ugorji/go/codec v0.0.0-20181204163529-d75b2dcb6bc8/go.mod h1:VFNgLljTbGfSG7qAOspJ7OScBnGdDN/yBr0sguwnwf0=
-github.com/ugorji/go/codec v1.1.7 h1:2SvQaVZ1ouYrrKKwoSk2pzd4A9evlKJb9oTL+OaLUSs=
github.com/ugorji/go/codec v1.1.7/go.mod h1:Ax+UKWsSmolVDwsd+7N3ZtXu+yMGCf907BLYF3GoBXY=
+github.com/ugorji/go/codec v1.2.7 h1:YPXUKf7fYbp/y8xloBqZOw2qaVggbfwMlI8WM3wZUJ0=
github.com/ulikunitz/xz v0.5.10/go.mod h1:nbz6k7qbPmH4IRqmfOplQw/tblSgqTqBwxkY0oWt/14=
github.com/ulikunitz/xz v0.5.11 h1:kpFauv27b6ynzBNT/Xy+1k+fK4WswhN/6PN5WhFAGw8=
github.com/ulikunitz/xz v0.5.11/go.mod h1:nbz6k7qbPmH4IRqmfOplQw/tblSgqTqBwxkY0oWt/14=
github.com/urfave/cli v1.20.0/go.mod h1:70zkFmudgCuE/ngEzBv17Jvp/497gISqfk5gWijbERA=
github.com/urfave/cli v1.22.1/go.mod h1:Gos4lmkARVdJ6EkW0WaNv/tZAAMe9V7XWyB60NtXRu0=
+github.com/valyala/bytebufferpool v1.0.0 h1:GqA5TC/0021Y/b9FG4Oi9Mr3q7XYx6KllzawFIhcdPw=
+github.com/valyala/bytebufferpool v1.0.0/go.mod h1:6bBcMArwyJ5K/AmCkWv1jt77kVWyCJ6HpOuEn7z0Csc=
+github.com/valyala/fasttemplate v1.2.1/go.mod h1:KHLXt3tVN2HBp8eijSv/kGJopbvo7S+qRAEEKiv+SiQ=
+github.com/valyala/fasttemplate v1.2.2 h1:lxLXG0uE3Qnshl9QyaK6XJxMXlQZELvChBOCmQD0Loo=
+github.com/valyala/fasttemplate v1.2.2/go.mod h1:KHLXt3tVN2HBp8eijSv/kGJopbvo7S+qRAEEKiv+SiQ=
+github.com/vmihailenco/msgpack/v4 v4.3.11 h1:Q47CePddpNGNhk4GCnAx9DDtASi2rasatE0cd26cZoE=
+github.com/vmihailenco/msgpack/v4 v4.3.11/go.mod h1:gborTTJjAo/GWTqqRjrLCn9pgNN+NXzzngzBKDPIqw4=
+github.com/vmihailenco/tagparser v0.1.1 h1:quXMXlA39OCbd2wAdTsGDlK9RkOk6Wuw+x37wVyIuWY=
+github.com/vmihailenco/tagparser v0.1.1/go.mod h1:OeAg3pn3UbLjkWt+rN9oFYB6u/cQgqMEUPoW2WPyhdI=
github.com/xiang90/probing v0.0.0-20190116061207-43a291ad63a2/go.mod h1:UETIi67q53MR2AWcXfiuqkDkRtnGDLqkBTpCHuJHxtU=
github.com/xordataexchange/crypt v0.0.3-0.20170626215501-b2862e3d0a77/go.mod h1:aYKd//L2LvnjZzWKhF00oedf4jCCReLcmhLdhm1A27Q=
github.com/yuin/goldmark v1.1.25/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74=
@@ -998,8 +1099,8 @@ github.com/zondax/hid v0.9.1/go.mod h1:l5wttcP0jwtdLjqjMMWFVEE7d1zO0jvSPA9OPZxWp
github.com/zondax/ledger-go v0.14.1 h1:Pip65OOl4iJ84WTpA4BKChvOufMhhbxED3BaihoZN4c=
github.com/zondax/ledger-go v0.14.1/go.mod h1:fZ3Dqg6qcdXWSOJFKMG8GCTnD7slO/RL2feOQv8K320=
go.etcd.io/bbolt v1.3.3/go.mod h1:IbVyRI1SCnLcuJnV2u8VeU0CEYM7e686BmAb1XKL+uU=
-go.etcd.io/bbolt v1.3.6 h1:/ecaJf0sk1l4l6V4awd65v2C3ILy7MSj+s/x1ADCIMU=
-go.etcd.io/bbolt v1.3.6/go.mod h1:qXsaaIqmgQH0T+OPdb99Bf+PKfBBQVAdyD6TY9G8XM4=
+go.etcd.io/bbolt v1.3.7 h1:j+zJOnnEjF/kyHlDDgGnVL/AIqIJPq8UoB2GSNfkUfQ=
+go.etcd.io/bbolt v1.3.7/go.mod h1:N9Mkw9X8x5fupy0IKsmuqVtoGDyxsaDlbk4Rd05IAQw=
go.etcd.io/etcd v0.0.0-20191023171146-3cf2f69b5738/go.mod h1:dnLIgRNXwCJa5e+c6mIZCrds/GIG4ncV9HhK5PX7jPg=
go.opencensus.io v0.20.1/go.mod h1:6WKK9ahsWS3RSO+PY9ZHZUfv2irvY6gN279GOPZjmmk=
go.opencensus.io v0.20.2/go.mod h1:6WKK9ahsWS3RSO+PY9ZHZUfv2irvY6gN279GOPZjmmk=
@@ -1039,14 +1140,14 @@ golang.org/x/crypto v0.0.0-20190605123033-f99c8df09eb5/go.mod h1:yigFU9vqHzYiE8U
golang.org/x/crypto v0.0.0-20190701094942-4def268fd1a4/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI=
golang.org/x/crypto v0.0.0-20191011191535-87dc89f01550/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI=
golang.org/x/crypto v0.0.0-20191206172530-e9b2fee46413/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto=
-golang.org/x/crypto v0.0.0-20200115085410-6d4e4cb37c7d/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto=
golang.org/x/crypto v0.0.0-20200622213623-75b288015ac9/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto=
golang.org/x/crypto v0.0.0-20200728195943-123391ffb6de/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto=
golang.org/x/crypto v0.0.0-20210421170649-83a5a9bb288b/go.mod h1:T9bdIzuCu7OtxOm1hfPfRQxPLYneinmdGuTeoZ9dtd4=
golang.org/x/crypto v0.0.0-20210921155107-089bfa567519/go.mod h1:GvvjBRRGRdwPK5ydBHafDWAxML/pGHZbMvKqRZ5+Abc=
-golang.org/x/crypto v0.0.0-20211108221036-ceb1ce70b4fa/go.mod h1:GvvjBRRGRdwPK5ydBHafDWAxML/pGHZbMvKqRZ5+Abc=
-golang.org/x/crypto v0.6.0 h1:qfktjS5LUO+fFKeJXZ+ikTRijMmljikvG68fpMMruSc=
-golang.org/x/crypto v0.6.0/go.mod h1:OFC/31mSvZgRz0V1QTNCzfAI1aIRzbiufJtkMIlEp58=
+golang.org/x/crypto v0.0.0-20220314234659-1baeb1ce4c0b/go.mod h1:IxCIyHEi3zRg3s0A5j5BB6A9Jmi73HwBIUl50j+osU4=
+golang.org/x/crypto v0.0.0-20220722155217-630584e8d5aa/go.mod h1:IxCIyHEi3zRg3s0A5j5BB6A9Jmi73HwBIUl50j+osU4=
+golang.org/x/crypto v0.11.0 h1:6Ewdq3tDic1mg5xRO4milcWCfMVQhI4NkqWWvqejpuA=
+golang.org/x/crypto v0.11.0/go.mod h1:xgJhtzW8F9jGdVFWZESrid1U1bjeNy4zgy5cRr/CIio=
golang.org/x/exp v0.0.0-20190121172915-509febef88a4/go.mod h1:CJ0aWSM057203Lf6IL+f9T1iT9GByDxfZKAQTCR3kQA=
golang.org/x/exp v0.0.0-20190306152737-a1d7652674e8/go.mod h1:CJ0aWSM057203Lf6IL+f9T1iT9GByDxfZKAQTCR3kQA=
golang.org/x/exp v0.0.0-20190510132918-efd6b22b2522/go.mod h1:ZjyILWgesfNpC6sMxTJOJm9Kp84zZh5NQWvqDGG3Qr8=
@@ -1058,8 +1159,8 @@ golang.org/x/exp v0.0.0-20200119233911-0405dc783f0a/go.mod h1:2RIsYlXP63K8oxa1u0
golang.org/x/exp v0.0.0-20200207192155-f17229e696bd/go.mod h1:J/WKrq2StrnmMY6+EHIKF9dgMWnmCNThgcyBT1FY9mM=
golang.org/x/exp v0.0.0-20200224162631-6cc2880d07d6/go.mod h1:3jZMyOhIsHpP37uCMkUooju7aAi5cS1Q23tOzKc+0MU=
golang.org/x/exp v0.0.0-20200331195152-e8c3332aa8e5/go.mod h1:4M0jN8W1tt0AVLNr8HDosyJCDCDuyL9N9+3m7wDWgKw=
-golang.org/x/exp v0.0.0-20230213192124-5e25df0256eb h1:PaBZQdo+iSDyHT053FjUCgZQ/9uqVwPOcl7KSWhKn6w=
-golang.org/x/exp v0.0.0-20230213192124-5e25df0256eb/go.mod h1:CxIveKay+FTh1D0yPZemJVgC/95VzuuOLq5Qi4xnoYc=
+golang.org/x/exp v0.0.0-20230711153332-06a737ee72cb h1:xIApU0ow1zwMa2uL1VDNeQlNVFTWMQxZUZCMDy0Q4Us=
+golang.org/x/exp v0.0.0-20230711153332-06a737ee72cb/go.mod h1:FXUEEKJgO7OQYeo8N01OfiKP8RXMtf6e8aTskBGqWdc=
golang.org/x/image v0.0.0-20190227222117-0694c2d4d067/go.mod h1:kZ7UVZpmo3dzQBMxlp+ypCbDeSB+sBbTgSJuh5dn5js=
golang.org/x/image v0.0.0-20190802002840-cff245a6509b/go.mod h1:FeLwcggjj3mMvU+oOTbSwawSJRM1uh48EjtB4UJZlP0=
golang.org/x/lint v0.0.0-20181026193005-c67002cb31c3/go.mod h1:UVdnD1Gm6xHRNCYTkRU2/jEulfH38KcIWyp/GAMgvoE=
@@ -1086,8 +1187,9 @@ golang.org/x/mod v0.4.0/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA=
golang.org/x/mod v0.4.1/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA=
golang.org/x/mod v0.4.2/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA=
golang.org/x/mod v0.6.0-dev.0.20220419223038-86c51ed26bb4/go.mod h1:jJ57K6gSWd91VN4djpZkiMVwK6gcyfeH4XE8wZrZaV4=
-golang.org/x/mod v0.8.0 h1:LUYupSeNrTNCGzR/hVBk2NHZO4hXcVaW1k4Qx7rjPx8=
-golang.org/x/mod v0.8.0/go.mod h1:iBbtSCu2XBx23ZKBPSOrRkjjQPZFPuis4dIYUhu/chs=
+golang.org/x/mod v0.11.0 h1:bUO06HqtnRcc/7l71XBe4WcqTZ+3AH1J59zWDDwLKgU=
+golang.org/x/mod v0.11.0/go.mod h1:iBbtSCu2XBx23ZKBPSOrRkjjQPZFPuis4dIYUhu/chs=
+golang.org/x/net v0.0.0-20180719180050-a680a1efc54d/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4=
golang.org/x/net v0.0.0-20180724234803-3673e40ba225/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4=
golang.org/x/net v0.0.0-20180826012351-8a410e7b638d/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4=
golang.org/x/net v0.0.0-20180906233101-161cd47e91fd/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4=
@@ -1123,6 +1225,7 @@ golang.org/x/net v0.0.0-20200520004742-59133d7f0dd7/go.mod h1:qpuaurCH72eLCgpAm/
golang.org/x/net v0.0.0-20200520182314-0ba52f642ac2/go.mod h1:qpuaurCH72eLCgpAm/N6yyVIVM9cpaDIP3A8BGJEC5A=
golang.org/x/net v0.0.0-20200625001655-4c5254603344/go.mod h1:/O7V0waA8r7cgGh81Ro3o1hOxt32SMVPicZroKQ2sZA=
golang.org/x/net v0.0.0-20200707034311-ab3426394381/go.mod h1:/O7V0waA8r7cgGh81Ro3o1hOxt32SMVPicZroKQ2sZA=
+golang.org/x/net v0.0.0-20200813134508-3edf25e44fcc/go.mod h1:/O7V0waA8r7cgGh81Ro3o1hOxt32SMVPicZroKQ2sZA=
golang.org/x/net v0.0.0-20200822124328-c89045814202/go.mod h1:/O7V0waA8r7cgGh81Ro3o1hOxt32SMVPicZroKQ2sZA=
golang.org/x/net v0.0.0-20201021035429-f5854403a974/go.mod h1:sp8m0HH+o8qH0wwXwYZr8TS3Oi6o0r6Gce1SSxlDquU=
golang.org/x/net v0.0.0-20201031054903-ff519b6c9102/go.mod h1:sp8m0HH+o8qH0wwXwYZr8TS3Oi6o0r6Gce1SSxlDquU=
@@ -1135,7 +1238,9 @@ golang.org/x/net v0.0.0-20210316092652-d523dce5a7f4/go.mod h1:RBQZq4jEuRlivfhVLd
golang.org/x/net v0.0.0-20210405180319-a5a99cb37ef4/go.mod h1:p54w0d4576C0XHj96bSt6lcn1PtDYWL6XObtHCRCNQM=
golang.org/x/net v0.0.0-20210428140749-89ef3d95e781/go.mod h1:OJAsFXCWl8Ukc7SiCT/9KSuxbyM7479/AVlXFRxuMCk=
golang.org/x/net v0.0.0-20210503060351-7fd8e65b6420/go.mod h1:9nx3DQGgdP8bBQD5qxJ1jj9UTztislL4KSBs9R2vV5Y=
+golang.org/x/net v0.0.0-20210525063256-abc453219eb5/go.mod h1:9nx3DQGgdP8bBQD5qxJ1jj9UTztislL4KSBs9R2vV5Y=
golang.org/x/net v0.0.0-20210805182204-aaa1db679c0d/go.mod h1:9nx3DQGgdP8bBQD5qxJ1jj9UTztislL4KSBs9R2vV5Y=
+golang.org/x/net v0.0.0-20211112202133-69e39bad7dc2/go.mod h1:9nx3DQGgdP8bBQD5qxJ1jj9UTztislL4KSBs9R2vV5Y=
golang.org/x/net v0.0.0-20220127200216-cd36cc0744dd/go.mod h1:CfG3xpIq0wQ8r1q4Su4UZFWDARRcnwPjda9FqA0JpMk=
golang.org/x/net v0.0.0-20220225172249-27dd8689420f/go.mod h1:CfG3xpIq0wQ8r1q4Su4UZFWDARRcnwPjda9FqA0JpMk=
golang.org/x/net v0.0.0-20220325170049-de3da57026de/go.mod h1:CfG3xpIq0wQ8r1q4Su4UZFWDARRcnwPjda9FqA0JpMk=
@@ -1148,8 +1253,8 @@ golang.org/x/net v0.0.0-20220722155237-a158d28d115b/go.mod h1:XRhObCWvk6IyKnWLug
golang.org/x/net v0.0.0-20220909164309-bea034e7d591/go.mod h1:YDH+HFinaLZZlnHAfSS6ZXJJ9M9t4Dl22yv3iI2vPwk=
golang.org/x/net v0.0.0-20221014081412-f15817d10f9b/go.mod h1:YDH+HFinaLZZlnHAfSS6ZXJJ9M9t4Dl22yv3iI2vPwk=
golang.org/x/net v0.1.0/go.mod h1:Cx3nUiGt4eDBEyega/BKRp+/AlGL8hYe7U9odMt2Cco=
-golang.org/x/net v0.7.0 h1:rJrUqqhjsgNp7KqAIc25s9pZnjU7TUcSY7HcVZjdn1g=
-golang.org/x/net v0.7.0/go.mod h1:2Tu9+aMcznHK/AK1HMvgo6xiTLG5rD5rZLDS+rp2Bjs=
+golang.org/x/net v0.12.0 h1:cfawfvKITfUsFCeJIHJrbSxpeu/E81khclypR0GVT50=
+golang.org/x/net v0.12.0/go.mod h1:zEVYFnQC7m/vmpQFELhcD1EWkZlX69l4oqgmer6hfKA=
golang.org/x/oauth2 v0.0.0-20180821212333-d2e6202438be/go.mod h1:N/0e6XlmueqKjAGxoOufVs8QHGRruUQn6yWY3a++T0U=
golang.org/x/oauth2 v0.0.0-20190226205417-e64efc72b421/go.mod h1:gOpvHmFTYa4IltrdGE7lF6nIHvwfUNPOp7c8zoXwtLw=
golang.org/x/oauth2 v0.0.0-20190604053449-0f29369cfe45/go.mod h1:gOpvHmFTYa4IltrdGE7lF6nIHvwfUNPOp7c8zoXwtLw=
@@ -1175,8 +1280,8 @@ golang.org/x/oauth2 v0.0.0-20220822191816-0ebed06d0094/go.mod h1:h4gKUeWbJ4rQPri
golang.org/x/oauth2 v0.0.0-20220909003341-f21342109be1/go.mod h1:h4gKUeWbJ4rQPri7E0u6Gs4e9Ri2zaLxzw5DI5XGrYg=
golang.org/x/oauth2 v0.0.0-20221014153046-6fdb5e3db783/go.mod h1:h4gKUeWbJ4rQPri7E0u6Gs4e9Ri2zaLxzw5DI5XGrYg=
golang.org/x/oauth2 v0.1.0/go.mod h1:G9FE4dLTsbXUu90h/Pf85g4w1D+SSAgR+q46nJZ8M4A=
-golang.org/x/oauth2 v0.5.0 h1:HuArIo48skDwlrvM3sEdHXElYslAMsf3KwRkkW4MC4s=
-golang.org/x/oauth2 v0.5.0/go.mod h1:9/XBHVqLaWO3/BRHs5jbpYCnOZVjj5V0ndyaAM7KB4I=
+golang.org/x/oauth2 v0.8.0 h1:6dkIjl3j3LtZ/O3sTgZTMsLKSftL/B8Zgq4huOIIUu8=
+golang.org/x/oauth2 v0.8.0/go.mod h1:yr7u4HXZRm1R1kBWqr/xKNqewf0plRYoB7sla+BCIXE=
golang.org/x/sync v0.0.0-20180314180146-1d60e4601c6f/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
golang.org/x/sync v0.0.0-20181108010431-42b317875d0f/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
golang.org/x/sync v0.0.0-20181221193216-37e7f081c4d4/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
@@ -1191,8 +1296,8 @@ golang.org/x/sync v0.0.0-20210220032951-036812b2e83c/go.mod h1:RxMgew5VJxzue5/jJ
golang.org/x/sync v0.0.0-20220601150217-0de741cfad7f/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
golang.org/x/sync v0.0.0-20220722155255-886fb9371eb4/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
golang.org/x/sync v0.0.0-20220929204114-8fcdb60fdcc0/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
-golang.org/x/sync v0.1.0 h1:wsuoTGHzEhffawBOhz5CYhcrV4IdKZbEyZjBMuTp12o=
-golang.org/x/sync v0.1.0/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
+golang.org/x/sync v0.2.0 h1:PUR+T4wwASmuSTYdKjYHI5TD22Wy5ogLU5qZCOLxBrI=
+golang.org/x/sync v0.2.0/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
golang.org/x/sys v0.0.0-20180823144017-11551d06cbcc/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
golang.org/x/sys v0.0.0-20180830151530-49385e6e1522/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
golang.org/x/sys v0.0.0-20180905080454-ebe1bf3edb33/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
@@ -1236,18 +1341,20 @@ golang.org/x/sys v0.0.0-20200420163511-1957bb5e6d1f/go.mod h1:h1NjWce9XRLGQEsW7w
golang.org/x/sys v0.0.0-20200501052902-10377860bb8e/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20200511232937-7e40ca221e25/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20200515095857-1151b9dac4a9/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
+golang.org/x/sys v0.0.0-20200519105757-fe76b779f299/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20200523222454-059865788121/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20200615200032-f1bc736245b1/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20200625212154-ddb9806d33ae/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20200803210538-64077c9b5642/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
+golang.org/x/sys v0.0.0-20200814200057-3d37ad5750ed/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20200905004654-be1d3432aa8f/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
-golang.org/x/sys v0.0.0-20200923182605-d9f96fdee20d/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20200930185726-fdedc70b468f/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20201119102817-f84b799fce68/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20201201145000-ef89a241ccb3/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20210104204734-6f8348627aad/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20210112080510-489259a85091/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20210119212857-b64e53b001e4/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
+golang.org/x/sys v0.0.0-20210124154548-22da62e12c0c/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20210220050731-9a76102bfb43/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20210225134936-a50acf3fe073/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20210305230114-8fe3ee5dd75b/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
@@ -1258,6 +1365,7 @@ golang.org/x/sys v0.0.0-20210423082822-04245dca01da/go.mod h1:h1NjWce9XRLGQEsW7w
golang.org/x/sys v0.0.0-20210423185535-09eb48e85fd7/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20210510120138-977fb7262007/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/sys v0.0.0-20210514084401-e8d321eab015/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
+golang.org/x/sys v0.0.0-20210603081109-ebe580a85c40/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/sys v0.0.0-20210603125802-9665404d3644/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/sys v0.0.0-20210615035016-665e8c7367d1/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/sys v0.0.0-20210616094352-59db8d763f22/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
@@ -1267,9 +1375,12 @@ golang.org/x/sys v0.0.0-20210809222454-d867a43fc93e/go.mod h1:oPkhp1MJrh7nUepCBc
golang.org/x/sys v0.0.0-20210819135213-f52c844e1c1c/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/sys v0.0.0-20210823070655-63515b42dcdf/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/sys v0.0.0-20210908233432-aa78b53d3365/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
+golang.org/x/sys v0.0.0-20210927094055-39ccf1dd6fa6/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
+golang.org/x/sys v0.0.0-20211103235746-7861aae1554b/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/sys v0.0.0-20211124211545-fe61309f8881/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/sys v0.0.0-20211210111614-af8b64212486/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/sys v0.0.0-20211216021012-1d35b9e2eb4e/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
+golang.org/x/sys v0.0.0-20220114195835-da31bd327af9/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/sys v0.0.0-20220128215802-99c3d69c2c27/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/sys v0.0.0-20220209214540-3681064d5158/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/sys v0.0.0-20220227234510-4e6760a101f9/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
@@ -1283,19 +1394,22 @@ golang.org/x/sys v0.0.0-20220520151302-bc2c85ada10a/go.mod h1:oPkhp1MJrh7nUepCBc
golang.org/x/sys v0.0.0-20220610221304-9f5ed59c137d/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/sys v0.0.0-20220615213510-4f61da869c0c/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/sys v0.0.0-20220624220833-87e55d714810/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
+golang.org/x/sys v0.0.0-20220708085239-5a0f0661e09d/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
+golang.org/x/sys v0.0.0-20220715151400-c0bba94af5f8/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/sys v0.0.0-20220722155257-8c9f86f7a55f/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/sys v0.0.0-20220728004956-3c1f35247d10/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/sys v0.0.0-20220811171246-fbc7d0a398ab/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/sys v0.0.0-20220908164124-27713097b956/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/sys v0.0.0-20221010170243-090e33056c14/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/sys v0.1.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
-golang.org/x/sys v0.5.0 h1:MUK/U/4lj1t1oPg0HfuXDN/Z1wv31ZJ/YcPiGccS4DU=
-golang.org/x/sys v0.5.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
+golang.org/x/sys v0.6.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
+golang.org/x/sys v0.11.0 h1:eG7RXZHdqOJ1i+0lgLgCpSXAp6M3LYlAo6osgSi0xOM=
+golang.org/x/sys v0.11.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/term v0.0.0-20201126162022-7de9c90e9dd1/go.mod h1:bj7SfCRtBDWHUb9snDiAeCFNEtKQo2Wmx5Cou7ajbmo=
golang.org/x/term v0.0.0-20210927222741-03fcf44c2211/go.mod h1:jbD1KX2456YbFQfuXm/mYQcufACuNUgVhRMnK/tPxf8=
golang.org/x/term v0.1.0/go.mod h1:jbD1KX2456YbFQfuXm/mYQcufACuNUgVhRMnK/tPxf8=
-golang.org/x/term v0.5.0 h1:n2a8QNdAb0sZNpU9R1ALUXBbY+w51fCQDN+7EdxNBsY=
-golang.org/x/term v0.5.0/go.mod h1:jMB1sMXY+tzblOD4FWmEbocvup2/aLOaQEp7JmGp78k=
+golang.org/x/term v0.10.0 h1:3R7pNqamzBraeqj/Tj8qt1aQ2HpmlC+Cx/qL/7hn4/c=
+golang.org/x/term v0.10.0/go.mod h1:lpqdcUyK/oCiQxvxVrppt5ggO2KCZ5QblwqPnfZ6d5o=
golang.org/x/text v0.0.0-20170915032832-14c0d48ead0c/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ=
golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ=
golang.org/x/text v0.3.1-0.20180807135948-17ff2d5776d2/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ=
@@ -1305,17 +1419,18 @@ golang.org/x/text v0.3.4/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ=
golang.org/x/text v0.3.5/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ=
golang.org/x/text v0.3.6/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ=
golang.org/x/text v0.3.7/go.mod h1:u+2+/6zg+i71rQMx5EYifcz6MCKuco9NR6JIITiCfzQ=
+golang.org/x/text v0.3.8/go.mod h1:E6s5w1FMmriuDzIBO73fBruAKo1PCIq6d2Q6DHfQ8WQ=
golang.org/x/text v0.4.0/go.mod h1:mrYo+phRRbMaCq/xk9113O4dZlRixOauAjOtrjsXDZ8=
-golang.org/x/text v0.7.0 h1:4BRB4x83lYWy72KwLD/qYDuTu7q9PjSagHvijDw7cLo=
-golang.org/x/text v0.7.0/go.mod h1:mrYo+phRRbMaCq/xk9113O4dZlRixOauAjOtrjsXDZ8=
+golang.org/x/text v0.12.0 h1:k+n5B8goJNdU7hSvEtMUz3d1Q6D/XW4COJSJR6fN0mc=
+golang.org/x/text v0.12.0/go.mod h1:TvPlkZtksWOMsz7fbANvkp4WM8x/WCo/om8BMLbz+aE=
golang.org/x/time v0.0.0-20180412165947-fbb02b2291d2/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ=
golang.org/x/time v0.0.0-20181108054448-85acf8d2951c/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ=
golang.org/x/time v0.0.0-20190308202827-9d24e82272b4/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ=
golang.org/x/time v0.0.0-20191024005414-555d28b269f0/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ=
-golang.org/x/tools v0.0.0-20180221164845-07fd8470d635/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ=
+golang.org/x/time v0.3.0 h1:rg5rLMjNzMS1RkNLzCG38eapWhnYLFYXDXj2gOlr8j4=
+golang.org/x/time v0.3.0/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ=
golang.org/x/tools v0.0.0-20180828015842-6cd1fcedba52/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ=
golang.org/x/tools v0.0.0-20180917221912-90fa682c2a6e/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ=
-golang.org/x/tools v0.0.0-20181030221726-6c7e314b6563/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ=
golang.org/x/tools v0.0.0-20190114222345-bf090417da8b/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ=
golang.org/x/tools v0.0.0-20190226205152-f727befe758c/go.mod h1:9Yl7xja0Znq3iFh3HoIrodX9oNMXvdceNzlUR8zjMvY=
golang.org/x/tools v0.0.0-20190311212946-11955173bddd/go.mod h1:LCzVGOaR6xXOjkQ3onu1FJEFr0SW1gC7cKk1uF8kGRs=
@@ -1375,7 +1490,7 @@ golang.org/x/tools v0.1.3/go.mod h1:o0xws9oXOQQZyjljx8fwUC0k7L1pTE6eaCbjGeHmOkk=
golang.org/x/tools v0.1.4/go.mod h1:o0xws9oXOQQZyjljx8fwUC0k7L1pTE6eaCbjGeHmOkk=
golang.org/x/tools v0.1.5/go.mod h1:o0xws9oXOQQZyjljx8fwUC0k7L1pTE6eaCbjGeHmOkk=
golang.org/x/tools v0.1.12/go.mod h1:hNGJHUnrk76NpqgfD5Aqm5Crs+Hm0VOH/i9J2+nxYbc=
-golang.org/x/tools v0.6.0 h1:BOw41kyTf3PuCW1pVQf8+Cyg8pMlkYB1oo9iJ6D/lKM=
+golang.org/x/tools v0.8.0 h1:vSDcovVPld282ceKgDimkRSC8kpaH1dgyc9UMzlt84Y=
golang.org/x/xerrors v0.0.0-20190717185122-a985d3407aa7/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
golang.org/x/xerrors v0.0.0-20191011141410-1b5146add898/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
@@ -1434,8 +1549,8 @@ google.golang.org/api v0.96.0/go.mod h1:w7wJQLTM+wvQpNf5JyEcBoxK0RH7EDrh/L4qfsuJ
google.golang.org/api v0.97.0/go.mod h1:w7wJQLTM+wvQpNf5JyEcBoxK0RH7EDrh/L4qfsuJ13s=
google.golang.org/api v0.98.0/go.mod h1:w7wJQLTM+wvQpNf5JyEcBoxK0RH7EDrh/L4qfsuJ13s=
google.golang.org/api v0.100.0/go.mod h1:ZE3Z2+ZOr87Rx7dqFsdRQkRBk36kDtp/h+QpHbB7a70=
-google.golang.org/api v0.110.0 h1:l+rh0KYUooe9JGbGVx71tbFo4SMbMTXK3I3ia2QSEeU=
-google.golang.org/api v0.110.0/go.mod h1:7FC4Vvx1Mooxh8C5HWjzZHcavuS2f6pmJpZx60ca7iI=
+google.golang.org/api v0.126.0 h1:q4GJq+cAdMAC7XP7njvQ4tvohGLiSlytuL4BQxbIZ+o=
+google.golang.org/api v0.126.0/go.mod h1:mBwVAtz+87bEN6CbA1GtZPDOqY2R5ONPqJeIlvyo4Aw=
google.golang.org/appengine v1.1.0/go.mod h1:EbEs0AVv82hx2wNQdGPgUI5lhzA/G0D9YwlJXL52JkM=
google.golang.org/appengine v1.2.0/go.mod h1:xpcJRLb0r/rnEns0DIKYYv+WjYCduHsrkT7/EB5XEv4=
google.golang.org/appengine v1.4.0/go.mod h1:xpcJRLb0r/rnEns0DIKYYv+WjYCduHsrkT7/EB5XEv4=
@@ -1467,6 +1582,7 @@ google.golang.org/genproto v0.0.0-20200224152610-e50cd9704f63/go.mod h1:55QSHmfG
google.golang.org/genproto v0.0.0-20200228133532-8c2c7df3a383/go.mod h1:55QSHmfGQM9UVYDPBsyGGes0y52j32PQ3BqQfXhyH3c=
google.golang.org/genproto v0.0.0-20200305110556-506484158171/go.mod h1:55QSHmfGQM9UVYDPBsyGGes0y52j32PQ3BqQfXhyH3c=
google.golang.org/genproto v0.0.0-20200312145019-da6875a35672/go.mod h1:55QSHmfGQM9UVYDPBsyGGes0y52j32PQ3BqQfXhyH3c=
+google.golang.org/genproto v0.0.0-20200324203455-a04cca1dde73/go.mod h1:55QSHmfGQM9UVYDPBsyGGes0y52j32PQ3BqQfXhyH3c=
google.golang.org/genproto v0.0.0-20200331122359-1ee6d9798940/go.mod h1:55QSHmfGQM9UVYDPBsyGGes0y52j32PQ3BqQfXhyH3c=
google.golang.org/genproto v0.0.0-20200423170343-7949de9c1215/go.mod h1:55QSHmfGQM9UVYDPBsyGGes0y52j32PQ3BqQfXhyH3c=
google.golang.org/genproto v0.0.0-20200430143042-b979b6f78d84/go.mod h1:55QSHmfGQM9UVYDPBsyGGes0y52j32PQ3BqQfXhyH3c=
@@ -1553,8 +1669,12 @@ google.golang.org/genproto v0.0.0-20221010155953-15ba04fc1c0e/go.mod h1:3526vdqw
google.golang.org/genproto v0.0.0-20221014173430-6e2ab493f96b/go.mod h1:1vXfmgAz9N9Jx0QA82PqRVauvCz1SGSz739p0f183jM=
google.golang.org/genproto v0.0.0-20221014213838-99cd37c6964a/go.mod h1:1vXfmgAz9N9Jx0QA82PqRVauvCz1SGSz739p0f183jM=
google.golang.org/genproto v0.0.0-20221025140454-527a21cfbd71/go.mod h1:9qHF0xnpdSfF6knlcsnpzUu5y+rpwgbvsyGAZPBMg4s=
-google.golang.org/genproto v0.0.0-20230216225411-c8e22ba71e44 h1:EfLuoKW5WfkgVdDy7dTK8qSbH37AX5mj/MFh+bGPz14=
-google.golang.org/genproto v0.0.0-20230216225411-c8e22ba71e44/go.mod h1:8B0gmkoRebU8ukX6HP+4wrVQUY1+6PkQ44BSyIlflHA=
+google.golang.org/genproto v0.0.0-20230706204954-ccb25ca9f130 h1:Au6te5hbKUV8pIYWHqOUZ1pva5qK/rwbIhoXEUB9Lu8=
+google.golang.org/genproto v0.0.0-20230706204954-ccb25ca9f130/go.mod h1:O9kGHb51iE/nOGvQaDUuadVYqovW56s5emA88lQnj6Y=
+google.golang.org/genproto/googleapis/api v0.0.0-20230629202037-9506855d4529 h1:s5YSX+ZH5b5vS9rnpGymvIyMpLRJizowqDlOuyjXnTk=
+google.golang.org/genproto/googleapis/api v0.0.0-20230629202037-9506855d4529/go.mod h1:vHYtlOoi6TsQ3Uk2yxR7NI5z8uoV+3pZtR4jmHIkRig=
+google.golang.org/genproto/googleapis/rpc v0.0.0-20230711160842-782d3b101e98 h1:bVf09lpb+OJbByTj913DRJioFFAjf/ZGxEz7MajTp2U=
+google.golang.org/genproto/googleapis/rpc v0.0.0-20230711160842-782d3b101e98/go.mod h1:TUfxEVdsvPg18p6AslUXFoLdpED4oBnGwyqk3dV1XzM=
google.golang.org/grpc v1.17.0/go.mod h1:6QZJwpn2B+Zp71q/5VxRsJ6NXXVCE5NRUHRo+f3cWCs=
google.golang.org/grpc v1.19.0/go.mod h1:mqu4LbDTu4XGKhr4mRzUsmM4RtVoemTSY81AxZiDr8c=
google.golang.org/grpc v1.20.0/go.mod h1:chYK+tFQF0nDUGJgXMSgLCQk3phJEuONr2DCgLDdAQM=
@@ -1596,8 +1716,8 @@ google.golang.org/grpc v1.48.0/go.mod h1:vN9eftEi1UMyUsIF80+uQXhHjbXYbm0uXoFCACu
google.golang.org/grpc v1.49.0/go.mod h1:ZgQEeidpAuNRZ8iRrlBKXZQP1ghovWIVhdJRyCDK+GI=
google.golang.org/grpc v1.50.0/go.mod h1:ZgQEeidpAuNRZ8iRrlBKXZQP1ghovWIVhdJRyCDK+GI=
google.golang.org/grpc v1.50.1/go.mod h1:ZgQEeidpAuNRZ8iRrlBKXZQP1ghovWIVhdJRyCDK+GI=
-google.golang.org/grpc v1.53.0 h1:LAv2ds7cmFV/XTS3XG1NneeENYrXGmorPxsBbptIjNc=
-google.golang.org/grpc v1.53.0/go.mod h1:OnIrk0ipVdj4N5d9IUoFUx72/VlD7+jUsHwZgwSMQpw=
+google.golang.org/grpc v1.56.2 h1:fVRFRnXvU+x6C4IlHZewvJOVHoOv1TUuQyoRsYnB4bI=
+google.golang.org/grpc v1.56.2/go.mod h1:I9bI3vqKfayGqPUAwGdOSu7kt6oIJLixfffKrpXqQ9s=
google.golang.org/grpc/cmd/protoc-gen-go-grpc v1.1.0/go.mod h1:6Kw0yEErY5E/yWrBtf03jp27GLLJujG4z/JK95pnjjw=
google.golang.org/protobuf v0.0.0-20200109180630-ec00e32a8dfd/go.mod h1:DFci5gLYBciE7Vtevhsrf46CRTquxDuWsQurQQe4oz8=
google.golang.org/protobuf v0.0.0-20200221191635-4d8936d0db64/go.mod h1:kwYJMbMJ01Woi6D6+Kah6886xMZcty6N08ah7+eCXa0=
@@ -1614,8 +1734,8 @@ google.golang.org/protobuf v1.26.0/go.mod h1:9q0QmTI4eRPtz6boOQmLYwt+qCgq0jsYwAQ
google.golang.org/protobuf v1.27.1/go.mod h1:9q0QmTI4eRPtz6boOQmLYwt+qCgq0jsYwAQnmE0givc=
google.golang.org/protobuf v1.28.0/go.mod h1:HV8QOd/L58Z+nl8r43ehVNZIU/HEI6OcFqwMG9pJV4I=
google.golang.org/protobuf v1.28.1/go.mod h1:HV8QOd/L58Z+nl8r43ehVNZIU/HEI6OcFqwMG9pJV4I=
-google.golang.org/protobuf v1.28.2-0.20230208135220-49eaa78c6c9c h1:gDe3xeLH/W6iv5d9xQBo6IwJbCdVcZRiV8xuix6FJW8=
-google.golang.org/protobuf v1.28.2-0.20230208135220-49eaa78c6c9c/go.mod h1:HV8QOd/L58Z+nl8r43ehVNZIU/HEI6OcFqwMG9pJV4I=
+google.golang.org/protobuf v1.31.0 h1:g0LDEJHgrBl9N9r17Ru3sqWhkIx2NB67okBHPwC7hs8=
+google.golang.org/protobuf v1.31.0/go.mod h1:HV8QOd/L58Z+nl8r43ehVNZIU/HEI6OcFqwMG9pJV4I=
gopkg.in/alecthomas/kingpin.v2 v2.2.6/go.mod h1:FMv+mEhP44yOT+4EoQTLFTRgOQ1FBLkstjWtayDeSgw=
gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
gopkg.in/check.v1 v1.0.0-20180628173108-788fd7840127/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
@@ -1627,8 +1747,13 @@ gopkg.in/cheggaaa/pb.v1 v1.0.27/go.mod h1:V/YB90LKu/1FcN3WVnfiiE5oMCibMjukxqG/qS
gopkg.in/errgo.v2 v2.1.0/go.mod h1:hNsd1EY+bozCKY1Ytp96fpM3vjJbqLJn88ws8XvfDNI=
gopkg.in/fsnotify.v1 v1.4.7/go.mod h1:Tz8NjZHkW78fSQdbUxIjBTcgA1z1m8ZHf0WmKUhAMys=
gopkg.in/gcfg.v1 v1.2.3/go.mod h1:yesOnuUOFQAhST5vPY4nbZsb/huCgGGXlipJsBn0b3o=
+gopkg.in/go-playground/assert.v1 v1.2.1 h1:xoYuJVE7KT85PYWrN730RguIQO0ePzVRfFMXadIrXTM=
+gopkg.in/go-playground/validator.v9 v9.28.0 h1:6pzvnzx1RWaaQiAmv6e1DvCFULRaz5cKoP5j1VcrLsc=
+gopkg.in/go-playground/validator.v9 v9.28.0/go.mod h1:+c9/zcJMFNgbLvly1L1V+PpxWdVbfP1avr/N00E2vyQ=
gopkg.in/ini.v1 v1.67.0 h1:Dgnx+6+nfE+IfzjUEISNeydPJh9AXNNsWbGP9KzCsOA=
gopkg.in/ini.v1 v1.67.0/go.mod h1:pNLf8WUiyNEtQjuu5G5vTm06TEv9tsIgeAvK8hOrP4k=
+gopkg.in/natefinch/lumberjack.v2 v2.0.0 h1:1Lc07Kr7qY4U2YPouBjpCLxpiyxIVoxqXgkXLknAOE8=
+gopkg.in/natefinch/lumberjack.v2 v2.0.0/go.mod h1:l0ndWWf7gzL7RNwBG7wST/UCcT4T24xpD6X8LsfU/+k=
gopkg.in/resty.v1 v1.12.0/go.mod h1:mDo4pnntr5jdWRML875a/NmxYqAlA73dVijT2AXvQQo=
gopkg.in/tomb.v1 v1.0.0-20141024135613-dd632973f1e7 h1:uRGJdciOHaEIrze2W8Q3AKkepLTh2hOroT7a+7czfdQ=
gopkg.in/tomb.v1 v1.0.0-20141024135613-dd632973f1e7/go.mod h1:dt/ZhP58zS4L8KSrWDmTeBkI65Dw0HsyUHuEVlX15mw=
@@ -1648,7 +1773,7 @@ gopkg.in/yaml.v3 v3.0.0-20210107192922-496545a6307b/go.mod h1:K4uyk7z7BCEPqu6E+C
gopkg.in/yaml.v3 v3.0.1 h1:fxVm/GzAzEWqLHuvctI91KS9hhNmmWOoWu0XTYJS7CA=
gopkg.in/yaml.v3 v3.0.1/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=
gotest.tools v2.2.0+incompatible h1:VsBPFP1AI068pPrMxtb/S8Zkgf9xEmTLJjfM+P5UIEo=
-gotest.tools/v3 v3.4.0 h1:ZazjZUfuVeZGLAmlKKuyv3IKP5orXcwtOwDQH6YVr6o=
+gotest.tools/v3 v3.5.0 h1:Ljk6PdHdOhAb5aDMWXjDLMMhph+BpztA4v1QdqEW2eY=
honnef.co/go/tools v0.0.0-20180728063816-88497007e858/go.mod h1:rf3lG4BRIbNafJWhAfAdb/ePZxsR/4RtNHQocxwk9r4=
honnef.co/go/tools v0.0.0-20190102054323-c2f93a96b099/go.mod h1:rf3lG4BRIbNafJWhAfAdb/ePZxsR/4RtNHQocxwk9r4=
honnef.co/go/tools v0.0.0-20190106161140-3f1c8253044a/go.mod h1:rf3lG4BRIbNafJWhAfAdb/ePZxsR/4RtNHQocxwk9r4=
diff --git a/go.work b/go.work
new file mode 100644
index 000000000..b9db675cb
--- /dev/null
+++ b/go.work
@@ -0,0 +1,6 @@
+go 1.20
+
+use (
+ .
+ ./interchaintest
+)
diff --git a/interchaintest/acc_cache_test.go b/interchaintest/acc_cache_test.go
new file mode 100644
index 000000000..3c255bbaa
--- /dev/null
+++ b/interchaintest/acc_cache_test.go
@@ -0,0 +1,43 @@
+package interchaintest
+
+import (
+ "testing"
+
+ "github.com/cometbft/cometbft/crypto/ed25519"
+ sdk "github.com/cosmos/cosmos-sdk/types"
+ "github.com/stretchr/testify/require"
+)
+
+// See https://github.com/cosmos/cosmos-sdk/issues/15317 for description of bug.
+// Basically, in cosmos SDK, there is an account address cache that will ignore the bech32 prefix setting.
+// This will cause the AccAddress.String() to print out unexpected prefixes.
+// If this function fails you are on an unsafe SDK version that should NOT be used with the relayer.
+func TestAccCacheBugfix(t *testing.T) {
+ sdk.SetAddrCacheEnabled(false)
+
+ // Use a random key
+ priv := ed25519.GenPrivKey()
+ pub := priv.PubKey()
+
+ //Set to 'osmo'
+ prefix := "osmo"
+ sdkConf := sdk.GetConfig()
+ sdkConf.SetBech32PrefixForAccount(prefix, prefix+"pub")
+ sdkConf.SetBech32PrefixForValidator(prefix+"valoper", prefix+"valoperpub")
+ sdkConf.SetBech32PrefixForConsensusNode(prefix+"valcons", prefix+"valconspub")
+
+ addrOsmo := sdk.AccAddress(pub.Address())
+ osmoAddrBech32 := addrOsmo.String()
+
+ //Set to 'cosmos'
+ prefix = "cosmos"
+ sdkConf.SetBech32PrefixForAccount(prefix, prefix+"pub")
+ sdkConf.SetBech32PrefixForValidator(prefix+"valoper", prefix+"valoperpub")
+ sdkConf.SetBech32PrefixForConsensusNode(prefix+"valcons", prefix+"valconspub")
+
+ addrCosmos := sdk.AccAddress(pub.Address())
+ cosmosAddrBech32 := addrCosmos.String()
+
+ //If the addresses are equal, the AccAddress caching caused a bug
+ require.NotEqual(t, osmoAddrBech32, cosmosAddrBech32)
+}
diff --git a/interchaintest/client_threshold_test.go b/interchaintest/client_threshold_test.go
index 8b608ca68..fd77f70db 100644
--- a/interchaintest/client_threshold_test.go
+++ b/interchaintest/client_threshold_test.go
@@ -12,6 +12,7 @@ import (
"github.com/strangelove-ventures/interchaintest/v7/testreporter"
"github.com/strangelove-ventures/interchaintest/v7/testutil"
"github.com/stretchr/testify/require"
+ "go.uber.org/zap"
"go.uber.org/zap/zaptest"
"golang.org/x/sync/errgroup"
)
@@ -24,8 +25,6 @@ const (
// Tests that the Relayer will update light clients within a
// user specified time threshold.
func TestScenarioClientThresholdUpdate(t *testing.T) {
- t.Parallel()
-
ctx := context.Background()
nv := 1
@@ -43,7 +42,7 @@ func TestScenarioClientThresholdUpdate(t *testing.T) {
g0, g1 := chains[0], chains[1]
client, network := interchaintest.DockerSetup(t)
- relayerinterchaintest.BuildRelayerImage(t)
+ image := relayerinterchaintest.BuildRelayerImage(t)
// Relayer is set with "--time-threshold 5m"
// The client being created below also has a trusting period of 5m.
@@ -51,7 +50,7 @@ func TestScenarioClientThresholdUpdate(t *testing.T) {
r := interchaintest.NewBuiltinRelayerFactory(
ibc.CosmosRly,
zaptest.NewLogger(t),
- interchaintestrelayer.CustomDockerImage(relayerinterchaintest.RelayerImageName, "latest", "100:1000"),
+ interchaintestrelayer.CustomDockerImage(image, "latest", "100:1000"),
interchaintestrelayer.ImagePull(false),
interchaintestrelayer.StartupFlags("--time-threshold", "20s"),
).Build(t, client, network)
@@ -85,6 +84,9 @@ func TestScenarioClientThresholdUpdate(t *testing.T) {
Client: client,
NetworkID: network,
}))
+
+ t.Parallel()
+
t.Cleanup(func() {
_ = ic.Close()
})
@@ -144,9 +146,8 @@ func TestScenarioClientThresholdUpdate(t *testing.T) {
// Tests that without the threshold flag, the clients will be updated
// automatically due to passing 2/3 trusting period expiration.
func TestScenarioClientTrustingPeriodUpdate(t *testing.T) {
- t.Parallel()
-
ctx := context.Background()
+ t.Parallel()
nv := 1
nf := 0
@@ -163,14 +164,15 @@ func TestScenarioClientTrustingPeriodUpdate(t *testing.T) {
g0, g1 := chains[0], chains[1]
client, network := interchaintest.DockerSetup(t)
- relayerinterchaintest.BuildRelayerImage(t)
+ image := relayerinterchaintest.BuildRelayerImage(t)
+ logger := zaptest.NewLogger(t)
// Relayer is set with "--time-threshold 0"
// The Relayer should NOT continuously update clients
r := interchaintest.NewBuiltinRelayerFactory(
ibc.CosmosRly,
- zaptest.NewLogger(t),
- interchaintestrelayer.CustomDockerImage(relayerinterchaintest.RelayerImageName, "latest", "100:1000"),
+ logger,
+ interchaintestrelayer.CustomDockerImage(image, "latest", "100:1000"),
interchaintestrelayer.ImagePull(false),
).Build(t, client, network)
@@ -203,18 +205,24 @@ func TestScenarioClientTrustingPeriodUpdate(t *testing.T) {
SkipPathCreation: false,
}))
+
t.Cleanup(func() {
_ = ic.Close()
})
// Wait 2 blocks after building interchain
require.NoError(t, testutil.WaitForBlocks(ctx, 2, g0, g1))
+ g0Ctx := context.Background()
+ g1Ctx := context.Background()
- g0Height, err := g0.Height(ctx)
+ g0Height, err := g0.Height(g0Ctx)
require.NoError(t, err)
- g1Height, err := g1.Height(ctx)
+ g1Height, err := g1.Height(g1Ctx)
require.NoError(t, err)
+ logger.Info("Chain height", zap.String("g0 chainID", g0.Config().ChainID), zap.Uint64("height", g0Height))
+ logger.Info("Chain height", zap.String("g1 chainID", g1.Config().ChainID), zap.Uint64("g1 height", g1Height))
+
require.NoError(t, r.StartRelayer(ctx, eRep, ibcPath))
t.Cleanup(func() {
_ = r.StopRelayer(ctx, eRep)
@@ -222,13 +230,13 @@ func TestScenarioClientTrustingPeriodUpdate(t *testing.T) {
const heightOffset = 10
- g0Conns, err := r.GetConnections(ctx, eRep, g0ChainId)
+ g0Conns, err := r.GetConnections(g0Ctx, eRep, g0ChainId)
require.NoError(t, err)
require.Len(t, g0Conns, 1)
g0ClientID := g0Conns[0].ClientID
- g1Conns, err := r.GetConnections(ctx, eRep, g1ChainId)
+ g1Conns, err := r.GetConnections(g1Ctx, eRep, g1ChainId)
require.NoError(t, err)
require.Len(t, g1Conns, 1)
@@ -236,7 +244,11 @@ func TestScenarioClientTrustingPeriodUpdate(t *testing.T) {
var eg errgroup.Group
eg.Go(func() error {
- msg, err := pollForUpdateClient(ctx, g0, g0Height, g0Height+heightOffset)
+ updatedG0Height, err := g0.Height(g0Ctx)
+ require.NoError(t, err)
+ logger.Info("G0 Chain height (2)", zap.String("g0 chainID", g0.Config().ChainID), zap.Uint64("g0 height", updatedG0Height))
+
+ msg, err := pollForUpdateClient(g0Ctx, g0, updatedG0Height, updatedG0Height+heightOffset)
if err != nil {
return fmt.Errorf("first chain: %w", err)
}
@@ -246,7 +258,11 @@ func TestScenarioClientTrustingPeriodUpdate(t *testing.T) {
return nil
})
eg.Go(func() error {
- msg, err := pollForUpdateClient(ctx, g1, g1Height, g1Height+heightOffset)
+ updatedG1Height, err := g1.Height(g1Ctx)
+ require.NoError(t, err)
+ logger.Info("G1 Chain height (2)", zap.String("g1 chainID", g1.Config().ChainID), zap.Uint64("g1 height", updatedG1Height))
+
+ msg, err := pollForUpdateClient(g1Ctx, g1, updatedG1Height, updatedG1Height+heightOffset)
if err != nil {
return fmt.Errorf("second chain: %w", err)
}
diff --git a/interchaintest/docker.go b/interchaintest/docker.go
index d44f35cc7..384b5e4c1 100644
--- a/interchaintest/docker.go
+++ b/interchaintest/docker.go
@@ -12,11 +12,12 @@ import (
dockertypes "github.com/docker/docker/api/types"
"github.com/docker/docker/pkg/archive"
+ "github.com/google/uuid"
"github.com/moby/moby/client"
"github.com/stretchr/testify/require"
)
-const RelayerImageName = "interchaintestrelayer"
+const RelayerImagePrefix = "interchaintestrelayer"
type dockerLogLine struct {
Stream string `json:"stream"`
@@ -29,7 +30,14 @@ type dockerErrorDetail struct {
Message string `json:"message"`
}
-func BuildRelayerImage(t *testing.T) {
+func uniqueRelayerImageName() (string, error) {
+ uuid, err := uuid.NewRandom()
+ if err != nil {
+ return "", fmt.Errorf("failed to generate uuid %v", err)
+ }
+ return RelayerImagePrefix + uuid.String()[:6], nil
+}
+func BuildRelayerImage(t *testing.T) string {
_, b, _, _ := runtime.Caller(0)
basepath := filepath.Join(filepath.Dir(b), "..")
@@ -39,14 +47,34 @@ func BuildRelayerImage(t *testing.T) {
cli, err := client.NewClientWithOpts(client.FromEnv, client.WithAPIVersionNegotiation())
require.NoError(t, err, "error building docker client")
+ image, err := uniqueRelayerImageName()
+ require.NoError(t, err, "error generating unique tag for docker image")
+
res, err := cli.ImageBuild(context.Background(), tar, dockertypes.ImageBuildOptions{
Dockerfile: "local.Dockerfile",
- Tags: []string{RelayerImageName},
+ Tags: []string{image},
})
require.NoError(t, err, "error building docker image")
defer res.Body.Close()
+ t.Cleanup(func() {
+ destroyRelayerImage(t, image)
+ })
handleDockerBuildOutput(t, res.Body)
+ return image
+}
+
+func destroyRelayerImage(t *testing.T, image string) {
+ // Create a Docker client
+ cli, err := client.NewClientWithOpts(client.FromEnv, client.WithAPIVersionNegotiation())
+ require.NoError(t, err, "error building docker client")
+
+ // Remove the Docker image using the provided tag (uniquestr)
+ _, err = cli.ImageRemove(context.Background(), image, dockertypes.ImageRemoveOptions{
+ Force: true, // Force remove the image
+ PruneChildren: true, // Remove all child images
+ })
+ require.NoError(t, err, "error removing docker image")
}
func handleDockerBuildOutput(t *testing.T, body io.Reader) {
diff --git a/interchaintest/fee_middleware_test.go b/interchaintest/fee_middleware_test.go
new file mode 100644
index 000000000..850fe27d7
--- /dev/null
+++ b/interchaintest/fee_middleware_test.go
@@ -0,0 +1,202 @@
+package interchaintest_test
+
+import (
+ "context"
+ "fmt"
+ "testing"
+
+ transfertypes "github.com/cosmos/ibc-go/v7/modules/apps/transfer/types"
+ relayertest "github.com/cosmos/relayer/v2/interchaintest"
+ interchaintest "github.com/strangelove-ventures/interchaintest/v7"
+ "github.com/strangelove-ventures/interchaintest/v7/chain/cosmos"
+ ibc "github.com/strangelove-ventures/interchaintest/v7/ibc"
+ "github.com/strangelove-ventures/interchaintest/v7/testreporter"
+ "github.com/strangelove-ventures/interchaintest/v7/testutil"
+ "github.com/stretchr/testify/require"
+ "go.uber.org/zap/zaptest"
+)
+
+func TestRelayerFeeMiddleware(t *testing.T) {
+ if testing.Short() {
+ t.Skip()
+ }
+
+ nv := 1
+ nf := 0
+
+ // Get both chains
+ cf := interchaintest.NewBuiltinChainFactory(zaptest.NewLogger(t), []*interchaintest.ChainSpec{
+ {Name: "juno", ChainName: "chaina", Version: "v13.0.0", NumValidators: &nv, NumFullNodes: &nf, ChainConfig: ibc.ChainConfig{ChainID: "chaina", GasPrices: "0.0ujuno"}},
+ {Name: "juno", ChainName: "chainb", Version: "v13.0.0", NumValidators: &nv, NumFullNodes: &nf, ChainConfig: ibc.ChainConfig{ChainID: "chainb", GasPrices: "0.0ujuno"}}},
+ )
+
+ chains, err := cf.Chains(t.Name())
+ require.NoError(t, err)
+ chainA, chainB := chains[0].(*cosmos.CosmosChain), chains[1].(*cosmos.CosmosChain)
+
+ ctx := context.Background()
+ client, network := interchaintest.DockerSetup(t)
+
+ rf := relayertest.NewRelayerFactory(relayertest.RelayerConfig{InitialBlockHistory: 50})
+ r := rf.Build(t, client, network)
+
+ const pathChainAChainB = "chainA-chainB"
+
+ // Build the network
+ ic := interchaintest.NewInterchain().
+ AddChain(chainA).
+ AddChain(chainB).
+ AddRelayer(r, "relayer").
+ AddLink(interchaintest.InterchainLink{
+ Chain1: chainA,
+ Chain2: chainB,
+ Relayer: r,
+ Path: pathChainAChainB,
+ CreateChannelOpts: ibc.CreateChannelOptions{
+ SourcePortName: "transfer",
+ DestPortName: "transfer",
+ Order: ibc.Unordered,
+ Version: "{\"fee_version\":\"ics29-1\",\"app_version\":\"ics20-1\"}",
+ },
+ CreateClientOpts: ibc.DefaultClientOpts(),
+ })
+
+ rep := testreporter.NewNopReporter()
+ eRep := rep.RelayerExecReporter(t)
+
+ require.NoError(t, ic.Build(ctx, eRep, interchaintest.InterchainBuildOptions{
+ TestName: t.Name(),
+ Client: client,
+ NetworkID: network,
+ SkipPathCreation: false,
+ }))
+
+ t.Parallel()
+
+ t.Cleanup(func() {
+ _ = ic.Close()
+ })
+
+ err = testutil.WaitForBlocks(ctx, 5, chainA, chainB)
+ require.NoError(t, err)
+
+ // ChainID of ChainA
+ chainIDA := chainA.Config().ChainID
+
+ // Channel of ChainA
+ chA, err := r.GetChannels(ctx, eRep, chainIDA)
+ require.NoError(t, err)
+ channelA := chA[0]
+
+ // Fund a user account on chain1 and chain2
+ const userFunds = int64(1_000_000_000_000)
+ users := interchaintest.GetAndFundTestUsers(t, ctx, t.Name(), userFunds, chainA, chainB)
+ userA := users[0]
+ userAddressA := userA.FormattedAddress()
+ userB := users[1]
+ userAddressB := userB.FormattedAddress()
+
+ // Addresses of both the chains
+ walletA, _ := r.GetWallet(chainA.Config().ChainID)
+ rlyAddressA := walletA.FormattedAddress()
+
+ walletB, _ := r.GetWallet(chainB.Config().ChainID)
+ rlyAddressB := walletB.FormattedAddress()
+
+ // register CounterpartyPayee
+ cmd := []string{
+ "tx", "register-counterparty",
+ chainA.Config().Name,
+ channelA.ChannelID,
+ "transfer",
+ rlyAddressA,
+ rlyAddressB,
+ }
+ _ = r.Exec(ctx, eRep, cmd, nil)
+ require.NoError(t, err)
+
+ // Query the relayer CounterpartyPayee on a given channel
+ query := []string{
+ chainA.Config().Bin, "query", "ibc-fee", "counterparty-payee", channelA.ChannelID, rlyAddressA,
+ "--chain-id", chainIDA,
+ "--node", chainA.GetRPCAddress(),
+ "--home", chainA.HomeDir(),
+ "--trace",
+ }
+ _, _, err = chainA.Exec(ctx, query, nil)
+ require.NoError(t, err)
+
+ // Get initial account balances
+ userAOrigBal, err := chainA.GetBalance(ctx, userAddressA, chainA.Config().Denom)
+ require.NoError(t, err)
+ require.Equal(t, userFunds, userAOrigBal)
+
+ userBOrigBal, err := chainB.GetBalance(ctx, userAddressB, chainB.Config().Denom)
+ require.NoError(t, err)
+ require.Equal(t, userFunds, userBOrigBal)
+
+ rlyAOrigBal, err := chainA.GetBalance(ctx, rlyAddressA, chainA.Config().Denom)
+ require.NoError(t, err)
+ require.Equal(t, userFunds, rlyAOrigBal)
+
+ rlyBOrigBal, err := chainB.GetBalance(ctx, rlyAddressB, chainB.Config().Denom)
+ require.NoError(t, err)
+ require.Equal(t, userFunds, rlyBOrigBal)
+
+ // send tx
+ const txAmount = 1000
+ transfer := ibc.WalletAmount{Address: userAddressB, Denom: chainA.Config().Denom, Amount: txAmount}
+ _, err = chainA.SendIBCTransfer(ctx, channelA.ChannelID, userAddressA, transfer, ibc.TransferOptions{})
+ require.NoError(t, err)
+
+ // Incentivizing async packet by returning MsgPayPacketFeeAsync
+ packetFeeAsync := []string{
+ chainA.Config().Bin, "tx", "ibc-fee", "pay-packet-fee", "transfer", channelA.ChannelID, "1",
+ "--recv-fee", fmt.Sprintf("1000%s", chainA.Config().Denom),
+ "--ack-fee", fmt.Sprintf("1000%s", chainA.Config().Denom),
+ "--timeout-fee", fmt.Sprintf("1000%s", chainA.Config().Denom),
+ "--chain-id", chainIDA,
+ "--node", chainA.GetRPCAddress(),
+ "--from", userA.FormattedAddress(),
+ "--keyring-backend", "test",
+ "--gas", "400000",
+ "--yes",
+ "--home", chainA.HomeDir(),
+ }
+ _, _, err = chainA.Exec(ctx, packetFeeAsync, nil)
+ require.NoError(t, err)
+
+ // start the relayer
+ err = r.StartRelayer(ctx, eRep, pathChainAChainB)
+ require.NoError(t, err)
+
+ t.Cleanup(
+ func() {
+ err := r.StopRelayer(ctx, eRep)
+ if err != nil {
+ t.Logf("an error occured while stopping the relayer: %s", err)
+ }
+ },
+ )
+
+ // Wait for relayer to run
+ err = testutil.WaitForBlocks(ctx, 10, chainA, chainB)
+ require.NoError(t, err)
+
+ // Assigning denom
+ chainATokenDenom := transfertypes.GetPrefixedDenom(channelA.PortID, channelA.ChannelID, chainA.Config().Denom)
+ chainADenomTrace := transfertypes.ParseDenomTrace(chainATokenDenom)
+
+ // Get balances after the fees
+ chainABal, err := chainA.GetBalance(ctx, userAddressA, chainA.Config().Denom)
+ require.NoError(t, err)
+ require.Equal(t, userAOrigBal-(txAmount+1000), chainABal)
+
+ chainBBal, err := chainB.GetBalance(ctx, userAddressB, chainADenomTrace.IBCDenom())
+ require.NoError(t, err)
+ require.Equal(t, int64(txAmount), chainBBal)
+
+ rlyABal, err := chainA.GetBalance(ctx, rlyAddressA, chainA.Config().Denom)
+ require.NoError(t, err)
+ require.Equal(t, rlyAOrigBal+1000, rlyABal)
+}
diff --git a/interchaintest/feegrant_test.go b/interchaintest/feegrant_test.go
new file mode 100644
index 000000000..6c35f2793
--- /dev/null
+++ b/interchaintest/feegrant_test.go
@@ -0,0 +1,547 @@
+package interchaintest
+
+import (
+ "context"
+ "encoding/hex"
+ "fmt"
+ "math/rand"
+ "strings"
+ "testing"
+ "time"
+
+ "github.com/avast/retry-go/v4"
+ rpcclient "github.com/cometbft/cometbft/rpc/client"
+ ctypes "github.com/cometbft/cometbft/rpc/core/types"
+ "github.com/cosmos/cosmos-sdk/types"
+ txtypes "github.com/cosmos/cosmos-sdk/types/tx"
+ "github.com/cosmos/go-bip39"
+ transfertypes "github.com/cosmos/ibc-go/v7/modules/apps/transfer/types"
+ chantypes "github.com/cosmos/ibc-go/v7/modules/core/04-channel/types"
+ "github.com/cosmos/relayer/v2/relayer"
+ "github.com/cosmos/relayer/v2/relayer/chains/cosmos"
+ "github.com/cosmos/relayer/v2/relayer/processor"
+ interchaintest "github.com/strangelove-ventures/interchaintest/v7"
+ "github.com/strangelove-ventures/interchaintest/v7/ibc"
+ "github.com/strangelove-ventures/interchaintest/v7/testreporter"
+ "github.com/strangelove-ventures/interchaintest/v7/testutil"
+ "github.com/stretchr/testify/require"
+ "go.uber.org/zap/zaptest"
+ "golang.org/x/sync/errgroup"
+)
+
+// protoTxProvider is a type which can provide a proto transaction. It is a
+// workaround to get access to the wrapper TxBuilder's method GetProtoTx().
+type protoTxProvider interface {
+ GetProtoTx() *txtypes.Tx
+}
+
+type chainFeegrantInfo struct {
+ granter string
+ grantees []string
+}
+
+func genMnemonic(t *testing.T) string {
+ // read entropy seed straight from tmcrypto.Rand and convert to mnemonic
+ entropySeed, err := bip39.NewEntropy(256)
+ if err != nil {
+ t.Fail()
+ }
+
+ mn, err := bip39.NewMnemonic(entropySeed)
+ if err != nil {
+ t.Fail()
+ }
+
+ return mn
+}
+
+// TestRelayerFeeGrant Feegrant on a single chain
+// Run this test with e.g. go test -timeout 300s -run ^TestRelayerFeeGrant$ github.com/cosmos/relayer/v2/ibctest.
+//
+// Helpful to debug:
+// docker ps -a --format {{.Names}} then e.g. docker logs gaia-1-val-0-TestRelayerFeeGrant 2>&1 -f
+func TestRelayerFeeGrant(t *testing.T) {
+ ctx := context.Background()
+ logger := zaptest.NewLogger(t)
+
+ nv := 1
+ nf := 0
+
+ //In order to have this image locally you'd need to build it with heighliner, e.g.,
+ //from within the local "gaia" directory, run the following command:
+ //../heighliner/heighliner build -c gaia --local -f ../heighliner/chains.yaml
+ // gaiaImage := ibc.DockerImage{
+ // Repository: "gaia",
+ // Version: "local",
+ // UidGid: "1025:1025", //the heighliner user string. this isn't exposed on ibctest
+ // }
+
+ // gaiaChainSpec := &interchaintest.ChainSpec{
+ // ChainName: "gaia",
+ // NumValidators: &nv,
+ // NumFullNodes: &nf,
+ // ChainConfig: ibc.ChainConfig{
+ // Type: "cosmos",
+ // Name: "gaia",
+ // //ChainID: "gaia-1", //I believe this will be auto-generated?
+ // Images: []ibc.DockerImage{gaiaImage},
+ // Bin: "gaiad",
+ // Bech32Prefix: "cosmos",
+ // Denom: "uatom",
+ // GasPrices: "0.01uatom",
+ // TrustingPeriod: "504h",
+ // GasAdjustment: 1.3,
+ // }}
+
+ var tests = [][]*interchaintest.ChainSpec{
+ {
+ {Name: "gaia", ChainName: "gaia", Version: "v7.0.3", NumValidators: &nv, NumFullNodes: &nf},
+ {Name: "osmosis", ChainName: "osmosis", Version: "v14.0.1", NumValidators: &nv, NumFullNodes: &nf},
+ },
+ {
+ {Name: "gaia", ChainName: "gaia", Version: "v7.0.3", NumValidators: &nv, NumFullNodes: &nf},
+ {Name: "kujira", ChainName: "kujira", Version: "v0.8.7", NumValidators: &nv, NumFullNodes: &nf},
+ },
+ }
+
+ for _, tt := range tests {
+ testname := fmt.Sprintf("%s,%s", tt[0].Name, tt[1].Name)
+ t.Run(testname, func(t *testing.T) {
+
+ // Chain Factory
+ cf := interchaintest.NewBuiltinChainFactory(zaptest.NewLogger(t), tt)
+
+ chains, err := cf.Chains(t.Name())
+ require.NoError(t, err)
+ gaia, osmosis := chains[0], chains[1]
+
+ // Relayer Factory to construct relayer
+ r := NewRelayerFactory(RelayerConfig{
+ Processor: relayer.ProcessorEvents,
+ InitialBlockHistory: 100,
+ }).Build(t, nil, "")
+
+ processor.PathProcMessageCollector = make(chan *processor.PathProcessorMessageResp, 10000)
+
+ // Prep Interchain
+ const ibcPath = "gaia-osmosis"
+ ic := interchaintest.NewInterchain().
+ AddChain(gaia).
+ AddChain(osmosis).
+ AddRelayer(r, "relayer").
+ AddLink(interchaintest.InterchainLink{
+ Chain1: gaia,
+ Chain2: osmosis,
+ Relayer: r,
+ Path: ibcPath,
+ })
+
+ // Reporter/logs
+ rep := testreporter.NewNopReporter()
+ eRep := rep.RelayerExecReporter(t)
+
+ client, network := interchaintest.DockerSetup(t)
+
+ // Build interchain
+ require.NoError(t, ic.Build(ctx, eRep, interchaintest.InterchainBuildOptions{
+ TestName: t.Name(),
+ Client: client,
+ NetworkID: network,
+
+ SkipPathCreation: false,
+ }))
+
+ t.Parallel()
+
+ // Get Channel ID
+ gaiaChans, err := r.GetChannels(ctx, eRep, gaia.Config().ChainID)
+ require.NoError(t, err)
+ gaiaChannel := gaiaChans[0]
+ osmosisChannel := gaiaChans[0].Counterparty
+
+ // Create and Fund User Wallets
+ fundAmount := int64(10_000_000)
+
+ // Tiny amount of funding, not enough to pay for a single TX fee (the GRANTER should be paying the fee)
+ granteeFundAmount := int64(10)
+ granteeKeyPrefix := "grantee1"
+ grantee2KeyPrefix := "grantee2"
+ grantee3KeyPrefix := "grantee3"
+ granterKeyPrefix := "default"
+
+ mnemonicAny := genMnemonic(t)
+ gaiaGranterWallet, err := interchaintest.GetAndFundTestUserWithMnemonic(ctx, granterKeyPrefix, mnemonicAny, int64(fundAmount), gaia)
+ require.NoError(t, err)
+
+ mnemonicAny = genMnemonic(t)
+ gaiaGranteeWallet, err := interchaintest.GetAndFundTestUserWithMnemonic(ctx, granteeKeyPrefix, mnemonicAny, int64(granteeFundAmount), gaia)
+ require.NoError(t, err)
+
+ mnemonicAny = genMnemonic(t)
+ gaiaGrantee2Wallet, err := interchaintest.GetAndFundTestUserWithMnemonic(ctx, grantee2KeyPrefix, mnemonicAny, int64(granteeFundAmount), gaia)
+ require.NoError(t, err)
+
+ mnemonicAny = genMnemonic(t)
+ gaiaGrantee3Wallet, err := interchaintest.GetAndFundTestUserWithMnemonic(ctx, grantee3KeyPrefix, mnemonicAny, int64(granteeFundAmount), gaia)
+ require.NoError(t, err)
+
+ mnemonicAny = genMnemonic(t)
+ osmosisUser, err := interchaintest.GetAndFundTestUserWithMnemonic(ctx, "recipient", mnemonicAny, int64(fundAmount), osmosis)
+ require.NoError(t, err)
+
+ mnemonicAny = genMnemonic(t)
+ gaiaUser, err := interchaintest.GetAndFundTestUserWithMnemonic(ctx, "recipient", mnemonicAny, int64(fundAmount), gaia)
+ require.NoError(t, err)
+
+ mnemonic := gaiaGranterWallet.Mnemonic()
+ fmt.Printf("Wallet mnemonic: %s\n", mnemonic)
+
+ rand.Seed(time.Now().UnixNano())
+
+ //IBC chain config is unrelated to RELAYER config so this step is necessary
+ if err := r.RestoreKey(ctx,
+ eRep,
+ gaia.Config(),
+ gaiaGranterWallet.KeyName(),
+ gaiaGranterWallet.Mnemonic(),
+ ); err != nil {
+ t.Fatalf("failed to restore granter key to relayer for chain %s: %s", gaia.Config().ChainID, err.Error())
+ }
+
+ //IBC chain config is unrelated to RELAYER config so this step is necessary
+ if err := r.RestoreKey(ctx,
+ eRep,
+ gaia.Config(),
+ gaiaGranteeWallet.KeyName(),
+ gaiaGranteeWallet.Mnemonic(),
+ ); err != nil {
+ t.Fatalf("failed to restore granter key to relayer for chain %s: %s", gaia.Config().ChainID, err.Error())
+ }
+
+ //IBC chain config is unrelated to RELAYER config so this step is necessary
+ if err := r.RestoreKey(ctx,
+ eRep,
+ gaia.Config(),
+ gaiaGrantee2Wallet.KeyName(),
+ gaiaGrantee2Wallet.Mnemonic(),
+ ); err != nil {
+ t.Fatalf("failed to restore granter key to relayer for chain %s: %s", gaia.Config().ChainID, err.Error())
+ }
+
+ //IBC chain config is unrelated to RELAYER config so this step is necessary
+ if err := r.RestoreKey(ctx,
+ eRep,
+ gaia.Config(),
+ gaiaGrantee3Wallet.KeyName(),
+ gaiaGrantee3Wallet.Mnemonic(),
+ ); err != nil {
+ t.Fatalf("failed to restore granter key to relayer for chain %s: %s", gaia.Config().ChainID, err.Error())
+ }
+
+ //IBC chain config is unrelated to RELAYER config so this step is necessary
+ if err := r.RestoreKey(ctx,
+ eRep,
+ osmosis.Config(),
+ osmosisUser.KeyName(),
+ osmosisUser.Mnemonic(),
+ ); err != nil {
+ t.Fatalf("failed to restore granter key to relayer for chain %s: %s", osmosis.Config().ChainID, err.Error())
+ }
+
+ //IBC chain config is unrelated to RELAYER config so this step is necessary
+ if err := r.RestoreKey(ctx,
+ eRep,
+ osmosis.Config(),
+ gaiaUser.KeyName(),
+ gaiaUser.Mnemonic(),
+ ); err != nil {
+ t.Fatalf("failed to restore granter key to relayer for chain %s: %s", gaia.Config().ChainID, err.Error())
+ }
+
+ gaiaGranteeAddr := gaiaGranteeWallet.FormattedAddress()
+ gaiaGrantee2Addr := gaiaGrantee2Wallet.FormattedAddress()
+ gaiaGrantee3Addr := gaiaGrantee3Wallet.FormattedAddress()
+ gaiaGranterAddr := gaiaGranterWallet.FormattedAddress()
+
+ granteeCsv := gaiaGranteeWallet.KeyName() + "," + gaiaGrantee2Wallet.KeyName() + "," + gaiaGrantee3Wallet.KeyName()
+
+ //You MUST run the configure feegrant command prior to starting the relayer, otherwise it'd be like you never set it up at all (within this test)
+ //Note that Gaia supports feegrants, but Osmosis does not (x/feegrant module, or any compatible module, is not included in Osmosis SDK app modules)
+ localRelayer := r.(*Relayer)
+ res := localRelayer.sys().Run(logger, "chains", "configure", "feegrant", "basicallowance", gaia.Config().ChainID, gaiaGranterWallet.KeyName(), "--grantees", granteeCsv, "--overwrite-granter")
+ if res.Err != nil {
+ fmt.Printf("configure feegrant results: %s\n", res.Stdout.String())
+ t.Fatalf("failed to rly config feegrants: %v", res.Err)
+ }
+
+ //Map of feegranted chains and the feegrant info for the chain
+ feegrantedChains := map[string]*chainFeegrantInfo{}
+ feegrantedChains[gaia.Config().ChainID] = &chainFeegrantInfo{granter: gaiaGranterAddr, grantees: []string{gaiaGranteeAddr, gaiaGrantee2Addr, gaiaGrantee3Addr}}
+
+ time.Sleep(14 * time.Second) //commit a couple blocks
+ r.StartRelayer(ctx, eRep, ibcPath)
+
+ // Send Transaction
+ amountToSend := int64(1_000)
+
+ gaiaDstAddress := types.MustBech32ifyAddressBytes(osmosis.Config().Bech32Prefix, gaiaUser.Address())
+ osmosisDstAddress := types.MustBech32ifyAddressBytes(gaia.Config().Bech32Prefix, osmosisUser.Address())
+
+ gaiaHeight, err := gaia.Height(ctx)
+ require.NoError(t, err)
+
+ osmosisHeight, err := osmosis.Height(ctx)
+ require.NoError(t, err)
+
+ var eg errgroup.Group
+ var gaiaTx ibc.Tx
+
+ eg.Go(func() error {
+ gaiaTx, err = gaia.SendIBCTransfer(ctx, gaiaChannel.ChannelID, gaiaUser.KeyName(), ibc.WalletAmount{
+ Address: gaiaDstAddress,
+ Denom: gaia.Config().Denom,
+ Amount: amountToSend,
+ },
+ ibc.TransferOptions{},
+ )
+ if err != nil {
+ return err
+ }
+ if err := gaiaTx.Validate(); err != nil {
+ return err
+ }
+
+ _, err = testutil.PollForAck(ctx, gaia, gaiaHeight, gaiaHeight+20, gaiaTx.Packet)
+ return err
+ })
+
+ eg.Go(func() error {
+ tx, err := osmosis.SendIBCTransfer(ctx, osmosisChannel.ChannelID, osmosisUser.KeyName(), ibc.WalletAmount{
+ Address: osmosisDstAddress,
+ Denom: osmosis.Config().Denom,
+ Amount: amountToSend,
+ },
+ ibc.TransferOptions{},
+ )
+ if err != nil {
+ return err
+ }
+ if err := tx.Validate(); err != nil {
+ return err
+ }
+ _, err = testutil.PollForAck(ctx, osmosis, osmosisHeight, osmosisHeight+20, tx.Packet)
+ return err
+ })
+
+ eg.Go(func() error {
+ tx, err := osmosis.SendIBCTransfer(ctx, osmosisChannel.ChannelID, osmosisUser.KeyName(), ibc.WalletAmount{
+ Address: osmosisDstAddress,
+ Denom: osmosis.Config().Denom,
+ Amount: amountToSend,
+ },
+ ibc.TransferOptions{},
+ )
+ if err != nil {
+ return err
+ }
+ if err := tx.Validate(); err != nil {
+ return err
+ }
+ _, err = testutil.PollForAck(ctx, osmosis, osmosisHeight, osmosisHeight+20, tx.Packet)
+ return err
+ })
+
+ eg.Go(func() error {
+ tx, err := osmosis.SendIBCTransfer(ctx, osmosisChannel.ChannelID, osmosisUser.KeyName(), ibc.WalletAmount{
+ Address: osmosisDstAddress,
+ Denom: osmosis.Config().Denom,
+ Amount: amountToSend,
+ },
+ ibc.TransferOptions{},
+ )
+ if err != nil {
+ return err
+ }
+ if err := tx.Validate(); err != nil {
+ return err
+ }
+ _, err = testutil.PollForAck(ctx, osmosis, osmosisHeight, osmosisHeight+20, tx.Packet)
+ return err
+ })
+
+ require.NoError(t, err)
+ require.NoError(t, eg.Wait())
+
+ feegrantMsgSigners := map[string][]string{} //chain to list of signers
+
+ for len(processor.PathProcMessageCollector) > 0 {
+ select {
+ case curr, ok := <-processor.PathProcMessageCollector:
+ if ok && curr.Error == nil && curr.SuccessfulTx {
+ cProv, cosmProv := curr.DestinationChain.(*cosmos.CosmosProvider)
+ if cosmProv {
+ chain := cProv.PCfg.ChainID
+ feegrantInfo, isFeegrantedChain := feegrantedChains[chain]
+ if isFeegrantedChain && !strings.Contains(cProv.PCfg.KeyDirectory, t.Name()) {
+ //This would indicate that a parallel test is inserting msgs into the queue.
+ //We can safely skip over any messages inserted by other test cases.
+ fmt.Println("Skipping PathProcessorMessageResp from unrelated Parallel test case")
+ continue
+ }
+
+ done := cProv.SetSDKContext()
+
+ hash, err := hex.DecodeString(curr.Response.TxHash)
+ require.Nil(t, err)
+ txResp, err := TxWithRetry(ctx, cProv.RPCClient, hash)
+ require.Nil(t, err)
+
+ require.Nil(t, err)
+ dc := cProv.Cdc.TxConfig.TxDecoder()
+ tx, err := dc(txResp.Tx)
+ require.Nil(t, err)
+ builder, err := cProv.Cdc.TxConfig.WrapTxBuilder(tx)
+ require.Nil(t, err)
+ txFinder := builder.(protoTxProvider)
+ fullTx := txFinder.GetProtoTx()
+ isFeegrantedMsg := false
+
+ msgs := ""
+ msgType := ""
+ for _, m := range fullTx.GetMsgs() {
+ msgType = types.MsgTypeURL(m)
+ //We want all IBC transfers (on an open channel/connection) to be feegranted in round robin fashion
+ if msgType == "/ibc.core.channel.v1.MsgRecvPacket" || msgType == "/ibc.core.channel.v1.MsgAcknowledgement" {
+ isFeegrantedMsg = true
+ msgs += msgType + ", "
+ } else {
+ msgs += msgType + ", "
+ }
+ }
+
+ //It's required that TXs be feegranted in a round robin fashion for this chain and message type
+ if isFeegrantedChain && isFeegrantedMsg {
+ fmt.Printf("Msg types: %+v\n", msgs)
+ signers := fullTx.GetSigners()
+ require.Equal(t, len(signers), 1)
+ granter := fullTx.FeeGranter()
+
+ //Feegranter for the TX that was signed on chain must be the relayer chain's configured feegranter
+ require.Equal(t, feegrantInfo.granter, granter.String())
+ require.NotEmpty(t, granter)
+
+ for _, msg := range fullTx.GetMsgs() {
+ msgType = types.MsgTypeURL(msg)
+ //We want all IBC transfers (on an open channel/connection) to be feegranted in round robin fashion
+ if msgType == "/ibc.core.channel.v1.MsgRecvPacket" {
+ c := msg.(*chantypes.MsgRecvPacket)
+ appData := c.Packet.GetData()
+ tokenTransfer := &transfertypes.FungibleTokenPacketData{}
+ err := tokenTransfer.Unmarshal(appData)
+ if err == nil {
+ fmt.Printf("%+v\n", tokenTransfer)
+ } else {
+ fmt.Println(string(appData))
+ }
+ }
+ }
+
+ //Grantee for the TX that was signed on chain must be a configured grantee in the relayer's chain feegrants.
+ //In addition, the grantee must be used in round robin fashion
+ //expectedGrantee := nextGrantee(feegrantInfo)
+ actualGrantee := signers[0].String()
+ signerList, ok := feegrantMsgSigners[chain]
+ if ok {
+ signerList = append(signerList, actualGrantee)
+ feegrantMsgSigners[chain] = signerList
+ } else {
+ feegrantMsgSigners[chain] = []string{actualGrantee}
+ }
+ fmt.Printf("Chain: %s, msg type: %s, height: %d, signer: %s, granter: %s\n", chain, msgType, curr.Response.Height, actualGrantee, granter.String())
+ }
+ done()
+ }
+ }
+ default:
+ fmt.Println("Unknown channel message")
+ }
+ }
+
+ for chain, signers := range feegrantMsgSigners {
+ require.Equal(t, chain, gaia.Config().ChainID)
+ signerCountMap := map[string]int{}
+
+ for _, signer := range signers {
+ count, ok := signerCountMap[signer]
+ if ok {
+ signerCountMap[signer] = count + 1
+ } else {
+ signerCountMap[signer] = 1
+ }
+ }
+
+ highestCount := 0
+ for _, count := range signerCountMap {
+ if count > highestCount {
+ highestCount = count
+ }
+ }
+
+ //At least one feegranter must have signed a TX
+ require.GreaterOrEqual(t, highestCount, 1)
+
+ //All of the feegrantees must have signed at least one TX
+ expectedFeegrantInfo := feegrantedChains[chain]
+ require.Equal(t, len(signerCountMap), len(expectedFeegrantInfo.grantees))
+
+ // verify that TXs were signed in a round robin fashion.
+ // no grantee should have signed more TXs than any other grantee (off by one is allowed).
+ for signer, count := range signerCountMap {
+ fmt.Printf("signer %s signed %d feegranted TXs \n", signer, count)
+ require.LessOrEqual(t, highestCount-count, 1)
+ }
+ }
+
+ // Trace IBC Denom
+ gaiaDenomTrace := transfertypes.ParseDenomTrace(transfertypes.GetPrefixedDenom(osmosisChannel.PortID, osmosisChannel.ChannelID, gaia.Config().Denom))
+ gaiaIbcDenom := gaiaDenomTrace.IBCDenom()
+
+ osmosisDenomTrace := transfertypes.ParseDenomTrace(transfertypes.GetPrefixedDenom(gaiaChannel.PortID, gaiaChannel.ChannelID, osmosis.Config().Denom))
+ osmosisIbcDenom := osmosisDenomTrace.IBCDenom()
+
+ // Test destination wallets have increased funds
+ gaiaIBCBalance, err := osmosis.GetBalance(ctx, gaiaDstAddress, gaiaIbcDenom)
+ require.NoError(t, err)
+ require.Equal(t, amountToSend, gaiaIBCBalance)
+
+ osmosisIBCBalance, err := gaia.GetBalance(ctx, osmosisDstAddress, osmosisIbcDenom)
+ require.NoError(t, err)
+ require.Equal(t, 3*amountToSend, osmosisIBCBalance)
+
+ // Test grantee still has exact amount expected
+ gaiaGranteeIBCBalance, err := gaia.GetBalance(ctx, gaiaGranteeAddr, gaia.Config().Denom)
+ require.NoError(t, err)
+ require.Equal(t, granteeFundAmount, gaiaGranteeIBCBalance)
+
+ // Test granter has less than they started with, meaning fees came from their account
+ gaiaGranterIBCBalance, err := gaia.GetBalance(ctx, gaiaGranterAddr, gaia.Config().Denom)
+ require.NoError(t, err)
+ require.Less(t, gaiaGranterIBCBalance, fundAmount)
+ r.StopRelayer(ctx, eRep)
+
+ })
+ }
+}
+
+func TxWithRetry(ctx context.Context, client rpcclient.Client, hash []byte) (*ctypes.ResultTx, error) {
+ var err error
+ var res *ctypes.ResultTx
+ if err = retry.Do(func() error {
+ res, err = client.Tx(ctx, hash, true)
+ return err
+ }, retry.Context(ctx), relayer.RtyAtt, relayer.RtyDel, relayer.RtyErr); err != nil {
+ return res, err
+ }
+
+ return res, err
+}
diff --git a/interchaintest/go.mod b/interchaintest/go.mod
index 0f529bd46..89c505f98 100644
--- a/interchaintest/go.mod
+++ b/interchaintest/go.mod
@@ -1,72 +1,78 @@
module github.com/cosmos/relayer/v2/interchaintest
-go 1.19
+go 1.20
require (
cosmossdk.io/simapp v0.0.0-20230224204036-a6adb0821462
- github.com/cometbft/cometbft v0.37.0
- github.com/cosmos/cosmos-sdk v0.47.0-rc3
- github.com/cosmos/ibc-go/v7 v7.0.0-rc1
+ github.com/avast/retry-go/v4 v4.3.4
+ github.com/cometbft/cometbft v0.37.2
+ github.com/cosmos/cosmos-sdk v0.47.5
+ github.com/cosmos/go-bip39 v1.0.0
+ github.com/cosmos/gogoproto v1.4.10
+ github.com/cosmos/ibc-go/v7 v7.3.0
github.com/cosmos/relayer/v2 v2.0.0
- github.com/docker/docker v20.10.19+incompatible
+ github.com/docker/docker v24.0.1+incompatible
+ github.com/google/uuid v1.3.0
github.com/icza/dyno v0.0.0-20220812133438-f0b6f8a18845
- github.com/moby/moby v20.10.22+incompatible
- github.com/strangelove-ventures/interchaintest/v7 v7.0.0-20230309210425-6f04be9aab19
- github.com/stretchr/testify v1.8.2
+ github.com/moby/moby v24.0.2+incompatible
+ github.com/strangelove-ventures/interchaintest/v7 v7.0.0-20230608002938-79172615eed0
+ github.com/stretchr/testify v1.8.4
go.uber.org/zap v1.24.0
- golang.org/x/sync v0.1.0
+ golang.org/x/sync v0.2.0
)
require (
- cloud.google.com/go v0.110.0 // indirect
- cloud.google.com/go/compute v1.18.0 // indirect
+ cloud.google.com/go v0.110.4 // indirect
+ cloud.google.com/go/compute v1.20.1 // indirect
cloud.google.com/go/compute/metadata v0.2.3 // indirect
- cloud.google.com/go/iam v0.12.0 // indirect
- cloud.google.com/go/storage v1.29.0 // indirect
+ cloud.google.com/go/iam v1.1.0 // indirect
+ cloud.google.com/go/storage v1.30.1 // indirect
cosmossdk.io/api v0.3.1 // indirect
cosmossdk.io/core v0.5.1 // indirect
- cosmossdk.io/depinject v1.0.0-alpha.3 // indirect
- cosmossdk.io/errors v1.0.0-beta.7 // indirect
- cosmossdk.io/math v1.0.0-beta.6.0.20230216172121-959ce49135e4 // indirect
+ cosmossdk.io/depinject v1.0.0-alpha.4 // indirect
+ cosmossdk.io/errors v1.0.0 // indirect
+ cosmossdk.io/log v1.2.1 // indirect
+ cosmossdk.io/math v1.1.2 // indirect
cosmossdk.io/tools/rosetta v0.2.1 // indirect
filippo.io/edwards25519 v1.0.0 // indirect
github.com/99designs/go-keychain v0.0.0-20191008050251-8e49817e8af4 // indirect
- github.com/99designs/keyring v1.2.1 // indirect
- github.com/BurntSushi/toml v1.2.1 // indirect
+ github.com/99designs/keyring v1.2.2 // indirect
+ github.com/BurntSushi/toml v1.3.0 // indirect
github.com/ChainSafe/go-schnorrkel v1.0.0 // indirect
github.com/ChainSafe/go-schnorrkel/1 v0.0.0-00010101000000-000000000000 // indirect
+ github.com/ComposableFi/go-subkey/v2 v2.0.0-tm03420 // indirect
+ github.com/FactomProject/basen v0.0.0-20150613233007-fe3947df716e // indirect
+ github.com/FactomProject/btcutilecc v0.0.0-20130527213604-d3a63a5752ec // indirect
github.com/Microsoft/go-winio v0.6.0 // indirect
- github.com/Microsoft/hcsshim v0.9.6 // indirect
github.com/StirlingMarketingGroup/go-namecase v1.0.0 // indirect
github.com/armon/go-metrics v0.4.1 // indirect
- github.com/avast/retry-go/v4 v4.3.2 // indirect
github.com/aws/aws-sdk-go v1.44.203 // indirect
github.com/benbjohnson/clock v1.3.0 // indirect
github.com/beorn7/perks v1.0.1 // indirect
github.com/bgentry/go-netrc v0.0.0-20140422174119-9fd32a8b3d3d // indirect
github.com/bgentry/speakeasy v0.1.1-0.20220910012023-760eaf8b6816 // indirect
- github.com/btcsuite/btcd v0.22.3 // indirect
+ github.com/btcsuite/btcd v0.23.4 // indirect
github.com/btcsuite/btcd/btcec/v2 v2.3.2 // indirect
+ github.com/btcsuite/btcd/btcutil v1.1.3 // indirect
github.com/btcsuite/btcd/chaincfg/chainhash v1.0.1 // indirect
- github.com/btcsuite/btcutil v1.0.3-0.20201208143702-a53e38424cce // indirect
github.com/cenkalti/backoff/v4 v4.1.3 // indirect
- github.com/centrifuge/go-substrate-rpc-client/v4 v4.0.10 // indirect
github.com/cespare/xxhash v1.1.0 // indirect
github.com/cespare/xxhash/v2 v2.2.0 // indirect
github.com/chzyer/readline v1.5.1 // indirect
github.com/cockroachdb/apd/v2 v2.0.2 // indirect
+ github.com/cockroachdb/errors v1.10.0 // indirect
+ github.com/cockroachdb/logtags v0.0.0-20230118201751-21c54148d20b // indirect
+ github.com/cockroachdb/redact v1.1.5 // indirect
github.com/coinbase/rosetta-sdk-go/types v1.0.0 // indirect
- github.com/cometbft/cometbft-db v0.7.0 // indirect
+ github.com/cometbft/cometbft-db v0.8.0 // indirect
github.com/confio/ics23/go v0.9.0 // indirect
- github.com/containerd/cgroups v1.0.4 // indirect
- github.com/containerd/containerd v1.6.18 // indirect
+ github.com/containerd/containerd v1.6.8 // indirect
github.com/cosmos/btcutil v1.0.5 // indirect
github.com/cosmos/cosmos-proto v1.0.0-beta.2 // indirect
- github.com/cosmos/go-bip39 v1.0.0 // indirect
github.com/cosmos/gogogateway v1.2.0 // indirect
- github.com/cosmos/gogoproto v1.4.6 // indirect
- github.com/cosmos/iavl v0.20.0-alpha4 // indirect
- github.com/cosmos/ics23/go v0.9.1-0.20221207100636-b1abd8678aab // indirect
+ github.com/cosmos/iavl v0.20.0 // indirect
+ github.com/cosmos/ibc-go/modules/capability v1.0.0-rc1 // indirect
+ github.com/cosmos/ics23/go v0.10.0 // indirect
github.com/cosmos/ledger-cosmos-go v0.12.2 // indirect
github.com/cosmos/rosetta-sdk-go v0.10.0 // indirect
github.com/creachadair/taskgroup v0.4.2 // indirect
@@ -81,7 +87,7 @@ require (
github.com/dgraph-io/badger/v2 v2.2007.4 // indirect
github.com/dgraph-io/ristretto v0.1.1 // indirect
github.com/dgryski/go-farm v0.0.0-20200201041132-a6ae2369ad13 // indirect
- github.com/docker/distribution v2.8.1+incompatible // indirect
+ github.com/docker/distribution v2.8.2+incompatible // indirect
github.com/docker/go-connections v0.4.0 // indirect
github.com/docker/go-units v0.5.0 // indirect
github.com/dustin/go-humanize v1.0.1 // indirect
@@ -89,28 +95,28 @@ require (
github.com/ethereum/go-ethereum v1.10.26 // indirect
github.com/felixge/httpsnoop v1.0.2 // indirect
github.com/fsnotify/fsnotify v1.6.0 // indirect
+ github.com/getsentry/sentry-go v0.23.0 // indirect
github.com/go-kit/kit v0.12.0 // indirect
github.com/go-kit/log v0.2.1 // indirect
github.com/go-logfmt/logfmt v0.6.0 // indirect
- github.com/go-ole/go-ole v1.2.6 // indirect
github.com/go-stack/stack v1.8.1 // indirect
github.com/godbus/dbus v0.0.0-20190726142602-4481cbc300e2 // indirect
github.com/gofrs/flock v0.8.1 // indirect
github.com/gogo/googleapis v1.4.1 // indirect
github.com/gogo/protobuf v1.3.3 // indirect
- github.com/golang/glog v1.0.0 // indirect
+ github.com/golang/glog v1.1.0 // indirect
github.com/golang/groupcache v0.0.0-20210331224755-41bb18bfe9da // indirect
github.com/golang/mock v1.6.0 // indirect
- github.com/golang/protobuf v1.5.2 // indirect
+ github.com/golang/protobuf v1.5.3 // indirect
github.com/golang/snappy v0.0.4 // indirect
github.com/google/btree v1.1.2 // indirect
github.com/google/go-cmp v0.5.9 // indirect
github.com/google/go-github/v43 v43.0.0 // indirect
github.com/google/go-querystring v1.1.0 // indirect
github.com/google/orderedcode v0.0.1 // indirect
- github.com/google/uuid v1.3.0 // indirect
+ github.com/google/s2a-go v0.1.4 // indirect
github.com/googleapis/enterprise-certificate-proxy v0.2.3 // indirect
- github.com/googleapis/gax-go/v2 v2.7.0 // indirect
+ github.com/googleapis/gax-go/v2 v2.11.0 // indirect
github.com/gorilla/handlers v1.5.1 // indirect
github.com/gorilla/mux v1.8.0 // indirect
github.com/gorilla/websocket v1.5.0 // indirect
@@ -120,7 +126,7 @@ require (
github.com/gtank/merlin v0.1.1 // indirect
github.com/gtank/ristretto255 v0.1.2 // indirect
github.com/hashicorp/go-cleanhttp v0.5.2 // indirect
- github.com/hashicorp/go-getter v1.7.0 // indirect
+ github.com/hashicorp/go-getter v1.7.1 // indirect
github.com/hashicorp/go-immutable-radix v1.3.1 // indirect
github.com/hashicorp/go-safetemp v1.0.0 // indirect
github.com/hashicorp/go-version v1.6.0 // indirect
@@ -131,114 +137,118 @@ require (
github.com/huandu/skiplist v1.2.0 // indirect
github.com/improbable-eng/grpc-web v0.15.0 // indirect
github.com/inconshreveable/mousetrap v1.1.0 // indirect
- github.com/ipfs/go-cid v0.0.7 // indirect
+ github.com/ipfs/go-cid v0.2.0 // indirect
github.com/jmespath/go-jmespath v0.4.0 // indirect
github.com/jmhodges/levigo v1.0.0 // indirect
- github.com/json-iterator/go v1.1.12 // indirect
github.com/jsternberg/zap-logfmt v1.3.0 // indirect
github.com/kballard/go-shellquote v0.0.0-20180428030007-95032a82bc51 // indirect
- github.com/klauspost/compress v1.15.15 // indirect
- github.com/klauspost/cpuid/v2 v2.0.9 // indirect
+ github.com/klauspost/compress v1.16.3 // indirect
+ github.com/klauspost/cpuid/v2 v2.2.3 // indirect
+ github.com/kr/pretty v0.3.1 // indirect
+ github.com/kr/text v0.2.0 // indirect
github.com/lib/pq v1.10.7 // indirect
github.com/libp2p/go-buffer-pool v0.1.0 // indirect
- github.com/libp2p/go-libp2p-core v0.15.1 // indirect
- github.com/libp2p/go-openssl v0.0.7 // indirect
+ github.com/libp2p/go-libp2p v0.22.0 // indirect
+ github.com/libp2p/go-openssl v0.1.0 // indirect
+ github.com/linxGnu/grocksdb v1.7.16 // indirect
github.com/magiconair/properties v1.8.7 // indirect
github.com/manifoldco/promptui v0.9.0 // indirect
- github.com/mattn/go-isatty v0.0.17 // indirect
+ github.com/mattn/go-colorable v0.1.13 // indirect
+ github.com/mattn/go-isatty v0.0.19 // indirect
+ github.com/mattn/go-pointer v0.0.1 // indirect
github.com/matttproud/golang_protobuf_extensions v1.0.4 // indirect
github.com/mimoo/StrobeGo v0.0.0-20220103164710-9a04d6ca976b // indirect
- github.com/minio/blake2b-simd v0.0.0-20160723061019-3f5f724cb5b1 // indirect
github.com/minio/highwayhash v1.0.2 // indirect
github.com/minio/sha256-simd v1.0.0 // indirect
+ github.com/misko9/go-substrate-rpc-client/v4 v4.0.0-20230413215336-5bd2aea337ae // indirect
github.com/mitchellh/go-homedir v1.1.0 // indirect
github.com/mitchellh/go-testing-interface v1.14.1 // indirect
github.com/mitchellh/mapstructure v1.5.0 // indirect
- github.com/moby/sys/mount v0.3.3 // indirect
- github.com/moby/sys/mountinfo v0.6.2 // indirect
- github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd // indirect
- github.com/modern-go/reflect2 v1.0.2 // indirect
+ github.com/moby/patternmatcher v0.5.0 // indirect
+ github.com/moby/sys/sequential v0.5.0 // indirect
github.com/mr-tron/base58 v1.2.0 // indirect
github.com/mtibben/percent v0.2.1 // indirect
- github.com/multiformats/go-base32 v0.0.3 // indirect
+ github.com/multiformats/go-base32 v0.0.4 // indirect
github.com/multiformats/go-base36 v0.1.0 // indirect
- github.com/multiformats/go-multiaddr v0.4.1 // indirect
- github.com/multiformats/go-multibase v0.0.3 // indirect
- github.com/multiformats/go-multicodec v0.4.1 // indirect
- github.com/multiformats/go-multihash v0.1.0 // indirect
+ github.com/multiformats/go-multiaddr v0.6.0 // indirect
+ github.com/multiformats/go-multibase v0.1.1 // indirect
+ github.com/multiformats/go-multicodec v0.5.0 // indirect
+ github.com/multiformats/go-multihash v0.2.1 // indirect
github.com/multiformats/go-varint v0.0.6 // indirect
github.com/opencontainers/go-digest v1.0.0 // indirect
github.com/opencontainers/image-spec v1.1.0-rc2 // indirect
github.com/opencontainers/runc v1.1.3 // indirect
github.com/pelletier/go-toml v1.9.5 // indirect
- github.com/pelletier/go-toml/v2 v2.0.6 // indirect
- github.com/petermattis/goid v0.0.0-20221215004737-a150e88a970d // indirect
+ github.com/pelletier/go-toml/v2 v2.0.8 // indirect
+ github.com/petermattis/goid v0.0.0-20230317030725-371a4b8eda08 // indirect
github.com/pierrec/xxHash v0.1.5 // indirect
github.com/pkg/errors v0.9.1 // indirect
github.com/pmezard/go-difflib v1.0.0 // indirect
- github.com/prometheus/client_golang v1.14.0 // indirect
+ github.com/prometheus/client_golang v1.15.0 // indirect
github.com/prometheus/client_model v0.3.0 // indirect
- github.com/prometheus/common v0.40.0 // indirect
+ github.com/prometheus/common v0.42.0 // indirect
github.com/prometheus/procfs v0.9.0 // indirect
github.com/rakyll/statik v0.1.7 // indirect
github.com/rcrowley/go-metrics v0.0.0-20201227073835-cf1acfcdf475 // indirect
- github.com/remyoudompheng/bigfft v0.0.0-20200410134404-eec4a21b6bb0 // indirect
+ github.com/remyoudompheng/bigfft v0.0.0-20230129092748-24d4a6f8daec // indirect
+ github.com/rogpeppe/go-internal v1.11.0 // indirect
github.com/rs/cors v1.8.3 // indirect
+ github.com/rs/zerolog v1.30.0 // indirect
github.com/sasha-s/go-deadlock v0.3.1 // indirect
github.com/sirupsen/logrus v1.9.0 // indirect
github.com/spacemonkeygo/spacelog v0.0.0-20180420211403-2296661a0572 // indirect
github.com/spaolacci/murmur3 v1.1.0 // indirect
- github.com/spf13/afero v1.9.3 // indirect
- github.com/spf13/cast v1.5.0 // indirect
- github.com/spf13/cobra v1.6.1 // indirect
+ github.com/spf13/afero v1.9.5 // indirect
+ github.com/spf13/cast v1.5.1 // indirect
+ github.com/spf13/cobra v1.7.0 // indirect
github.com/spf13/jwalterweatherman v1.1.0 // indirect
github.com/spf13/pflag v1.0.5 // indirect
- github.com/spf13/viper v1.15.0 // indirect
+ github.com/spf13/viper v1.16.0 // indirect
github.com/subosito/gotenv v1.4.2 // indirect
github.com/syndtr/goleveldb v1.0.1-0.20220721030215-126854af5e6d // indirect
- github.com/tecbot/gorocksdb v0.0.0-20191217155057-f0fad39f321c // indirect
github.com/tendermint/go-amino v0.16.0 // indirect
github.com/tidwall/btree v1.6.0 // indirect
- github.com/tklauser/go-sysconf v0.3.10 // indirect
+ github.com/tyler-smith/go-bip32 v1.0.0 // indirect
github.com/tyler-smith/go-bip39 v1.1.0 // indirect
github.com/ulikunitz/xz v0.5.11 // indirect
- github.com/vedhavyas/go-subkey v1.0.3 // indirect
github.com/zondax/hid v0.9.1 // indirect
github.com/zondax/ledger-go v0.14.1 // indirect
- go.etcd.io/bbolt v1.3.6 // indirect
+ go.etcd.io/bbolt v1.3.7 // indirect
go.opencensus.io v0.24.0 // indirect
go.uber.org/atomic v1.10.0 // indirect
- go.uber.org/multierr v1.8.0 // indirect
- golang.org/x/crypto v0.6.0 // indirect
- golang.org/x/exp v0.0.0-20230213192124-5e25df0256eb // indirect
- golang.org/x/mod v0.8.0 // indirect
- golang.org/x/net v0.7.0 // indirect
- golang.org/x/oauth2 v0.5.0 // indirect
- golang.org/x/sys v0.5.0 // indirect
- golang.org/x/term v0.5.0 // indirect
- golang.org/x/text v0.7.0 // indirect
- golang.org/x/tools v0.6.0 // indirect
+ go.uber.org/multierr v1.11.0 // indirect
+ golang.org/x/crypto v0.11.0 // indirect
+ golang.org/x/exp v0.0.0-20230711153332-06a737ee72cb // indirect
+ golang.org/x/mod v0.11.0 // indirect
+ golang.org/x/net v0.12.0 // indirect
+ golang.org/x/oauth2 v0.8.0 // indirect
+ golang.org/x/sys v0.11.0 // indirect
+ golang.org/x/term v0.10.0 // indirect
+ golang.org/x/text v0.12.0 // indirect
+ golang.org/x/tools v0.9.3 // indirect
golang.org/x/xerrors v0.0.0-20220907171357-04be3eba64a2 // indirect
- google.golang.org/api v0.110.0 // indirect
+ google.golang.org/api v0.126.0 // indirect
google.golang.org/appengine v1.6.7 // indirect
- google.golang.org/genproto v0.0.0-20230216225411-c8e22ba71e44 // indirect
- google.golang.org/grpc v1.53.0 // indirect
- google.golang.org/protobuf v1.28.2-0.20230208135220-49eaa78c6c9c // indirect
+ google.golang.org/genproto v0.0.0-20230706204954-ccb25ca9f130 // indirect
+ google.golang.org/genproto/googleapis/api v0.0.0-20230629202037-9506855d4529 // indirect
+ google.golang.org/genproto/googleapis/rpc v0.0.0-20230711160842-782d3b101e98 // indirect
+ google.golang.org/grpc v1.56.2 // indirect
+ google.golang.org/protobuf v1.31.0 // indirect
gopkg.in/ini.v1 v1.67.0 // indirect
gopkg.in/natefinch/npipe.v2 v2.0.0-20160621034901-c1b8fa8bdcce // indirect
gopkg.in/yaml.v2 v2.4.0 // indirect
gopkg.in/yaml.v3 v3.0.1 // indirect
- lukechampine.com/blake3 v1.1.6 // indirect
- lukechampine.com/uint128 v1.1.1 // indirect
- modernc.org/cc/v3 v3.36.0 // indirect
- modernc.org/ccgo/v3 v3.16.6 // indirect
- modernc.org/libc v1.16.7 // indirect
- modernc.org/mathutil v1.4.1 // indirect
- modernc.org/memory v1.1.1 // indirect
- modernc.org/opt v0.1.1 // indirect
- modernc.org/sqlite v1.17.3 // indirect
- modernc.org/strutil v1.1.1 // indirect
- modernc.org/token v1.0.0 // indirect
+ lukechampine.com/blake3 v1.1.7 // indirect
+ lukechampine.com/uint128 v1.2.0 // indirect
+ modernc.org/cc/v3 v3.40.0 // indirect
+ modernc.org/ccgo/v3 v3.16.13 // indirect
+ modernc.org/libc v1.22.5 // indirect
+ modernc.org/mathutil v1.5.0 // indirect
+ modernc.org/memory v1.5.0 // indirect
+ modernc.org/opt v0.1.3 // indirect
+ modernc.org/sqlite v1.23.0 // indirect
+ modernc.org/strutil v1.1.3 // indirect
+ modernc.org/token v1.0.1 // indirect
nhooyr.io/websocket v1.8.6 // indirect
pgregory.net/rapid v0.5.5 // indirect
sigs.k8s.io/yaml v1.3.0 // indirect
diff --git a/interchaintest/go.sum b/interchaintest/go.sum
index 53804d403..abdaf4f74 100644
--- a/interchaintest/go.sum
+++ b/interchaintest/go.sum
@@ -1,4 +1,3 @@
-bazil.org/fuse v0.0.0-20160811212531-371fbbdaa898/go.mod h1:Xbm+BRKSBEpa4q4hTSxohYNQpsxXPbPry4JJWOB3LB8=
cloud.google.com/go v0.26.0/go.mod h1:aQUYkXzVsufM+DwF1aE+0xfcU+56JwCaLick0ClmMTw=
cloud.google.com/go v0.34.0/go.mod h1:aQUYkXzVsufM+DwF1aE+0xfcU+56JwCaLick0ClmMTw=
cloud.google.com/go v0.38.0/go.mod h1:990N+gfupTy94rShfmMCWGDn0LpTmnzTp2qbd1dvSRU=
@@ -33,8 +32,8 @@ cloud.google.com/go v0.100.2/go.mod h1:4Xra9TjzAeYHrl5+oeLlzbM2k3mjVhZh4UqTZ//w9
cloud.google.com/go v0.102.0/go.mod h1:oWcCzKlqJ5zgHQt9YsaeTY9KzIvjyy0ArmiBUgpQ+nc=
cloud.google.com/go v0.102.1/go.mod h1:XZ77E9qnTEnrgEOvr4xzfdX5TRo7fB4T2F4O6+34hIU=
cloud.google.com/go v0.104.0/go.mod h1:OO6xxXdJyvuJPcEPBLN9BJPD+jep5G1+2U5B5gkRYtA=
-cloud.google.com/go v0.110.0 h1:Zc8gqp3+a9/Eyph2KDmcGaPtbKRIoqq4YTlL4NMD0Ys=
-cloud.google.com/go v0.110.0/go.mod h1:SJnCLqQ0FCFGSZMUNUf84MV3Aia54kn7pi8st7tMzaY=
+cloud.google.com/go v0.110.4 h1:1JYyxKMN9hd5dR2MYTPWkGUgcoxVVhg0LKNKEo0qvmk=
+cloud.google.com/go v0.110.4/go.mod h1:+EYjdK8e5RME/VY/qLCAtuyALQ9q67dvuum8i+H5xsI=
cloud.google.com/go/aiplatform v1.22.0/go.mod h1:ig5Nct50bZlzV6NvKaTwmplLLddFx0YReh9WfTO5jKw=
cloud.google.com/go/aiplatform v1.24.0/go.mod h1:67UUvRBKG6GTayHKV8DBv2RtR1t93YRu5B1P3x99mYY=
cloud.google.com/go/analytics v0.11.0/go.mod h1:DjEWCu41bVbYcKyvlws9Er60YE4a//bK6mnhWvQeFNI=
@@ -71,8 +70,8 @@ cloud.google.com/go/compute v1.6.0/go.mod h1:T29tfhtVbq1wvAPo0E3+7vhgmkOYeXjhFvz
cloud.google.com/go/compute v1.6.1/go.mod h1:g85FgpzFvNULZ+S8AYq87axRKuf2Kh7deLqV/jJ3thU=
cloud.google.com/go/compute v1.7.0/go.mod h1:435lt8av5oL9P3fv1OEzSbSUe+ybHXGMPQHHZWZxy9U=
cloud.google.com/go/compute v1.10.0/go.mod h1:ER5CLbMxl90o2jtNbGSbtfOpQKR0t15FOtRsugnLrlU=
-cloud.google.com/go/compute v1.18.0 h1:FEigFqoDbys2cvFkZ9Fjq4gnHBP55anJ0yQyau2f9oY=
-cloud.google.com/go/compute v1.18.0/go.mod h1:1X7yHxec2Ga+Ss6jPyjxRxpu2uu7PLgsOVXvgU0yacs=
+cloud.google.com/go/compute v1.20.1 h1:6aKEtlUiwEpJzM001l0yFkpXmUVXaN8W+fbkb2AZNbg=
+cloud.google.com/go/compute v1.20.1/go.mod h1:4tCnrn48xsqlwSAiLf1HXMQk8CONslYbdiEZc9FEIbM=
cloud.google.com/go/compute/metadata v0.2.3 h1:mg4jlk7mCAj6xXp9UJ4fjI9VUI5rubuGBW5aJ7UnBMY=
cloud.google.com/go/compute/metadata v0.2.3/go.mod h1:VAV5nSsACxMJvgaAuX6Pk2AawlZn8kiOGuCv6gTkwuA=
cloud.google.com/go/containeranalysis v0.5.1/go.mod h1:1D92jd8gRR/c0fGMlymRgxWD3Qw9C1ff6/T7mLgVL8I=
@@ -112,13 +111,12 @@ cloud.google.com/go/gkehub v0.10.0/go.mod h1:UIPwxI0DsrpsVoWpLB0stwKCP+WFVG9+y97
cloud.google.com/go/grafeas v0.2.0/go.mod h1:KhxgtF2hb0P191HlY5besjYm6MqTSTj3LSI+M+ByZHc=
cloud.google.com/go/iam v0.3.0/go.mod h1:XzJPvDayI+9zsASAFO68Hk07u3z+f+JrT2xXNdp4bnY=
cloud.google.com/go/iam v0.5.0/go.mod h1:wPU9Vt0P4UmCux7mqtRu6jcpPAb74cP1fh50J3QpkUc=
-cloud.google.com/go/iam v0.12.0 h1:DRtTY29b75ciH6Ov1PHb4/iat2CLCvrOm40Q0a6DFpE=
-cloud.google.com/go/iam v0.12.0/go.mod h1:knyHGviacl11zrtZUoDuYpDgLjvr28sLQaG0YB2GYAY=
+cloud.google.com/go/iam v1.1.0 h1:67gSqaPukx7O8WLLHMa0PNs3EBGd2eE4d+psbO/CO94=
+cloud.google.com/go/iam v1.1.0/go.mod h1:nxdHjaKfCr7fNYx/HJMM8LgiMugmveWlkatear5gVyk=
cloud.google.com/go/language v1.4.0/go.mod h1:F9dRpNFQmJbkaop6g0JhSBXCNlO90e1KWx5iDdxbWic=
cloud.google.com/go/language v1.6.0/go.mod h1:6dJ8t3B+lUYfStgls25GusK04NLh3eDLQnWM3mdEbhI=
cloud.google.com/go/lifesciences v0.5.0/go.mod h1:3oIKy8ycWGPUyZDR/8RNnTOYevhaMLqh5vLUXs9zvT8=
cloud.google.com/go/lifesciences v0.6.0/go.mod h1:ddj6tSX/7BOnhxCSd3ZcETvtNr8NZ6t/iPhY2Tyfu08=
-cloud.google.com/go/longrunning v0.3.0 h1:NjljC+FYPV3uh5/OwWT6pVU+doBqMg2x/rZlE+CamDs=
cloud.google.com/go/mediatranslation v0.5.0/go.mod h1:jGPUhGTybqsPQn91pNXw0xVHfuJ3leR1wj37oU3y1f4=
cloud.google.com/go/mediatranslation v0.6.0/go.mod h1:hHdBCTYNigsBxshbznuIMFNe5QXEowAuNmmC7h8pu5w=
cloud.google.com/go/memcache v1.4.0/go.mod h1:rTOfiGZtJX1AaFUrOgsMHX5kAzaTQ8azHiuDoTPzNsE=
@@ -176,8 +174,8 @@ cloud.google.com/go/storage v1.14.0/go.mod h1:GrKmX003DSIwi9o29oFT7YDnHYwZoctc3f
cloud.google.com/go/storage v1.22.1/go.mod h1:S8N1cAStu7BOeFfE8KAQzmyyLkK8p/vmRq6kuBTW58Y=
cloud.google.com/go/storage v1.23.0/go.mod h1:vOEEDNFnciUMhBeT6hsJIn3ieU5cFRmzeLgDvXzfIXc=
cloud.google.com/go/storage v1.27.0/go.mod h1:x9DOL8TK/ygDUMieqwfhdpQryTeEkhGKMi80i/iqR2s=
-cloud.google.com/go/storage v1.29.0 h1:6weCgzRvMg7lzuUurI4697AqIRPU1SvzHhynwpW31jI=
-cloud.google.com/go/storage v1.29.0/go.mod h1:4puEjyTKnku6gfKoTfNOU/W+a9JyuVNxjpS5GBrB8h4=
+cloud.google.com/go/storage v1.30.1 h1:uOdMxAs8HExqBlnLtnQyP0YkvbiDpdGShGKtx6U/oNM=
+cloud.google.com/go/storage v1.30.1/go.mod h1:NfxhC0UJE1aXSx7CIIbCf7y9HKT7BiccwkR7+P7gN8E=
cloud.google.com/go/talent v1.1.0/go.mod h1:Vl4pt9jiHKvOgF9KoZo6Kob9oV4lwd/ZD5Cto54zDRw=
cloud.google.com/go/talent v1.2.0/go.mod h1:MoNF9bhFQbiJ6eFD3uSsg0uBALw4n4gaCaEjBw9zo8g=
cloud.google.com/go/videointelligence v1.6.0/go.mod h1:w0DIDlVRKtwPCn/C4iwZIJdvC69yInhW0cfi+p546uU=
@@ -193,12 +191,14 @@ cosmossdk.io/api v0.3.1 h1:NNiOclKRR0AOlO4KIqeaG6PS6kswOMhHD0ir0SscNXE=
cosmossdk.io/api v0.3.1/go.mod h1:DfHfMkiNA2Uhy8fj0JJlOCYOBp4eWUUJ1te5zBGNyIw=
cosmossdk.io/core v0.5.1 h1:vQVtFrIYOQJDV3f7rw4pjjVqc1id4+mE0L9hHP66pyI=
cosmossdk.io/core v0.5.1/go.mod h1:KZtwHCLjcFuo0nmDc24Xy6CRNEL9Vl/MeimQ2aC7NLE=
-cosmossdk.io/depinject v1.0.0-alpha.3 h1:6evFIgj//Y3w09bqOUOzEpFj5tsxBqdc5CfkO7z+zfw=
-cosmossdk.io/depinject v1.0.0-alpha.3/go.mod h1:eRbcdQ7MRpIPEM5YUJh8k97nxHpYbc3sMUnEtt8HPWU=
-cosmossdk.io/errors v1.0.0-beta.7 h1:gypHW76pTQGVnHKo6QBkb4yFOJjC+sUGRc5Al3Odj1w=
-cosmossdk.io/errors v1.0.0-beta.7/go.mod h1:mz6FQMJRku4bY7aqS/Gwfcmr/ue91roMEKAmDUDpBfE=
-cosmossdk.io/math v1.0.0-beta.6.0.20230216172121-959ce49135e4 h1:/jnzJ9zFsL7qkV8LCQ1JH3dYHh2EsKZ3k8Mr6AqqiOA=
-cosmossdk.io/math v1.0.0-beta.6.0.20230216172121-959ce49135e4/go.mod h1:gUVtWwIzfSXqcOT+lBVz2jyjfua8DoBdzRsIyaUAT/8=
+cosmossdk.io/depinject v1.0.0-alpha.4 h1:PLNp8ZYAMPTUKyG9IK2hsbciDWqna2z1Wsl98okJopc=
+cosmossdk.io/depinject v1.0.0-alpha.4/go.mod h1:HeDk7IkR5ckZ3lMGs/o91AVUc7E596vMaOmslGFM3yU=
+cosmossdk.io/errors v1.0.0 h1:nxF07lmlBbB8NKQhtJ+sJm6ef5uV1XkvPXG2bUntb04=
+cosmossdk.io/errors v1.0.0/go.mod h1:+hJZLuhdDE0pYN8HkOrVNwrIOYvUGnn6+4fjnJs/oV0=
+cosmossdk.io/log v1.2.1 h1:Xc1GgTCicniwmMiKwDxUjO4eLhPxoVdI9vtMW8Ti/uk=
+cosmossdk.io/log v1.2.1/go.mod h1:GNSCc/6+DhFIj1aLn/j7Id7PaO8DzNylUZoOYBL9+I4=
+cosmossdk.io/math v1.1.2 h1:ORZetZCTyWkI5GlZ6CZS28fMHi83ZYf+A2vVnHNzZBM=
+cosmossdk.io/math v1.1.2/go.mod h1:l2Gnda87F0su8a/7FEKJfFdJrM0JZRXQaohlgJeyQh0=
cosmossdk.io/simapp v0.0.0-20230224204036-a6adb0821462 h1:g8muUHnXL8vhld2Sjilyhb1UQObc+x9GVuDK43TYZns=
cosmossdk.io/simapp v0.0.0-20230224204036-a6adb0821462/go.mod h1:4Dd3NLoLYoN90kZ0uyHoTHzVVk9+J0v4HhZRBNTAq2c=
cosmossdk.io/tools/rosetta v0.2.1 h1:ddOMatOH+pbxWbrGJKRAawdBkPYLfKXutK9IETnjYxw=
@@ -208,62 +208,32 @@ filippo.io/edwards25519 v1.0.0 h1:0wAIcmJUqRdI8IJ/3eGi5/HwXZWPujYXXlkrQogz0Ek=
filippo.io/edwards25519 v1.0.0/go.mod h1:N1IkdkCkiLB6tki+MYJoSx2JTY9NUlxZE7eHn5EwJns=
github.com/99designs/go-keychain v0.0.0-20191008050251-8e49817e8af4 h1:/vQbFIOMbk2FiG/kXiLl8BRyzTWDw7gX/Hz7Dd5eDMs=
github.com/99designs/go-keychain v0.0.0-20191008050251-8e49817e8af4/go.mod h1:hN7oaIRCjzsZ2dE+yG5k+rsdt3qcwykqK6HVGcKwsw4=
-github.com/99designs/keyring v1.2.1 h1:tYLp1ULvO7i3fI5vE21ReQuj99QFSs7lGm0xWyJo87o=
-github.com/99designs/keyring v1.2.1/go.mod h1:fc+wB5KTk9wQ9sDx0kFXB3A0MaeGHM9AwRStKOQ5vOA=
-github.com/Azure/azure-sdk-for-go v16.2.1+incompatible/go.mod h1:9XXNKU+eRnpl9moKnB4QOLf1HestfXbmab5FXxiDBjc=
-github.com/Azure/go-ansiterm v0.0.0-20170929234023-d6e3b3328b78/go.mod h1:LmzpDX56iTiv29bbRTIsUNlaFfuhWRQBWjQdVyAevI8=
+github.com/99designs/keyring v1.2.2 h1:pZd3neh/EmUzWONb35LxQfvuY7kiSXAq3HQd97+XBn0=
+github.com/99designs/keyring v1.2.2/go.mod h1:wes/FrByc8j7lFOAGLGSNEg8f/PaI3cgTBqhFkHUrPk=
+github.com/AdaLogics/go-fuzz-headers v0.0.0-20210715213245-6c3934b029d8 h1:V8krnnfGj4pV65YLUm3C0/8bl7V5Nry2Pwvy3ru/wLc=
github.com/Azure/go-ansiterm v0.0.0-20210617225240-d185dfc1b5a1 h1:UQHMgLO+TxOElx5B5HZ4hJQsoJ/PvUvKRhJHDQXO8P8=
-github.com/Azure/go-autorest v10.8.1+incompatible/go.mod h1:r+4oMnoxhatjLLJ6zxSWATqVooLgysK6ZNox3g/xq24=
-github.com/Azure/go-autorest v14.2.0+incompatible/go.mod h1:r+4oMnoxhatjLLJ6zxSWATqVooLgysK6ZNox3g/xq24=
-github.com/Azure/go-autorest/autorest v0.11.1/go.mod h1:JFgpikqFJ/MleTTxwepExTKnFUKKszPS8UavbQYUMuw=
-github.com/Azure/go-autorest/autorest/adal v0.9.0/go.mod h1:/c022QCutn2P7uY+/oQWWNcK9YU+MH96NgK+jErpbcg=
-github.com/Azure/go-autorest/autorest/adal v0.9.5/go.mod h1:B7KF7jKIeC9Mct5spmyCB/A8CG/sEz1vwIRGv/bbw7A=
-github.com/Azure/go-autorest/autorest/date v0.3.0/go.mod h1:BI0uouVdmngYNUzGWeSYnokU+TrmwEsOqdt8Y6sso74=
-github.com/Azure/go-autorest/autorest/mocks v0.4.0/go.mod h1:LTp+uSrOhSkaKrUy935gNZuuIPPVsHlr9DSOxSayd+k=
-github.com/Azure/go-autorest/autorest/mocks v0.4.1/go.mod h1:LTp+uSrOhSkaKrUy935gNZuuIPPVsHlr9DSOxSayd+k=
-github.com/Azure/go-autorest/logger v0.2.0/go.mod h1:T9E3cAhj2VqvPOtCYAvby9aBXkZmbF5NWuPV8+WeEW8=
-github.com/Azure/go-autorest/tracing v0.6.0/go.mod h1:+vhtPC754Xsa23ID7GlGsrdKBpUA79WCAKPPZVC2DeU=
github.com/BurntSushi/toml v0.3.1/go.mod h1:xHWCNGjB5oqiDr8zfno3MHue2Ht5sIBksp03qcyfWMU=
-github.com/BurntSushi/toml v1.2.1 h1:9F2/+DoOYIOksmaJFPw1tGFy1eDnIJXg+UHjuD8lTak=
-github.com/BurntSushi/toml v1.2.1/go.mod h1:CxXYINrC8qIiEnFrOxCa7Jy5BFHlXnUU2pbicEuybxQ=
+github.com/BurntSushi/toml v1.3.0 h1:Ws8e5YmnrGEHzZEzg0YvK/7COGYtTC5PbaH9oSSbgfA=
+github.com/BurntSushi/toml v1.3.0/go.mod h1:CxXYINrC8qIiEnFrOxCa7Jy5BFHlXnUU2pbicEuybxQ=
github.com/BurntSushi/xgb v0.0.0-20160522181843-27f122750802/go.mod h1:IVnqGOEym/WlBOVXweHU+Q+/VP0lqqI8lqeDx9IjBqo=
github.com/ChainSafe/go-schnorrkel v0.0.0-20200405005733-88cbf1b4c40d h1:nalkkPQcITbvhmL4+C4cKA87NW0tfm3Kl9VXRoPywFg=
github.com/ChainSafe/go-schnorrkel v0.0.0-20200405005733-88cbf1b4c40d/go.mod h1:URdX5+vg25ts3aCh8H5IFZybJYKWhJHYMTnf+ULtoC4=
github.com/ChainSafe/go-schnorrkel v1.0.0 h1:3aDA67lAykLaG1y3AOjs88dMxC88PgUuHRrLeDnvGIM=
github.com/ChainSafe/go-schnorrkel v1.0.0/go.mod h1:dpzHYVxLZcp8pjlV+O+UR8K0Hp/z7vcchBSbMBEhCw4=
+github.com/ComposableFi/go-subkey/v2 v2.0.0-tm03420 h1:oknQF/iIhf5lVjbwjsVDzDByupRhga8nhA3NAmwyHDA=
+github.com/ComposableFi/go-subkey/v2 v2.0.0-tm03420/go.mod h1:KYkiMX5AbOlXXYfxkrYPrRPV6EbVUALTQh5ptUOJzu8=
github.com/DataDog/datadog-go v3.2.0+incompatible/go.mod h1:LButxg5PwREeZtORoXG3tL4fMGNddJ+vMq1mwgfaqoQ=
+github.com/FactomProject/basen v0.0.0-20150613233007-fe3947df716e h1:ahyvB3q25YnZWly5Gq1ekg6jcmWaGj/vG/MhF4aisoc=
+github.com/FactomProject/basen v0.0.0-20150613233007-fe3947df716e/go.mod h1:kGUqhHd//musdITWjFvNTHn90WG9bMLBEPQZ17Cmlpw=
+github.com/FactomProject/btcutilecc v0.0.0-20130527213604-d3a63a5752ec h1:1Qb69mGp/UtRPn422BH4/Y4Q3SLUrD9KHuDkm8iodFc=
+github.com/FactomProject/btcutilecc v0.0.0-20130527213604-d3a63a5752ec/go.mod h1:CD8UlnlLDiqb36L110uqiP2iSflVjx9g/3U9hCI4q2U=
github.com/Knetic/govaluate v3.0.1-0.20171022003610-9aa49832a739+incompatible/go.mod h1:r7JcOSlj0wfOMncg0iLm8Leh48TZaKVeNIfJntJ2wa0=
-github.com/Microsoft/go-winio v0.4.11/go.mod h1:VhR8bwka0BXejwEJY73c50VrPtXAaKcyvVC4A4RozmA=
-github.com/Microsoft/go-winio v0.4.14/go.mod h1:qXqCSQ3Xa7+6tgxaGTIe4Kpcdsi+P8jBhyzoq1bpyYA=
-github.com/Microsoft/go-winio v0.4.15-0.20190919025122-fc70bd9a86b5/go.mod h1:tTuCMEN+UleMWgg9dVx4Hu52b1bJo+59jBh3ajtinzw=
-github.com/Microsoft/go-winio v0.4.16-0.20201130162521-d1ffc52c7331/go.mod h1:XB6nPKklQyQ7GC9LdcBEcBl8PF76WugXOPRXwdLnMv0=
-github.com/Microsoft/go-winio v0.4.16/go.mod h1:XB6nPKklQyQ7GC9LdcBEcBl8PF76WugXOPRXwdLnMv0=
-github.com/Microsoft/go-winio v0.4.17-0.20210211115548-6eac466e5fa3/go.mod h1:JPGBdM1cNvN/6ISo+n8V5iA4v8pBzdOpzfwIujj1a84=
-github.com/Microsoft/go-winio v0.4.17-0.20210324224401-5516f17a5958/go.mod h1:JPGBdM1cNvN/6ISo+n8V5iA4v8pBzdOpzfwIujj1a84=
-github.com/Microsoft/go-winio v0.4.17/go.mod h1:JPGBdM1cNvN/6ISo+n8V5iA4v8pBzdOpzfwIujj1a84=
github.com/Microsoft/go-winio v0.6.0 h1:slsWYD/zyx7lCXoZVlvQrj0hPTM1HI4+v1sIda2yDvg=
github.com/Microsoft/go-winio v0.6.0/go.mod h1:cTAf44im0RAYeL23bpB+fzCyDH2MJiz2BO69KH/soAE=
-github.com/Microsoft/hcsshim v0.8.6/go.mod h1:Op3hHsoHPAvb6lceZHDtd9OkTew38wNoXnJs8iY7rUg=
-github.com/Microsoft/hcsshim v0.8.7-0.20190325164909-8abdbb8205e4/go.mod h1:Op3hHsoHPAvb6lceZHDtd9OkTew38wNoXnJs8iY7rUg=
-github.com/Microsoft/hcsshim v0.8.7/go.mod h1:OHd7sQqRFrYd3RmSgbgji+ctCwkbq2wbEYNSzOYtcBQ=
-github.com/Microsoft/hcsshim v0.8.9/go.mod h1:5692vkUqntj1idxauYlpoINNKeqCiG6Sg38RRsjT5y8=
-github.com/Microsoft/hcsshim v0.8.14/go.mod h1:NtVKoYxQuTLx6gEq0L96c9Ju4JbRJ4nY2ow3VK6a9Lg=
-github.com/Microsoft/hcsshim v0.8.15/go.mod h1:x38A4YbHbdxJtc0sF6oIz+RG0npwSCAvn69iY6URG00=
-github.com/Microsoft/hcsshim v0.8.16/go.mod h1:o5/SZqmR7x9JNKsW3pu+nqHm0MF8vbA+VxGOoXdC600=
-github.com/Microsoft/hcsshim v0.8.21/go.mod h1:+w2gRZ5ReXQhFOrvSQeNfhrYB/dg3oDwTOcER2fw4I4=
-github.com/Microsoft/hcsshim v0.9.6 h1:VwnDOgLeoi2du6dAznfmspNqTiwczvjv4K7NxuY9jsY=
-github.com/Microsoft/hcsshim v0.9.6/go.mod h1:7pLA8lDk46WKDWlVsENo92gC0XFa8rbKfyFRBqxEbCc=
-github.com/Microsoft/hcsshim/test v0.0.0-20201218223536-d3e5debf77da/go.mod h1:5hlzMzRKMLyo42nCZ9oml8AdTlq/0cvIaBv6tK1RehU=
-github.com/Microsoft/hcsshim/test v0.0.0-20210227013316-43a75bb4edd3/go.mod h1:mw7qgWloBUl75W/gVH3cQszUg1+gUITj7D6NY7ywVnY=
-github.com/NYTimes/gziphandler v0.0.0-20170623195520-56545f4a5d46/go.mod h1:3wb06e3pkSAbeQ52E9H9iFoQsEEwGN64994WTCIhntQ=
+github.com/Microsoft/hcsshim v0.9.4 h1:mnUj0ivWy6UzbB1uLFqKR6F+ZyiDc7j4iGgHTpO+5+I=
github.com/Nvveen/Gotty v0.0.0-20120604004816-cd527374f1e5 h1:TngWCqHvy9oXAN6lEVMRuU21PR1EtLVZJmdB18Gu3Rw=
github.com/OneOfOne/xxhash v1.2.2 h1:KMrpdQIwFcEqXDklaen+P1axHaj9BSKzvpUUfnHldSE=
github.com/OneOfOne/xxhash v1.2.2/go.mod h1:HSdplMjZKSmBqAxg5vPj2TmRDmfkzw+cTzAElWljhcU=
-github.com/PuerkitoBio/purell v1.0.0/go.mod h1:c11w/QuzBsJSee3cPx9rAFu61PvFxuPbtSwDGJws/X0=
-github.com/PuerkitoBio/purell v1.1.1/go.mod h1:c11w/QuzBsJSee3cPx9rAFu61PvFxuPbtSwDGJws/X0=
-github.com/PuerkitoBio/urlesc v0.0.0-20160726150825-5bd2802263f2/go.mod h1:uGdkoq3SwY9Y+13GIhn11/XLaGBb4BfwItxLd5jeuXE=
-github.com/PuerkitoBio/urlesc v0.0.0-20170810143723-de5bf2ad4578/go.mod h1:uGdkoq3SwY9Y+13GIhn11/XLaGBb4BfwItxLd5jeuXE=
-github.com/Shopify/logrus-bugsnag v0.0.0-20171204204709-577dee27f20d/go.mod h1:HI8ITrYtUY+O+ZhtlqUnD8+KwNPOyugEhfP9fdUIaEQ=
github.com/Shopify/sarama v1.19.0/go.mod h1:FVkBWblsNy7DGZRfXLU0O9RCGt5g3g3yEuWXgklEdEo=
github.com/Shopify/toxiproxy v2.1.4+incompatible/go.mod h1:OXgGpZ6Cli1/URJOF1DMxUHB2q5Ap20/P/eIdh4G0pI=
github.com/StackExchange/wmi v0.0.0-20180116203802-5d049714c4a6 h1:fLjPD/aNc3UIOA6tDi6QXUemppXK3P9BI7mr2hd6gx8=
@@ -275,13 +245,11 @@ github.com/VividCortex/gohistogram v1.0.0/go.mod h1:Pf5mBqqDxYaXu3hDrrU+w6nw50o/
github.com/adlio/schema v1.3.3 h1:oBJn8I02PyTB466pZO1UZEn1TV5XLlifBSyMrmHl/1I=
github.com/aead/siphash v1.0.1/go.mod h1:Nywa3cDsYNNK3gaciGTWPwHt0wlpNV15vwmswBAUSII=
github.com/afex/hystrix-go v0.0.0-20180502004556-fa1af6a1f4f5/go.mod h1:SkGFH1ia65gfNATL8TAiHDNxPzPdmEL5uirI2Uyuz6c=
-github.com/alecthomas/participle/v2 v2.0.0-alpha7 h1:cK4vjj0VSgb3lN1nuKA5F7dw+1s1pWBe5bx7nNCnN+c=
github.com/alecthomas/template v0.0.0-20160405071501-a0175ee3bccc/go.mod h1:LOuyumcjzFXgccqObfd/Ljyb9UuFJ6TxHnclSeseNhc=
github.com/alecthomas/template v0.0.0-20190718012654-fb15b899a751/go.mod h1:LOuyumcjzFXgccqObfd/Ljyb9UuFJ6TxHnclSeseNhc=
github.com/alecthomas/units v0.0.0-20151022065526-2efee857e7cf/go.mod h1:ybxpYRFXyAe+OPACYpWeL0wqObRcbAqCMya13uyzqw0=
github.com/alecthomas/units v0.0.0-20190717042225-c3de453c63f4/go.mod h1:ybxpYRFXyAe+OPACYpWeL0wqObRcbAqCMya13uyzqw0=
github.com/alecthomas/units v0.0.0-20190924025748-f65c72e2690d/go.mod h1:rBZYJk541a8SKzHPHnH3zbiI+7dagKZ0cgpgrD7Fyho=
-github.com/alexflint/go-filemutex v0.0.0-20171022225611-72bdc8eae2ae/go.mod h1:CgnQgUtFrFz9mxFNtED3jI5tLDjKlOM+oUF/sTk6ps0=
github.com/antihax/optional v1.0.0/go.mod h1:uupD/76wgC+ih3iEmQUL+0Ugr19nfwCT1kdvxnR2qWY=
github.com/apache/thrift v0.12.0/go.mod h1:cp2SuWMxlEZw2r+iP2GNCdIi4C1qmUzdZFSVb+bacwQ=
github.com/apache/thrift v0.13.0/go.mod h1:cp2SuWMxlEZw2r+iP2GNCdIi4C1qmUzdZFSVb+bacwQ=
@@ -292,11 +260,9 @@ github.com/armon/go-metrics v0.4.1 h1:hR91U9KYmb6bLBYLQjyM+3j+rcd/UhE+G78SFnF8gJ
github.com/armon/go-metrics v0.4.1/go.mod h1:E6amYzXo6aW1tqzoZGT755KkbgrJsSdpwZ+3JqfkOG4=
github.com/armon/go-radix v0.0.0-20180808171621-7fddfc383310/go.mod h1:ufUuZ+zHj4x4TnLV4JWEpy2hxWSpsRywHrMgIH9cCH8=
github.com/aryann/difflib v0.0.0-20170710044230-e206f873d14a/go.mod h1:DAHtR1m6lCRdSC2Tm3DSWRPvIPr6xNKyeHdqDQSQT+A=
-github.com/asaskevich/govalidator v0.0.0-20190424111038-f61b66f89f4a/go.mod h1:lB+ZfQJz7igIIfQNfa7Ml4HSf2uFQQRzpGGRXenZAgY=
-github.com/avast/retry-go/v4 v4.3.2 h1:x4sTEu3jSwr7zNjya8NTdIN+U88u/jtO/q3OupBoDtM=
-github.com/avast/retry-go/v4 v4.3.2/go.mod h1:rg6XFaiuFYII0Xu3RDbZQkxCofFwruZKW8oEF1jpWiU=
+github.com/avast/retry-go/v4 v4.3.4 h1:pHLkL7jvCvP317I8Ge+Km2Yhntv3SdkJm7uekkqbKhM=
+github.com/avast/retry-go/v4 v4.3.4/go.mod h1:rv+Nla6Vk3/ilU0H51VHddWHiwimzX66yZ0JT6T+UvE=
github.com/aws/aws-lambda-go v1.13.3/go.mod h1:4UKl9IzQMoD+QF79YdCuzCwp8VbmG4VAQwij/eHl5CU=
-github.com/aws/aws-sdk-go v1.15.11/go.mod h1:mFuSZ37Z9YOHbQEwBWztmVzqXrEkub65tZoCYDt7FT0=
github.com/aws/aws-sdk-go v1.27.0/go.mod h1:KmX6BPdI08NWTb3/sm4ZGu5ShLoqVDhKgpiN924inxo=
github.com/aws/aws-sdk-go v1.44.122/go.mod h1:y4AeaBuwd2Lk+GepC1E9v0qOiTws0MIWAX4oIKwKHZo=
github.com/aws/aws-sdk-go v1.44.203 h1:pcsP805b9acL3wUqa4JR2vg1k2wnItkDYNvfmcy6F+U=
@@ -304,7 +270,6 @@ github.com/aws/aws-sdk-go v1.44.203/go.mod h1:aVsgQcEevwlmQ7qHE9I3h+dtQgpqhFB+i8
github.com/aws/aws-sdk-go-v2 v0.18.0/go.mod h1:JWVYvqSMppoMJC0x5wdwiImzgXTI9FuZwxzkQq9wy+g=
github.com/benbjohnson/clock v1.3.0 h1:ip6w0uFQkncKQ979AypyG0ER7mqUSBdKLOgAle/AT8A=
github.com/benbjohnson/clock v1.3.0/go.mod h1:J11/hYXuz8f4ySSvYwY0FKfm+ezbsZBKZxNJlLklBHA=
-github.com/beorn7/perks v0.0.0-20160804104726-4c0e84591b9a/go.mod h1:Dwedo/Wpr24TaqPxmxbtue+5NUziq4I4S80YR8gNf3Q=
github.com/beorn7/perks v0.0.0-20180321164747-3a771d992973/go.mod h1:Dwedo/Wpr24TaqPxmxbtue+5NUziq4I4S80YR8gNf3Q=
github.com/beorn7/perks v1.0.0/go.mod h1:KWe93zE9D1o94FZ5RNwFwVgaQK1VOXiVxmqh+CedLV8=
github.com/beorn7/perks v1.0.1 h1:VlbKKnNfV8bJzeqoa4cOKqO6bYr3WgKZxO8Z16+hsOM=
@@ -314,33 +279,33 @@ github.com/bgentry/go-netrc v0.0.0-20140422174119-9fd32a8b3d3d/go.mod h1:6QX/PXZ
github.com/bgentry/speakeasy v0.1.0/go.mod h1:+zsyZBPWlz7T6j88CTgSN5bM796AkVf0kBD4zp0CCIs=
github.com/bgentry/speakeasy v0.1.1-0.20220910012023-760eaf8b6816 h1:41iFGWnSlI2gVpmOtVTJZNodLdLQLn/KsJqFvXwnd/s=
github.com/bgentry/speakeasy v0.1.1-0.20220910012023-760eaf8b6816/go.mod h1:+zsyZBPWlz7T6j88CTgSN5bM796AkVf0kBD4zp0CCIs=
-github.com/bitly/go-simplejson v0.5.0/go.mod h1:cXHtHw4XUPsvGaxgjIAn8PhEWG9NfngEKAMDJEczWVA=
-github.com/bits-and-blooms/bitset v1.2.0/go.mod h1:gIdJ4wp64HaoK2YrL1Q5/N7Y16edYb8uY+O0FJTyyDA=
-github.com/blang/semver v3.1.0+incompatible/go.mod h1:kRBLl5iJ+tD4TcOOxsy/0fnwebNt5EWlYSAyrTnjyyk=
-github.com/blang/semver v3.5.1+incompatible/go.mod h1:kRBLl5iJ+tD4TcOOxsy/0fnwebNt5EWlYSAyrTnjyyk=
-github.com/bmizerany/assert v0.0.0-20160611221934-b7ed37b82869/go.mod h1:Ekp36dRnpXw/yCqJaO+ZrUyxD+3VXMFFr56k5XYrpB4=
-github.com/bshuster-repo/logrus-logstash-hook v0.4.1/go.mod h1:zsTqEiSzDgAa/8GZR7E1qaXrhYNDKBYy5/dWPTIflbk=
github.com/btcsuite/btcd v0.20.1-beta/go.mod h1:wVuoA8VJLEcwgqHBwHmzLRazpKxTv13Px/pDuV7OomQ=
-github.com/btcsuite/btcd v0.22.3 h1:kYNaWFvOw6xvqP0vR20RP1Zq1DVMBxEO8QN5d1/EfNg=
-github.com/btcsuite/btcd v0.22.3/go.mod h1:wqgTSL29+50LRkmOVknEdmt8ZojIzhuWvgu/iptuN7Y=
+github.com/btcsuite/btcd v0.22.0-beta.0.20220111032746-97732e52810c/go.mod h1:tjmYdS6MLJ5/s0Fj4DbLgSbDHbEqLJrtnHecBFkdz5M=
+github.com/btcsuite/btcd v0.23.0/go.mod h1:0QJIIN1wwIXF/3G/m87gIwGniDMDQqjVn4SZgnFpsYY=
+github.com/btcsuite/btcd v0.23.4 h1:IzV6qqkfwbItOS/sg/aDfPDsjPP8twrCOE2R93hxMlQ=
+github.com/btcsuite/btcd v0.23.4/go.mod h1:0QJIIN1wwIXF/3G/m87gIwGniDMDQqjVn4SZgnFpsYY=
+github.com/btcsuite/btcd/btcec/v2 v2.1.0/go.mod h1:2VzYrv4Gm4apmbVVsSq5bqf1Ec8v56E48Vt0Y/umPgA=
+github.com/btcsuite/btcd/btcec/v2 v2.1.3/go.mod h1:ctjw4H1kknNJmRN4iP1R7bTQ+v3GJkZBd6mui8ZsAZE=
github.com/btcsuite/btcd/btcec/v2 v2.3.2 h1:5n0X6hX0Zk+6omWcihdYvdAlGf2DfasC0GMf7DClJ3U=
github.com/btcsuite/btcd/btcec/v2 v2.3.2/go.mod h1:zYzJ8etWJQIv1Ogk7OzpWjowwOdXY1W/17j2MW85J04=
-github.com/btcsuite/btcd/btcutil v1.1.2 h1:XLMbX8JQEiwMcYft2EGi8zPUkoa0abKIU6/BJSRsjzQ=
+github.com/btcsuite/btcd/btcutil v1.0.0/go.mod h1:Uoxwv0pqYWhD//tfTiipkxNfdhG9UrLwaeswfjfdF0A=
+github.com/btcsuite/btcd/btcutil v1.1.0/go.mod h1:5OapHB7A2hBBWLm48mmw4MOHNJCcUBTwmWH/0Jn8VHE=
+github.com/btcsuite/btcd/btcutil v1.1.3 h1:xfbtw8lwpp0G6NwSHb+UE67ryTFHJAiNuipusjXSohQ=
+github.com/btcsuite/btcd/btcutil v1.1.3/go.mod h1:UR7dsSJzJUfMmFiiLlIrMq1lS9jh9EdCV7FStZSnpi0=
+github.com/btcsuite/btcd/chaincfg/chainhash v1.0.0/go.mod h1:7SFka0XMvUgj3hfZtydOrQY2mwhPclbT2snogU7SQQc=
github.com/btcsuite/btcd/chaincfg/chainhash v1.0.1 h1:q0rUy8C/TYNBQS1+CGKw68tLOFYSNEs0TFnxxnS9+4U=
github.com/btcsuite/btcd/chaincfg/chainhash v1.0.1/go.mod h1:7SFka0XMvUgj3hfZtydOrQY2mwhPclbT2snogU7SQQc=
github.com/btcsuite/btclog v0.0.0-20170628155309-84c8d2346e9f/go.mod h1:TdznJufoqS23FtqVCzL0ZqgP5MqXbb4fg/WgDys70nA=
github.com/btcsuite/btcutil v0.0.0-20190425235716-9e5f4b9a998d/go.mod h1:+5NJ2+qvTyV9exUAL/rxXi3DcLg2Ts+ymUAY5y4NvMg=
github.com/btcsuite/btcutil v1.0.3-0.20201208143702-a53e38424cce h1:YtWJF7RHm2pYCvA5t0RPmAaLUhREsKuKd+SLhxFbFeQ=
-github.com/btcsuite/btcutil v1.0.3-0.20201208143702-a53e38424cce/go.mod h1:0DVlHczLPewLcPGEIeUEzfOJhqGPQ0mJJRDBtD307+o=
github.com/btcsuite/go-socks v0.0.0-20170105172521-4720035b7bfd/go.mod h1:HHNXQzUsZCxOoE+CPiyCTO6x34Zs86zZUiwtpXoGdtg=
github.com/btcsuite/goleveldb v0.0.0-20160330041536-7834afc9e8cd/go.mod h1:F+uVaaLLH7j4eDXPRvw78tMflu7Ie2bzYOH4Y8rRKBY=
+github.com/btcsuite/goleveldb v1.0.0/go.mod h1:QiK9vBlgftBg6rWQIj6wFzbPfRjiykIEhBH4obrXJ/I=
github.com/btcsuite/snappy-go v0.0.0-20151229074030-0bdef8d06723/go.mod h1:8woku9dyThutzjeg+3xrA5iCpBRH8XEEg3lh6TiUghc=
+github.com/btcsuite/snappy-go v1.0.0/go.mod h1:8woku9dyThutzjeg+3xrA5iCpBRH8XEEg3lh6TiUghc=
github.com/btcsuite/websocket v0.0.0-20150119174127-31079b680792/go.mod h1:ghJtEyQwv5/p4Mg4C0fgbePVuGr935/5ddU9Z3TmDRY=
github.com/btcsuite/winsvc v1.0.0/go.mod h1:jsenWakMcC0zFBFurPLEAyrnc/teJEM1O46fmI40EZs=
-github.com/buger/jsonparser v0.0.0-20180808090653-f4dd9f5a6b44/go.mod h1:bbYlZJ7hK1yFx9hf58LP0zeX7UjIGs20ufpu3evjr+s=
-github.com/bugsnag/bugsnag-go v0.0.0-20141110184014-b1d153021fcd/go.mod h1:2oa8nejYd4cQ/b0hMIopN0lCRxU0bueqREvZLWFrtK8=
-github.com/bugsnag/osext v0.0.0-20130617224835-0dd3f918b21b/go.mod h1:obH5gd0BsqsP2LwDJ9aOkm/6J86V6lyAXCoQWGw3K50=
-github.com/bugsnag/panicwrap v0.0.0-20151223152923-e2c28503fcd0/go.mod h1:D/8v3kj0zr8ZAKg1AQ6crr+5VwKN5eIywRkfhyM/+dE=
+github.com/bufbuild/protocompile v0.4.0 h1:LbFKd2XowZvQ/kajzguUp2DC9UEIQhIq77fZZlaQsNA=
github.com/casbin/casbin/v2 v2.1.2/go.mod h1:YcPU1XXisHhLzuxH9coDNf2FbKpjGlbCg3n9yuLkIJQ=
github.com/cenkalti/backoff v2.2.1+incompatible h1:tNowT99t7UNflLxfYYSlKYsBpXdEet03Pg2g16Swow4=
github.com/cenkalti/backoff v2.2.1+incompatible/go.mod h1:90ReRw6GdpyfrHakVjL/QHaoyV4aDUVVkXQJJJ3NXXM=
@@ -348,15 +313,11 @@ github.com/cenkalti/backoff/v4 v4.1.1/go.mod h1:scbssz8iZGpm3xbr14ovlUdkxfGXNInq
github.com/cenkalti/backoff/v4 v4.1.3 h1:cFAlzYUlVYDysBEH2T5hyJZMh3+5+WCBvSnK6Q8UtC4=
github.com/cenkalti/backoff/v4 v4.1.3/go.mod h1:scbssz8iZGpm3xbr14ovlUdkxfGXNInqkPWOWmG2CLw=
github.com/census-instrumentation/opencensus-proto v0.2.1/go.mod h1:f6KPmirojxKA12rnyqOA5BBL4O983OfeGPqjHWSTneU=
-github.com/centrifuge/go-substrate-rpc-client/v4 v4.0.10 h1:HW3XP9G3mXr0gYPfxCAQLD29u+Ys0uIeotv9RWfnhrM=
-github.com/centrifuge/go-substrate-rpc-client/v4 v4.0.10/go.mod h1:5g1oM4Zu3BOaLpsKQ+O8PAv2kNuq+kPcA1VzFbsSqxE=
github.com/cespare/xxhash v1.1.0 h1:a6HrQnmkObjyL+Gs60czilIUGqrzKutQD6XZog3p+ko=
github.com/cespare/xxhash v1.1.0/go.mod h1:XrSqR1VqqWfGrhpAt58auRo0WTKS1nRRg3ghfAqPWnc=
github.com/cespare/xxhash/v2 v2.1.1/go.mod h1:VGX0DQ3Q6kWi7AoAeZDth3/j3BFtOZR5XLFGgcrjCOs=
github.com/cespare/xxhash/v2 v2.2.0 h1:DC2CZ1Ep5Y4k3ZQ899DldepgrayRUGE6BBZ/cd9Cj44=
github.com/cespare/xxhash/v2 v2.2.0/go.mod h1:VGX0DQ3Q6kWi7AoAeZDth3/j3BFtOZR5XLFGgcrjCOs=
-github.com/checkpoint-restore/go-criu/v4 v4.1.0/go.mod h1:xUQBLp4RLc5zJtWY++yjOoMoB5lihDt7fai+75m+rGw=
-github.com/checkpoint-restore/go-criu/v5 v5.0.0/go.mod h1:cfwC0EG7HMUenopBsUf9d89JlCLQIfgVcNsNN0t6T2M=
github.com/checkpoint-restore/go-criu/v5 v5.3.0/go.mod h1:E/eQpaFtUKGOOSEBZgmKAcn+zUUwWxqcaKZlF54wK8E=
github.com/cheggaaa/pb v1.0.27/go.mod h1:pQciLPpbU0oxA0h+VJYYLxO+XeDQb5pZijXscXHm81s=
github.com/chzyer/logex v1.1.10/go.mod h1:+Ywpsq7O8HXn0nuIou7OrIPyXbp3wmkHB+jjWRnGsAI=
@@ -368,16 +329,13 @@ github.com/chzyer/readline v1.5.1/go.mod h1:Eh+b79XXUwfKfcPLepksvw2tcLE/Ct21YObk
github.com/chzyer/test v0.0.0-20180213035817-a1ea475d72b1/go.mod h1:Q3SI9o4m/ZMnBNeIyt5eFwwo7qiLfzFZmjNmxjkiQlU=
github.com/chzyer/test v1.0.0 h1:p3BQDXSxOhOG0P9z6/hGnII4LGiEPOYBhs8asl/fC04=
github.com/chzyer/test v1.0.0/go.mod h1:2JlltgoNkt4TW/z9V/IzDdFaMTM2JPIi26O1pF38GC8=
-github.com/cilium/ebpf v0.0.0-20200110133405-4032b1d8aae3/go.mod h1:MA5e5Lr8slmEg9bt0VpxxWqJlO4iwu3FBdHUzV7wQVg=
-github.com/cilium/ebpf v0.0.0-20200702112145-1c8d4c9ef775/go.mod h1:7cR51M8ViRLIdUjrmSXlK9pkrsDlLHbO8jiB8X8JnOc=
-github.com/cilium/ebpf v0.2.0/go.mod h1:To2CFviqOWL/M0gIMsvSMlqe7em/l1ALkX1PyjrX2Qs=
-github.com/cilium/ebpf v0.4.0/go.mod h1:4tRaxcgiL706VnOzHOdBlY8IEAIdxINsQBcU4xJJXRs=
-github.com/cilium/ebpf v0.6.2/go.mod h1:4tRaxcgiL706VnOzHOdBlY8IEAIdxINsQBcU4xJJXRs=
github.com/cilium/ebpf v0.7.0/go.mod h1:/oI2+1shJiTGAMgl6/RgJr36Eo1jzrRcAWbcXO2usCA=
github.com/circonus-labs/circonus-gometrics v2.3.1+incompatible/go.mod h1:nmEj6Dob7S7YxXgwXpfOuvO54S+tGdZdw9fuRZt25Ag=
github.com/circonus-labs/circonusllhist v0.1.3/go.mod h1:kMXHVDlOchFAehlya5ePtbp5jckzBHf4XRpQvBOLI+I=
github.com/clbanning/x2j v0.0.0-20191024224557-825249438eec/go.mod h1:jMjuTZXRI4dUb/I5gc9Hdhagfvm9+RyrPryS/auMzxE=
github.com/client9/misspell v0.3.4/go.mod h1:qj6jICC3Q7zFZvVWo7KLAzC3yx5G7kyvSDkc90ppPyw=
+github.com/cmars/basen v0.0.0-20150613233007-fe3947df716e h1:0XBUw73chJ1VYSsfvcPvVT7auykAJce9FpRr10L6Qhw=
+github.com/cmars/basen v0.0.0-20150613233007-fe3947df716e/go.mod h1:P13beTBKr5Q18lJe1rIoLUqjM+CB1zYrRg44ZqGuQSA=
github.com/cncf/udpa/go v0.0.0-20191209042840-269d4d468f6f/go.mod h1:M8M6+tZqaGXZJjfX53e64911xZQV5JYwmTeXPW+k8Sc=
github.com/cncf/udpa/go v0.0.0-20200629203442-efcf912fb354/go.mod h1:WmhPx2Nbnhtbo57+VJT5O0JRkEi1Wbu0z5j0R8u5Hbk=
github.com/cncf/udpa/go v0.0.0-20201120205902-5459f2c99403/go.mod h1:WmhPx2Nbnhtbo57+VJT5O0JRkEi1Wbu0z5j0R8u5Hbk=
@@ -389,163 +347,67 @@ github.com/cncf/xds/go v0.0.0-20211001041855-01bcc9b48dfe/go.mod h1:eXthEFrGJvWH
github.com/cncf/xds/go v0.0.0-20211011173535-cb28da3451f1/go.mod h1:eXthEFrGJvWHgFFCl3hGmgk+/aYT6PnTQLykKQRLhEs=
github.com/cockroachdb/apd/v2 v2.0.2 h1:weh8u7Cneje73dDh+2tEVLUvyBc89iwepWCD8b8034E=
github.com/cockroachdb/apd/v2 v2.0.2/go.mod h1:DDxRlzC2lo3/vSlmSoS7JkqbbrARPuFOGr0B9pvN3Gw=
-github.com/cockroachdb/apd/v3 v3.1.0 h1:MK3Ow7LH0W8zkd5GMKA1PvS9qG3bWFI95WaVNfyZJ/w=
github.com/cockroachdb/datadriven v0.0.0-20190809214429-80d97fb3cbaa/go.mod h1:zn76sxSg3SzpJ0PPJaLDCu+Bu0Lg3sKTORVIj19EIF8=
+github.com/cockroachdb/errors v1.10.0 h1:lfxS8zZz1+OjtV4MtNWgboi/W5tyLEB6VQZBXN+0VUU=
+github.com/cockroachdb/errors v1.10.0/go.mod h1:lknhIsEVQ9Ss/qKDBQS/UqFSvPQjOwNq2qyKAxtHRqE=
+github.com/cockroachdb/logtags v0.0.0-20230118201751-21c54148d20b h1:r6VH0faHjZeQy818SGhaone5OnYfxFR/+AzdY3sf5aE=
+github.com/cockroachdb/logtags v0.0.0-20230118201751-21c54148d20b/go.mod h1:Vz9DsVWQQhf3vs21MhPMZpMGSht7O/2vFW2xusFUVOs=
+github.com/cockroachdb/redact v1.1.5 h1:u1PMllDkdFfPWaNGMyLD1+so+aq3uUItthCFqzwPJ30=
+github.com/cockroachdb/redact v1.1.5/go.mod h1:BVNblN9mBWFyMyqK1k3AAiSxhvhfK2oOZZ2lK+dpvRg=
github.com/codahale/hdrhistogram v0.0.0-20161010025455-3a0bb77429bd/go.mod h1:sE/e/2PUdi/liOCUjSTXgM1o87ZssimdTWN964YiIeI=
github.com/coinbase/rosetta-sdk-go/types v1.0.0 h1:jpVIwLcPoOeCR6o1tU+Xv7r5bMONNbHU7MuEHboiFuA=
github.com/coinbase/rosetta-sdk-go/types v1.0.0/go.mod h1:eq7W2TMRH22GTW0N0beDnN931DW0/WOI1R2sdHNHG4c=
-github.com/cometbft/cometbft v0.37.0 h1:M005vBaSaugvYYmNZwJOopynQSjwLoDTwflnQ/I/eYk=
-github.com/cometbft/cometbft v0.37.0/go.mod h1:Y2MMMN//O5K4YKd8ze4r9jmk4Y7h0ajqILXbH5JQFVs=
-github.com/cometbft/cometbft-db v0.7.0 h1:uBjbrBx4QzU0zOEnU8KxoDl18dMNgDh+zZRUE0ucsbo=
-github.com/cometbft/cometbft-db v0.7.0/go.mod h1:yiKJIm2WKrt6x8Cyxtq9YTEcIMPcEe4XPxhgX59Fzf0=
+github.com/cometbft/cometbft v0.37.2 h1:XB0yyHGT0lwmJlFmM4+rsRnczPlHoAKFX6K8Zgc2/Jc=
+github.com/cometbft/cometbft v0.37.2/go.mod h1:Y2MMMN//O5K4YKd8ze4r9jmk4Y7h0ajqILXbH5JQFVs=
+github.com/cometbft/cometbft-db v0.8.0 h1:vUMDaH3ApkX8m0KZvOFFy9b5DZHBAjsnEuo9AKVZpjo=
+github.com/cometbft/cometbft-db v0.8.0/go.mod h1:6ASCP4pfhmrCBpfk01/9E1SI29nD3HfVHrY4PG8x5c0=
github.com/confio/ics23/go v0.9.0 h1:cWs+wdbS2KRPZezoaaj+qBleXgUk5WOQFMP3CQFGTr4=
github.com/confio/ics23/go v0.9.0/go.mod h1:4LPZ2NYqnYIVRklaozjNR1FScgDJ2s5Xrp+e/mYVRak=
-github.com/containerd/aufs v0.0.0-20200908144142-dab0cbea06f4/go.mod h1:nukgQABAEopAHvB6j7cnP5zJ+/3aVcE7hCYqvIwAHyE=
-github.com/containerd/aufs v0.0.0-20201003224125-76a6863f2989/go.mod h1:AkGGQs9NM2vtYHaUen+NljV0/baGCAPELGm2q9ZXpWU=
-github.com/containerd/aufs v0.0.0-20210316121734-20793ff83c97/go.mod h1:kL5kd6KM5TzQjR79jljyi4olc1Vrx6XBlcyj3gNv2PU=
-github.com/containerd/aufs v1.0.0/go.mod h1:kL5kd6KM5TzQjR79jljyi4olc1Vrx6XBlcyj3gNv2PU=
-github.com/containerd/btrfs v0.0.0-20201111183144-404b9149801e/go.mod h1:jg2QkJcsabfHugurUvvPhS3E08Oxiuh5W/g1ybB4e0E=
-github.com/containerd/btrfs v0.0.0-20210316141732-918d888fb676/go.mod h1:zMcX3qkXTAi9GI50+0HOeuV8LU2ryCE/V2vG/ZBiTss=
-github.com/containerd/btrfs v1.0.0/go.mod h1:zMcX3qkXTAi9GI50+0HOeuV8LU2ryCE/V2vG/ZBiTss=
-github.com/containerd/cgroups v0.0.0-20190717030353-c4b9ac5c7601/go.mod h1:X9rLEHIqSf/wfK8NsPqxJmeZgW4pcfzdXITDrUSJ6uI=
-github.com/containerd/cgroups v0.0.0-20190919134610-bf292b21730f/go.mod h1:OApqhQ4XNSNC13gXIwDjhOQxjWa/NxkwZXJ1EvqT0ko=
-github.com/containerd/cgroups v0.0.0-20200531161412-0dbf7f05ba59/go.mod h1:pA0z1pT8KYB3TCXK/ocprsh7MAkoW8bZVzPdih9snmM=
-github.com/containerd/cgroups v0.0.0-20200710171044-318312a37340/go.mod h1:s5q4SojHctfxANBDvMeIaIovkq29IP48TKAxnhYRxvo=
-github.com/containerd/cgroups v0.0.0-20200824123100-0b889c03f102/go.mod h1:s5q4SojHctfxANBDvMeIaIovkq29IP48TKAxnhYRxvo=
-github.com/containerd/cgroups v0.0.0-20210114181951-8a68de567b68/go.mod h1:ZJeTFisyysqgcCdecO57Dj79RfL0LNeGiFUqLYQRYLE=
-github.com/containerd/cgroups v1.0.1/go.mod h1:0SJrPIenamHDcZhEcJMNBB85rHcUsw4f25ZfBiPYRkU=
-github.com/containerd/cgroups v1.0.4 h1:jN/mbWBEaz+T1pi5OFtnkQ+8qnmEbAr1Oo1FRm5B0dA=
-github.com/containerd/cgroups v1.0.4/go.mod h1:nLNQtsF7Sl2HxNebu77i1R0oDlhiTG+kO4JTrUzo6IA=
-github.com/containerd/console v0.0.0-20180822173158-c12b1e7919c1/go.mod h1:Tj/on1eG8kiEhd0+fhSDzsPAFESxzBBvdyEgyryXffw=
-github.com/containerd/console v0.0.0-20181022165439-0650fd9eeb50/go.mod h1:Tj/on1eG8kiEhd0+fhSDzsPAFESxzBBvdyEgyryXffw=
-github.com/containerd/console v0.0.0-20191206165004-02ecf6a7291e/go.mod h1:8Pf4gM6VEbTNRIT26AyyU7hxdQU3MvAvxVI0sc00XBE=
-github.com/containerd/console v1.0.1/go.mod h1:XUsP6YE/mKtz6bxc+I8UiKKTP04qjQL4qcS3XoQ5xkw=
-github.com/containerd/console v1.0.2/go.mod h1:ytZPjGgY2oeTkAONYafi2kSj0aYggsf8acV1PGKCbzQ=
github.com/containerd/console v1.0.3/go.mod h1:7LqA/THxQ86k76b8c/EMSiaJ3h1eZkMkXar0TQ1gf3U=
-github.com/containerd/containerd v1.2.10/go.mod h1:bC6axHOhabU15QhwfG7w5PipXdVtMXFTttgp+kVtyUA=
-github.com/containerd/containerd v1.3.0-beta.2.0.20190828155532-0293cbd26c69/go.mod h1:bC6axHOhabU15QhwfG7w5PipXdVtMXFTttgp+kVtyUA=
-github.com/containerd/containerd v1.3.0/go.mod h1:bC6axHOhabU15QhwfG7w5PipXdVtMXFTttgp+kVtyUA=
-github.com/containerd/containerd v1.3.1-0.20191213020239-082f7e3aed57/go.mod h1:bC6axHOhabU15QhwfG7w5PipXdVtMXFTttgp+kVtyUA=
-github.com/containerd/containerd v1.3.2/go.mod h1:bC6axHOhabU15QhwfG7w5PipXdVtMXFTttgp+kVtyUA=
-github.com/containerd/containerd v1.4.0-beta.2.0.20200729163537-40b22ef07410/go.mod h1:bC6axHOhabU15QhwfG7w5PipXdVtMXFTttgp+kVtyUA=
-github.com/containerd/containerd v1.4.1/go.mod h1:bC6axHOhabU15QhwfG7w5PipXdVtMXFTttgp+kVtyUA=
-github.com/containerd/containerd v1.4.3/go.mod h1:bC6axHOhabU15QhwfG7w5PipXdVtMXFTttgp+kVtyUA=
-github.com/containerd/containerd v1.5.0-beta.1/go.mod h1:5HfvG1V2FsKesEGQ17k5/T7V960Tmcumvqn8Mc+pCYQ=
-github.com/containerd/containerd v1.5.0-beta.3/go.mod h1:/wr9AVtEM7x9c+n0+stptlo/uBBoBORwEx6ardVcmKU=
-github.com/containerd/containerd v1.5.0-beta.4/go.mod h1:GmdgZd2zA2GYIBZ0w09ZvgqEq8EfBp/m3lcVZIvPHhI=
-github.com/containerd/containerd v1.5.0-rc.0/go.mod h1:V/IXoMqNGgBlabz3tHD2TWDoTJseu1FGOKuoA4nNb2s=
-github.com/containerd/containerd v1.5.1/go.mod h1:0DOxVqwDy2iZvrZp2JUx/E+hS0UNTVn7dJnIOwtYR4g=
-github.com/containerd/containerd v1.5.7/go.mod h1:gyvv6+ugqY25TiXxcZC3L5yOeYgEw0QMhscqVp1AR9c=
-github.com/containerd/containerd v1.6.18 h1:qZbsLvmyu+Vlty0/Ex5xc0z2YtKpIsb5n45mAMI+2Ns=
-github.com/containerd/containerd v1.6.18/go.mod h1:1RdCUu95+gc2v9t3IL+zIlpClSmew7/0YS8O5eQZrOw=
-github.com/containerd/continuity v0.0.0-20190426062206-aaeac12a7ffc/go.mod h1:GL3xCUCBDV3CZiTSEKksMWbLE66hEyuu9qyDOOqM47Y=
-github.com/containerd/continuity v0.0.0-20190815185530-f2a389ac0a02/go.mod h1:GL3xCUCBDV3CZiTSEKksMWbLE66hEyuu9qyDOOqM47Y=
-github.com/containerd/continuity v0.0.0-20191127005431-f65d91d395eb/go.mod h1:GL3xCUCBDV3CZiTSEKksMWbLE66hEyuu9qyDOOqM47Y=
-github.com/containerd/continuity v0.0.0-20200710164510-efbc4488d8fe/go.mod h1:cECdGN1O8G9bgKTlLhuPJimka6Xb/Gg7vYzCTNVxhvo=
-github.com/containerd/continuity v0.0.0-20201208142359-180525291bb7/go.mod h1:kR3BEg7bDFaEddKm54WSmrol1fKWDU1nKYkgrcgZT7Y=
-github.com/containerd/continuity v0.0.0-20210208174643-50096c924a4e/go.mod h1:EXlVlkqNba9rJe3j7w3Xa924itAMLgZH4UD/Q4PExuQ=
-github.com/containerd/continuity v0.1.0/go.mod h1:ICJu0PwR54nI0yPEnJ6jcS+J7CZAUXrLh8lPo2knzsM=
+github.com/containerd/containerd v1.6.8 h1:h4dOFDwzHmqFEP754PgfgTeVXFnLiRc6kiqC7tplDJs=
+github.com/containerd/containerd v1.6.8/go.mod h1:By6p5KqPK0/7/CgO/A6t/Gz+CUYUu2zf1hUaaymVXB0=
github.com/containerd/continuity v0.3.0 h1:nisirsYROK15TAMVukJOUyGJjz4BNQJBVsNvAXZJ/eg=
-github.com/containerd/fifo v0.0.0-20180307165137-3d5202aec260/go.mod h1:ODA38xgv3Kuk8dQz2ZQXpnv/UZZUHUCL7pnLehbXgQI=
-github.com/containerd/fifo v0.0.0-20190226154929-a9fb20d87448/go.mod h1:ODA38xgv3Kuk8dQz2ZQXpnv/UZZUHUCL7pnLehbXgQI=
-github.com/containerd/fifo v0.0.0-20200410184934-f15a3290365b/go.mod h1:jPQ2IAeZRCYxpS/Cm1495vGFww6ecHmMk1YJH2Q5ln0=
-github.com/containerd/fifo v0.0.0-20201026212402-0724c46b320c/go.mod h1:jPQ2IAeZRCYxpS/Cm1495vGFww6ecHmMk1YJH2Q5ln0=
-github.com/containerd/fifo v0.0.0-20210316144830-115abcc95a1d/go.mod h1:ocF/ME1SX5b1AOlWi9r677YJmCPSwwWnQ9O123vzpE4=
-github.com/containerd/fifo v1.0.0/go.mod h1:ocF/ME1SX5b1AOlWi9r677YJmCPSwwWnQ9O123vzpE4=
-github.com/containerd/go-cni v1.0.1/go.mod h1:+vUpYxKvAF72G9i1WoDOiPGRtQpqsNW/ZHtSlv++smU=
-github.com/containerd/go-cni v1.0.2/go.mod h1:nrNABBHzu0ZwCug9Ije8hL2xBCYh/pjfMb1aZGrrohk=
-github.com/containerd/go-runc v0.0.0-20180907222934-5a6d9f37cfa3/go.mod h1:IV7qH3hrUgRmyYrtgEeGWJfWbgcHL9CSRruz2Vqcph0=
-github.com/containerd/go-runc v0.0.0-20190911050354-e029b79d8cda/go.mod h1:IV7qH3hrUgRmyYrtgEeGWJfWbgcHL9CSRruz2Vqcph0=
-github.com/containerd/go-runc v0.0.0-20200220073739-7016d3ce2328/go.mod h1:PpyHrqVs8FTi9vpyHwPwiNEGaACDxT/N/pLcvMSRA9g=
-github.com/containerd/go-runc v0.0.0-20201020171139-16b287bc67d0/go.mod h1:cNU0ZbCgCQVZK4lgG3P+9tn9/PaJNmoDXPpoJhDR+Ok=
-github.com/containerd/go-runc v1.0.0/go.mod h1:cNU0ZbCgCQVZK4lgG3P+9tn9/PaJNmoDXPpoJhDR+Ok=
-github.com/containerd/imgcrypt v1.0.1/go.mod h1:mdd8cEPW7TPgNG4FpuP3sGBiQ7Yi/zak9TYCG3juvb0=
-github.com/containerd/imgcrypt v1.0.4-0.20210301171431-0ae5c75f59ba/go.mod h1:6TNsg0ctmizkrOgXRNQjAPFWpMYRWuiB6dSF4Pfa5SA=
-github.com/containerd/imgcrypt v1.1.1-0.20210312161619-7ed62a527887/go.mod h1:5AZJNI6sLHJljKuI9IHnw1pWqo/F0nGDOuR9zgTs7ow=
-github.com/containerd/imgcrypt v1.1.1/go.mod h1:xpLnwiQmEUJPvQoAapeb2SNCxz7Xr6PJrXQb0Dpc4ms=
-github.com/containerd/nri v0.0.0-20201007170849-eb1350a75164/go.mod h1:+2wGSDGFYfE5+So4M5syatU0N0f0LbWpuqyMi4/BE8c=
-github.com/containerd/nri v0.0.0-20210316161719-dbaa18c31c14/go.mod h1:lmxnXF6oMkbqs39FiCt1s0R2HSMhcLel9vNL3m4AaeY=
-github.com/containerd/nri v0.1.0/go.mod h1:lmxnXF6oMkbqs39FiCt1s0R2HSMhcLel9vNL3m4AaeY=
-github.com/containerd/stargz-snapshotter/estargz v0.4.1/go.mod h1:x7Q9dg9QYb4+ELgxmo4gBUeJB0tl5dqH1Sdz0nJU1QM=
-github.com/containerd/ttrpc v0.0.0-20190828154514-0e0f228740de/go.mod h1:PvCDdDGpgqzQIzDW1TphrGLssLDZp2GuS+X5DkEJB8o=
-github.com/containerd/ttrpc v0.0.0-20190828172938-92c8520ef9f8/go.mod h1:PvCDdDGpgqzQIzDW1TphrGLssLDZp2GuS+X5DkEJB8o=
-github.com/containerd/ttrpc v0.0.0-20191028202541-4f1b8fe65a5c/go.mod h1:LPm1u0xBw8r8NOKoOdNMeVHSawSsltak+Ihv+etqsE8=
-github.com/containerd/ttrpc v1.0.1/go.mod h1:UAxOpgT9ziI0gJrmKvgcZivgxOp8iFPSk8httJEt98Y=
-github.com/containerd/ttrpc v1.0.2/go.mod h1:UAxOpgT9ziI0gJrmKvgcZivgxOp8iFPSk8httJEt98Y=
-github.com/containerd/ttrpc v1.1.0/go.mod h1:XX4ZTnoOId4HklF4edwc4DcqskFZuvXB1Evzy5KFQpQ=
-github.com/containerd/typeurl v0.0.0-20180627222232-a93fcdb778cd/go.mod h1:Cm3kwCdlkCfMSHURc+r6fwoGH6/F1hH3S4sg0rLFWPc=
-github.com/containerd/typeurl v0.0.0-20190911142611-5eb25027c9fd/go.mod h1:GeKYzf2pQcqv7tJ0AoCuuhtnqhva5LNU3U+OyKxxJpk=
-github.com/containerd/typeurl v1.0.1/go.mod h1:TB1hUtrpaiO88KEK56ijojHS1+NeF0izUACaJW2mdXg=
-github.com/containerd/typeurl v1.0.2/go.mod h1:9trJWW2sRlGub4wZJRTW83VtbOLS6hwcDZXTn6oPz9s=
-github.com/containerd/zfs v0.0.0-20200918131355-0a33824f23a2/go.mod h1:8IgZOBdv8fAgXddBT4dBXJPtxyRsejFIpXoklgxgEjw=
-github.com/containerd/zfs v0.0.0-20210301145711-11e8f1707f62/go.mod h1:A9zfAbMlQwE+/is6hi0Xw8ktpL+6glmqZYtevJgaB8Y=
-github.com/containerd/zfs v0.0.0-20210315114300-dde8f0fda960/go.mod h1:m+m51S1DvAP6r3FcmYCp54bQ34pyOwTieQDNRIRHsFY=
-github.com/containerd/zfs v0.0.0-20210324211415-d5c4544f0433/go.mod h1:m+m51S1DvAP6r3FcmYCp54bQ34pyOwTieQDNRIRHsFY=
-github.com/containerd/zfs v1.0.0/go.mod h1:m+m51S1DvAP6r3FcmYCp54bQ34pyOwTieQDNRIRHsFY=
-github.com/containernetworking/cni v0.7.1/go.mod h1:LGwApLUm2FpoOfxTDEeq8T9ipbpZ61X79hmU3w8FmsY=
-github.com/containernetworking/cni v0.8.0/go.mod h1:LGwApLUm2FpoOfxTDEeq8T9ipbpZ61X79hmU3w8FmsY=
-github.com/containernetworking/cni v0.8.1/go.mod h1:LGwApLUm2FpoOfxTDEeq8T9ipbpZ61X79hmU3w8FmsY=
-github.com/containernetworking/plugins v0.8.6/go.mod h1:qnw5mN19D8fIwkqW7oHHYDHVlzhJpcY6TQxn/fUyDDM=
-github.com/containernetworking/plugins v0.9.1/go.mod h1:xP/idU2ldlzN6m4p5LmGiwRDjeJr6FLK6vuiUwoH7P8=
-github.com/containers/ocicrypt v1.0.1/go.mod h1:MeJDzk1RJHv89LjsH0Sp5KTY3ZYkjXO/C+bKAeWFIrc=
-github.com/containers/ocicrypt v1.1.0/go.mod h1:b8AOe0YR67uU8OqfVNcznfFpAzu3rdgUV4GP9qXPfu4=
-github.com/containers/ocicrypt v1.1.1/go.mod h1:Dm55fwWm1YZAjYRaJ94z2mfZikIyIN4B0oB3dj3jFxY=
-github.com/coreos/bbolt v1.3.2/go.mod h1:iRUV2dpdMOn7Bo10OQBFzIJO9kkE559Wcmn+qkEiiKk=
github.com/coreos/etcd v3.3.10+incompatible/go.mod h1:uF7uidLiAD3TWHmW31ZFd/JWoc32PjwdhPthX9715RE=
github.com/coreos/go-etcd v2.0.0+incompatible/go.mod h1:Jez6KQU2B/sWsbdaef3ED8NzMklzPG4d5KIOhIy30Tk=
-github.com/coreos/go-iptables v0.4.5/go.mod h1:/mVI274lEDI2ns62jHCDnCyBF9Iwsmekav8Dbxlm1MU=
-github.com/coreos/go-iptables v0.5.0/go.mod h1:/mVI274lEDI2ns62jHCDnCyBF9Iwsmekav8Dbxlm1MU=
-github.com/coreos/go-oidc v2.1.0+incompatible/go.mod h1:CgnwVTmzoESiwO9qyAFEMiHoZ1nMCKZlZ9V6mm3/LKc=
github.com/coreos/go-semver v0.2.0/go.mod h1:nnelYz7RCh+5ahJtPPxZlU+153eP4D4r3EedlOD2RNk=
-github.com/coreos/go-semver v0.3.0/go.mod h1:nnelYz7RCh+5ahJtPPxZlU+153eP4D4r3EedlOD2RNk=
-github.com/coreos/go-systemd v0.0.0-20161114122254-48702e0da86b/go.mod h1:F5haX7vjVVG0kc13fIWeqUViNPyEJxv/OmvnBo0Yme4=
github.com/coreos/go-systemd v0.0.0-20180511133405-39ca1b05acc7/go.mod h1:F5haX7vjVVG0kc13fIWeqUViNPyEJxv/OmvnBo0Yme4=
-github.com/coreos/go-systemd v0.0.0-20190321100706-95778dfbb74e/go.mod h1:F5haX7vjVVG0kc13fIWeqUViNPyEJxv/OmvnBo0Yme4=
-github.com/coreos/go-systemd/v22 v22.0.0/go.mod h1:xO0FLkIi5MaZafQlIrOotqXZ90ih+1atmu1JpKERPPk=
-github.com/coreos/go-systemd/v22 v22.1.0/go.mod h1:xO0FLkIi5MaZafQlIrOotqXZ90ih+1atmu1JpKERPPk=
github.com/coreos/go-systemd/v22 v22.3.2/go.mod h1:Y58oyj3AT4RCenI/lSvhwexgC+NSVTIJ3seZv2GcEnc=
+github.com/coreos/go-systemd/v22 v22.5.0/go.mod h1:Y58oyj3AT4RCenI/lSvhwexgC+NSVTIJ3seZv2GcEnc=
github.com/coreos/pkg v0.0.0-20160727233714-3ac0863d7acf/go.mod h1:E3G3o1h8I7cfcXa63jLwjI0eiQQMgzzUDFVpN/nH/eA=
-github.com/coreos/pkg v0.0.0-20180928190104-399ea9e2e55f/go.mod h1:E3G3o1h8I7cfcXa63jLwjI0eiQQMgzzUDFVpN/nH/eA=
github.com/cosmos/btcutil v1.0.5 h1:t+ZFcX77LpKtDBhjucvnOH8C2l2ioGsBNEQ3jef8xFk=
github.com/cosmos/btcutil v1.0.5/go.mod h1:IyB7iuqZMJlthe2tkIFL33xPyzbFYP0XVdS8P5lUPis=
github.com/cosmos/cosmos-proto v1.0.0-beta.2 h1:X3OKvWgK9Gsejo0F1qs5l8Qn6xJV/AzgIWR2wZ8Nua8=
github.com/cosmos/cosmos-proto v1.0.0-beta.2/go.mod h1:+XRCLJ14pr5HFEHIUcn51IKXD1Fy3rkEQqt4WqmN4V0=
-github.com/cosmos/cosmos-sdk v0.47.0-rc3 h1:MMun/+mMpzise9d85csTp+kGkhLCkjJLwLK0urp0Bcs=
-github.com/cosmos/cosmos-sdk v0.47.0-rc3/go.mod h1:GlXjIIIsIZAD5CPqm7FHtr3v5/anE9eXWDjSWdNmznw=
+github.com/cosmos/cosmos-sdk v0.47.5 h1:n1+WjP/VM/gAEOx3TqU2/Ny734rj/MX1kpUnn7zVJP8=
+github.com/cosmos/cosmos-sdk v0.47.5/go.mod h1:EHwCeN9IXonsjKcjpS12MqeStdZvIdxt3VYXhus3G3c=
github.com/cosmos/go-bip39 v0.0.0-20180819234021-555e2067c45d/go.mod h1:tSxLoYXyBmiFeKpvmq4dzayMdCjCnu8uqmCysIGBT2Y=
github.com/cosmos/go-bip39 v1.0.0 h1:pcomnQdrdH22njcAatO0yWojsUnCO3y2tNoV1cb6hHY=
github.com/cosmos/go-bip39 v1.0.0/go.mod h1:RNJv0H/pOIVgxw6KS7QeX2a0Uo0aKUlfhZ4xuwvCdJw=
github.com/cosmos/gogogateway v1.2.0 h1:Ae/OivNhp8DqBi/sh2A8a1D0y638GpL3tkmLQAiKxTE=
github.com/cosmos/gogogateway v1.2.0/go.mod h1:iQpLkGWxYcnCdz5iAdLcRBSw3h7NXeOkZ4GUkT+tbFI=
github.com/cosmos/gogoproto v1.4.2/go.mod h1:cLxOsn1ljAHSV527CHOtaIP91kK6cCrZETRBrkzItWU=
-github.com/cosmos/gogoproto v1.4.6 h1:Ee7z15dWJaGlgM2rWrK8N2IX7PQcuccu8oG68jp5RL4=
-github.com/cosmos/gogoproto v1.4.6/go.mod h1:VS/ASYmPgv6zkPKLjR9EB91lwbLHOzaGCirmKKhncfI=
-github.com/cosmos/iavl v0.20.0-alpha4 h1:49SZoxNwah5nqbVE1da8BAhenC7HMSVOTZ0XKVhZpOE=
-github.com/cosmos/iavl v0.20.0-alpha4/go.mod h1:WO7FyvaZJoH65+HFOsDir7xU9FWk2w9cHXNW1XHcl7A=
-github.com/cosmos/ibc-go/v7 v7.0.0-rc1 h1:+HokO9GDqWNmjKSLGSC1WjcqjOdDIeSmNGuXQFSHMQE=
-github.com/cosmos/ibc-go/v7 v7.0.0-rc1/go.mod h1:wpKGb+lqAnxwThgS3LoCPgDEFNAPVX+1YIQCAJcePcM=
-github.com/cosmos/ics23/go v0.9.1-0.20221207100636-b1abd8678aab h1:I9ialKTQo7248V827Bba4OuKPmk+FPzmTVHsLXaIJWw=
-github.com/cosmos/ics23/go v0.9.1-0.20221207100636-b1abd8678aab/go.mod h1:2CwqasX5dSD7Hbp/9b6lhK6BwoBDCBldx7gPKRukR60=
+github.com/cosmos/gogoproto v1.4.10 h1:QH/yT8X+c0F4ZDacDv3z+xE3WU1P1Z3wQoLMBRJoKuI=
+github.com/cosmos/gogoproto v1.4.10/go.mod h1:3aAZzeRWpAwr+SS/LLkICX2/kDFyaYVzckBDzygIxek=
+github.com/cosmos/iavl v0.20.0 h1:fTVznVlepH0KK8NyKq8w+U7c2L6jofa27aFX6YGlm38=
+github.com/cosmos/iavl v0.20.0/go.mod h1:WO7FyvaZJoH65+HFOsDir7xU9FWk2w9cHXNW1XHcl7A=
+github.com/cosmos/ibc-go/modules/capability v1.0.0-rc1 h1:BvSKnPFKxL+TTSLxGKwJN4x0ndCZj0yfXhSvmsQztSA=
+github.com/cosmos/ibc-go/modules/capability v1.0.0-rc1/go.mod h1:A+CxAQdn2j6ihDTbClpEEBdHthWgAUAcHbRAQPY8sl4=
+github.com/cosmos/ibc-go/v7 v7.3.0 h1:QtGeVMi/3JeLWuvEuC60sBHpAF40Oenx/y+bP8+wRRw=
+github.com/cosmos/ibc-go/v7 v7.3.0/go.mod h1:mUmaHFXpXrEdcxfdXyau+utZf14pGKVUiXwYftRZZfQ=
+github.com/cosmos/ics23/go v0.10.0 h1:iXqLLgp2Lp+EdpIuwXTYIQU+AiHj9mOC2X9ab++bZDM=
+github.com/cosmos/ics23/go v0.10.0/go.mod h1:ZfJSmng/TBNTBkFemHHHj5YY7VAU/MBU980F4VU1NG0=
github.com/cosmos/ledger-cosmos-go v0.12.2 h1:/XYaBlE2BJxtvpkHiBm97gFGSGmYGKunKyF3nNqAXZA=
github.com/cosmos/ledger-cosmos-go v0.12.2/go.mod h1:ZcqYgnfNJ6lAXe4HPtWgarNEY+B74i+2/8MhZw4ziiI=
github.com/cosmos/rosetta-sdk-go v0.10.0 h1:E5RhTruuoA7KTIXUcMicL76cffyeoyvNybzUGSKFTcM=
github.com/cosmos/rosetta-sdk-go v0.10.0/go.mod h1:SImAZkb96YbwvoRkzSMQB6noNJXFgWl/ENIznEoYQI4=
github.com/cpuguy83/go-md2man v1.0.10/go.mod h1:SmD6nW6nTyfqj6ABTjUi3V3JVMnlJmwcJI5acqYI6dE=
github.com/cpuguy83/go-md2man/v2 v2.0.0-20190314233015-f79a8a8ca69d/go.mod h1:maD7wRr/U5Z6m/iR4s+kqSMx2CaBsrgA7czyZG/E6dU=
-github.com/cpuguy83/go-md2man/v2 v2.0.0/go.mod h1:maD7wRr/U5Z6m/iR4s+kqSMx2CaBsrgA7czyZG/E6dU=
github.com/cpuguy83/go-md2man/v2 v2.0.2/go.mod h1:tgQtvFlXSQOSOSIRvRPT7W67SCa46tRHOmNcaadrF8o=
github.com/creachadair/taskgroup v0.4.2 h1:jsBLdAJE42asreGss2xZGZ8fJra7WtwnHWeJFxv2Li8=
github.com/creachadair/taskgroup v0.4.2/go.mod h1:qiXUOSrbwAY3u0JPGTzObbE3yf9hcXHDKBZ2ZjpCbgM=
github.com/creack/pty v1.1.7/go.mod h1:lj5s0c3V2DBrqTV7llrYr5NG6My20zk30Fl46Y7DoTY=
github.com/creack/pty v1.1.9/go.mod h1:oKZEueFk5CKHvIhNR5MUki03XCEU+Q6VDXinZuGJ33E=
-github.com/cucumber/common/gherkin/go/v22 v22.0.0 h1:4K8NqptbvdOrjL9DEea6HFjSpbdT9+Q5kgLpmmsHYl0=
-github.com/cucumber/common/messages/go/v17 v17.1.1 h1:RNqopvIFyLWnKv0LfATh34SWBhXeoFTJnSrgm9cT/Ts=
-github.com/cyphar/filepath-securejoin v0.2.2/go.mod h1:FpkQEhXnPnOthhzymB7CGsFk2G9VLXONKD9G7QGMM+4=
github.com/cyphar/filepath-securejoin v0.2.3/go.mod h1:aPGpWjXOXUn2NCNjFvBE6aRxGGx79pTxQpKOJNYHHl4=
-github.com/d2g/dhcp4 v0.0.0-20170904100407-a1d1b6c41b1c/go.mod h1:Ct2BUK8SB0YC1SMSibvLzxjeJLnrYEVLULFNiHY9YfQ=
-github.com/d2g/dhcp4client v1.0.0/go.mod h1:j0hNfjhrt2SxUOw55nL0ATM/z4Yt3t2Kd1mW34z5W5s=
-github.com/d2g/dhcp4server v0.0.0-20181031114812-7d4a0a7f59a5/go.mod h1:Eo87+Kg/IX2hfWJfwxMzLyuSZyxSoAug2nGa1G2QAi8=
-github.com/d2g/hardwareaddr v0.0.0-20190221164911-e7d9fbe030e4/go.mod h1:bMl4RjIciD2oAxI7DmWRx6gbeqrkoLqv3MV0vzNad+I=
github.com/danieljoos/wincred v1.1.2 h1:QLdCxFs1/Yl4zduvBdcHB8goaYk9RARS2SgLLRuAyr0=
github.com/danieljoos/wincred v1.1.2/go.mod h1:GijpziifJoIBfYh+S7BbkdUTU4LfM+QnGqR5Vl2tAx0=
github.com/davecgh/go-spew v0.0.0-20171005155431-ecdeabc65495/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
@@ -562,9 +424,10 @@ github.com/decred/dcrd/crypto/blake256 v1.0.0 h1:/8DMNYp9SGi5f0w7uCm6d6M4OU2rGFK
github.com/decred/dcrd/crypto/blake256 v1.0.0/go.mod h1:sQl2p6Y26YV+ZOcSTP6thNdn47hh8kt6rqSlvmrXFAc=
github.com/decred/dcrd/dcrec/secp256k1/v2 v2.0.0 h1:3GIJYXQDAKpLEFriGFN8SbSffak10UXHGdIcFaMPykY=
github.com/decred/dcrd/dcrec/secp256k1/v2 v2.0.0/go.mod h1:3s92l0paYkZoIHuj4X93Teg/HB7eGM9x/zokGw+u4mY=
+github.com/decred/dcrd/dcrec/secp256k1/v4 v4.0.1/go.mod h1:hyedUtir6IdtD/7lIxGeCxkaw7y45JueMRL4DIyJDKs=
github.com/decred/dcrd/dcrec/secp256k1/v4 v4.1.0 h1:HbphB4TFFXpv7MNrT52FGrrgVXF1owhMVTHFZIlnvd4=
github.com/decred/dcrd/dcrec/secp256k1/v4 v4.1.0/go.mod h1:DZGJHZMqrU4JJqFAWUS2UO1+lbSKsdiOoYi9Zzey7Fc=
-github.com/denverdino/aliyungo v0.0.0-20190125010748-a747050bb1ba/go.mod h1:dV8lFg6daOBZbT6/BDGIz6Y3WFGn8juu6G+CQ6LHtl0=
+github.com/decred/dcrd/lru v1.0.0/go.mod h1:mxKOwFd7lFjN2GZYsiz/ecgqR6kkYAl+0pz0tEMk218=
github.com/desertbit/timer v0.0.0-20180107155436-c41aec40b27f h1:U5y3Y5UE0w7amNe7Z5G/twsBW0KEalRQXZzf8ufSh9I=
github.com/desertbit/timer v0.0.0-20180107155436-c41aec40b27f/go.mod h1:xH/i4TFMt8koVQZ6WFms69WAsDWr2XsYL3Hkl7jkoLE=
github.com/dgraph-io/badger/v2 v2.2007.4 h1:TRWBQg8UrlUhaFdco01nO2uXwzKS7zd+HVdwV/GHc4o=
@@ -572,35 +435,19 @@ github.com/dgraph-io/badger/v2 v2.2007.4/go.mod h1:vSw/ax2qojzbN6eXHIx6KPKtCSHJN
github.com/dgraph-io/ristretto v0.0.3-0.20200630154024-f66de99634de/go.mod h1:KPxhHT9ZxKefz+PCeOGsrHpl1qZ7i70dGTu2u+Ahh6E=
github.com/dgraph-io/ristretto v0.1.1 h1:6CWw5tJNgpegArSHpNHJKldNeq03FQCwYvfMVWajOK8=
github.com/dgraph-io/ristretto v0.1.1/go.mod h1:S1GPSBCYCIhmVNfcth17y2zZtQT6wzkzgwUve0VDWWA=
-github.com/dgrijalva/jwt-go v0.0.0-20170104182250-a601269ab70c/go.mod h1:E3ru+11k8xSBh+hMPgOLZmtrrCbhqsmaPHjLKYnJCaQ=
github.com/dgrijalva/jwt-go v3.2.0+incompatible/go.mod h1:E3ru+11k8xSBh+hMPgOLZmtrrCbhqsmaPHjLKYnJCaQ=
github.com/dgryski/go-farm v0.0.0-20190423205320-6a90982ecee2/go.mod h1:SqUrOPUnsFjfmXRMNPybcSiG0BgUW2AuFH8PAnS2iTw=
github.com/dgryski/go-farm v0.0.0-20200201041132-a6ae2369ad13 h1:fAjc9m62+UWV/WAFKLNi6ZS0675eEUC9y3AlwSbQu1Y=
github.com/dgryski/go-farm v0.0.0-20200201041132-a6ae2369ad13/go.mod h1:SqUrOPUnsFjfmXRMNPybcSiG0BgUW2AuFH8PAnS2iTw=
-github.com/dgryski/go-sip13 v0.0.0-20181026042036-e10d5fee7954/go.mod h1:vAd38F8PWV+bWy6jNmig1y/TA+kYO4g3RSRF0IAv0no=
-github.com/dnaeon/go-vcr v1.0.1/go.mod h1:aBB1+wY4s93YsC3HHjMBMrwTj2R9FHDzUr9KyGc8n1E=
-github.com/docker/cli v0.0.0-20191017083524-a8ff7f821017/go.mod h1:JLrzqnKDaYBop7H2jaqPtU4hHvMKP+vjCwu2uszcLI8=
-github.com/docker/distribution v0.0.0-20190905152932-14b96e55d84c/go.mod h1:0+TTO4EOBfRPhZXAeF1Vu+W3hHZ8eLp8PgKVZlcvtFY=
-github.com/docker/distribution v2.7.1-0.20190205005809-0d3efadf0154+incompatible/go.mod h1:J2gT2udsDAN96Uj4KfcMRqY0/ypR+oyYUYmja8H+y+w=
-github.com/docker/distribution v2.7.1+incompatible/go.mod h1:J2gT2udsDAN96Uj4KfcMRqY0/ypR+oyYUYmja8H+y+w=
-github.com/docker/distribution v2.8.1+incompatible h1:Q50tZOPR6T/hjNsyc9g8/syEs6bk8XXApsHjKukMl68=
-github.com/docker/distribution v2.8.1+incompatible/go.mod h1:J2gT2udsDAN96Uj4KfcMRqY0/ypR+oyYUYmja8H+y+w=
-github.com/docker/docker v1.4.2-0.20190924003213-a8608b5b67c7/go.mod h1:eEKB0N0r5NX/I1kEveEz05bcu8tLC/8azJZsviup8Sk=
-github.com/docker/docker v20.10.19+incompatible h1:lzEmjivyNHFHMNAFLXORMBXyGIhw/UP4DvJwvyKYq64=
-github.com/docker/docker v20.10.19+incompatible/go.mod h1:eEKB0N0r5NX/I1kEveEz05bcu8tLC/8azJZsviup8Sk=
-github.com/docker/docker-credential-helpers v0.6.3/go.mod h1:WRaJzqw3CTB9bk10avuGsjVBZsD05qeibJ1/TYlvc0Y=
+github.com/docker/distribution v2.8.2+incompatible h1:T3de5rq0dB1j30rp0sA2rER+m322EBzniBPB6ZIzuh8=
+github.com/docker/distribution v2.8.2+incompatible/go.mod h1:J2gT2udsDAN96Uj4KfcMRqY0/ypR+oyYUYmja8H+y+w=
+github.com/docker/docker v24.0.1+incompatible h1:NxN81beIxDlUaVt46iUQrYHD9/W3u9EGl52r86O/IGw=
+github.com/docker/docker v24.0.1+incompatible/go.mod h1:eEKB0N0r5NX/I1kEveEz05bcu8tLC/8azJZsviup8Sk=
github.com/docker/go-connections v0.4.0 h1:El9xVISelRB7BuFusrZozjnkIM5YnzCViNKohAFqRJQ=
github.com/docker/go-connections v0.4.0/go.mod h1:Gbd7IOopHjR8Iph03tsViu4nIes5XhDvyHbTtUxmeec=
-github.com/docker/go-events v0.0.0-20170721190031-9461782956ad/go.mod h1:Uw6UezgYA44ePAFQYUehOuCzmy5zmg/+nl2ZfMWGkpA=
-github.com/docker/go-events v0.0.0-20190806004212-e31b211e4f1c/go.mod h1:Uw6UezgYA44ePAFQYUehOuCzmy5zmg/+nl2ZfMWGkpA=
-github.com/docker/go-metrics v0.0.0-20180209012529-399ea8c73916/go.mod h1:/u0gXw0Gay3ceNrsHubL3BtdOL2fHf93USgMTe0W5dI=
-github.com/docker/go-metrics v0.0.1/go.mod h1:cG1hvH2utMXtqgqqYE9plW6lDxS3/5ayHzueweSI3Vw=
github.com/docker/go-units v0.4.0/go.mod h1:fgPhTUdO+D/Jk86RDLlptpiXQzgHJF7gydDDbaIK4Dk=
github.com/docker/go-units v0.5.0 h1:69rxXcBk27SvSaaxTtLh/8llcHD8vYHT7WSdRZ/jvr4=
github.com/docker/go-units v0.5.0/go.mod h1:fgPhTUdO+D/Jk86RDLlptpiXQzgHJF7gydDDbaIK4Dk=
-github.com/docker/libtrust v0.0.0-20150114040149-fa567046d9b1/go.mod h1:cyGadeNEkKy96OOhEzfZl+yxihPEzKnqJwvfuSUqbZE=
-github.com/docker/spdystream v0.0.0-20160310174837-449fdfce4d96/go.mod h1:Qh8CwZgvJUkLughtfhJv5dyTYa91l1fOUCrgjqmcifM=
-github.com/docopt/docopt-go v0.0.0-20180111231733-ee0de3bc6815/go.mod h1:WwZ+bS3ebgob9U8Nd0kOddGdZWjyMGR8Wziv+TBNwSE=
github.com/dustin/go-humanize v0.0.0-20171111073723-bb3d318650d4/go.mod h1:HtrtbFcZ19U5GC7JDqmcUSB87Iq5E25KnS6fMYU6eOk=
github.com/dustin/go-humanize v1.0.0/go.mod h1:HtrtbFcZ19U5GC7JDqmcUSB87Iq5E25KnS6fMYU6eOk=
github.com/dustin/go-humanize v1.0.1 h1:GzkhY7T5VNhEkwH0PVJgjz+fX1rhBrR7pRT3mDkpeCY=
@@ -611,9 +458,6 @@ github.com/eapache/go-resiliency v1.1.0/go.mod h1:kFI+JgMyC7bLPUVY133qvEBtVayf5m
github.com/eapache/go-xerial-snappy v0.0.0-20180814174437-776d5712da21/go.mod h1:+020luEh2TKB4/GOp8oxxtq0Daoen/Cii55CzbTV6DU=
github.com/eapache/queue v1.1.0/go.mod h1:6eCeP0CKFpHLu8blIFXhExK/dRa7WDZfr6jVFPTqq+I=
github.com/edsrzf/mmap-go v1.0.0/go.mod h1:YO35OhQPt3KJa3ryjFM5Bs14WD66h8eGKpfaBNrHW5M=
-github.com/elazarl/goproxy v0.0.0-20180725130230-947c36da3153/go.mod h1:/Zj4wYkgs4iZTTu3o/KG3Itv/qCCa8VVMlb3i9OVuzc=
-github.com/emicklei/go-restful v0.0.0-20170410110728-ff4f55a20633/go.mod h1:otzb+WCGbkyDHkqmQmT5YD2WR4BBwUdeQoFo8l/7tVs=
-github.com/emicklei/go-restful v2.9.5+incompatible/go.mod h1:otzb+WCGbkyDHkqmQmT5YD2WR4BBwUdeQoFo8l/7tVs=
github.com/envoyproxy/go-control-plane v0.6.9/go.mod h1:SBwIajubJHhxtWwsL9s8ss4safvEdbitLhGGK48rN6g=
github.com/envoyproxy/go-control-plane v0.9.0/go.mod h1:YTl/9mNaCwkRvm6d1a2C3ymFceY/DCBVvsKhRF0iEA4=
github.com/envoyproxy/go-control-plane v0.9.1-0.20191026205805-5f8ba28d4473/go.mod h1:YTl/9mNaCwkRvm6d1a2C3ymFceY/DCBVvsKhRF0iEA4=
@@ -627,37 +471,31 @@ github.com/envoyproxy/go-control-plane v0.10.2-0.20220325020618-49ff273808a1/go.
github.com/envoyproxy/protoc-gen-validate v0.1.0/go.mod h1:iSmxcyjqTsJpI2R4NaDN7+kN2VEUnK/pcBlmesArF7c=
github.com/ethereum/go-ethereum v1.10.26 h1:i/7d9RBBwiXCEuyduBQzJw/mKmnvzsN14jqBmytw72s=
github.com/ethereum/go-ethereum v1.10.26/go.mod h1:EYFyF19u3ezGLD4RqOkLq+ZCXzYbLoNDdZlMt7kyKFg=
-github.com/evanphx/json-patch v4.9.0+incompatible/go.mod h1:50XU6AFN0ol/bzJsmQLiYLvXMP4fmwYFNcr97nuDLSk=
-github.com/facebookgo/ensure v0.0.0-20200202191622-63f1cf65ac4c h1:8ISkoahWXwZR41ois5lSJBSVw4D0OV19Ht/JSTzvSv0=
-github.com/facebookgo/stack v0.0.0-20160209184415-751773369052 h1:JWuenKqqX8nojtoVVWjGfOF9635RETekkoH6Cc9SX0A=
-github.com/facebookgo/subset v0.0.0-20200203212716-c811ad88dec4 h1:7HZCaLC5+BZpmbhCOZJ293Lz68O7PYrF2EzeiFMwCLk=
github.com/fatih/color v1.7.0/go.mod h1:Zm6kSWBoL9eyXnKyktHP6abPY2pDugNf5KwzbycvMj4=
github.com/felixge/httpsnoop v1.0.1/go.mod h1:m8KPJKqk1gH5J9DgRY2ASl2lWCfGKXixSwevea8zH2U=
github.com/felixge/httpsnoop v1.0.2 h1:+nS9g82KMXccJ/wp0zyRW9ZBHFETmMGtkk+2CTTrW4o=
github.com/felixge/httpsnoop v1.0.2/go.mod h1:m8KPJKqk1gH5J9DgRY2ASl2lWCfGKXixSwevea8zH2U=
-github.com/form3tech-oss/jwt-go v3.2.2+incompatible/go.mod h1:pbq4aXjuKjdthFRnoDwaVPLA+WlJuPGy+QneDUgJi2k=
github.com/fortytw2/leaktest v1.3.0 h1:u8491cBMTQ8ft8aeV+adlcytMZylmA5nnwwkRZjI8vw=
github.com/franela/goblin v0.0.0-20200105215937-c9ffbefa60db/go.mod h1:7dvUGVsVBjqR7JHJk0brhHOZYGmfBYOrK0ZhYMEtBr4=
github.com/franela/goreq v0.0.0-20171204163338-bcd34c9993f8/go.mod h1:ZhphrRTfi2rbfLwlschooIH4+wKKDR4Pdxhh+TRoA20=
github.com/frankban/quicktest v1.11.3/go.mod h1:wRf/ReqHper53s+kmmSZizM8NamnL3IM0I9ntUbOk+k=
-github.com/frankban/quicktest v1.14.3 h1:FJKSZTDHjyhriyC81FLQ0LY93eSai0ZyR/ZIkd3ZUKE=
+github.com/frankban/quicktest v1.14.4 h1:g2rn0vABPOOXmZUj+vbmUp0lPoXEMuhTpIluN0XL9UY=
github.com/fsnotify/fsnotify v1.4.7/go.mod h1:jwhsz4b93w/PPRr/qN1Yymfu8t87LnFCMoQvtojpjFo=
github.com/fsnotify/fsnotify v1.4.9/go.mod h1:znqG4EE+3YCdAaPaxE2ZRY/06pZUdp0tY4IgpuI1SZQ=
github.com/fsnotify/fsnotify v1.5.4/go.mod h1:OVB6XrOHzAwXMpEM7uPOzcehqUV2UqJxmVXmkdnm1bU=
github.com/fsnotify/fsnotify v1.6.0 h1:n+5WquG0fcWoWp6xPWfHdbskMCQaFnG6PfBrh1Ky4HY=
github.com/fsnotify/fsnotify v1.6.0/go.mod h1:sl3t1tCWJFWoRz9R8WJCbQihKKwmorjAbSClcnxKAGw=
-github.com/fullsailor/pkcs7 v0.0.0-20190404230743-d7302db945fa/go.mod h1:KnogPXtdwXqoenmZCw6S+25EAm2MkxbG0deNDu4cbSA=
-github.com/garyburd/redigo v0.0.0-20150301180006-535138d7bcd7/go.mod h1:NR3MbYisc3/PwhQ00EMzDiPmrwpPxAn5GI05/YaO1SY=
-github.com/ghodss/yaml v0.0.0-20150909031657-73d445a93680/go.mod h1:4dBDuWmgqj2HViK6kFavaiC9ZROes6MMH2rRYeMEF04=
+github.com/getsentry/sentry-go v0.23.0 h1:dn+QRCeJv4pPt9OjVXiMcGIBIefaTJPw/h0bZWO05nE=
+github.com/getsentry/sentry-go v0.23.0/go.mod h1:lc76E2QywIyW8WuBnwl8Lc4bkmQH4+w1gwTf25trprY=
github.com/ghodss/yaml v1.0.0/go.mod h1:4dBDuWmgqj2HViK6kFavaiC9ZROes6MMH2rRYeMEF04=
github.com/gin-contrib/sse v0.1.0 h1:Y/yl/+YNO8GZSjAhjMsSuLt29uWRFHdHYUb5lYOV9qE=
github.com/gin-contrib/sse v0.1.0/go.mod h1:RHrZQHXnP2xjPF+u1gW/2HnVO7nvIa9PG3Gm+fLHvGI=
github.com/gin-gonic/gin v1.6.3/go.mod h1:75u5sXoLsGZoRN5Sgbi1eraJ4GU3++wFwWzhwvtwp4M=
github.com/gin-gonic/gin v1.8.1 h1:4+fr/el88TOO3ewCmQr8cx/CtZ/umlIRIs5M4NTNjf8=
+github.com/go-errors/errors v1.4.2 h1:J6MZopCL4uSllY1OfXM374weqZFFItUbrImctkmUxIA=
github.com/go-gl/glfw v0.0.0-20190409004039-e6da0acd62b1/go.mod h1:vR7hzQXu2zJy9AVAgeJqvqgH9Q5CA+iKCZ2gyEVpxRU=
github.com/go-gl/glfw/v3.3/glfw v0.0.0-20191125211704-12ad95a8df72/go.mod h1:tQ2UAYgL5IevRw8kRxooKSPJfGvJ9fJQFa0TUsXzTg8=
github.com/go-gl/glfw/v3.3/glfw v0.0.0-20200222043503-6f7a984d4dc4/go.mod h1:tQ2UAYgL5IevRw8kRxooKSPJfGvJ9fJQFa0TUsXzTg8=
-github.com/go-ini/ini v1.25.4/go.mod h1:ByCAeIL28uOIIG0E3PJtZPDL8WnHpFKFOtgjp+3Ies8=
github.com/go-kit/kit v0.8.0/go.mod h1:xBxKIO96dXMWWy0MnWVtmwkA9/13aqxPnvrjFYMA2as=
github.com/go-kit/kit v0.9.0/go.mod h1:xBxKIO96dXMWWy0MnWVtmwkA9/13aqxPnvrjFYMA2as=
github.com/go-kit/kit v0.10.0/go.mod h1:xUsJbQ/Fp4kEt7AFgCuvyX4a71u8h9jB8tj/ORgOZ7o=
@@ -670,26 +508,12 @@ github.com/go-logfmt/logfmt v0.4.0/go.mod h1:3RMwSq7FuexP4Kalkev3ejPJsZTpXXBr9+V
github.com/go-logfmt/logfmt v0.5.0/go.mod h1:wCYkCAKZfumFQihp8CzCvQ3paCTfi41vtzG1KdI/P7A=
github.com/go-logfmt/logfmt v0.6.0 h1:wGYYu3uicYdqXVgoYbvnkrPVXkuLM1p1ifugDMEdRi4=
github.com/go-logfmt/logfmt v0.6.0/go.mod h1:WYhtIu8zTZfxdn5+rREduYbwxfcBr/Vr6KEVveWlfTs=
-github.com/go-logr/logr v0.1.0/go.mod h1:ixOQHD9gLJUVQQ2ZOR7zLEifBX6tGkNJF4QyIY7sIas=
-github.com/go-logr/logr v0.2.0/go.mod h1:z6/tIYblkpsD+a4lm/fGIIU9mZ+XfAiaFtq7xTgseGU=
github.com/go-ole/go-ole v1.2.6 h1:/Fpf6oFPoeFik9ty7siob0G6Ke8QvQEuVcuChpwXzpY=
-github.com/go-ole/go-ole v1.2.6/go.mod h1:pprOEPIfldk/42T2oK7lQ4v4JSDwmV0As9GaiUsvbm0=
-github.com/go-openapi/jsonpointer v0.0.0-20160704185906-46af16f9f7b1/go.mod h1:+35s3my2LFTysnkMfxsJBAMHj/DoqoB9knIWoYG/Vk0=
-github.com/go-openapi/jsonpointer v0.19.2/go.mod h1:3akKfEdA7DF1sugOqz1dVQHBcuDBPKZGEoHC/NkiQRg=
-github.com/go-openapi/jsonpointer v0.19.3/go.mod h1:Pl9vOtqEWErmShwVjC8pYs9cog34VGT37dQOVbmoatg=
-github.com/go-openapi/jsonreference v0.0.0-20160704190145-13c6e3589ad9/go.mod h1:W3Z9FmVs9qj+KR4zFKmDPGiLdk1D9Rlm7cyMvf57TTg=
-github.com/go-openapi/jsonreference v0.19.2/go.mod h1:jMjeRr2HHw6nAVajTXJ4eiUwohSTlpa0o73RUL1owJc=
-github.com/go-openapi/jsonreference v0.19.3/go.mod h1:rjx6GuL8TTa9VaixXglHmQmIL98+wF9xc8zWvFonSJ8=
-github.com/go-openapi/spec v0.0.0-20160808142527-6aced65f8501/go.mod h1:J8+jY1nAiCcj+friV/PDoE1/3eeccG9LYBs0tYvLOWc=
-github.com/go-openapi/spec v0.19.3/go.mod h1:FpwSN1ksY1eteniUU7X0N/BgJ7a4WvBFVA8Lj9mJglo=
-github.com/go-openapi/swag v0.0.0-20160704191624-1d0bd113de87/go.mod h1:DXUve3Dpr1UfpPtxFw+EFuQ41HhCWZfha5jSVRG7C7I=
-github.com/go-openapi/swag v0.19.2/go.mod h1:POnQmlKehdgb5mhVOsnJFsivZCEZ/vjK9gh66Z9tfKk=
-github.com/go-openapi/swag v0.19.5/go.mod h1:POnQmlKehdgb5mhVOsnJFsivZCEZ/vjK9gh66Z9tfKk=
github.com/go-playground/assert/v2 v2.0.1/go.mod h1:VDjEfimB/XKnb+ZQfWdccd7VUvScMdVu0Titje2rxJ4=
-github.com/go-playground/locales v0.13.0 h1:HyWk6mgj5qFqCT5fjGBuRArbVDfE4hi8+e8ceBS/t7Q=
github.com/go-playground/locales v0.13.0/go.mod h1:taPMhCMXrRLJO55olJkUXHZBHCxTMfnGwq/HNwmWNS8=
-github.com/go-playground/universal-translator v0.17.0 h1:icxd5fm+REJzpZx7ZfpaD876Lmtgy7VtROAbHHXk8no=
+github.com/go-playground/locales v0.14.0 h1:u50s323jtVGugKlcYeyzC0etD1HifMjqmJqb8WugfUU=
github.com/go-playground/universal-translator v0.17.0/go.mod h1:UkSxE5sNxxRwHyU+Scu5vgOQjsIJAF8j9muTVoKLVtA=
+github.com/go-playground/universal-translator v0.18.0 h1:82dyy6p4OuJq4/CByFNOn/jYrnRPArHwAcmLoJZxyho=
github.com/go-playground/validator/v10 v10.2.0/go.mod h1:uOYAAleCW8F/7oMFd6aG0GOhaH6EGOAJShg8Id5JGkI=
github.com/go-playground/validator/v10 v10.11.1 h1:prmOlTVv+YjZjmRmNSF3VmspqJIxJWXmqUsHwfTRRkQ=
github.com/go-sql-driver/mysql v1.4.0/go.mod h1:zAC/RDZ24gD3HViQzih4MyKcchzm+sOG5ZlKdlhCg5w=
@@ -704,28 +528,20 @@ github.com/gobwas/pool v0.2.0/go.mod h1:q8bcK0KcYlCgd9e7WYLm9LpyS+YeLd8JVDW6Wezm
github.com/gobwas/ws v1.0.2 h1:CoAavW/wd/kulfZmSIBt6p24n4j7tHgNVCjsfHVNUbo=
github.com/gobwas/ws v1.0.2/go.mod h1:szmBTxLgaFppYjEmNtny/v3w89xOydFnnZMcgRRu/EM=
github.com/goccy/go-json v0.9.11 h1:/pAaQDLHEoCq/5FFmSKBswWmK6H0e8g4159Kc/X/nqk=
-github.com/godbus/dbus v0.0.0-20151105175453-c7fdd8b5cd55/go.mod h1:/YcGZj5zSblfDWMMoOzV4fas9FZnQYTkDnsGvmh2Grw=
-github.com/godbus/dbus v0.0.0-20180201030542-885f9cc04c9c/go.mod h1:/YcGZj5zSblfDWMMoOzV4fas9FZnQYTkDnsGvmh2Grw=
-github.com/godbus/dbus v0.0.0-20190422162347-ade71ed3457e/go.mod h1:bBOAhwG1umN6/6ZUMtDFBMQR8jRg9O75tm9K00oMsK4=
github.com/godbus/dbus v0.0.0-20190726142602-4481cbc300e2 h1:ZpnhV/YsD2/4cESfV5+Hoeu/iUR3ruzNvZ+yQfO03a0=
github.com/godbus/dbus v0.0.0-20190726142602-4481cbc300e2/go.mod h1:bBOAhwG1umN6/6ZUMtDFBMQR8jRg9O75tm9K00oMsK4=
-github.com/godbus/dbus/v5 v5.0.3/go.mod h1:xhWf0FNVPg57R7Z0UbKHbJfkEywrmjJnf7w5xrFpKfA=
github.com/godbus/dbus/v5 v5.0.4/go.mod h1:xhWf0FNVPg57R7Z0UbKHbJfkEywrmjJnf7w5xrFpKfA=
github.com/godbus/dbus/v5 v5.0.6/go.mod h1:xhWf0FNVPg57R7Z0UbKHbJfkEywrmjJnf7w5xrFpKfA=
github.com/gofrs/flock v0.8.1 h1:+gYjHKf32LDeiEEFhQaotPbLuUXjY5ZqxKgXy7n59aw=
github.com/gofrs/flock v0.8.1/go.mod h1:F1TvTiK9OcQqauNUHlbJvyl9Qa1QvF/gOUDKA14jxHU=
-github.com/gofrs/uuid v4.3.0+incompatible h1:CaSVZxm5B+7o45rtab4jC2G37WGYX1zQfuU2i6DSvnc=
github.com/gogo/googleapis v1.1.0/go.mod h1:gf4bu3Q80BeJ6H1S1vYPm8/ELATdvryBaNFGgqEef3s=
-github.com/gogo/googleapis v1.2.0/go.mod h1:Njal3psf3qN6dwBtQfUmBZh2ybovJ0tlu3o/AC7HYjU=
-github.com/gogo/googleapis v1.4.0/go.mod h1:5YRNX2z1oM5gXdAkurHa942MDgEJyk02w4OecKY87+c=
github.com/gogo/googleapis v1.4.1-0.20201022092350-68b0159b7869/go.mod h1:5YRNX2z1oM5gXdAkurHa942MDgEJyk02w4OecKY87+c=
github.com/gogo/googleapis v1.4.1 h1:1Yx4Myt7BxzvUr5ldGSbwYiZG6t9wGBZ+8/fX3Wvtq0=
github.com/gogo/googleapis v1.4.1/go.mod h1:2lpHqI5OcWCtVElxXnPt+s8oJvMpySlOyM6xDCrzib4=
github.com/golang/glog v0.0.0-20160126235308-23def4e6c14b/go.mod h1:SBH7ygxi8pfUlaOkMMuAQtPIUF8ecWP5IEl/CR7VP2Q=
-github.com/golang/glog v1.0.0 h1:nfP3RFugxnNRyKgeWd4oI1nYvXpxrx8ck8ZrcizshdQ=
-github.com/golang/glog v1.0.0/go.mod h1:EWib/APOK0SL3dFbYqvxE3UYd8E6s1ouQ7iEp/0LWV4=
+github.com/golang/glog v1.1.0 h1:/d3pCKDPWNnvIWe0vVUpNP32qc8U3PDVxySP/y360qE=
+github.com/golang/glog v1.1.0/go.mod h1:pfYeQZ3JWZoXTV5sFc986z3HTpwQs9At6P4ImfuP3NQ=
github.com/golang/groupcache v0.0.0-20160516000752-02826c3e7903/go.mod h1:cIg4eruTrX1D+g88fzRXU5OdNfaM+9IcxsU14FzY7Hc=
-github.com/golang/groupcache v0.0.0-20190129154638-5b532d6fd5ef/go.mod h1:cIg4eruTrX1D+g88fzRXU5OdNfaM+9IcxsU14FzY7Hc=
github.com/golang/groupcache v0.0.0-20190702054246-869f871628b6/go.mod h1:cIg4eruTrX1D+g88fzRXU5OdNfaM+9IcxsU14FzY7Hc=
github.com/golang/groupcache v0.0.0-20191227052852-215e87163ea7/go.mod h1:cIg4eruTrX1D+g88fzRXU5OdNfaM+9IcxsU14FzY7Hc=
github.com/golang/groupcache v0.0.0-20200121045136-8c9f03a8e57e/go.mod h1:cIg4eruTrX1D+g88fzRXU5OdNfaM+9IcxsU14FzY7Hc=
@@ -758,8 +574,9 @@ github.com/golang/protobuf v1.4.2/go.mod h1:oDoupMAO8OvCJWAcko0GGGIgR6R6ocIYbsSw
github.com/golang/protobuf v1.4.3/go.mod h1:oDoupMAO8OvCJWAcko0GGGIgR6R6ocIYbsSw735rRwI=
github.com/golang/protobuf v1.5.0/go.mod h1:FsONVRAS9T7sI+LIUmWTfcYkHO4aIWwzhcaSAoJOfIk=
github.com/golang/protobuf v1.5.1/go.mod h1:DopwsBzvsk0Fs44TXzsVbJyPhcCPeIwnvohx4u74HPM=
-github.com/golang/protobuf v1.5.2 h1:ROPKBNFfQgOUMifHyP+KYbvpjbdoFNs+aK7DXlji0Tw=
github.com/golang/protobuf v1.5.2/go.mod h1:XVQd3VNwM+JqD3oG2Ue2ip4fOMUkwXdXDdiuN0vRsmY=
+github.com/golang/protobuf v1.5.3 h1:KhyjKVUg7Usr/dYsdSqoFveMYd5ko72D+zANwlG1mmg=
+github.com/golang/protobuf v1.5.3/go.mod h1:XVQd3VNwM+JqD3oG2Ue2ip4fOMUkwXdXDdiuN0vRsmY=
github.com/golang/snappy v0.0.0-20180518054509-2e65f85255db/go.mod h1:/XxbfmMg8lxefKM7IXC3fBNl/7bRcc72aCRzEWrmP2Q=
github.com/golang/snappy v0.0.3/go.mod h1:/XxbfmMg8lxefKM7IXC3fBNl/7bRcc72aCRzEWrmP2Q=
github.com/golang/snappy v0.0.4 h1:yAGX7huGHXlcLOEtBnF4w7FQwA26wojNCwOYAEhLjQM=
@@ -784,14 +601,12 @@ github.com/google/go-cmp v0.5.7/go.mod h1:n+brtR0CgQNWTVd5ZUFpTBC8YFBDLK/h/bpaJ8
github.com/google/go-cmp v0.5.8/go.mod h1:17dUlkBOakJ0+DkrSSNjCkIjxS6bF9zb3elmeNGIjoY=
github.com/google/go-cmp v0.5.9 h1:O2Tfq5qg4qc4AmwVlvv0oLiVAGB7enBSJ2x2DqQFi38=
github.com/google/go-cmp v0.5.9/go.mod h1:17dUlkBOakJ0+DkrSSNjCkIjxS6bF9zb3elmeNGIjoY=
-github.com/google/go-containerregistry v0.5.1/go.mod h1:Ct15B4yir3PLOP5jsy0GNeYVaIZs/MK/Jz5any1wFW0=
github.com/google/go-github/v43 v43.0.0 h1:y+GL7LIsAIF2NZlJ46ZoC/D1W1ivZasT0lnWHMYPZ+U=
github.com/google/go-github/v43 v43.0.0/go.mod h1:ZkTvvmCXBvsfPpTHXnH/d2hP9Y0cTbvN9kr5xqyXOIc=
github.com/google/go-querystring v1.1.0 h1:AnCroh3fv4ZBgVIf1Iwtovgjaw/GiKJo8M8yD/fhyJ8=
github.com/google/go-querystring v1.1.0/go.mod h1:Kcdr2DB4koayq7X8pmAG4sNG59So17icRSOU623lUBU=
github.com/google/gofuzz v0.0.0-20170612174753-24818f796faf/go.mod h1:HP5RmnzzSNb993RKQDq4+1A4ia9nllfqcQFTQJedwGI=
github.com/google/gofuzz v1.0.0/go.mod h1:dBl0BpW6vV/+mYPU4Po3pmUjxk6FQPldtuIdl/M65Eg=
-github.com/google/gofuzz v1.1.0/go.mod h1:dBl0BpW6vV/+mYPU4Po3pmUjxk6FQPldtuIdl/M65Eg=
github.com/google/gofuzz v1.2.0 h1:xRy4A+RhZaiKjJ1bPfwQ8sedCA+YS2YcCHW6ec7JMi0=
github.com/google/martian v2.1.0+incompatible h1:/CP5g8u/VJHijgedC/Legn3BAbAaWPgecwXBIDzw5no=
github.com/google/martian v2.1.0+incompatible/go.mod h1:9I4somxYTbIHy5NJKHRl3wXiIaQGbYVAs8BPL6v8lEs=
@@ -817,11 +632,12 @@ github.com/google/pprof v0.0.0-20210407192527-94a9f03dee38/go.mod h1:kpwsk12EmLe
github.com/google/pprof v0.0.0-20210601050228-01bbb1931b22/go.mod h1:kpwsk12EmLew5upagYY7GY0pfYCcupk39gWOCRROcvE=
github.com/google/pprof v0.0.0-20210609004039-a478d1d731e9/go.mod h1:kpwsk12EmLew5upagYY7GY0pfYCcupk39gWOCRROcvE=
github.com/google/pprof v0.0.0-20210720184732-4bb14d4b1be1/go.mod h1:kpwsk12EmLew5upagYY7GY0pfYCcupk39gWOCRROcvE=
+github.com/google/pprof v0.0.0-20221118152302-e6195bd50e26 h1:Xim43kblpZXfIBQsbuBVKCudVG457BR2GZFIz3uw3hQ=
github.com/google/renameio v0.1.0/go.mod h1:KWCgfxg9yswjAJkECMjeO8J8rahYeXnNhOm40UhjYkI=
+github.com/google/s2a-go v0.1.4 h1:1kZ/sQM3srePvKs3tXAvQzo66XfcReoqFpIpIccE7Oc=
+github.com/google/s2a-go v0.1.4/go.mod h1:Ej+mSEMGRnqRzjc7VtF+jdBwYG5fuJfiZ8ELkjEwM0A=
github.com/google/uuid v1.0.0/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo=
-github.com/google/uuid v1.1.1/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo=
github.com/google/uuid v1.1.2/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo=
-github.com/google/uuid v1.2.0/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo=
github.com/google/uuid v1.3.0 h1:t6JiXgmwXMjEs8VusXIJk2BXHsn+wx8BZdTaoZ5fu7I=
github.com/google/uuid v1.3.0/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo=
github.com/googleapis/enterprise-certificate-proxy v0.0.0-20220520183353-fd19c99a87aa/go.mod h1:17drOmN3MwGY7t0e+Ei9b45FFGA3fBs3x36SsCg1hq8=
@@ -838,35 +654,27 @@ github.com/googleapis/gax-go/v2 v2.3.0/go.mod h1:b8LNqSzNabLiUpXKkY7HAR5jr6bIT99
github.com/googleapis/gax-go/v2 v2.4.0/go.mod h1:XOTVJ59hdnfJLIP/dh8n5CGryZR2LxK9wbMD5+iXC6c=
github.com/googleapis/gax-go/v2 v2.5.1/go.mod h1:h6B0KMMFNtI2ddbGJn3T3ZbwkeT6yqEF02fYlzkUCyo=
github.com/googleapis/gax-go/v2 v2.6.0/go.mod h1:1mjbznJAPHFpesgE5ucqfYEscaz5kMdcIDwU/6+DDoY=
-github.com/googleapis/gax-go/v2 v2.7.0 h1:IcsPKeInNvYi7eqSaDjiZqDDKu5rsmunY0Y1YupQSSQ=
-github.com/googleapis/gax-go/v2 v2.7.0/go.mod h1:TEop28CZZQ2y+c0VxMUmu1lV+fQx57QpBWsYpwqHJx8=
-github.com/googleapis/gnostic v0.4.1/go.mod h1:LRhVm6pbyptWbWbuZ38d1eyptfvIytN3ir6b65WBswg=
+github.com/googleapis/gax-go/v2 v2.11.0 h1:9V9PWXEsWnPpQhu/PeQIkS4eGzMlTLGgt80cUUI8Ki4=
+github.com/googleapis/gax-go/v2 v2.11.0/go.mod h1:DxmR61SGKkGLa2xigwuZIQpkCI2S5iydzRfb3peWZJI=
github.com/googleapis/go-type-adapters v1.0.0/go.mod h1:zHW75FOG2aur7gAO2B+MLby+cLsWGBF62rFAi7WjWO4=
github.com/googleapis/google-cloud-go-testing v0.0.0-20200911160855-bcd43fbb19e8/go.mod h1:dvDLG8qkwmyD9a/MJJN3XJcT3xFxOKAvTZGvuZmac9g=
github.com/gopherjs/gopherjs v0.0.0-20181017120253-0766667cb4d1/go.mod h1:wJfORRmW1u3UXTncJ5qlYoELFm8eSnnEO6hX4iZ3EWY=
github.com/gorilla/context v1.1.1/go.mod h1:kBGZzfjB9CEq2AlWe17Uuf7NDRt0dE0s8S51q0aT7Yg=
-github.com/gorilla/handlers v0.0.0-20150720190736-60c7bfde3e33/go.mod h1:Qkdc/uu4tH4g6mTK6auzZ766c4CA0Ng8+o/OAirnOIQ=
github.com/gorilla/handlers v1.5.1 h1:9lRY6j8DEeeBT10CvO9hGW0gmky0BprnvDI5vfhUHH4=
github.com/gorilla/handlers v1.5.1/go.mod h1:t8XrUpc4KVXb7HGyJ4/cEnwQiaxrX/hz1Zv/4g96P1Q=
github.com/gorilla/mux v1.6.2/go.mod h1:1lud6UwP+6orDFRuTfBEV8e9/aOM/c4fVVCaMa2zaAs=
-github.com/gorilla/mux v1.7.2/go.mod h1:1lud6UwP+6orDFRuTfBEV8e9/aOM/c4fVVCaMa2zaAs=
github.com/gorilla/mux v1.7.3/go.mod h1:1lud6UwP+6orDFRuTfBEV8e9/aOM/c4fVVCaMa2zaAs=
github.com/gorilla/mux v1.8.0 h1:i40aqfkR1h2SlN9hojwV5ZA91wcXFOvkdNIeFDP5koI=
github.com/gorilla/mux v1.8.0/go.mod h1:DVbg23sWSpFRCP0SfiEN6jmj59UnW/n46BH5rLB71So=
github.com/gorilla/websocket v0.0.0-20170926233335-4201258b820c/go.mod h1:E7qHFY5m1UJ88s3WnNqhKjPHQ0heANvMoAMk2YaljkQ=
-github.com/gorilla/websocket v1.4.0/go.mod h1:E7qHFY5m1UJ88s3WnNqhKjPHQ0heANvMoAMk2YaljkQ=
github.com/gorilla/websocket v1.4.1/go.mod h1:YR8l580nyteQvAITg2hZ9XVh4b55+EU/adAjf1fMHhE=
-github.com/gorilla/websocket v1.4.2/go.mod h1:YR8l580nyteQvAITg2hZ9XVh4b55+EU/adAjf1fMHhE=
github.com/gorilla/websocket v1.5.0 h1:PPwGk2jz7EePpoHN/+ClbZu8SPxiqlu12wZP/3sWmnc=
github.com/gorilla/websocket v1.5.0/go.mod h1:YR8l580nyteQvAITg2hZ9XVh4b55+EU/adAjf1fMHhE=
-github.com/gregjones/httpcache v0.0.0-20180305231024-9cad4c3443a7/go.mod h1:FecbI9+v66THATjSRHfNgh1IVFe/9kFxbXtjV0ctIMA=
-github.com/grpc-ecosystem/go-grpc-middleware v1.0.0/go.mod h1:FiyG127CGDf3tlThmgyCl78X/SZQqEOJBCDaAfeWzPs=
github.com/grpc-ecosystem/go-grpc-middleware v1.0.1-0.20190118093823-f849b5445de4/go.mod h1:FiyG127CGDf3tlThmgyCl78X/SZQqEOJBCDaAfeWzPs=
github.com/grpc-ecosystem/go-grpc-middleware v1.2.2/go.mod h1:EaizFBKfUKtMIF5iaDEhniwNedqGo9FuLFzppDr3uwI=
github.com/grpc-ecosystem/go-grpc-middleware v1.3.0 h1:+9834+KizmvFV7pXQGSXQTsaWhq2GjuNUt0aUU0YBYw=
github.com/grpc-ecosystem/go-grpc-middleware v1.3.0/go.mod h1:z0ButlSOZa5vEBq9m2m2hlwIgKw+rp3sdCBRoJY+30Y=
github.com/grpc-ecosystem/go-grpc-prometheus v1.2.0/go.mod h1:8NvIoxWQoOIhqOTXgfV/d3M/q6VIi02HzZEHgUlZvzk=
-github.com/grpc-ecosystem/grpc-gateway v1.9.0/go.mod h1:vNeuVxBJEsws4ogUvrchl83t/GYV9WGTSLVdBhOQFDY=
github.com/grpc-ecosystem/grpc-gateway v1.9.5/go.mod h1:vNeuVxBJEsws4ogUvrchl83t/GYV9WGTSLVdBhOQFDY=
github.com/grpc-ecosystem/grpc-gateway v1.16.0 h1:gmcG1KaJ57LophUzW0Hy8NmPhnMZb4M0+kPpLofRdBo=
github.com/grpc-ecosystem/grpc-gateway v1.16.0/go.mod h1:BDjrQk3hbvj6Nolgz8mAMFbcEtjT1g+wF4CSlocrBnw=
@@ -879,19 +687,17 @@ github.com/gtank/ristretto255 v0.1.2 h1:JEqUCPA1NvLq5DwYtuzigd7ss8fwbYay9fi4/5uM
github.com/gtank/ristretto255 v0.1.2/go.mod h1:Ph5OpO6c7xKUGROZfWVLiJf9icMDwUeIvY4OmlYW69o=
github.com/hashicorp/consul/api v1.3.0/go.mod h1:MmDNSzIMUjNpY/mQ398R4bk2FnqQLoPndWW5VkKPlCE=
github.com/hashicorp/consul/sdk v0.3.0/go.mod h1:VKf9jXwCTEY1QZP2MOLRhb5i/I/ssyNV1vwHyQBF0x8=
-github.com/hashicorp/errwrap v0.0.0-20141028054710-7554cd9344ce/go.mod h1:YH+1FKiLXxHSkmPseP+kNlulaMuP3n2brvKWEqk/Jc4=
github.com/hashicorp/errwrap v1.0.0/go.mod h1:YH+1FKiLXxHSkmPseP+kNlulaMuP3n2brvKWEqk/Jc4=
github.com/hashicorp/go-cleanhttp v0.5.0/go.mod h1:JpRdi6/HCYpAwUzNwuwqhbovhLtngrth3wmdIIUrZ80=
github.com/hashicorp/go-cleanhttp v0.5.1/go.mod h1:JpRdi6/HCYpAwUzNwuwqhbovhLtngrth3wmdIIUrZ80=
github.com/hashicorp/go-cleanhttp v0.5.2 h1:035FKYIWjmULyFRBKPs8TBQoi0x6d9G4xc9neXJWAZQ=
github.com/hashicorp/go-cleanhttp v0.5.2/go.mod h1:kO/YDlP8L1346E6Sodw+PrpBSV4/SoxCXGY6BqNFT48=
-github.com/hashicorp/go-getter v1.7.0 h1:bzrYP+qu/gMrL1au7/aDvkoOVGUJpeKBgbqRHACAFDY=
-github.com/hashicorp/go-getter v1.7.0/go.mod h1:W7TalhMmbPmsSMdNjD0ZskARur/9GJ17cfHTRtXV744=
+github.com/hashicorp/go-getter v1.7.1 h1:SWiSWN/42qdpR0MdhaOc/bLR48PLuP1ZQtYLRlM69uY=
+github.com/hashicorp/go-getter v1.7.1/go.mod h1:W7TalhMmbPmsSMdNjD0ZskARur/9GJ17cfHTRtXV744=
github.com/hashicorp/go-immutable-radix v1.0.0/go.mod h1:0y9vanUI8NX6FsYoO3zeMjhV/C5i9g4Q3DwcSNZ4P60=
github.com/hashicorp/go-immutable-radix v1.3.1 h1:DKHmCUm2hRBK510BaiZlwvpD40f8bJFeZnpfm2KLowc=
github.com/hashicorp/go-immutable-radix v1.3.1/go.mod h1:0y9vanUI8NX6FsYoO3zeMjhV/C5i9g4Q3DwcSNZ4P60=
github.com/hashicorp/go-msgpack v0.5.3/go.mod h1:ahLV/dePpqEmjfWmKiqvPkv/twdG7iPBM1vqhUKIvfM=
-github.com/hashicorp/go-multierror v0.0.0-20161216184304-ed905158d874/go.mod h1:JMRHfdO9jKNzS/+BTlxCjKNQHg/jZAft8U7LloJvN7I=
github.com/hashicorp/go-multierror v1.0.0/go.mod h1:dHtQlpGsu+cZNNAkkCN/P3hoUDHhCYQXV3UM06sGGrk=
github.com/hashicorp/go-retryablehttp v0.5.3/go.mod h1:9B5zBasrRhHXnJnui7y6sL7es7NDiJgTc6Er0maI1Xs=
github.com/hashicorp/go-rootcerts v1.0.0/go.mod h1:K6zTfqpRlCUIjkwsN4Z+hiSfzSTQa6eBIzfwKfwNnHU=
@@ -931,25 +737,17 @@ github.com/ianlancetaylor/demangle v0.0.0-20181102032728-5e5cf60278f6/go.mod h1:
github.com/ianlancetaylor/demangle v0.0.0-20200824232613-28f6c0f3b639/go.mod h1:aSSvb/t6k1mPoxDqO4vJh6VOCGPwU4O0C2/Eqndh1Sc=
github.com/icza/dyno v0.0.0-20220812133438-f0b6f8a18845 h1:H+uM0Bv88eur3ZSsd2NGKg3YIiuXxwxtlN7HjE66UTU=
github.com/icza/dyno v0.0.0-20220812133438-f0b6f8a18845/go.mod h1:c1tRKs5Tx7E2+uHGSyyncziFjvGpgv4H2HrqXeUQ/Uk=
-github.com/imdario/mergo v0.3.5/go.mod h1:2EnlNZ0deacrJVfApfmtdGgDfMuh/nq6Ok1EcJh5FfA=
-github.com/imdario/mergo v0.3.8/go.mod h1:2EnlNZ0deacrJVfApfmtdGgDfMuh/nq6Ok1EcJh5FfA=
-github.com/imdario/mergo v0.3.10/go.mod h1:jmQim1M+e3UYxmgPu/WyfjB3N3VflVyUjjjwH0dnCYA=
-github.com/imdario/mergo v0.3.11/go.mod h1:jmQim1M+e3UYxmgPu/WyfjB3N3VflVyUjjjwH0dnCYA=
-github.com/imdario/mergo v0.3.12/go.mod h1:jmQim1M+e3UYxmgPu/WyfjB3N3VflVyUjjjwH0dnCYA=
github.com/improbable-eng/grpc-web v0.15.0 h1:BN+7z6uNXZ1tQGcNAuaU1YjsLTApzkjt2tzCixLaUPQ=
github.com/improbable-eng/grpc-web v0.15.0/go.mod h1:1sy9HKV4Jt9aEs9JSnkWlRJPuPtwNr0l57L4f878wP8=
github.com/inconshreveable/mousetrap v1.0.0/go.mod h1:PxqpIevigyE2G7u3NXJIT2ANytuPF1OarO4DADm73n8=
-github.com/inconshreveable/mousetrap v1.0.1/go.mod h1:vpF70FUmC8bwa3OWnCshd2FqLfsEA9PFc4w1p2J65bw=
github.com/inconshreveable/mousetrap v1.1.0 h1:wN+x4NVGpMsO7ErUn/mUI3vEoE6Jt13X2s0bqwp9tc8=
github.com/inconshreveable/mousetrap v1.1.0/go.mod h1:vpF70FUmC8bwa3OWnCshd2FqLfsEA9PFc4w1p2J65bw=
github.com/influxdata/influxdb1-client v0.0.0-20191209144304-8bf82d3c094d/go.mod h1:qj24IKcXYK6Iy9ceXlo3Tc+vtHo9lIhSX5JddghvEPo=
-github.com/ipfs/go-cid v0.0.7 h1:ysQJVJA3fNDF1qigJbsSQOdjhVLsOEoPdh0+R97k3jY=
-github.com/ipfs/go-cid v0.0.7/go.mod h1:6Ux9z5e+HpkQdckYoX1PG/6xqKspzlEIR5SDmgqgC/I=
-github.com/j-keck/arping v0.0.0-20160618110441-2cf9dc699c56/go.mod h1:ymszkNOg6tORTn+6F6j+Jc8TOr5osrynvN6ivFWZ2GA=
+github.com/ipfs/go-cid v0.2.0 h1:01JTiihFq9en9Vz0lc0VDWvZe/uBonGpzo4THP0vcQ0=
+github.com/ipfs/go-cid v0.2.0/go.mod h1:P+HXFDF4CVhaVayiEb4wkAy7zBHxBwsJyt0Y5U6MLro=
github.com/jessevdk/go-flags v0.0.0-20141203071132-1679536dcc89/go.mod h1:4FA24M0QyGHXBuZZK/XkWh8h0e1EYbRYJSGM75WSRxI=
-github.com/jhump/protoreflect v1.12.1-0.20220721211354-060cc04fc18b h1:izTof8BKh/nE1wrKOrloNA5q4odOarjf+Xpe+4qow98=
-github.com/jmespath/go-jmespath v0.0.0-20160202185014-0b12d6b521d8/go.mod h1:Nht3zPeWKUH0NzdCt2Blrr5ys8VGpn0CEB0cQHVjt7k=
-github.com/jmespath/go-jmespath v0.0.0-20160803190731-bd40a432e4c7/go.mod h1:Nht3zPeWKUH0NzdCt2Blrr5ys8VGpn0CEB0cQHVjt7k=
+github.com/jessevdk/go-flags v1.4.0/go.mod h1:4FA24M0QyGHXBuZZK/XkWh8h0e1EYbRYJSGM75WSRxI=
+github.com/jhump/protoreflect v1.15.1 h1:HUMERORf3I3ZdX05WaQ6MIpd/NJ434hTp5YiKgfCL6c=
github.com/jmespath/go-jmespath v0.0.0-20180206201540-c2b33e8439af/go.mod h1:Nht3zPeWKUH0NzdCt2Blrr5ys8VGpn0CEB0cQHVjt7k=
github.com/jmespath/go-jmespath v0.4.0 h1:BEgLn5cpjn8UN1mAw4NjwDrS35OdebyEtFe+9YPoQUg=
github.com/jmespath/go-jmespath v0.4.0/go.mod h1:T8mJZnbsbmF+m6zOOFylbeCJqk5+pHWvzYPziyZiYoo=
@@ -957,7 +755,6 @@ github.com/jmespath/go-jmespath/internal/testify v1.5.1 h1:shLQSRRSCCPj3f2gpwzGw
github.com/jmespath/go-jmespath/internal/testify v1.5.1/go.mod h1:L3OGu8Wl2/fWfCI6z80xFu9LTZmf1ZRjMHUOPmWr69U=
github.com/jmhodges/levigo v1.0.0 h1:q5EC36kV79HWeTBWsod3mG11EgStG3qArTKcvlksN1U=
github.com/jmhodges/levigo v1.0.0/go.mod h1:Q6Qx+uH3RAqyK4rFQroq9RL7mdkABMcfhEI+nNuzMJQ=
-github.com/joefitzgerald/rainbow-reporter v0.1.0/go.mod h1:481CNgqmVHQZzdIbN52CupLJyoVwB10FQ/IQlF1pdL8=
github.com/jonboulle/clockwork v0.1.0/go.mod h1:Ii8DK3G1RaLaWxj9trq07+26W01tbo22gdxWY5EU2bo=
github.com/jpillora/backoff v1.0.0/go.mod h1:J/6gKK9jxlEcS3zixgDgUAsiuZ7yrSoa/FX5e0EB2j4=
github.com/jrick/logrotate v1.0.0/go.mod h1:LNinyqDIJnpAur+b8yyulnQw/wDuN1+BYKlTRt3OuAQ=
@@ -967,7 +764,6 @@ github.com/json-iterator/go v1.1.8/go.mod h1:KdQUCv79m/52Kvf8AW2vK1V8akMuk1QjK/u
github.com/json-iterator/go v1.1.9/go.mod h1:KdQUCv79m/52Kvf8AW2vK1V8akMuk1QjK/uOdHXbAo4=
github.com/json-iterator/go v1.1.10/go.mod h1:KdQUCv79m/52Kvf8AW2vK1V8akMuk1QjK/uOdHXbAo4=
github.com/json-iterator/go v1.1.12 h1:PV8peI4a0ysnczrg+LtxykD8LfKY9ML6u2jnxaEnrnM=
-github.com/json-iterator/go v1.1.12/go.mod h1:e30LSqwooZae/UwlEbR2852Gd8hjQvJoHmT4TnhNGBo=
github.com/jstemmer/go-junit-report v0.0.0-20190106144839-af01ea7f8024/go.mod h1:6v2b51hI/fHJwM22ozAgKL4VKDeJcHhJFhtBdhmNjmU=
github.com/jstemmer/go-junit-report v0.9.1/go.mod h1:Brl9GWCQeLvo8nXZwPNNblvFj/XSXhF0NWZEnDohbsk=
github.com/jsternberg/zap-logfmt v1.3.0 h1:z1n1AOHVVydOOVuyphbOKyR4NICDQFiJMn1IK5hVQ5Y=
@@ -981,85 +777,77 @@ github.com/kisielk/errcheck v1.5.0/go.mod h1:pFxgyoBC7bSaBwPgfKdkLd5X25qrDl4LWUI
github.com/kisielk/gotool v1.0.0/go.mod h1:XhKaO+MFFWcvkIS/tQcRk01m1F5IRFswLeQ+oQHNcck=
github.com/kkdai/bstream v0.0.0-20161212061736-f391b8402d23/go.mod h1:J+Gs4SYgM6CZQHDETBtE9HaSEkGmuNXF86RwHhHUvq4=
github.com/klauspost/compress v1.10.3/go.mod h1:aoV0uJVorq1K+umq18yTdKaF57EivdYsUV+/s2qKfXs=
-github.com/klauspost/compress v1.11.3/go.mod h1:aoV0uJVorq1K+umq18yTdKaF57EivdYsUV+/s2qKfXs=
github.com/klauspost/compress v1.11.7/go.mod h1:aoV0uJVorq1K+umq18yTdKaF57EivdYsUV+/s2qKfXs=
-github.com/klauspost/compress v1.11.13/go.mod h1:aoV0uJVorq1K+umq18yTdKaF57EivdYsUV+/s2qKfXs=
github.com/klauspost/compress v1.12.3/go.mod h1:8dP1Hq4DHOhN9w426knH3Rhby4rFm6D8eO+e+Dq5Gzg=
github.com/klauspost/compress v1.15.11/go.mod h1:QPwzmACJjUTFsnSHH934V6woptycfrDDJnH7hvFVbGM=
-github.com/klauspost/compress v1.15.15 h1:EF27CXIuDsYJ6mmvtBRlEuB2UVOqHG1tAXgZ7yIO+lw=
-github.com/klauspost/compress v1.15.15/go.mod h1:ZcK2JAFqKOpnBlxcLsJzYfrS9X1akm9fHZNnD9+Vo/4=
+github.com/klauspost/compress v1.16.3 h1:XuJt9zzcnaz6a16/OU53ZjWp/v7/42WcR5t2a0PcNQY=
+github.com/klauspost/compress v1.16.3/go.mod h1:ntbaceVETuRiXiv4DpjP66DpAtAGkEQskQzEyD//IeE=
github.com/klauspost/cpuid/v2 v2.0.4/go.mod h1:FInQzS24/EEf25PyTYn52gqo7WaD8xa0213Md/qVLRg=
-github.com/klauspost/cpuid/v2 v2.0.9 h1:lgaqFMSdTdQYdZ04uHyN2d/eKdOMyi2YLSvlQIBFYa4=
github.com/klauspost/cpuid/v2 v2.0.9/go.mod h1:FInQzS24/EEf25PyTYn52gqo7WaD8xa0213Md/qVLRg=
+github.com/klauspost/cpuid/v2 v2.2.3 h1:sxCkb+qR91z4vsqw4vGGZlDgPz3G7gjaLyK3V8y70BU=
+github.com/klauspost/cpuid/v2 v2.2.3/go.mod h1:RVVoqg1df56z8g3pUjL/3lE5UfnlrJX8tyFgg4nqhuY=
github.com/konsorten/go-windows-terminal-sequences v1.0.1/go.mod h1:T0+1ngSBFLxvqU3pZ+m/2kptfBszLMUkC4ZK/EgS/cQ=
-github.com/konsorten/go-windows-terminal-sequences v1.0.2/go.mod h1:T0+1ngSBFLxvqU3pZ+m/2kptfBszLMUkC4ZK/EgS/cQ=
github.com/konsorten/go-windows-terminal-sequences v1.0.3/go.mod h1:T0+1ngSBFLxvqU3pZ+m/2kptfBszLMUkC4ZK/EgS/cQ=
github.com/kr/fs v0.1.0/go.mod h1:FFnZGqtBN9Gxj7eW1uZ42v5BccTP0vu6NEaFoC2HwRg=
github.com/kr/logfmt v0.0.0-20140226030751-b84e30acd515/go.mod h1:+0opPa2QZZtGFBFZlji/RkVcI2GknAs/DXo4wKdlNEc=
github.com/kr/pretty v0.1.0/go.mod h1:dAy3ld7l9f0ibDNOQOHHMYYIIbhfbHSm3C4ZsoJORNo=
-github.com/kr/pretty v0.2.0/go.mod h1:ipq/a2n7PKx3OHsz4KJII5eveXtPO4qwEXGdVfWzfnI=
github.com/kr/pretty v0.2.1/go.mod h1:ipq/a2n7PKx3OHsz4KJII5eveXtPO4qwEXGdVfWzfnI=
github.com/kr/pretty v0.3.1 h1:flRD4NNwYAUpkphVc1HcthR4KEIFJ65n8Mw5qdRn3LE=
+github.com/kr/pretty v0.3.1/go.mod h1:hoEshYVHaxMs3cyo3Yncou5ZscifuDolrwPKZanG3xk=
github.com/kr/pty v1.1.1/go.mod h1:pFQYn66WHrOpPYNljwOMqo10TkYh1fy3cYio2l3bCsQ=
-github.com/kr/pty v1.1.5/go.mod h1:9r2w37qlBe7rQ6e1fg1S/9xpWHSnaqNdHD3WcMdbPDA=
github.com/kr/text v0.1.0/go.mod h1:4Jbv+DJW3UT/LiOwJeYQe1efqtUx/iVham/4vfdArNI=
github.com/kr/text v0.2.0 h1:5Nx0Ya0ZqY2ygV366QzturHI13Jq95ApcVaJBhpS+AY=
github.com/kr/text v0.2.0/go.mod h1:eLer722TekiGuMkidMxC/pM04lWEeraHUUmBw8l2grE=
-github.com/leodido/go-urn v1.2.0 h1:hpXL4XnriNwQ/ABnpepYM/1vCLWNDfUNts8dX3xTG6Y=
github.com/leodido/go-urn v1.2.0/go.mod h1:+8+nEpDfqqsY+g338gtMEUOtuK+4dEMhiQEgxpxOKII=
+github.com/leodido/go-urn v1.2.1 h1:BqpAaACuzVSgi/VLzGZIobT2z4v53pjosyNd9Yv6n/w=
github.com/lib/pq v1.10.7 h1:p7ZhMD+KsSRozJr34udlUrhboJwWAgCg34+/ZZNvZZw=
github.com/lib/pq v1.10.7/go.mod h1:AlVN5x4E4T544tWzH6hKfbfQvm3HdbOxrmggDNAPY9o=
github.com/libp2p/go-buffer-pool v0.1.0 h1:oK4mSFcQz7cTQIfqbe4MIj9gLW+mnanjyFtc6cdF0Y8=
github.com/libp2p/go-buffer-pool v0.1.0/go.mod h1:N+vh8gMqimBzdKkSMVuydVDq+UV5QTWy5HSiZacSbPg=
-github.com/libp2p/go-libp2p-core v0.15.1 h1:0RY+Mi/ARK9DgG1g9xVQLb8dDaaU8tCePMtGALEfBnM=
-github.com/libp2p/go-libp2p-core v0.15.1/go.mod h1:agSaboYM4hzB1cWekgVReqV5M4g5M+2eNNejV+1EEhs=
-github.com/libp2p/go-openssl v0.0.7 h1:eCAzdLejcNVBzP/iZM9vqHnQm+XyCEbSSIheIPRGNsw=
-github.com/libp2p/go-openssl v0.0.7/go.mod h1:unDrJpgy3oFr+rqXsarWifmJuNnJR4chtO1HmaZjggc=
+github.com/libp2p/go-libp2p v0.22.0 h1:2Tce0kHOp5zASFKJbNzRElvh0iZwdtG5uZheNW8chIw=
+github.com/libp2p/go-libp2p v0.22.0/go.mod h1:UDolmweypBSjQb2f7xutPnwZ/fxioLbMBxSjRksxxU4=
+github.com/libp2p/go-openssl v0.1.0 h1:LBkKEcUv6vtZIQLVTegAil8jbNpJErQ9AnT+bWV+Ooo=
+github.com/libp2p/go-openssl v0.1.0/go.mod h1:OiOxwPpL3n4xlenjx2h7AwSGaFSC/KZvf6gNdOBQMtc=
github.com/lightstep/lightstep-tracer-common/golang/gogo v0.0.0-20190605223551-bc2310a04743/go.mod h1:qklhhLq1aX+mtWk9cPHPzaBjWImj5ULL6C7HFJtXQMM=
github.com/lightstep/lightstep-tracer-go v0.18.1/go.mod h1:jlF1pusYV4pidLvZ+XD0UBX0ZE6WURAspgAczcDHrL4=
-github.com/linuxkit/virtsock v0.0.0-20201010232012-f8cee7dfc7a3/go.mod h1:3r6x7q95whyfWQpmGZTu3gk3v2YkMi05HEzl7Tf7YEo=
+github.com/linxGnu/grocksdb v1.7.16 h1:Q2co1xrpdkr5Hx3Fp+f+f7fRGhQFQhvi/+226dtLmA8=
+github.com/linxGnu/grocksdb v1.7.16/go.mod h1:JkS7pl5qWpGpuVb3bPqTz8nC12X3YtPZT+Xq7+QfQo4=
github.com/lyft/protoc-gen-validate v0.0.13/go.mod h1:XbGvPuh87YZc5TdIa2/I4pLk0QoUACkjt2znoq26NVQ=
github.com/magiconair/properties v1.8.0/go.mod h1:PppfXfuXeibc/6YijjN8zIbojt8czPbwD3XqdrwzmxQ=
github.com/magiconair/properties v1.8.7 h1:IeQXZAiQcpL9mgcAe1Nu6cX9LLw6ExEHKjN0VQdvPDY=
github.com/magiconair/properties v1.8.7/go.mod h1:Dhd985XPs7jluiymwWYZ0G4Z61jb3vdS329zhj2hYo0=
-github.com/mailru/easyjson v0.0.0-20160728113105-d5b7844b561a/go.mod h1:C1wdFJiN94OJF2b5HbByQZoLdCWB1Yqtg26g4irojpc=
-github.com/mailru/easyjson v0.0.0-20190614124828-94de47d64c63/go.mod h1:C1wdFJiN94OJF2b5HbByQZoLdCWB1Yqtg26g4irojpc=
-github.com/mailru/easyjson v0.0.0-20190626092158-b2ccc519800e/go.mod h1:C1wdFJiN94OJF2b5HbByQZoLdCWB1Yqtg26g4irojpc=
-github.com/mailru/easyjson v0.7.0/go.mod h1:KAzv3t3aY1NaHWoQz1+4F1ccyAH66Jk7yos7ldAVICs=
github.com/manifoldco/promptui v0.9.0 h1:3V4HzJk1TtXW1MTZMP7mdlwbBpIinw3HztaIlYthEiA=
github.com/manifoldco/promptui v0.9.0/go.mod h1:ka04sppxSGFAtxX0qhlYQjISsg9mR4GWtQEhdbn6Pgg=
-github.com/marstr/guid v1.1.0/go.mod h1:74gB1z2wpxxInTG6yaqA7KrtM0NZ+RbrcqDvYHefzho=
github.com/mattn/go-colorable v0.0.9/go.mod h1:9vuHe8Xs5qXnSaW/c/ABM9alt+Vo+STaOChaDxuIBZU=
+github.com/mattn/go-colorable v0.1.12/go.mod h1:u5H1YNBxpqRaxsYJYSkiCWKzEfiAb1Gb520KVy5xxl4=
+github.com/mattn/go-colorable v0.1.13 h1:fFA4WZxdEF4tXPZVKMLwD8oUnCTTo08duU7wxecdEvA=
+github.com/mattn/go-colorable v0.1.13/go.mod h1:7S9/ev0klgBDR4GtXTXX8a3vIGJpMovkB8vQcUbaXHg=
github.com/mattn/go-isatty v0.0.3/go.mod h1:M+lRXTBqGeGNdLjl/ufCoiOlB5xdOkqRJdNxMWT7Zi4=
github.com/mattn/go-isatty v0.0.4/go.mod h1:M+lRXTBqGeGNdLjl/ufCoiOlB5xdOkqRJdNxMWT7Zi4=
github.com/mattn/go-isatty v0.0.12/go.mod h1:cbi8OIDigv2wuxKPP5vlRcQ1OAZbq2CE4Kysco4FUpU=
-github.com/mattn/go-isatty v0.0.17 h1:BTarxUcIeDqL27Mc+vyvdWYSL28zpIhv3RoTdsLMPng=
-github.com/mattn/go-isatty v0.0.17/go.mod h1:kYGgaQfpe5nmfYZH+SKPsOc2e4SrIfOl2e/yFXSvRLM=
+github.com/mattn/go-isatty v0.0.14/go.mod h1:7GGIvUiUoEMVVmxf/4nioHXj79iQHKdU27kJ6hsGG94=
+github.com/mattn/go-isatty v0.0.16/go.mod h1:kYGgaQfpe5nmfYZH+SKPsOc2e4SrIfOl2e/yFXSvRLM=
+github.com/mattn/go-isatty v0.0.19 h1:JITubQf0MOLdlGRuRq+jtsDlekdYPia9ZFsB8h/APPA=
+github.com/mattn/go-isatty v0.0.19/go.mod h1:W+V8PltTTMOvKvAeJH7IuucS94S2C6jfK/D7dTCTo3Y=
+github.com/mattn/go-pointer v0.0.1 h1:n+XhsuGeVO6MEAp7xyEukFINEa+Quek5psIR/ylA6o0=
+github.com/mattn/go-pointer v0.0.1/go.mod h1:2zXcozF6qYGgmsG+SeTZz3oAbFLdD3OWqnUbNvJZAlc=
github.com/mattn/go-runewidth v0.0.2/go.mod h1:LwmH8dsx7+W8Uxz3IHJYH5QSwggIsqBzpuz5H//U1FU=
github.com/mattn/go-runewidth v0.0.4/go.mod h1:LwmH8dsx7+W8Uxz3IHJYH5QSwggIsqBzpuz5H//U1FU=
-github.com/mattn/go-runewidth v0.0.13 h1:lTGmDsbAYt5DmK6OnoV7EuIF1wEIFAcxld6ypU4OSgU=
-github.com/mattn/go-shellwords v1.0.3/go.mod h1:3xCvwCdWdlDJUrvuMn7Wuy9eWs4pE8vqg+NOMyg4B2o=
-github.com/mattn/go-shellwords v1.0.6/go.mod h1:3xCvwCdWdlDJUrvuMn7Wuy9eWs4pE8vqg+NOMyg4B2o=
-github.com/mattn/go-sqlite3 v1.14.12 h1:TJ1bhYJPV44phC+IMu1u2K/i5RriLTPe+yc68XDJ1Z0=
-github.com/mattn/go-sqlite3 v1.14.12/go.mod h1:NyWgC/yNuGj7Q9rpYnZvas74GogHl5/Z4A/KQRfk6bU=
+github.com/mattn/go-runewidth v0.0.14 h1:+xnbZSEeDbOIg5/mE6JF0w6n9duR1l3/WmbinWVwUuU=
+github.com/mattn/go-sqlite3 v1.14.16 h1:yOQRA0RpS5PFz/oikGwBEqvAWhWg5ufRz4ETLjwpU1Y=
github.com/matttproud/golang_protobuf_extensions v1.0.1/go.mod h1:D8He9yQNgCq6Z5Ld7szi9bcBfOoFv/3dc6xSMkL2PC0=
-github.com/matttproud/golang_protobuf_extensions v1.0.2-0.20181231171920-c182affec369/go.mod h1:BSXmuO+STAnVfrANrmjBb36TMTDstsz7MSK+HVaYKv4=
github.com/matttproud/golang_protobuf_extensions v1.0.4 h1:mmDVorXM7PCGKw94cs5zkfA9PSy5pEvNWRP0ET0TIVo=
github.com/matttproud/golang_protobuf_extensions v1.0.4/go.mod h1:BSXmuO+STAnVfrANrmjBb36TMTDstsz7MSK+HVaYKv4=
-github.com/maxbrunsfeld/counterfeiter/v6 v6.2.2/go.mod h1:eD9eIE7cdwcMi9rYluz88Jz2VyhSmden33/aXg4oVIY=
github.com/miekg/dns v1.0.14/go.mod h1:W1PPwlIAgtquWBMBEV9nkV9Cazfe8ScdGz/Lj7v3Nrg=
-github.com/miekg/pkcs11 v1.0.3/go.mod h1:XsNlhZGX73bx86s2hdc/FuaLm2CPZJemRLMA+WTFxgs=
github.com/mimoo/StrobeGo v0.0.0-20181016162300-f8f6d4d2b643/go.mod h1:43+3pMjjKimDBf5Kr4ZFNGbLql1zKkbImw+fZbw3geM=
github.com/mimoo/StrobeGo v0.0.0-20220103164710-9a04d6ca976b h1:QrHweqAtyJ9EwCaGHBu1fghwxIPiopAHV06JlXrMHjk=
github.com/mimoo/StrobeGo v0.0.0-20220103164710-9a04d6ca976b/go.mod h1:xxLb2ip6sSUts3g1irPVHyk/DGslwQsNOo9I7smJfNU=
-github.com/minio/blake2b-simd v0.0.0-20160723061019-3f5f724cb5b1 h1:lYpkrQH5ajf0OXOcUbGjvZxxijuBwbbmlSxLiuofa+g=
-github.com/minio/blake2b-simd v0.0.0-20160723061019-3f5f724cb5b1/go.mod h1:pD8RvIylQ358TN4wwqatJ8rNavkEINozVn9DtGI3dfQ=
github.com/minio/highwayhash v1.0.2 h1:Aak5U0nElisjDCfPSG79Tgzkn2gl66NxOMspRrKnA/g=
github.com/minio/highwayhash v1.0.2/go.mod h1:BQskDq+xkJ12lmlUUi7U0M5Swg3EWR+dLTk+kldvVxY=
-github.com/minio/sha256-simd v0.1.1-0.20190913151208-6de447530771/go.mod h1:B5e1o+1/KgNmWrSQK08Y6Z1Vb5pwIktudl0J58iy0KM=
github.com/minio/sha256-simd v1.0.0 h1:v1ta+49hkWZyvaKwrQB8elexRqm6Y0aMLjCNsrYxo6g=
github.com/minio/sha256-simd v1.0.0/go.mod h1:OuYzVNI5vcoYIAmbIvHPl3N3jUzVedXbKy5RFepssQM=
-github.com/mistifyio/go-zfs v2.1.2-0.20190413222219-f784269be439+incompatible/go.mod h1:8AuVvqP/mXw1px98n46wfvcGfQ4ci2FwoAjKYxuo3Z4=
+github.com/misko9/go-substrate-rpc-client/v4 v4.0.0-20230413215336-5bd2aea337ae h1:ZYbJh4TLwfSuSQe6DT/1982SfNNBcmvzrX5FycfSrmo=
+github.com/misko9/go-substrate-rpc-client/v4 v4.0.0-20230413215336-5bd2aea337ae/go.mod h1:XexEkZgpnQ3sqUYz84DFoVUcDake6G/tYHrwdbdERhM=
github.com/mitchellh/cli v1.0.0/go.mod h1:hNIlj7HEI86fIcpObd7a0FcrxTWetlwJDGcceTlRvqc=
github.com/mitchellh/go-homedir v1.0.0/go.mod h1:SfyaCUpYCn1Vlf4IUYiD9fPX4A5wJrkLzIz1N1q0pr0=
github.com/mitchellh/go-homedir v1.1.0 h1:lukF9ziXFxDFPkA1vsr5zpc1XuPDn/wFntq5mG+4E0Y=
@@ -1073,19 +861,13 @@ github.com/mitchellh/mapstructure v0.0.0-20160808181253-ca63d7c062ee/go.mod h1:F
github.com/mitchellh/mapstructure v1.1.2/go.mod h1:FVVH3fgwuzCH5S8UJGiWEs2h04kUh9fWfEaFds41c1Y=
github.com/mitchellh/mapstructure v1.5.0 h1:jeMsZIYE/09sWLaz43PL7Gy6RuMjD2eJVyuac5Z2hdY=
github.com/mitchellh/mapstructure v1.5.0/go.mod h1:bFUtVrKA4DC2yAKiSyO/QUcy7e+RRV2QTWOzhPopBRo=
-github.com/mitchellh/osext v0.0.0-20151018003038-5e2d6d41470f/go.mod h1:OkQIRizQZAeMln+1tSwduZz7+Af5oFlKirV/MSYes2A=
-github.com/moby/locker v1.0.1/go.mod h1:S7SDdo5zpBK84bzzVlKr2V0hz+7x9hWbYC/kq7oQppc=
-github.com/moby/moby v20.10.22+incompatible h1:KHnFMlxjgGizH7+3fQj8+PjmrwEnilKgahf/TgTQIxI=
-github.com/moby/moby v20.10.22+incompatible/go.mod h1:fDXVQ6+S340veQPv35CzDahGBmHsiclFwfEygB/TWMc=
-github.com/moby/sys/mount v0.3.3 h1:fX1SVkXFJ47XWDoeFW4Sq7PdQJnV2QIDZAqjNqgEjUs=
-github.com/moby/sys/mount v0.3.3/go.mod h1:PBaEorSNTLG5t/+4EgukEQVlAvVEc6ZjTySwKdqp5K0=
-github.com/moby/sys/mountinfo v0.4.0/go.mod h1:rEr8tzG/lsIZHBtN/JjGG+LMYx9eXgW2JI+6q0qou+A=
-github.com/moby/sys/mountinfo v0.4.1/go.mod h1:rEr8tzG/lsIZHBtN/JjGG+LMYx9eXgW2JI+6q0qou+A=
+github.com/moby/moby v24.0.2+incompatible h1:yH+5dRHH1x3XRKzl1THA2aGTy6CHYnkt5N924ADMax8=
+github.com/moby/moby v24.0.2+incompatible/go.mod h1:fDXVQ6+S340veQPv35CzDahGBmHsiclFwfEygB/TWMc=
+github.com/moby/patternmatcher v0.5.0 h1:YCZgJOeULcxLw1Q+sVR636pmS7sPEn1Qo2iAN6M7DBo=
+github.com/moby/patternmatcher v0.5.0/go.mod h1:hDPoyOpDY7OrrMDLaYoY3hf52gNCR/YOUYxkhApJIxc=
github.com/moby/sys/mountinfo v0.5.0/go.mod h1:3bMD3Rg+zkqx8MRYPi7Pyb0Ie97QEBmdxbhnCLlSvSU=
-github.com/moby/sys/mountinfo v0.6.2 h1:BzJjoreD5BMFNmD9Rus6gdd1pLuecOFPt8wC+Vygl78=
-github.com/moby/sys/mountinfo v0.6.2/go.mod h1:IJb6JQeOklcdMU9F5xQ8ZALD+CUr5VlGpwtX+VE0rpI=
-github.com/moby/sys/symlink v0.1.0/go.mod h1:GGDODQmbFOjFsXvfLVn3+ZRxkch54RkSiGqsZeMYowQ=
-github.com/moby/term v0.0.0-20200312100748-672ec06f55cd/go.mod h1:DdlQx2hp0Ss5/fLikoLlEeIYiATotOjgB//nb973jeo=
+github.com/moby/sys/sequential v0.5.0 h1:OPvI35Lzn9K04PBbCLW0g4LcFAJgHsvXsRyewg5lXtc=
+github.com/moby/sys/sequential v0.5.0/go.mod h1:tH2cOOs5V9MlPiXcQzRC+eEyab644PWKGRYaaV5ZZlo=
github.com/moby/term v0.0.0-20220808134915-39b0c02b01ae h1:O4SWKdcHVCvYqyDV+9CJA1fcDN2L11Bule0iFy3YlAI=
github.com/modern-go/concurrent v0.0.0-20180228061459-e0a39a4cb421/go.mod h1:6dJC0mAP4ikYIbvyc7fijjWJddQyLn8Ig3JB5CqoB9Q=
github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd h1:TRLaZ9cD/w8PVh93nsPXa1VrQ6jlwL5oN8l14QlcNfg=
@@ -1093,40 +875,30 @@ github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd/go.mod h1:6dJ
github.com/modern-go/reflect2 v0.0.0-20180701023420-4b7aa43c6742/go.mod h1:bx2lNnkwVCuqBIxFjflWJWanXIb3RllmbCylyMrvgv0=
github.com/modern-go/reflect2 v1.0.1/go.mod h1:bx2lNnkwVCuqBIxFjflWJWanXIb3RllmbCylyMrvgv0=
github.com/modern-go/reflect2 v1.0.2 h1:xBagoLtFs94CBntxluKeaWgTMpvLxC4ur3nMaC9Gz0M=
-github.com/modern-go/reflect2 v1.0.2/go.mod h1:yWuevngMOJpCy52FWWMvUC8ws7m/LJsjYzDa0/r8luk=
github.com/morikuni/aec v1.0.0 h1:nP9CBfwrvYnBRgY6qfDQkygYDmYwOilePFkwzv4dU8A=
-github.com/morikuni/aec v1.0.0/go.mod h1:BbKIizmSmc5MMPqRYbxO4ZU0S0+P200+tUnFx7PXmsc=
-github.com/mr-tron/base58 v1.1.0/go.mod h1:xcD2VGqlgYjBdcBLw+TuYLr8afG+Hj8g2eTVqeSzSU8=
-github.com/mr-tron/base58 v1.1.3/go.mod h1:BinMc/sQntlIE1frQmRFPUoPA1Zkr8VRgBdjWI2mNwc=
github.com/mr-tron/base58 v1.2.0 h1:T/HDJBh4ZCPbU39/+c3rRvE0uKBQlU27+QI8LJ4t64o=
github.com/mr-tron/base58 v1.2.0/go.mod h1:BinMc/sQntlIE1frQmRFPUoPA1Zkr8VRgBdjWI2mNwc=
github.com/mrunalp/fileutils v0.5.0/go.mod h1:M1WthSahJixYnrXQl/DFQuteStB1weuxD2QJNHXfbSQ=
github.com/mtibben/percent v0.2.1 h1:5gssi8Nqo8QU/r2pynCm+hBQHpkB/uNK7BJCFogWdzs=
github.com/mtibben/percent v0.2.1/go.mod h1:KG9uO+SZkUp+VkRHsCdYQV3XSZrrSpR3O9ibNBTZrns=
-github.com/multiformats/go-base32 v0.0.3 h1:tw5+NhuwaOjJCC5Pp82QuXbrmLzWg7uxlMFp8Nq/kkI=
-github.com/multiformats/go-base32 v0.0.3/go.mod h1:pLiuGC8y0QR3Ue4Zug5UzK9LjgbkL8NSQj0zQ5Nz/AA=
+github.com/multiformats/go-base32 v0.0.4 h1:+qMh4a2f37b4xTNs6mqitDinryCI+tfO2dRVMN9mjSE=
+github.com/multiformats/go-base32 v0.0.4/go.mod h1:jNLFzjPZtp3aIARHbJRZIaPuspdH0J6q39uUM5pnABM=
github.com/multiformats/go-base36 v0.1.0 h1:JR6TyF7JjGd3m6FbLU2cOxhC0Li8z8dLNGQ89tUg4F4=
github.com/multiformats/go-base36 v0.1.0/go.mod h1:kFGE83c6s80PklsHO9sRn2NCoffoRdUUOENyW/Vv6sM=
-github.com/multiformats/go-multiaddr v0.4.1 h1:Pq37uLx3hsyNlTDir7FZyU8+cFCTqd5y1KiM2IzOutI=
-github.com/multiformats/go-multiaddr v0.4.1/go.mod h1:3afI9HfVW8csiF8UZqtpYRiDyew8pRX7qLIGHu9FLuM=
-github.com/multiformats/go-multibase v0.0.3 h1:l/B6bJDQjvQ5G52jw4QGSYeOTZoAwIO77RblWplfIqk=
-github.com/multiformats/go-multibase v0.0.3/go.mod h1:5+1R4eQrT3PkYZ24C3W2Ue2tPwIdYQD509ZjSb5y9Oc=
-github.com/multiformats/go-multicodec v0.4.1 h1:BSJbf+zpghcZMZrwTYBGwy0CPcVZGWiC72Cp8bBd4R4=
-github.com/multiformats/go-multicodec v0.4.1/go.mod h1:1Hj/eHRaVWSXiSNNfcEPcwZleTmdNP81xlxDLnWU9GQ=
-github.com/multiformats/go-multihash v0.0.13/go.mod h1:VdAWLKTwram9oKAatUcLxBNUjdtcVwxObEQBtRfuyjc=
-github.com/multiformats/go-multihash v0.0.14/go.mod h1:VdAWLKTwram9oKAatUcLxBNUjdtcVwxObEQBtRfuyjc=
-github.com/multiformats/go-multihash v0.1.0 h1:CgAgwqk3//SVEw3T+6DqI4mWMyRuDwZtOWcJT0q9+EA=
-github.com/multiformats/go-multihash v0.1.0/go.mod h1:RJlXsxt6vHGaia+S8We0ErjhojtKzPP2AH4+kYM7k84=
-github.com/multiformats/go-varint v0.0.5/go.mod h1:3Ls8CIEsrijN6+B7PbrXRPxHRPuXSrVKRY101jdMZYE=
+github.com/multiformats/go-multiaddr v0.6.0 h1:qMnoOPj2s8xxPU5kZ57Cqdr0hHhARz7mFsPMIiYNqzg=
+github.com/multiformats/go-multiaddr v0.6.0/go.mod h1:F4IpaKZuPP360tOMn2Tpyu0At8w23aRyVqeK0DbFeGM=
+github.com/multiformats/go-multibase v0.1.1 h1:3ASCDsuLX8+j4kx58qnJ4YFq/JWTJpCyDW27ztsVTOI=
+github.com/multiformats/go-multibase v0.1.1/go.mod h1:ZEjHE+IsUrgp5mhlEAYjMtZwK1k4haNkcaPg9aoe1a8=
+github.com/multiformats/go-multicodec v0.5.0 h1:EgU6cBe/D7WRwQb1KmnBvU7lrcFGMggZVTPtOW9dDHs=
+github.com/multiformats/go-multicodec v0.5.0/go.mod h1:DiY2HFaEp5EhEXb/iYzVAunmyX/aSFMxq2KMKfWEues=
+github.com/multiformats/go-multihash v0.2.1 h1:aem8ZT0VA2nCHHk7bPJ1BjUbHNciqZC/d16Vve9l108=
+github.com/multiformats/go-multihash v0.2.1/go.mod h1:WxoMcYG85AZVQUyRyo9s4wULvW5qrI9vb2Lt6evduFc=
github.com/multiformats/go-varint v0.0.6 h1:gk85QWKxh3TazbLxED/NlDVv8+q+ReFJk7Y2W/KhfNY=
github.com/multiformats/go-varint v0.0.6/go.mod h1:3Ls8CIEsrijN6+B7PbrXRPxHRPuXSrVKRY101jdMZYE=
-github.com/munnerz/goautoneg v0.0.0-20120707110453-a547fc61f48d/go.mod h1:+n7T8mK8HuQTcFwEeznm/DIxMOiR9yIdICNftLE1DvQ=
-github.com/munnerz/goautoneg v0.0.0-20191010083416-a7dc8b61c822/go.mod h1:+n7T8mK8HuQTcFwEeznm/DIxMOiR9yIdICNftLE1DvQ=
github.com/mwitkow/go-conntrack v0.0.0-20161129095857-cc309e4a2223/go.mod h1:qRWi+5nqEBWmkhHvq77mSJWrCKwh8bxhgT7d/eI7P4U=
github.com/mwitkow/go-conntrack v0.0.0-20190716064945-2f068394615f h1:KUppIJq7/+SVif2QVs3tOP0zanoHgBEVAwHxUSIzRqU=
github.com/mwitkow/go-conntrack v0.0.0-20190716064945-2f068394615f/go.mod h1:qRWi+5nqEBWmkhHvq77mSJWrCKwh8bxhgT7d/eI7P4U=
github.com/mwitkow/grpc-proxy v0.0.0-20181017164139-0f1106ef9c76/go.mod h1:x5OoJHDHqxHS801UIuhqGl6QdSAEJvtausosHSdazIo=
-github.com/mxk/go-flowrate v0.0.0-20140419014527-cca7078d478f/go.mod h1:ZdcZmHo+o7JKHSa8/e818NopupXU1YMK5fe1lsApnBw=
github.com/nats-io/jwt v0.3.0/go.mod h1:fRYCDE99xlTsqUzISS1Bi75UBJ6ljOJQOAAu5VglpSg=
github.com/nats-io/jwt v0.3.2/go.mod h1:/euKqTS1ZD+zzjYrY7pseZrTtWQSjujC7xjPc8wL6eU=
github.com/nats-io/nats-server/v2 v2.1.2/go.mod h1:Afk+wRZqkMQs/p45uXdrVLuab3gwv3Z8C4HTBu8GD/k=
@@ -1134,71 +906,37 @@ github.com/nats-io/nats.go v1.9.1/go.mod h1:ZjDU1L/7fJ09jvUSRVBR2e7+RnLiiIQyqyzE
github.com/nats-io/nkeys v0.1.0/go.mod h1:xpnFELMwJABBLVhffcfd1MZx6VsNRFpEugbxziKVo7w=
github.com/nats-io/nkeys v0.1.3/go.mod h1:xpnFELMwJABBLVhffcfd1MZx6VsNRFpEugbxziKVo7w=
github.com/nats-io/nuid v1.0.1/go.mod h1:19wcPz3Ph3q0Jbyiqsd0kePYG7A95tJPxeL+1OSON2c=
-github.com/ncw/swift v1.0.47/go.mod h1:23YIA4yWVnGwv2dQlN4bB7egfYX6YLn0Yo/S6zZO/ZM=
github.com/niemeyer/pretty v0.0.0-20200227124842-a10e7caefd8e/go.mod h1:zD1mROLANZcx1PVRCS0qkT7pwLkGfwJo4zjcN/Tysno=
github.com/nxadm/tail v1.4.4/go.mod h1:kenIhsEOeOJmVchQTgglprH7qJGnHDVpk1VPCcaMI8A=
github.com/nxadm/tail v1.4.8 h1:nPr65rt6Y5JFSKQO7qToXr7pePgD6Gwiw05lkbyAQTE=
github.com/nxadm/tail v1.4.8/go.mod h1:+ncqLTQzXmGhMZNUePPaPqPvBxHAIsmXswZKocGu+AU=
github.com/oklog/oklog v0.3.2/go.mod h1:FCV+B7mhrz4o+ueLpx+KqkyXRGMWOYEvfiXtdGtbWGs=
github.com/oklog/run v1.0.0/go.mod h1:dlhp/R75TPv97u0XWUtDeV/lRKWPKSdTuV0TZvrmrQA=
-github.com/oklog/ulid v1.3.1/go.mod h1:CirwcVhetQ6Lv90oh/F+FBtV6XMibvdAFo93nm5qn4U=
github.com/olekukonko/tablewriter v0.0.0-20170122224234-a0225b3f23b5/go.mod h1:vsDQFd/mU46D+Z4whnwzcISnGGzXWMclvtLoiIKAKIo=
github.com/olekukonko/tablewriter v0.0.5 h1:P2Ga83D34wi1o9J6Wh1mRuqd4mF/x/lgBS7N7AbDhec=
-github.com/onsi/ginkgo v0.0.0-20151202141238-7f8ab55aaf3b/go.mod h1:lLunBs/Ym6LB5Z9jYTR76FiuTmxDTDusOGeTQH+WWjE=
-github.com/onsi/ginkgo v0.0.0-20170829012221-11459a886d9c/go.mod h1:lLunBs/Ym6LB5Z9jYTR76FiuTmxDTDusOGeTQH+WWjE=
github.com/onsi/ginkgo v1.6.0/go.mod h1:lLunBs/Ym6LB5Z9jYTR76FiuTmxDTDusOGeTQH+WWjE=
github.com/onsi/ginkgo v1.7.0/go.mod h1:lLunBs/Ym6LB5Z9jYTR76FiuTmxDTDusOGeTQH+WWjE=
-github.com/onsi/ginkgo v1.8.0/go.mod h1:lLunBs/Ym6LB5Z9jYTR76FiuTmxDTDusOGeTQH+WWjE=
-github.com/onsi/ginkgo v1.10.1/go.mod h1:lLunBs/Ym6LB5Z9jYTR76FiuTmxDTDusOGeTQH+WWjE=
-github.com/onsi/ginkgo v1.10.3/go.mod h1:lLunBs/Ym6LB5Z9jYTR76FiuTmxDTDusOGeTQH+WWjE=
-github.com/onsi/ginkgo v1.11.0/go.mod h1:lLunBs/Ym6LB5Z9jYTR76FiuTmxDTDusOGeTQH+WWjE=
-github.com/onsi/ginkgo v1.12.0/go.mod h1:oUhWkIvk5aDxtKvDDuw8gItl8pKl42LzjC9KZE0HfGg=
github.com/onsi/ginkgo v1.12.1/go.mod h1:zj2OWP4+oCPe1qIXoGWkgMRwljMUYCdkwsT2108oapk=
+github.com/onsi/ginkgo v1.14.0/go.mod h1:iSB4RoI2tjJc9BBv4NKIKWKya62Rps+oPG/Lv9klQyY=
github.com/onsi/ginkgo v1.16.4/go.mod h1:dX+/inL/fNMqNlz0e9LfyB9TswhZpCVdJM/Z6Vvnwo0=
github.com/onsi/ginkgo v1.16.5 h1:8xi0RTUf59SOSfEtZMvwTvXYMzG4gV23XVHOZiXNtnE=
github.com/onsi/ginkgo v1.16.5/go.mod h1:+E8gABHa3K6zRBolWtd+ROzc/U5bkGt0FwiG042wbpU=
github.com/onsi/ginkgo/v2 v2.1.3/go.mod h1:vw5CSIxN1JObi/U8gcbwft7ZxR2dgaR70JSE3/PpL4c=
-github.com/onsi/gomega v0.0.0-20151007035656-2152b45fa28a/go.mod h1:C1qb7wdrVGGVU+Z6iS04AVkA3Q65CEZX59MT0QO5uiA=
-github.com/onsi/gomega v0.0.0-20170829124025-dcabb60a477c/go.mod h1:C1qb7wdrVGGVU+Z6iS04AVkA3Q65CEZX59MT0QO5uiA=
+github.com/onsi/gomega v1.4.1/go.mod h1:C1qb7wdrVGGVU+Z6iS04AVkA3Q65CEZX59MT0QO5uiA=
github.com/onsi/gomega v1.4.3/go.mod h1:ex+gbHU/CVuBBDIJjb2X0qEXbFg53c61hWP/1CpauHY=
-github.com/onsi/gomega v1.5.0/go.mod h1:ex+gbHU/CVuBBDIJjb2X0qEXbFg53c61hWP/1CpauHY=
-github.com/onsi/gomega v1.7.0/go.mod h1:ex+gbHU/CVuBBDIJjb2X0qEXbFg53c61hWP/1CpauHY=
github.com/onsi/gomega v1.7.1/go.mod h1:XdKZgCCFLUoM/7CFJVPcG8C1xQ1AJ0vpAezJrB7JYyY=
-github.com/onsi/gomega v1.9.0/go.mod h1:Ho0h+IUsWyvy1OpqCwxlQ/21gkhVunqlU8fDGcoTdcA=
github.com/onsi/gomega v1.10.1/go.mod h1:iN09h71vgCQne3DLsj+A5owkum+a2tYe+TOCB1ybHNo=
-github.com/onsi/gomega v1.10.3/go.mod h1:V9xEwhxec5O8UDM77eCW8vLymOMltsqPVYWrpDsH8xc=
github.com/onsi/gomega v1.17.0/go.mod h1:HnhC7FXeEQY45zxNK3PPoIUhzk/80Xly9PcubAlGdZY=
github.com/onsi/gomega v1.19.0/go.mod h1:LY+I3pBVzYsTBU1AnDwOSxaYi9WoWiqgwooUqq9yPro=
github.com/onsi/gomega v1.20.0 h1:8W0cWlwFkflGPLltQvLRB7ZVD5HuP6ng320w2IS245Q=
github.com/op/go-logging v0.0.0-20160315200505-970db520ece7/go.mod h1:HzydrMdWErDVzsI23lYNej1Htcns9BCg93Dk0bBINWk=
-github.com/opencontainers/go-digest v0.0.0-20170106003457-a6d0ee40d420/go.mod h1:cMLVZDEM3+U2I4VmLI6N8jQYUd2OVphdqWwCJHrFt2s=
-github.com/opencontainers/go-digest v0.0.0-20180430190053-c9281466c8b2/go.mod h1:cMLVZDEM3+U2I4VmLI6N8jQYUd2OVphdqWwCJHrFt2s=
-github.com/opencontainers/go-digest v1.0.0-rc1/go.mod h1:cMLVZDEM3+U2I4VmLI6N8jQYUd2OVphdqWwCJHrFt2s=
-github.com/opencontainers/go-digest v1.0.0-rc1.0.20180430190053-c9281466c8b2/go.mod h1:cMLVZDEM3+U2I4VmLI6N8jQYUd2OVphdqWwCJHrFt2s=
github.com/opencontainers/go-digest v1.0.0 h1:apOUWs51W5PlhuyGyz9FCeeBIOUDA/6nW8Oi/yOhh5U=
github.com/opencontainers/go-digest v1.0.0/go.mod h1:0JzlMkj0TRzQZfJkVvzbP0HBR3IKzErnv2BNG4W4MAM=
-github.com/opencontainers/image-spec v1.0.0/go.mod h1:BtxoFyWECRxE4U/7sNtV5W15zMzWCbyJoFRP3s7yZA0=
-github.com/opencontainers/image-spec v1.0.1/go.mod h1:BtxoFyWECRxE4U/7sNtV5W15zMzWCbyJoFRP3s7yZA0=
github.com/opencontainers/image-spec v1.1.0-rc2 h1:2zx/Stx4Wc5pIPDvIxHXvXtQFW/7XWJGmnM7r3wg034=
github.com/opencontainers/image-spec v1.1.0-rc2/go.mod h1:3OVijpioIKYWTqjiG0zfF6wvoJ4fAXGbjdZuI2NgsRQ=
-github.com/opencontainers/runc v0.0.0-20190115041553-12f6a991201f/go.mod h1:qT5XzbpPznkRYVz/mWwUaVBUv2rmF59PVA73FjuZG0U=
-github.com/opencontainers/runc v0.1.1/go.mod h1:qT5XzbpPznkRYVz/mWwUaVBUv2rmF59PVA73FjuZG0U=
-github.com/opencontainers/runc v1.0.0-rc8.0.20190926000215-3e425f80a8c9/go.mod h1:qT5XzbpPznkRYVz/mWwUaVBUv2rmF59PVA73FjuZG0U=
-github.com/opencontainers/runc v1.0.0-rc9/go.mod h1:qT5XzbpPznkRYVz/mWwUaVBUv2rmF59PVA73FjuZG0U=
-github.com/opencontainers/runc v1.0.0-rc93/go.mod h1:3NOsor4w32B2tC0Zbl8Knk4Wg84SM2ImC1fxBuqJ/H0=
-github.com/opencontainers/runc v1.0.2/go.mod h1:aTaHFFwQXuA71CiyxOdFFIorAoemI04suvGRQFzWTD0=
github.com/opencontainers/runc v1.1.3 h1:vIXrkId+0/J2Ymu2m7VjGvbSlAId9XNRPhn2p4b+d8w=
github.com/opencontainers/runc v1.1.3/go.mod h1:1J5XiS+vdZ3wCyZybsuxXZWGrgSr8fFJHLXuG2PsnNg=
-github.com/opencontainers/runtime-spec v0.1.2-0.20190507144316-5b71a03e2700/go.mod h1:jwyrGlmzljRJv/Fgzds9SsS/C5hL+LL3ko9hs6T5lQ0=
-github.com/opencontainers/runtime-spec v1.0.1/go.mod h1:jwyrGlmzljRJv/Fgzds9SsS/C5hL+LL3ko9hs6T5lQ0=
-github.com/opencontainers/runtime-spec v1.0.2-0.20190207185410-29686dbc5559/go.mod h1:jwyrGlmzljRJv/Fgzds9SsS/C5hL+LL3ko9hs6T5lQ0=
-github.com/opencontainers/runtime-spec v1.0.2/go.mod h1:jwyrGlmzljRJv/Fgzds9SsS/C5hL+LL3ko9hs6T5lQ0=
-github.com/opencontainers/runtime-spec v1.0.3-0.20200929063507-e6143ca7d51d/go.mod h1:jwyrGlmzljRJv/Fgzds9SsS/C5hL+LL3ko9hs6T5lQ0=
github.com/opencontainers/runtime-spec v1.0.3-0.20210326190908-1c3f411f0417/go.mod h1:jwyrGlmzljRJv/Fgzds9SsS/C5hL+LL3ko9hs6T5lQ0=
-github.com/opencontainers/runtime-tools v0.0.0-20181011054405-1d69bd0f9c39/go.mod h1:r3f7wjNzSs2extwzU3Y+6pKfobzPh+kKFJ3ofN+3nfs=
-github.com/opencontainers/selinux v1.6.0/go.mod h1:VVGKuOLlE7v4PJyT6h7mNWvq1rzqiriPsEqVhc+svHE=
-github.com/opencontainers/selinux v1.8.0/go.mod h1:RScLhm78qiWa2gbVCcGkC7tCGdgk3ogry1nUQF8Evvo=
-github.com/opencontainers/selinux v1.8.2/go.mod h1:MUIHuUEvKB1wtJjQdOyYRgOnLD2xAPP8dBsCoU0KuF8=
github.com/opencontainers/selinux v1.10.0/go.mod h1:2i0OySw99QjzBBQByd1Gr9gSjvuho1lHsJxIJ3gGbJI=
github.com/opentracing-contrib/go-observer v0.0.0-20170622124052-a52f23424492/go.mod h1:Ngi6UdF0k5OKD5t5wlmGhe/EDKPoUM3BXZSSfIuJbis=
github.com/opentracing/basictracer-go v1.0.0/go.mod h1:QfBfYuafItcjQuMwinw9GhYKwFXS9KnPs5lxoYwgW74=
@@ -1215,22 +953,21 @@ github.com/pascaldekloe/goe v0.1.0 h1:cBOtyMzM9HTpWjXfbbunk26uA6nG3a8n06Wieeh0Mw
github.com/pascaldekloe/goe v0.1.0/go.mod h1:lzWF7FIEvWOWxwDKqyGYQf6ZUaNfKdP144TG7ZOy1lc=
github.com/pborman/uuid v1.2.0/go.mod h1:X/NO0urCmaxf9VXbdlT7C2Yzkj2IKimNn4k+gtPdI/k=
github.com/pelletier/go-toml v1.2.0/go.mod h1:5z9KED0ma1S8pY6P1sdut58dfprrGBbd/94hg7ilaic=
-github.com/pelletier/go-toml v1.8.1/go.mod h1:T2/BmBdy8dvIRq1a/8aqjN41wvWlN4lrapLU/GW4pbc=
github.com/pelletier/go-toml v1.9.5 h1:4yBQzkHv+7BHq2PQUZF3Mx0IYxG7LsP222s7Agd3ve8=
github.com/pelletier/go-toml v1.9.5/go.mod h1:u1nR/EPcESfeI/szUZKdtJ0xRNbUoANCkoOuaOx1Y+c=
-github.com/pelletier/go-toml/v2 v2.0.6 h1:nrzqCb7j9cDFj2coyLNLaZuJTLjWjlaz6nvTvIwycIU=
-github.com/pelletier/go-toml/v2 v2.0.6/go.mod h1:eumQOmlWiOPt5WriQQqoM5y18pDHwha2N+QD+EUNTek=
+github.com/pelletier/go-toml/v2 v2.0.8 h1:0ctb6s9mE31h0/lhu+J6OPmVeDxJn+kYnJc2jZR9tGQ=
+github.com/pelletier/go-toml/v2 v2.0.8/go.mod h1:vuYfssBdrU2XDZ9bYydBu6t+6a6PYNcZljzZR9VXg+4=
github.com/performancecopilot/speed v3.0.0+incompatible/go.mod h1:/CLtqpZ5gBg1M9iaPbIdPPGyKcA8hKdoy6hAWba7Yac=
-github.com/peterbourgon/diskv v2.0.1+incompatible/go.mod h1:uqqh8zWWbv1HBMNONnaR/tNboyR3/BZd58JJSHlUSCU=
github.com/petermattis/goid v0.0.0-20180202154549-b0b1615b78e5/go.mod h1:jvVRKCrJTQWu0XVbaOlby/2lO20uSCHEMzzplHXte1o=
-github.com/petermattis/goid v0.0.0-20221215004737-a150e88a970d h1:htwtWgtQo8YS6JFWWi2DNgY0RwSGJ1ruMoxY6CUUclk=
-github.com/petermattis/goid v0.0.0-20221215004737-a150e88a970d/go.mod h1:pxMtw7cyUw6B2bRH0ZBANSPg+AoSud1I1iyJHI69jH4=
+github.com/petermattis/goid v0.0.0-20230317030725-371a4b8eda08 h1:hDSdbBuw3Lefr6R18ax0tZ2BJeNB3NehB3trOwYBsdU=
+github.com/petermattis/goid v0.0.0-20230317030725-371a4b8eda08/go.mod h1:pxMtw7cyUw6B2bRH0ZBANSPg+AoSud1I1iyJHI69jH4=
github.com/pierrec/lz4 v1.0.2-0.20190131084431-473cd7ce01a1/go.mod h1:3/3N9NVKO0jef7pBehbT1qWhCMrIgbYNnFAZCqQ5LRc=
github.com/pierrec/lz4 v2.0.5+incompatible/go.mod h1:pdkljMzZIN41W+lC3N2tnIh5sFi+IEE17M5jbnwPHcY=
github.com/pierrec/xxHash v0.1.5 h1:n/jBpwTHiER4xYvK3/CdPVnLDPchj8eTJFFLUb4QHBo=
github.com/pierrec/xxHash v0.1.5/go.mod h1:w2waW5Zoa/Wc4Yqe0wgrIYAGKqRMf7czn2HNKXmuL+I=
+github.com/pingcap/errors v0.11.4 h1:lFuQV/oaUMGcD2tqt+01ROSmJs75VG1ToEOkZIZ4nE4=
+github.com/pkg/diff v0.0.0-20210226163009-20ebb0f2a09e/go.mod h1:pJLUxLENpZxwdsKMEsNbx1VGcRFpLqf3715MtcvvzbA=
github.com/pkg/errors v0.8.0/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0=
-github.com/pkg/errors v0.8.1-0.20171018195549-f15c970de5b7/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0=
github.com/pkg/errors v0.8.1/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0=
github.com/pkg/errors v0.9.1 h1:FEBLx1zS214owpjy7qsBeixbURkuhQAwrK5UwLGTwt4=
github.com/pkg/errors v0.9.1/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0=
@@ -1239,19 +976,14 @@ github.com/pkg/sftp v1.13.1/go.mod h1:3HaPG6Dq1ILlpPZRO0HVMrsydcdLt6HRDccSgb87qR
github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM=
github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4=
github.com/posener/complete v1.1.1/go.mod h1:em0nMJCgc9GFtwrmVmEMR/ZL6WyhyjMBndrE9hABlRI=
-github.com/pquerna/cachecontrol v0.0.0-20171018203845-0dec1b30a021/go.mod h1:prYjPmNq4d1NPVmpShWobRqXY3q7Vp+80DqgxxUrUIA=
-github.com/prometheus/client_golang v0.0.0-20180209125602-c332b6f63c06/go.mod h1:7SWBe2y4D6OKWSNQJUaRYU/AaXPKyh/dDVn+NZz0KFw=
github.com/prometheus/client_golang v0.9.1/go.mod h1:7SWBe2y4D6OKWSNQJUaRYU/AaXPKyh/dDVn+NZz0KFw=
github.com/prometheus/client_golang v0.9.3-0.20190127221311-3c4408c8b829/go.mod h1:p2iRAGwDERtqlqzRXnrOVns+ignqQo//hLXqYxZYVNs=
-github.com/prometheus/client_golang v0.9.3/go.mod h1:/TN21ttK/J9q6uSwhBd54HahCDft0ttaMvbicHlPoso=
github.com/prometheus/client_golang v1.0.0/go.mod h1:db9x61etRT2tGnBNRi70OPL5FsnadC4Ky3P0J6CfImo=
-github.com/prometheus/client_golang v1.1.0/go.mod h1:I1FGZT9+L76gKKOs5djB6ezCbFQP1xR9D75/vuwEF3g=
github.com/prometheus/client_golang v1.3.0/go.mod h1:hJaj2vgQTGQmVCsAACORcieXFeDPbaTKGT+JTgUa3og=
github.com/prometheus/client_golang v1.4.0/go.mod h1:e9GMxYsXl05ICDXkRhurwBS4Q3OK1iX/F2sw+iXX5zU=
github.com/prometheus/client_golang v1.7.1/go.mod h1:PY5Wy2awLA44sXw4AOSfFBetzPP4j5+D6mVACh+pe2M=
-github.com/prometheus/client_golang v1.14.0 h1:nJdhIvne2eSX/XRAFV9PcvFFRbrjbcTUj0VP62TMhnw=
-github.com/prometheus/client_golang v1.14.0/go.mod h1:8vpkKitgIVNcqrRBWh1C4TIUQgYNtG/XQE4E/Zae36Y=
-github.com/prometheus/client_model v0.0.0-20171117100541-99fa1f4be8e5/go.mod h1:MbSGuTsp3dbXC40dX6PRTWyKYBIrTGTE9sqQNg2J8bo=
+github.com/prometheus/client_golang v1.15.0 h1:5fCgGYogn0hFdhyhLbw7hEsWxufKtY9klyvdNfFlFhM=
+github.com/prometheus/client_golang v1.15.0/go.mod h1:e9yaBhRPU2pPNsZwE+JdQl0KEt1N9XgF6zxWmaC0xOk=
github.com/prometheus/client_model v0.0.0-20180712105110-5c3871d89910/go.mod h1:MbSGuTsp3dbXC40dX6PRTWyKYBIrTGTE9sqQNg2J8bo=
github.com/prometheus/client_model v0.0.0-20190115171406-56726106282f/go.mod h1:MbSGuTsp3dbXC40dX6PRTWyKYBIrTGTE9sqQNg2J8bo=
github.com/prometheus/client_model v0.0.0-20190129233127-fd36f4220a90/go.mod h1:xMI15A0UPsDsEKsMN9yxemIoYk6Tm2C1GtYGdfGttqA=
@@ -1260,72 +992,58 @@ github.com/prometheus/client_model v0.1.0/go.mod h1:xMI15A0UPsDsEKsMN9yxemIoYk6T
github.com/prometheus/client_model v0.2.0/go.mod h1:xMI15A0UPsDsEKsMN9yxemIoYk6Tm2C1GtYGdfGttqA=
github.com/prometheus/client_model v0.3.0 h1:UBgGFHqYdG/TPFD1B1ogZywDqEkwp3fBMvqdiQ7Xew4=
github.com/prometheus/client_model v0.3.0/go.mod h1:LDGWKZIo7rky3hgvBe+caln+Dr3dPggB5dvjtD7w9+w=
-github.com/prometheus/common v0.0.0-20180110214958-89604d197083/go.mod h1:daVV7qP5qjZbuso7PdcryaAu0sAZbrN9i7WWcTMWvro=
-github.com/prometheus/common v0.0.0-20181113130724-41aa239b4cce/go.mod h1:daVV7qP5qjZbuso7PdcryaAu0sAZbrN9i7WWcTMWvro=
github.com/prometheus/common v0.2.0/go.mod h1:TNfzLD0ON7rHzMJeJkieUDPYmFC7Snx/y86RQel1bk4=
-github.com/prometheus/common v0.4.0/go.mod h1:TNfzLD0ON7rHzMJeJkieUDPYmFC7Snx/y86RQel1bk4=
github.com/prometheus/common v0.4.1/go.mod h1:TNfzLD0ON7rHzMJeJkieUDPYmFC7Snx/y86RQel1bk4=
-github.com/prometheus/common v0.6.0/go.mod h1:eBmuwkDJBwy6iBfxCBob6t6dR6ENT/y+J+Zk0j9GMYc=
github.com/prometheus/common v0.7.0/go.mod h1:DjGbpBbp5NYNiECxcL/VnbXCCaQpKd3tt26CguLLsqA=
github.com/prometheus/common v0.9.1/go.mod h1:yhUN8i9wzaXS3w1O07YhxHEBxD+W35wd8bs7vj7HSQ4=
github.com/prometheus/common v0.10.0/go.mod h1:Tlit/dnDKsSWFlCLTWaA1cyBgKHSMdTB80sz/V91rCo=
github.com/prometheus/common v0.15.0/go.mod h1:U+gB1OBLb1lF3O42bTCL+FK18tX9Oar16Clt/msog/s=
-github.com/prometheus/common v0.40.0 h1:Afz7EVRqGg2Mqqf4JuF9vdvp1pi220m55Pi9T2JnO4Q=
-github.com/prometheus/common v0.40.0/go.mod h1:L65ZJPSmfn/UBWLQIHV7dBrKFidB/wPlF1y5TlSt9OE=
-github.com/prometheus/procfs v0.0.0-20180125133057-cb4147076ac7/go.mod h1:c3At6R/oaqEKCNdg8wHV1ftS6bRYblBhIjjI8uT2IGk=
+github.com/prometheus/common v0.42.0 h1:EKsfXEYo4JpWMHH5cg+KOUWeuJSov1Id8zGR8eeI1YM=
+github.com/prometheus/common v0.42.0/go.mod h1:xBwqVerjNdUDjgODMpudtOMwlOwf2SaTr1yjz4b7Zbc=
github.com/prometheus/procfs v0.0.0-20181005140218-185b4288413d/go.mod h1:c3At6R/oaqEKCNdg8wHV1ftS6bRYblBhIjjI8uT2IGk=
github.com/prometheus/procfs v0.0.0-20190117184657-bf6a532e95b1/go.mod h1:c3At6R/oaqEKCNdg8wHV1ftS6bRYblBhIjjI8uT2IGk=
-github.com/prometheus/procfs v0.0.0-20190507164030-5867b95ac084/go.mod h1:TjEm7ze935MbeOT/UhFTIMYKhuLP4wbCsTZCD3I8kEA=
-github.com/prometheus/procfs v0.0.0-20190522114515-bc1a522cf7b1/go.mod h1:TjEm7ze935MbeOT/UhFTIMYKhuLP4wbCsTZCD3I8kEA=
github.com/prometheus/procfs v0.0.2/go.mod h1:TjEm7ze935MbeOT/UhFTIMYKhuLP4wbCsTZCD3I8kEA=
-github.com/prometheus/procfs v0.0.3/go.mod h1:4A/X28fw3Fc593LaREMrKMqOKvUAntwMDaekg4FpcdQ=
-github.com/prometheus/procfs v0.0.5/go.mod h1:4A/X28fw3Fc593LaREMrKMqOKvUAntwMDaekg4FpcdQ=
github.com/prometheus/procfs v0.0.8/go.mod h1:7Qr8sr6344vo1JqZ6HhLceV9o3AJ1Ff+GxbHq6oeK9A=
github.com/prometheus/procfs v0.1.3/go.mod h1:lV6e/gmhEcM9IjHGsFOCxxuZ+z1YqCvr4OA4YeYWdaU=
-github.com/prometheus/procfs v0.2.0/go.mod h1:lV6e/gmhEcM9IjHGsFOCxxuZ+z1YqCvr4OA4YeYWdaU=
github.com/prometheus/procfs v0.3.0/go.mod h1:lV6e/gmhEcM9IjHGsFOCxxuZ+z1YqCvr4OA4YeYWdaU=
-github.com/prometheus/procfs v0.6.0/go.mod h1:cz+aTbrPOrUb4q7XlbU9ygM+/jj0fzG6c1xBZuNvfVA=
github.com/prometheus/procfs v0.9.0 h1:wzCHvIvM5SxWqYvwgVL7yJY8Lz3PKn49KQtpgMYJfhI=
github.com/prometheus/procfs v0.9.0/go.mod h1:+pB4zwohETzFnmlpe6yd2lSc+0/46IYZRB/chUwxUZY=
github.com/prometheus/tsdb v0.7.1 h1:YZcsG11NqnK4czYLrWd9mpEuAJIHVQLwdrleYfszMAA=
-github.com/prometheus/tsdb v0.7.1/go.mod h1:qhTCs0VvXwvX/y3TZrWD7rabWM+ijKTux40TwIPHuXU=
github.com/rakyll/statik v0.1.7 h1:OF3QCZUuyPxuGEP7B4ypUa7sB/iHtqOTDYZXGM8KOdQ=
github.com/rakyll/statik v0.1.7/go.mod h1:AlZONWzMtEnMs7W4e/1LURLiI49pIMmp6V9Unghqrcc=
github.com/rcrowley/go-metrics v0.0.0-20181016184325-3113b8401b8a/go.mod h1:bCqnVzQkZxMG4s8nGwiZ5l3QUCyqpo9Y+/ZMZ9VjZe4=
github.com/rcrowley/go-metrics v0.0.0-20201227073835-cf1acfcdf475 h1:N/ElC8H3+5XpJzTSTfLsJV/mx9Q9g7kxmchpfZyxgzM=
github.com/rcrowley/go-metrics v0.0.0-20201227073835-cf1acfcdf475/go.mod h1:bCqnVzQkZxMG4s8nGwiZ5l3QUCyqpo9Y+/ZMZ9VjZe4=
-github.com/regen-network/gocuke v0.6.2 h1:pHviZ0kKAq2U2hN2q3smKNxct6hS0mGByFMHGnWA97M=
github.com/regen-network/protobuf v1.3.3-alpha.regen.1 h1:OHEc+q5iIAXpqiqFKeLpu5NwTIkVXUs48vFMwzqpqY4=
github.com/regen-network/protobuf v1.3.3-alpha.regen.1/go.mod h1:2DjTFR1HhMQhiWC5sZ4OhQ3+NtdbZ6oBDKQwq5Ou+FI=
-github.com/remyoudompheng/bigfft v0.0.0-20200410134404-eec4a21b6bb0 h1:OdAsTTz6OkFY5QxjkYwrChwuRruF69c169dPK26NUlk=
github.com/remyoudompheng/bigfft v0.0.0-20200410134404-eec4a21b6bb0/go.mod h1:qqbHyh8v60DhA7CoWK5oRCqLrMHRGoxYCSS9EjAz6Eo=
-github.com/rivo/uniseg v0.2.0 h1:S1pD9weZBuJdFmowNwbpi7BJ8TNftyUImj/0WQi72jY=
+github.com/remyoudompheng/bigfft v0.0.0-20230129092748-24d4a6f8daec h1:W09IVJc94icq4NjY3clb7Lk8O1qJ8BdBEF8z0ibU0rE=
+github.com/remyoudompheng/bigfft v0.0.0-20230129092748-24d4a6f8daec/go.mod h1:qqbHyh8v60DhA7CoWK5oRCqLrMHRGoxYCSS9EjAz6Eo=
+github.com/rivo/uniseg v0.4.3 h1:utMvzDsuh3suAEnhH0RdHmoPbU648o6CvXxTx4SBMOw=
github.com/rogpeppe/fastuuid v0.0.0-20150106093220-6724a57986af/go.mod h1:XWv6SoW27p1b0cqNHllgS5HIMJraePCO15w5zCzIWYg=
github.com/rogpeppe/fastuuid v1.2.0/go.mod h1:jVj6XXZzXRy/MSR5jhDC/2q6DgLz+nrA6LYCDYWNEvQ=
github.com/rogpeppe/go-internal v1.3.0/go.mod h1:M8bDsm7K2OlrFYOpmOWEs/qY81heoFRclV5y23lUDJ4=
-github.com/rogpeppe/go-internal v1.9.0 h1:73kH8U+JUqXU8lRuOHeVHaa/SZPifC7BkcraZVejAe8=
+github.com/rogpeppe/go-internal v1.9.0/go.mod h1:WtVeX8xhTBvf0smdhujwtBcq4Qrzq/fJaraNFVN+nFs=
+github.com/rogpeppe/go-internal v1.11.0 h1:cWPaGQEPrBb5/AsnsZesgZZ9yb1OQ+GOISoDNXVBh4M=
+github.com/rogpeppe/go-internal v1.11.0/go.mod h1:ddIwULY96R17DhadqLgMfk9H9tvdUzkipdSkR5nkCZA=
github.com/rs/cors v1.7.0/go.mod h1:gFx+x8UowdsKA9AchylcLynDq+nNFfI8FkUZdN/jGCU=
github.com/rs/cors v1.8.3 h1:O+qNyWn7Z+F9M0ILBHgMVPuB1xTOucVd5gtaYyXBpRo=
github.com/rs/cors v1.8.3/go.mod h1:XyqrcTp5zjWr1wsJ8PIRZssZ8b/WMcMf71DJnit4EMU=
+github.com/rs/xid v1.5.0/go.mod h1:trrq9SKmegXys3aeAKXMUTdJsYXVwGY3RLcfgqegfbg=
+github.com/rs/zerolog v1.30.0 h1:SymVODrcRsaRaSInD9yQtKbtWqwsfoPcRff/oRXLj4c=
+github.com/rs/zerolog v1.30.0/go.mod h1:/tk+P47gFdPXq4QYjvCmT5/Gsug2nagsFWBWhAiSi1w=
github.com/russross/blackfriday v1.5.2/go.mod h1:JO/DiYxRf+HjHt06OyowR9PTA263kcR/rfWxYHBV53g=
github.com/russross/blackfriday/v2 v2.0.1/go.mod h1:+Rmxgy9KzJVeS9/2gXHxylqXiyQDYRxCVz55jmeOWTM=
github.com/russross/blackfriday/v2 v2.1.0/go.mod h1:+Rmxgy9KzJVeS9/2gXHxylqXiyQDYRxCVz55jmeOWTM=
github.com/ryanuber/columnize v0.0.0-20160712163229-9b3edd62028f/go.mod h1:sm1tb6uqfes/u+d4ooFouqFdy9/2g9QGwK3SQygK0Ts=
-github.com/safchain/ethtool v0.0.0-20190326074333-42ed695e3de8/go.mod h1:Z0q5wiBQGYcxhMZ6gUqHn6pYNLypFAvaL3UvgZLR0U4=
github.com/samuel/go-zookeeper v0.0.0-20190923202752-2cc03de413da/go.mod h1:gi+0XIa01GRL2eRQVjQkKGqKF3SF9vZR/HnPullcV2E=
github.com/sasha-s/go-deadlock v0.3.1 h1:sqv7fDNShgjcaxkO0JNcOAlr8B9+cV5Ey/OB71efZx0=
github.com/sasha-s/go-deadlock v0.3.1/go.mod h1:F73l+cr82YSh10GxyRI6qZiCgK64VaZjwesgfQ1/iLM=
-github.com/satori/go.uuid v1.2.0/go.mod h1:dA0hQrYB0VpLJoorglMZABFdXlWrHn1NEOzdhQKdks0=
-github.com/sclevine/spec v1.2.0/go.mod h1:W4J29eT/Kzv7/b9IWLB055Z+qvVC9vt0Arko24q7p+U=
github.com/sean-/seed v0.0.0-20170313163322-e2103e2c3529/go.mod h1:DxrIzT+xaE7yg65j358z/aeFdxmN0P9QXhEzd20vsDc=
-github.com/seccomp/libseccomp-golang v0.9.1/go.mod h1:GbW5+tmTXfcxTToHLXlScSlAvWlF4P2Ca7zGrPiEpWo=
github.com/seccomp/libseccomp-golang v0.9.2-0.20220502022130-f33da4d89646/go.mod h1:JA8cRccbGaA1s33RQf7Y1+q9gHmZX1yB/z9WDN1C6fg=
github.com/shirou/gopsutil v3.21.4-0.20210419000835-c7a38de76ee5+incompatible h1:Bn1aCHHRnjv4Bl16T8rcaFjYSrGrIZvpiGO6P3Q4GpU=
github.com/shurcooL/sanitized_anchor_name v1.0.0/go.mod h1:1NzhyTcUVG4SuEtjjoZeVRXNmyL/1OwPU0+IJeTBvfc=
-github.com/sirupsen/logrus v1.0.4-0.20170822132746-89742aefa4b2/go.mod h1:pMByvHTf9Beacp5x1UXfOR9xyW/9antXMhjMPG0dEzc=
-github.com/sirupsen/logrus v1.0.6/go.mod h1:pMByvHTf9Beacp5x1UXfOR9xyW/9antXMhjMPG0dEzc=
github.com/sirupsen/logrus v1.2.0/go.mod h1:LxeOpSwHxABJmUn/MG1IvRgCAasNZTLOkJPxbbu5VWo=
-github.com/sirupsen/logrus v1.4.1/go.mod h1:ni0Sbl8bgC9z8RoU9G6nDWqqs/fq4eDPysMBDgk/93Q=
github.com/sirupsen/logrus v1.4.2/go.mod h1:tLMulIdttU9McNUspp0xgXVQah82FyeX6MwdIuYE2rE=
github.com/sirupsen/logrus v1.6.0/go.mod h1:7uNnSEd1DgxDLC74fIahvMZmmYsHGZGEOFrfsX/uA88=
github.com/sirupsen/logrus v1.7.0/go.mod h1:yWOB1SBYBC5VeMP7gHvWumXLIWorT60ONWic61uBYv0=
@@ -1333,7 +1051,6 @@ github.com/sirupsen/logrus v1.8.1/go.mod h1:yWOB1SBYBC5VeMP7gHvWumXLIWorT60ONWic
github.com/sirupsen/logrus v1.9.0 h1:trlNQbNUG3OdDrDil03MCb1H2o9nJ1x4/5LYw7byDE0=
github.com/sirupsen/logrus v1.9.0/go.mod h1:naHLuLoDiP4jHNo9R0sCBMtWGeIprob74mVsIT4qYEQ=
github.com/smartystreets/assertions v0.0.0-20180927180507-b2de0cb4f26d/go.mod h1:OnSkiWE9lh6wB0YB77sQom3nweQdgAjqCqsofrRNTgc=
-github.com/smartystreets/goconvey v0.0.0-20190330032615-68dc04aab96a/go.mod h1:syvi0/a8iFYH4r/RixwvyeAJjdLS9QV7WQ/tjFTllLA=
github.com/smartystreets/goconvey v1.6.4/go.mod h1:syvi0/a8iFYH4r/RixwvyeAJjdLS9QV7WQ/tjFTllLA=
github.com/soheilhy/cmux v0.1.4/go.mod h1:IM3LyeVVIOuxMH7sFAkER9+bJ4dT7Ms6E4xg4kGIyLM=
github.com/sony/gobreaker v0.4.1/go.mod h1:ZKptC7FHNvhBz7dN2LGjPVBz2sZJmc0/PkyDJOjmxWY=
@@ -1343,47 +1060,36 @@ github.com/spaolacci/murmur3 v0.0.0-20180118202830-f09979ecbc72/go.mod h1:JwIasO
github.com/spaolacci/murmur3 v1.1.0 h1:7c1g84S4BPRrfL5Xrdp6fOJ206sU9y293DDHaoy0bLI=
github.com/spaolacci/murmur3 v1.1.0/go.mod h1:JwIasOWyU6f++ZhiEuf87xNszmSA2myDM2Kzu9HwQUA=
github.com/spf13/afero v1.1.2/go.mod h1:j4pytiNVoe2o6bmDsKpLACNPDBIoEAkihy7loJ1B0CQ=
-github.com/spf13/afero v1.2.2/go.mod h1:9ZxEEn6pIJ8Rxe320qSDBk6AsU0r9pR7Q4OcevTdifk=
-github.com/spf13/afero v1.9.3 h1:41FoI0fD7OR7mGcKE/aOiLkGreyf8ifIOQmJANWogMk=
-github.com/spf13/afero v1.9.3/go.mod h1:iUV7ddyEEZPO5gA3zD4fJt6iStLlL+Lg4m2cihcDf8Y=
+github.com/spf13/afero v1.9.5 h1:stMpOSZFs//0Lv29HduCmli3GUfpFoF3Y1Q/aXj/wVM=
+github.com/spf13/afero v1.9.5/go.mod h1:UBogFpq8E9Hx+xc5CNTTEpTnuHVmXDwZcZcE1eb/UhQ=
github.com/spf13/cast v1.3.0/go.mod h1:Qx5cxh0v+4UWYiBimWS+eyWzqEqokIECu5etghLkUJE=
-github.com/spf13/cast v1.5.0 h1:rj3WzYc11XZaIZMPKmwP96zkFEnnAmV8s6XbB2aY32w=
-github.com/spf13/cast v1.5.0/go.mod h1:SpXXQ5YoyJw6s3/6cMTQuxvgRl3PCJiyaX9p6b155UU=
-github.com/spf13/cobra v0.0.2-0.20171109065643-2da4a54c5cee/go.mod h1:1l0Ry5zgKvJasoi3XT1TypsSe7PqH0Sj9dhYf7v3XqQ=
+github.com/spf13/cast v1.5.1 h1:R+kOtfhWQE6TVQzY+4D7wJLBgkdVasCEFxSUBYBYIlA=
+github.com/spf13/cast v1.5.1/go.mod h1:b9PdjNptOpzXr7Rq1q9gJML/2cdGQAo69NKzQ10KN48=
github.com/spf13/cobra v0.0.3/go.mod h1:1l0Ry5zgKvJasoi3XT1TypsSe7PqH0Sj9dhYf7v3XqQ=
github.com/spf13/cobra v0.0.5/go.mod h1:3K3wKZymM7VvHMDS9+Akkh4K60UwM26emMESw8tLCHU=
-github.com/spf13/cobra v1.0.0/go.mod h1:/6GTrnGXV9HjY+aR4k0oJ5tcvakLuG6EuKReYlHNrgE=
-github.com/spf13/cobra v1.6.1 h1:o94oiPyS4KD1mPy2fmcYYHHfCxLqYjJOhGsCHFZtEzA=
-github.com/spf13/cobra v1.6.1/go.mod h1:IOw/AERYS7UzyrGinqmz6HLUo219MORXGxhbaJUqzrY=
+github.com/spf13/cobra v1.7.0 h1:hyqWnYt1ZQShIddO5kBpj3vu05/++x6tJ6dg8EC572I=
+github.com/spf13/cobra v1.7.0/go.mod h1:uLxZILRyS/50WlhOIKD7W6V5bgeIt+4sICxh6uRMrb0=
github.com/spf13/jwalterweatherman v1.0.0/go.mod h1:cQK4TGJAtQXfYWX+Ddv3mKDzgVb68N+wFjFa4jdeBTo=
github.com/spf13/jwalterweatherman v1.1.0 h1:ue6voC5bR5F8YxI5S67j9i582FU4Qvo2bmqnqMYADFk=
github.com/spf13/jwalterweatherman v1.1.0/go.mod h1:aNWZUN0dPAAO/Ljvb5BEdw96iTZ0EXowPYD95IqWIGo=
-github.com/spf13/pflag v0.0.0-20170130214245-9ff6c6923cff/go.mod h1:DYY7MBk1bdzusC3SYhjObp+wFpr4gzcvqqNjLnInEg4=
-github.com/spf13/pflag v1.0.1-0.20171106142849-4c012f6dcd95/go.mod h1:DYY7MBk1bdzusC3SYhjObp+wFpr4gzcvqqNjLnInEg4=
github.com/spf13/pflag v1.0.1/go.mod h1:DYY7MBk1bdzusC3SYhjObp+wFpr4gzcvqqNjLnInEg4=
github.com/spf13/pflag v1.0.3/go.mod h1:DYY7MBk1bdzusC3SYhjObp+wFpr4gzcvqqNjLnInEg4=
github.com/spf13/pflag v1.0.5 h1:iy+VFUOCP1a+8yFto/drg2CJ5u0yRoB7fZw3DKv/JXA=
github.com/spf13/pflag v1.0.5/go.mod h1:McXfInJRrz4CZXVZOBLb0bTZqETkiAhM9Iw0y3An2Bg=
github.com/spf13/viper v1.3.2/go.mod h1:ZiWeW+zYFKm7srdB9IoDzzZXaJaI5eL9QjNiN/DMA2s=
-github.com/spf13/viper v1.4.0/go.mod h1:PTJ7Z/lr49W6bUbkmS1V3by4uWynFiR9p7+dSq/yZzE=
-github.com/spf13/viper v1.15.0 h1:js3yy885G8xwJa6iOISGFwd+qlUo5AvyXb7CiihdtiU=
-github.com/spf13/viper v1.15.0/go.mod h1:fFcTBJxvhhzSJiZy8n+PeW6t8l+KeT/uTARa0jHOQLA=
-github.com/stefanberger/go-pkcs11uri v0.0.0-20201008174630-78d3cae3a980/go.mod h1:AO3tvPzVZ/ayst6UlUKUv6rcPQInYe3IknH3jYhAKu8=
-github.com/strangelove-ventures/go-subkey v1.0.7 h1:cOP/Lajg3uxV/tvspu0m6+0Cu+DJgygkEAbx/s+f35I=
-github.com/strangelove-ventures/go-subkey v1.0.7/go.mod h1:E34izOIEm+sZ1YmYawYRquqBQWeZBjVB4pF7bMuhc1c=
-github.com/strangelove-ventures/interchaintest/v7 v7.0.0-20230309210425-6f04be9aab19 h1:myDhIC75y5Kycqke0Go3PeRnsXvGW6fynHDGds2dKFk=
-github.com/strangelove-ventures/interchaintest/v7 v7.0.0-20230309210425-6f04be9aab19/go.mod h1:DTYkHkPDFjGE0jGLSG3elpgngb9fhaCHdmM0ERRd/T4=
+github.com/spf13/viper v1.16.0 h1:rGGH0XDZhdUOryiDWjmIvUSWpbNqisK8Wk0Vyefw8hc=
+github.com/spf13/viper v1.16.0/go.mod h1:yg78JgCJcbrQOvV9YLXgkLaZqUidkY9K+Dd1FofRzQg=
+github.com/strangelove-ventures/interchaintest/v7 v7.0.0-20230608002938-79172615eed0 h1:WoRj3il7OqGknKxf3IRwGTY65AVbTnDjKAgezpEHM3E=
+github.com/strangelove-ventures/interchaintest/v7 v7.0.0-20230608002938-79172615eed0/go.mod h1:RG6EsHW08mfwJQmZykqzkAQwAmVojcrqujjFBFPIHcY=
github.com/streadway/amqp v0.0.0-20190404075320-75d898a42a94/go.mod h1:AZpEONHx3DKn8O/DFsRAY58/XVQiIPMTMB1SddzLXVw=
github.com/streadway/amqp v0.0.0-20190827072141-edfb9018d271/go.mod h1:AZpEONHx3DKn8O/DFsRAY58/XVQiIPMTMB1SddzLXVw=
github.com/streadway/handy v0.0.0-20190108123426-d5acb3125c2a/go.mod h1:qNTQ5P5JnDBl6z3cMAg/SywNDC5ABu5ApDIw6lUbRmI=
-github.com/stretchr/objx v0.0.0-20180129172003-8a3f7159479f/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME=
github.com/stretchr/objx v0.1.0/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME=
github.com/stretchr/objx v0.1.1/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME=
-github.com/stretchr/objx v0.2.0/go.mod h1:qt09Ya8vawLte6SNmTgCsAVtYtaKzEcn8ATUoHMkEqE=
github.com/stretchr/objx v0.4.0/go.mod h1:YvHI0jy2hoMjB+UWwv71VJQ9isScKT/TqJzVSSt89Yw=
github.com/stretchr/objx v0.5.0 h1:1zr/of2m5FGMsad5YfcqgdqdWrIhu+EBEJRhR1U7z/c=
github.com/stretchr/objx v0.5.0/go.mod h1:Yh+to48EsGEfYuaHDzXPcE3xhTkx73EhmCGUpEOglKo=
-github.com/stretchr/testify v0.0.0-20180303142811-b89eecf5ca5d/go.mod h1:a8OnRcib4nhh0OaRAV+Yts87kKdq0PP7pXfy6kDkUVs=
+github.com/stretchr/testify v1.1.5-0.20170601210322-f6abca593680/go.mod h1:a8OnRcib4nhh0OaRAV+Yts87kKdq0PP7pXfy6kDkUVs=
github.com/stretchr/testify v1.2.2/go.mod h1:a8OnRcib4nhh0OaRAV+Yts87kKdq0PP7pXfy6kDkUVs=
github.com/stretchr/testify v1.3.0/go.mod h1:M5WIy9Dh21IEIfnGCwXGc5bZfKNJtfHm1UVUgZn+9EI=
github.com/stretchr/testify v1.4.0/go.mod h1:j7eGeouHqKxXV5pUuKE4zz7dFj8WfuZ+81PSLYec5m4=
@@ -1394,55 +1100,40 @@ github.com/stretchr/testify v1.7.1/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/
github.com/stretchr/testify v1.7.2/go.mod h1:R6va5+xMeoiuVRoj+gSkQ7d3FALtqAAGI1FQKckRals=
github.com/stretchr/testify v1.8.0/go.mod h1:yNjHg4UonilssWZ8iaSj1OCr/vHnekPRkoO+kdMU+MU=
github.com/stretchr/testify v1.8.1/go.mod h1:w2LPCIKwWwSfY2zedu0+kehJoqGctiVI29o6fzry7u4=
-github.com/stretchr/testify v1.8.2 h1:+h33VjcLVPDHtOdpUCuF+7gSuG3yGIftsP1YvFihtJ8=
github.com/stretchr/testify v1.8.2/go.mod h1:w2LPCIKwWwSfY2zedu0+kehJoqGctiVI29o6fzry7u4=
+github.com/stretchr/testify v1.8.3/go.mod h1:sz/lmYIOXD/1dqDmKjjqLyZ2RngseejIcXlSw2iwfAo=
+github.com/stretchr/testify v1.8.4 h1:CcVxjf3Q8PM0mHUKJCdn+eZZtm5yQwehR5yeSVQQcUk=
+github.com/stretchr/testify v1.8.4/go.mod h1:sz/lmYIOXD/1dqDmKjjqLyZ2RngseejIcXlSw2iwfAo=
github.com/subosito/gotenv v1.4.2 h1:X1TuBLAMDFbaTAChgCBLu3DU3UPyELpnF2jjJ2cz/S8=
github.com/subosito/gotenv v1.4.2/go.mod h1:ayKnFf/c6rvx/2iiLrJUk1e6plDbT3edrFNGqEflhK0=
-github.com/syndtr/gocapability v0.0.0-20170704070218-db04d3cc01c8/go.mod h1:hkRG7XYTFWNJGYcbNJQlaLq0fg1yr4J4t/NcTQtrfww=
-github.com/syndtr/gocapability v0.0.0-20180916011248-d98352740cb2/go.mod h1:hkRG7XYTFWNJGYcbNJQlaLq0fg1yr4J4t/NcTQtrfww=
github.com/syndtr/gocapability v0.0.0-20200815063812-42c35b437635/go.mod h1:hkRG7XYTFWNJGYcbNJQlaLq0fg1yr4J4t/NcTQtrfww=
+github.com/syndtr/goleveldb v1.0.1-0.20210819022825-2ae1ddf74ef7/go.mod h1:q4W45IWZaF22tdD+VEXcAWRA037jwmWEB5VWYORlTpc=
github.com/syndtr/goleveldb v1.0.1-0.20220721030215-126854af5e6d h1:vfofYNRScrDdvS342BElfbETmL1Aiz3i2t0zfRj16Hs=
github.com/syndtr/goleveldb v1.0.1-0.20220721030215-126854af5e6d/go.mod h1:RRCYJbIwD5jmqPI9XoAFR0OcDxqUctll6zUj/+B4S48=
-github.com/tchap/go-patricia v2.2.6+incompatible/go.mod h1:bmLyhP68RS6kStMGxByiQ23RP/odRBOTVjwp2cDyi6I=
-github.com/tecbot/gorocksdb v0.0.0-20191217155057-f0fad39f321c h1:g+WoO5jjkqGAzHWCjJB1zZfXPIAaDpzXIEJ0eS6B5Ok=
-github.com/tecbot/gorocksdb v0.0.0-20191217155057-f0fad39f321c/go.mod h1:ahpPrc7HpcfEWDQRZEmnXMzHY03mLDYMCxeDzy46i+8=
github.com/tendermint/go-amino v0.16.0 h1:GyhmgQKvqF82e2oZeuMSp9JTN0N09emoSZlb2lyGa2E=
github.com/tendermint/go-amino v0.16.0/go.mod h1:TQU0M1i/ImAo+tYpZi73AU3V/dKeCoMC9Sphe2ZwGME=
github.com/tidwall/btree v1.6.0 h1:LDZfKfQIBHGHWSwckhXI0RPSXzlo+KYdjK7FWSqOzzg=
github.com/tidwall/btree v1.6.0/go.mod h1:twD9XRA5jj9VUQGELzDO4HPQTNJsoWWfYEL+EUQ2cKY=
github.com/tklauser/go-sysconf v0.3.10 h1:IJ1AZGZRWbY8T5Vfk04D9WOA5WSejdflXxP03OUqALw=
-github.com/tklauser/go-sysconf v0.3.10/go.mod h1:C8XykCvCb+Gn0oNCWPIlcb0RuglQTYaQ2hGm7jmxEFk=
github.com/tklauser/numcpus v0.4.0 h1:E53Dm1HjH1/R2/aoCtXtPgzmElmn51aOkhCFSuZq//o=
-github.com/tklauser/numcpus v0.4.0/go.mod h1:1+UI3pD8NW14VMwdgJNJ1ESk2UnwhAnz5hMwiKKqXCQ=
github.com/tmc/grpc-websocket-proxy v0.0.0-20170815181823-89b8d40f7ca8/go.mod h1:ncp9v5uamzpCO7NfCPTXjqaC+bZgJeR0sMTm6dMHP7U=
-github.com/tmc/grpc-websocket-proxy v0.0.0-20190109142713-0ad062ec5ee5/go.mod h1:ncp9v5uamzpCO7NfCPTXjqaC+bZgJeR0sMTm6dMHP7U=
github.com/tv42/httpunix v0.0.0-20150427012821-b75d8614f926/go.mod h1:9ESjWnEqriFuLhtthL60Sar/7RFoluCcXsuvEwTV5KM=
+github.com/tyler-smith/go-bip32 v1.0.0 h1:sDR9juArbUgX+bO/iblgZnMPeWY1KZMUC2AFUJdv5KE=
+github.com/tyler-smith/go-bip32 v1.0.0/go.mod h1:onot+eHknzV4BVPwrzqY5OoVpyCvnwD7lMawL5aQupE=
github.com/tyler-smith/go-bip39 v1.1.0 h1:5eUemwrMargf3BSLRRCalXT93Ns6pQJIjYQN2nyfOP8=
github.com/tyler-smith/go-bip39 v1.1.0/go.mod h1:gUYDtqQw1JS3ZJ8UWVcGTGqqr6YIN3CWg+kkNaLt55U=
-github.com/ugorji/go v1.1.4/go.mod h1:uQMGLiO92mf5W77hV/PUCpI3pbzQx3CRekS0kk+RGrc=
github.com/ugorji/go v1.1.7 h1:/68gy2h+1mWMrwZFeD1kQialdSzAb432dtpeJ42ovdo=
github.com/ugorji/go v1.1.7/go.mod h1:kZn38zHttfInRq0xu/PH0az30d+z6vm202qpg1oXVMw=
github.com/ugorji/go/codec v0.0.0-20181204163529-d75b2dcb6bc8/go.mod h1:VFNgLljTbGfSG7qAOspJ7OScBnGdDN/yBr0sguwnwf0=
-github.com/ugorji/go/codec v1.1.7 h1:2SvQaVZ1ouYrrKKwoSk2pzd4A9evlKJb9oTL+OaLUSs=
github.com/ugorji/go/codec v1.1.7/go.mod h1:Ax+UKWsSmolVDwsd+7N3ZtXu+yMGCf907BLYF3GoBXY=
+github.com/ugorji/go/codec v1.2.7 h1:YPXUKf7fYbp/y8xloBqZOw2qaVggbfwMlI8WM3wZUJ0=
github.com/ulikunitz/xz v0.5.10/go.mod h1:nbz6k7qbPmH4IRqmfOplQw/tblSgqTqBwxkY0oWt/14=
github.com/ulikunitz/xz v0.5.11 h1:kpFauv27b6ynzBNT/Xy+1k+fK4WswhN/6PN5WhFAGw8=
github.com/ulikunitz/xz v0.5.11/go.mod h1:nbz6k7qbPmH4IRqmfOplQw/tblSgqTqBwxkY0oWt/14=
-github.com/urfave/cli v0.0.0-20171014202726-7bc6a0acffa5/go.mod h1:70zkFmudgCuE/ngEzBv17Jvp/497gISqfk5gWijbERA=
github.com/urfave/cli v1.20.0/go.mod h1:70zkFmudgCuE/ngEzBv17Jvp/497gISqfk5gWijbERA=
github.com/urfave/cli v1.22.1/go.mod h1:Gos4lmkARVdJ6EkW0WaNv/tZAAMe9V7XWyB60NtXRu0=
-github.com/urfave/cli v1.22.2/go.mod h1:Gos4lmkARVdJ6EkW0WaNv/tZAAMe9V7XWyB60NtXRu0=
-github.com/vishvananda/netlink v0.0.0-20181108222139-023a6dafdcdf/go.mod h1:+SR5DhBJrl6ZM7CoCKvpw5BKroDKQ+PJqOg65H/2ktk=
github.com/vishvananda/netlink v1.1.0/go.mod h1:cTgwzPIzzgDAYoQrMm0EdrjRUBkTqKYppBueQtXaqoE=
-github.com/vishvananda/netlink v1.1.1-0.20201029203352-d40f9887b852/go.mod h1:twkDnbuQxJYemMlGd4JFIcuhgX83tXhKS2B/PRMpOho=
-github.com/vishvananda/netns v0.0.0-20180720170159-13995c7128cc/go.mod h1:ZjcWmFBXmLKZu9Nxj3WKYEafiSqer2rnvPr0en9UNpI=
github.com/vishvananda/netns v0.0.0-20191106174202-0a2b9b5464df/go.mod h1:JP3t17pCcGlemwknint6hfoeCVQrEMVwxRLRjXpq+BU=
-github.com/vishvananda/netns v0.0.0-20200728191858-db3c7e526aae/go.mod h1:DD4vA1DwXk04H54A1oHXtwZmA0grkVMdPxx/VGLCah0=
-github.com/willf/bitset v1.1.11-0.20200630133818-d5bec3311243/go.mod h1:RjeCKbqT1RxIR/KWY6phxZiaY1IyutSBfGjNPySAYV4=
-github.com/willf/bitset v1.1.11/go.mod h1:83CECat5yLh5zVOf4P1ErAgKA5UDvKtgyUABdr3+MjI=
-github.com/xeipuuv/gojsonpointer v0.0.0-20180127040702-4e3ac2762d5f/go.mod h1:N2zxlSyiKSe5eX1tZViRH5QA0qijqEDrYZiPEAiq3wU=
-github.com/xeipuuv/gojsonreference v0.0.0-20180127040603-bd5ef7bd5415/go.mod h1:GwrjFmJcFw6At/Gs6z4yjiIwzuJ1/+UwLxMQDVQXShQ=
-github.com/xeipuuv/gojsonschema v0.0.0-20180618132009-1d523034197f/go.mod h1:5yf86TLmAcydyeJq5YvxkGPE2fm/u4myDekKRoLuqhs=
github.com/xiang90/probing v0.0.0-20190116061207-43a291ad63a2/go.mod h1:UETIi67q53MR2AWcXfiuqkDkRtnGDLqkBTpCHuJHxtU=
github.com/xordataexchange/crypt v0.0.3-0.20170626215501-b2862e3d0a77/go.mod h1:aYKd//L2LvnjZzWKhF00oedf4jCCReLcmhLdhm1A27Q=
github.com/yuin/goldmark v1.1.25/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74=
@@ -1451,21 +1142,14 @@ github.com/yuin/goldmark v1.1.32/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9de
github.com/yuin/goldmark v1.2.1/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74=
github.com/yuin/goldmark v1.3.5/go.mod h1:mwnBkeHKe2W/ZEtQ+71ViKU8L12m81fl3OWwC1Zlc8k=
github.com/yuin/goldmark v1.4.13/go.mod h1:6yULJ656Px+3vBD8DxQVa3kxgyrAnzto9xy5taEt/CY=
-github.com/yvasiyarov/go-metrics v0.0.0-20140926110328-57bccd1ccd43/go.mod h1:aX5oPXxHm3bOH+xeAttToC8pqch2ScQN/JoXYupl6xs=
-github.com/yvasiyarov/gorelic v0.0.0-20141212073537-a9bba5b9ab50/go.mod h1:NUSPSUX/bi6SeDMUh6brw0nXpxHnc96TguQh0+r/ssA=
-github.com/yvasiyarov/newrelic_platform_go v0.0.0-20140908184405-b21fdbd4370f/go.mod h1:GlGEuHIJweS1mbCqG+7vt2nvWLzLLnRHbXz5JKd/Qbg=
github.com/zondax/hid v0.9.1 h1:gQe66rtmyZ8VeGFcOpbuH3r7erYtNEAezCAYu8LdkJo=
github.com/zondax/hid v0.9.1/go.mod h1:l5wttcP0jwtdLjqjMMWFVEE7d1zO0jvSPA9OPZxWpEM=
github.com/zondax/ledger-go v0.14.1 h1:Pip65OOl4iJ84WTpA4BKChvOufMhhbxED3BaihoZN4c=
github.com/zondax/ledger-go v0.14.1/go.mod h1:fZ3Dqg6qcdXWSOJFKMG8GCTnD7slO/RL2feOQv8K320=
-go.etcd.io/bbolt v1.3.2/go.mod h1:IbVyRI1SCnLcuJnV2u8VeU0CEYM7e686BmAb1XKL+uU=
go.etcd.io/bbolt v1.3.3/go.mod h1:IbVyRI1SCnLcuJnV2u8VeU0CEYM7e686BmAb1XKL+uU=
-go.etcd.io/bbolt v1.3.5/go.mod h1:G5EMThwa9y8QZGBClrRx5EY+Yw9kAhnjy3bSjsnlVTQ=
-go.etcd.io/bbolt v1.3.6 h1:/ecaJf0sk1l4l6V4awd65v2C3ILy7MSj+s/x1ADCIMU=
-go.etcd.io/bbolt v1.3.6/go.mod h1:qXsaaIqmgQH0T+OPdb99Bf+PKfBBQVAdyD6TY9G8XM4=
+go.etcd.io/bbolt v1.3.7 h1:j+zJOnnEjF/kyHlDDgGnVL/AIqIJPq8UoB2GSNfkUfQ=
+go.etcd.io/bbolt v1.3.7/go.mod h1:N9Mkw9X8x5fupy0IKsmuqVtoGDyxsaDlbk4Rd05IAQw=
go.etcd.io/etcd v0.0.0-20191023171146-3cf2f69b5738/go.mod h1:dnLIgRNXwCJa5e+c6mIZCrds/GIG4ncV9HhK5PX7jPg=
-go.etcd.io/etcd v0.5.0-alpha.5.0.20200910180754-dd1b699fc489/go.mod h1:yVHk9ub3CSBatqGNg7GRmsnfLWtoW60w4eDYfh7vHDg=
-go.mozilla.org/pkcs7 v0.0.0-20200128120323-432b2356ecb1/go.mod h1:SNgMg+EgDFwmvSmLRTNKC5fegJjB7v23qTQ0XLGUNHk=
go.opencensus.io v0.20.1/go.mod h1:6WKK9ahsWS3RSO+PY9ZHZUfv2irvY6gN279GOPZjmmk=
go.opencensus.io v0.20.2/go.mod h1:6WKK9ahsWS3RSO+PY9ZHZUfv2irvY6gN279GOPZjmmk=
go.opencensus.io v0.21.0/go.mod h1:mSImk1erAIZhrmZN+AvHh14ztQfjbGwt4TtuofqLduU=
@@ -1481,43 +1165,37 @@ go.opentelemetry.io/proto/otlp v0.7.0/go.mod h1:PqfVotwruBrMGOCsRd/89rSnXhoiJIqe
go.uber.org/atomic v1.3.2/go.mod h1:gD2HeocX3+yG+ygLZcrzQJaqmWj9AIm7n08wl/qW/PE=
go.uber.org/atomic v1.4.0/go.mod h1:gD2HeocX3+yG+ygLZcrzQJaqmWj9AIm7n08wl/qW/PE=
go.uber.org/atomic v1.5.0/go.mod h1:sABNBOSYdrvTF6hTgEIbc7YasKWGhgEQZyfxyTvoXHQ=
-go.uber.org/atomic v1.7.0/go.mod h1:fEN4uk6kAWBTFdckzkM89CLk9XfWZrxpCo0nPH17wJc=
go.uber.org/atomic v1.10.0 h1:9qC72Qh0+3MqyJbAn8YU5xVq1frD8bn3JtD2oXtafVQ=
go.uber.org/atomic v1.10.0/go.mod h1:LUxbIzbOniOlMKjJjyPfpl4v+PKK2cNJn91OQbhoJI0=
go.uber.org/goleak v1.1.12 h1:gZAh5/EyT/HQwlpkCy6wTpqfH9H8Lz8zbm3dZh+OyzA=
go.uber.org/multierr v1.1.0/go.mod h1:wR5kodmAFQ0UK8QlbwjlSNy0Z68gJhDJUG5sjR94q/0=
go.uber.org/multierr v1.3.0/go.mod h1:VgVr7evmIr6uPjLBxg28wmKNXyqE9akIJ5XnfpiKl+4=
-go.uber.org/multierr v1.8.0 h1:dg6GjLku4EH+249NNmoIciG9N/jURbDG+pFlTkhzIC8=
-go.uber.org/multierr v1.8.0/go.mod h1:7EAYxJLBy9rStEaz58O2t4Uvip6FSURkq8/ppBp95ak=
+go.uber.org/multierr v1.11.0 h1:blXXJkSxSSfBVBlC76pxqeO+LN3aDfLQo+309xJstO0=
+go.uber.org/multierr v1.11.0/go.mod h1:20+QtiLqy0Nd6FdQB9TLXag12DsQkrbs3htMFfDN80Y=
go.uber.org/tools v0.0.0-20190618225709-2cfd321de3ee/go.mod h1:vJERXedbb3MVM5f9Ejo0C68/HhF8uaILCdgjnY+goOA=
go.uber.org/zap v1.10.0/go.mod h1:vwi/ZaCAaUcBkycHslxD9B2zi4UTXhF60s6SWpuDF0Q=
go.uber.org/zap v1.13.0/go.mod h1:zwrFLgMcdUuIBviXEYEH1YKNaOBnKXsx2IPda5bBwHM=
go.uber.org/zap v1.24.0 h1:FiJd5l1UOLj0wCgbSE0rwwXHzEdAZS6hiiSnxJN/D60=
go.uber.org/zap v1.24.0/go.mod h1:2kMP+WWQ8aoFoedH3T2sq6iJ2yDWpHbP0f6MQbS9Gkg=
+golang.org/x/crypto v0.0.0-20170613210332-850760c427c5/go.mod h1:6SG95UA2DQfeDnfUPMdvaQW0Q7yPrPDi9nlGo2tz2b4=
golang.org/x/crypto v0.0.0-20170930174604-9419663f5a44/go.mod h1:6SG95UA2DQfeDnfUPMdvaQW0Q7yPrPDi9nlGo2tz2b4=
-golang.org/x/crypto v0.0.0-20171113213409-9f005a07e0d3/go.mod h1:6SG95UA2DQfeDnfUPMdvaQW0Q7yPrPDi9nlGo2tz2b4=
golang.org/x/crypto v0.0.0-20180904163835-0709b304e793/go.mod h1:6SG95UA2DQfeDnfUPMdvaQW0Q7yPrPDi9nlGo2tz2b4=
-golang.org/x/crypto v0.0.0-20181009213950-7c1a557ab941/go.mod h1:6SG95UA2DQfeDnfUPMdvaQW0Q7yPrPDi9nlGo2tz2b4=
golang.org/x/crypto v0.0.0-20181029021203-45a5f77698d3/go.mod h1:6SG95UA2DQfeDnfUPMdvaQW0Q7yPrPDi9nlGo2tz2b4=
golang.org/x/crypto v0.0.0-20181203042331-505ab145d0a9/go.mod h1:6SG95UA2DQfeDnfUPMdvaQW0Q7yPrPDi9nlGo2tz2b4=
golang.org/x/crypto v0.0.0-20190308221718-c2843e01d9a2/go.mod h1:djNgcEr1/C05ACkg1iLfiJU5Ep61QUkGW8qpdssI0+w=
golang.org/x/crypto v0.0.0-20190510104115-cbcb75029529/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI=
golang.org/x/crypto v0.0.0-20190605123033-f99c8df09eb5/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI=
-golang.org/x/crypto v0.0.0-20190611184440-5c40567a22f8/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI=
golang.org/x/crypto v0.0.0-20190701094942-4def268fd1a4/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI=
golang.org/x/crypto v0.0.0-20191011191535-87dc89f01550/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI=
golang.org/x/crypto v0.0.0-20191206172530-e9b2fee46413/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto=
-golang.org/x/crypto v0.0.0-20200115085410-6d4e4cb37c7d/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto=
golang.org/x/crypto v0.0.0-20200622213623-75b288015ac9/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto=
golang.org/x/crypto v0.0.0-20200728195943-123391ffb6de/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto=
-golang.org/x/crypto v0.0.0-20201002170205-7f63de1d35b0/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto=
-golang.org/x/crypto v0.0.0-20210220033148-5ea612d1eb83/go.mod h1:jdWPYTVW3xRLrWPugEBEK3UY2ZEsg3UU495nc5E+M+I=
-golang.org/x/crypto v0.0.0-20210322153248-0c34fe9e7dc2/go.mod h1:T9bdIzuCu7OtxOm1hfPfRQxPLYneinmdGuTeoZ9dtd4=
golang.org/x/crypto v0.0.0-20210421170649-83a5a9bb288b/go.mod h1:T9bdIzuCu7OtxOm1hfPfRQxPLYneinmdGuTeoZ9dtd4=
golang.org/x/crypto v0.0.0-20210921155107-089bfa567519/go.mod h1:GvvjBRRGRdwPK5ydBHafDWAxML/pGHZbMvKqRZ5+Abc=
-golang.org/x/crypto v0.0.0-20211108221036-ceb1ce70b4fa/go.mod h1:GvvjBRRGRdwPK5ydBHafDWAxML/pGHZbMvKqRZ5+Abc=
-golang.org/x/crypto v0.6.0 h1:qfktjS5LUO+fFKeJXZ+ikTRijMmljikvG68fpMMruSc=
-golang.org/x/crypto v0.6.0/go.mod h1:OFC/31mSvZgRz0V1QTNCzfAI1aIRzbiufJtkMIlEp58=
+golang.org/x/crypto v0.0.0-20220314234659-1baeb1ce4c0b/go.mod h1:IxCIyHEi3zRg3s0A5j5BB6A9Jmi73HwBIUl50j+osU4=
+golang.org/x/crypto v0.0.0-20220722155217-630584e8d5aa/go.mod h1:IxCIyHEi3zRg3s0A5j5BB6A9Jmi73HwBIUl50j+osU4=
+golang.org/x/crypto v0.11.0 h1:6Ewdq3tDic1mg5xRO4milcWCfMVQhI4NkqWWvqejpuA=
+golang.org/x/crypto v0.11.0/go.mod h1:xgJhtzW8F9jGdVFWZESrid1U1bjeNy4zgy5cRr/CIio=
golang.org/x/exp v0.0.0-20190121172915-509febef88a4/go.mod h1:CJ0aWSM057203Lf6IL+f9T1iT9GByDxfZKAQTCR3kQA=
golang.org/x/exp v0.0.0-20190306152737-a1d7652674e8/go.mod h1:CJ0aWSM057203Lf6IL+f9T1iT9GByDxfZKAQTCR3kQA=
golang.org/x/exp v0.0.0-20190510132918-efd6b22b2522/go.mod h1:ZjyILWgesfNpC6sMxTJOJm9Kp84zZh5NQWvqDGG3Qr8=
@@ -1529,8 +1207,8 @@ golang.org/x/exp v0.0.0-20200119233911-0405dc783f0a/go.mod h1:2RIsYlXP63K8oxa1u0
golang.org/x/exp v0.0.0-20200207192155-f17229e696bd/go.mod h1:J/WKrq2StrnmMY6+EHIKF9dgMWnmCNThgcyBT1FY9mM=
golang.org/x/exp v0.0.0-20200224162631-6cc2880d07d6/go.mod h1:3jZMyOhIsHpP37uCMkUooju7aAi5cS1Q23tOzKc+0MU=
golang.org/x/exp v0.0.0-20200331195152-e8c3332aa8e5/go.mod h1:4M0jN8W1tt0AVLNr8HDosyJCDCDuyL9N9+3m7wDWgKw=
-golang.org/x/exp v0.0.0-20230213192124-5e25df0256eb h1:PaBZQdo+iSDyHT053FjUCgZQ/9uqVwPOcl7KSWhKn6w=
-golang.org/x/exp v0.0.0-20230213192124-5e25df0256eb/go.mod h1:CxIveKay+FTh1D0yPZemJVgC/95VzuuOLq5Qi4xnoYc=
+golang.org/x/exp v0.0.0-20230711153332-06a737ee72cb h1:xIApU0ow1zwMa2uL1VDNeQlNVFTWMQxZUZCMDy0Q4Us=
+golang.org/x/exp v0.0.0-20230711153332-06a737ee72cb/go.mod h1:FXUEEKJgO7OQYeo8N01OfiKP8RXMtf6e8aTskBGqWdc=
golang.org/x/image v0.0.0-20190227222117-0694c2d4d067/go.mod h1:kZ7UVZpmo3dzQBMxlp+ypCbDeSB+sBbTgSJuh5dn5js=
golang.org/x/image v0.0.0-20190802002840-cff245a6509b/go.mod h1:FeLwcggjj3mMvU+oOTbSwawSJRM1uh48EjtB4UJZlP0=
golang.org/x/lint v0.0.0-20181026193005-c67002cb31c3/go.mod h1:UVdnD1Gm6xHRNCYTkRU2/jEulfH38KcIWyp/GAMgvoE=
@@ -1557,12 +1235,12 @@ golang.org/x/mod v0.4.0/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA=
golang.org/x/mod v0.4.1/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA=
golang.org/x/mod v0.4.2/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA=
golang.org/x/mod v0.6.0-dev.0.20220419223038-86c51ed26bb4/go.mod h1:jJ57K6gSWd91VN4djpZkiMVwK6gcyfeH4XE8wZrZaV4=
-golang.org/x/mod v0.8.0 h1:LUYupSeNrTNCGzR/hVBk2NHZO4hXcVaW1k4Qx7rjPx8=
-golang.org/x/mod v0.8.0/go.mod h1:iBbtSCu2XBx23ZKBPSOrRkjjQPZFPuis4dIYUhu/chs=
+golang.org/x/mod v0.11.0 h1:bUO06HqtnRcc/7l71XBe4WcqTZ+3AH1J59zWDDwLKgU=
+golang.org/x/mod v0.11.0/go.mod h1:iBbtSCu2XBx23ZKBPSOrRkjjQPZFPuis4dIYUhu/chs=
+golang.org/x/net v0.0.0-20180719180050-a680a1efc54d/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4=
golang.org/x/net v0.0.0-20180724234803-3673e40ba225/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4=
golang.org/x/net v0.0.0-20180826012351-8a410e7b638d/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4=
golang.org/x/net v0.0.0-20180906233101-161cd47e91fd/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4=
-golang.org/x/net v0.0.0-20181011144130-49bb7cea24b1/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4=
golang.org/x/net v0.0.0-20181023162649-9b4f9f5ad519/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4=
golang.org/x/net v0.0.0-20181114220301-adae6a3d119a/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4=
golang.org/x/net v0.0.0-20181201002055-351d144fa1fc/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4=
@@ -1574,16 +1252,12 @@ golang.org/x/net v0.0.0-20190311183353-d8887717615a/go.mod h1:t9HGtf8HONx5eT2rtn
golang.org/x/net v0.0.0-20190404232315-eb5bcb51f2a3/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg=
golang.org/x/net v0.0.0-20190501004415-9ce7a6920f09/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg=
golang.org/x/net v0.0.0-20190503192946-f4e77d36d62c/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg=
-golang.org/x/net v0.0.0-20190522155817-f3200d17e092/go.mod h1:HSz+uSET+XFnRR8LxR5pz3Of3rY3CfYBVs4xY44aLks=
golang.org/x/net v0.0.0-20190603091049-60506f45cf65/go.mod h1:HSz+uSET+XFnRR8LxR5pz3Of3rY3CfYBVs4xY44aLks=
golang.org/x/net v0.0.0-20190613194153-d28f0bde5980/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s=
-golang.org/x/net v0.0.0-20190619014844-b5b0513f8c1b/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s=
golang.org/x/net v0.0.0-20190620200207-3b0461eec859/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s=
golang.org/x/net v0.0.0-20190628185345-da137c7871d7/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s=
golang.org/x/net v0.0.0-20190724013045-ca1201d0de80/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s=
golang.org/x/net v0.0.0-20190813141303-74dc4d7220e7/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s=
-golang.org/x/net v0.0.0-20190827160401-ba9fcec4b297/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s=
-golang.org/x/net v0.0.0-20191004110552-13f9640d40b9/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s=
golang.org/x/net v0.0.0-20191209160850-c0dbc17a3553/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s=
golang.org/x/net v0.0.0-20200114155413-6afb5195e5aa/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s=
golang.org/x/net v0.0.0-20200202094626-16171245cfb2/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s=
@@ -1599,8 +1273,8 @@ golang.org/x/net v0.0.0-20200520004742-59133d7f0dd7/go.mod h1:qpuaurCH72eLCgpAm/
golang.org/x/net v0.0.0-20200520182314-0ba52f642ac2/go.mod h1:qpuaurCH72eLCgpAm/N6yyVIVM9cpaDIP3A8BGJEC5A=
golang.org/x/net v0.0.0-20200625001655-4c5254603344/go.mod h1:/O7V0waA8r7cgGh81Ro3o1hOxt32SMVPicZroKQ2sZA=
golang.org/x/net v0.0.0-20200707034311-ab3426394381/go.mod h1:/O7V0waA8r7cgGh81Ro3o1hOxt32SMVPicZroKQ2sZA=
+golang.org/x/net v0.0.0-20200813134508-3edf25e44fcc/go.mod h1:/O7V0waA8r7cgGh81Ro3o1hOxt32SMVPicZroKQ2sZA=
golang.org/x/net v0.0.0-20200822124328-c89045814202/go.mod h1:/O7V0waA8r7cgGh81Ro3o1hOxt32SMVPicZroKQ2sZA=
-golang.org/x/net v0.0.0-20201006153459-a7d1128ccaa0/go.mod h1:sp8m0HH+o8qH0wwXwYZr8TS3Oi6o0r6Gce1SSxlDquU=
golang.org/x/net v0.0.0-20201021035429-f5854403a974/go.mod h1:sp8m0HH+o8qH0wwXwYZr8TS3Oi6o0r6Gce1SSxlDquU=
golang.org/x/net v0.0.0-20201031054903-ff519b6c9102/go.mod h1:sp8m0HH+o8qH0wwXwYZr8TS3Oi6o0r6Gce1SSxlDquU=
golang.org/x/net v0.0.0-20201110031124-69a78807bb2b/go.mod h1:sp8m0HH+o8qH0wwXwYZr8TS3Oi6o0r6Gce1SSxlDquU=
@@ -1613,7 +1287,7 @@ golang.org/x/net v0.0.0-20210405180319-a5a99cb37ef4/go.mod h1:p54w0d4576C0XHj96b
golang.org/x/net v0.0.0-20210428140749-89ef3d95e781/go.mod h1:OJAsFXCWl8Ukc7SiCT/9KSuxbyM7479/AVlXFRxuMCk=
golang.org/x/net v0.0.0-20210503060351-7fd8e65b6420/go.mod h1:9nx3DQGgdP8bBQD5qxJ1jj9UTztislL4KSBs9R2vV5Y=
golang.org/x/net v0.0.0-20210805182204-aaa1db679c0d/go.mod h1:9nx3DQGgdP8bBQD5qxJ1jj9UTztislL4KSBs9R2vV5Y=
-golang.org/x/net v0.0.0-20210825183410-e898025ed96a/go.mod h1:9nx3DQGgdP8bBQD5qxJ1jj9UTztislL4KSBs9R2vV5Y=
+golang.org/x/net v0.0.0-20211112202133-69e39bad7dc2/go.mod h1:9nx3DQGgdP8bBQD5qxJ1jj9UTztislL4KSBs9R2vV5Y=
golang.org/x/net v0.0.0-20220127200216-cd36cc0744dd/go.mod h1:CfG3xpIq0wQ8r1q4Su4UZFWDARRcnwPjda9FqA0JpMk=
golang.org/x/net v0.0.0-20220225172249-27dd8689420f/go.mod h1:CfG3xpIq0wQ8r1q4Su4UZFWDARRcnwPjda9FqA0JpMk=
golang.org/x/net v0.0.0-20220325170049-de3da57026de/go.mod h1:CfG3xpIq0wQ8r1q4Su4UZFWDARRcnwPjda9FqA0JpMk=
@@ -1626,8 +1300,8 @@ golang.org/x/net v0.0.0-20220722155237-a158d28d115b/go.mod h1:XRhObCWvk6IyKnWLug
golang.org/x/net v0.0.0-20220909164309-bea034e7d591/go.mod h1:YDH+HFinaLZZlnHAfSS6ZXJJ9M9t4Dl22yv3iI2vPwk=
golang.org/x/net v0.0.0-20221014081412-f15817d10f9b/go.mod h1:YDH+HFinaLZZlnHAfSS6ZXJJ9M9t4Dl22yv3iI2vPwk=
golang.org/x/net v0.1.0/go.mod h1:Cx3nUiGt4eDBEyega/BKRp+/AlGL8hYe7U9odMt2Cco=
-golang.org/x/net v0.7.0 h1:rJrUqqhjsgNp7KqAIc25s9pZnjU7TUcSY7HcVZjdn1g=
-golang.org/x/net v0.7.0/go.mod h1:2Tu9+aMcznHK/AK1HMvgo6xiTLG5rD5rZLDS+rp2Bjs=
+golang.org/x/net v0.12.0 h1:cfawfvKITfUsFCeJIHJrbSxpeu/E81khclypR0GVT50=
+golang.org/x/net v0.12.0/go.mod h1:zEVYFnQC7m/vmpQFELhcD1EWkZlX69l4oqgmer6hfKA=
golang.org/x/oauth2 v0.0.0-20180821212333-d2e6202438be/go.mod h1:N/0e6XlmueqKjAGxoOufVs8QHGRruUQn6yWY3a++T0U=
golang.org/x/oauth2 v0.0.0-20190226205417-e64efc72b421/go.mod h1:gOpvHmFTYa4IltrdGE7lF6nIHvwfUNPOp7c8zoXwtLw=
golang.org/x/oauth2 v0.0.0-20190604053449-0f29369cfe45/go.mod h1:gOpvHmFTYa4IltrdGE7lF6nIHvwfUNPOp7c8zoXwtLw=
@@ -1653,8 +1327,8 @@ golang.org/x/oauth2 v0.0.0-20220822191816-0ebed06d0094/go.mod h1:h4gKUeWbJ4rQPri
golang.org/x/oauth2 v0.0.0-20220909003341-f21342109be1/go.mod h1:h4gKUeWbJ4rQPri7E0u6Gs4e9Ri2zaLxzw5DI5XGrYg=
golang.org/x/oauth2 v0.0.0-20221014153046-6fdb5e3db783/go.mod h1:h4gKUeWbJ4rQPri7E0u6Gs4e9Ri2zaLxzw5DI5XGrYg=
golang.org/x/oauth2 v0.1.0/go.mod h1:G9FE4dLTsbXUu90h/Pf85g4w1D+SSAgR+q46nJZ8M4A=
-golang.org/x/oauth2 v0.5.0 h1:HuArIo48skDwlrvM3sEdHXElYslAMsf3KwRkkW4MC4s=
-golang.org/x/oauth2 v0.5.0/go.mod h1:9/XBHVqLaWO3/BRHs5jbpYCnOZVjj5V0ndyaAM7KB4I=
+golang.org/x/oauth2 v0.8.0 h1:6dkIjl3j3LtZ/O3sTgZTMsLKSftL/B8Zgq4huOIIUu8=
+golang.org/x/oauth2 v0.8.0/go.mod h1:yr7u4HXZRm1R1kBWqr/xKNqewf0plRYoB7sla+BCIXE=
golang.org/x/sync v0.0.0-20180314180146-1d60e4601c6f/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
golang.org/x/sync v0.0.0-20181108010431-42b317875d0f/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
golang.org/x/sync v0.0.0-20181221193216-37e7f081c4d4/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
@@ -1669,8 +1343,8 @@ golang.org/x/sync v0.0.0-20210220032951-036812b2e83c/go.mod h1:RxMgew5VJxzue5/jJ
golang.org/x/sync v0.0.0-20220601150217-0de741cfad7f/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
golang.org/x/sync v0.0.0-20220722155255-886fb9371eb4/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
golang.org/x/sync v0.0.0-20220929204114-8fcdb60fdcc0/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
-golang.org/x/sync v0.1.0 h1:wsuoTGHzEhffawBOhz5CYhcrV4IdKZbEyZjBMuTp12o=
-golang.org/x/sync v0.1.0/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
+golang.org/x/sync v0.2.0 h1:PUR+T4wwASmuSTYdKjYHI5TD22Wy5ogLU5qZCOLxBrI=
+golang.org/x/sync v0.2.0/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
golang.org/x/sys v0.0.0-20180823144017-11551d06cbcc/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
golang.org/x/sys v0.0.0-20180830151530-49385e6e1522/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
golang.org/x/sys v0.0.0-20180905080454-ebe1bf3edb33/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
@@ -1687,39 +1361,27 @@ golang.org/x/sys v0.0.0-20190412213103-97732733099d/go.mod h1:h1NjWce9XRLGQEsW7w
golang.org/x/sys v0.0.0-20190422165155-953cdadca894/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20190502145724-3ef323f4f1fd/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20190507160741-ecd444e8653b/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
-golang.org/x/sys v0.0.0-20190514135907-3a4b5fb9f71f/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
-golang.org/x/sys v0.0.0-20190522044717-8097e1b27ff5/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
-golang.org/x/sys v0.0.0-20190602015325-4c4f7f33c9ed/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20190606165138-5da285871e9c/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20190606203320-7fc4e5ec1444/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
-golang.org/x/sys v0.0.0-20190616124812-15dcb6c0061f/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20190624142023-c5567b49c5d0/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20190626221950-04f50cda93cb/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20190726091711-fc99dfbffb4e/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
-golang.org/x/sys v0.0.0-20190801041406-cbf593c0f2f3/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
-golang.org/x/sys v0.0.0-20190812073006-9eafafc0a87e/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20190826190057-c7b8b68b1456/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20190904154756-749cb33beabd/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
-golang.org/x/sys v0.0.0-20190916202348-b4ddaad3f8a3/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20191001151750-bb3f8db39f24/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20191005200804-aed5e4c7ecf9/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
-golang.org/x/sys v0.0.0-20191022100944-742c48ecaeb7/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20191026070338-33540a1f6037/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20191115151921-52ab43148777/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20191120155948-bd437916bb0e/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20191204072324-ce4227a45e2e/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
-golang.org/x/sys v0.0.0-20191210023423-ac6580df4449/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20191220142924-d4481acd189f/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20191228213918-04cbcbbfeed8/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20200106162015-b016eb3dc98e/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20200113162924-86b910548bc1/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20200116001909-b77594299b42/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
-golang.org/x/sys v0.0.0-20200120151820-655fe14d7479/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20200122134326-e047566fdf82/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
-golang.org/x/sys v0.0.0-20200124204421-9fbb57f87de9/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20200202164722-d101bd2416d5/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20200212091648-12a6c2dcc1e4/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
-golang.org/x/sys v0.0.0-20200217220822-9197077df867/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20200223170610-d5e6a3e2c0ae/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20200302150141-5c8b2ff67527/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20200323222414-85ca7c5b95cd/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
@@ -1728,24 +1390,16 @@ golang.org/x/sys v0.0.0-20200420163511-1957bb5e6d1f/go.mod h1:h1NjWce9XRLGQEsW7w
golang.org/x/sys v0.0.0-20200501052902-10377860bb8e/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20200511232937-7e40ca221e25/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20200515095857-1151b9dac4a9/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
+golang.org/x/sys v0.0.0-20200519105757-fe76b779f299/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20200523222454-059865788121/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20200615200032-f1bc736245b1/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
-golang.org/x/sys v0.0.0-20200622214017-ed371f2e16b4/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20200625212154-ddb9806d33ae/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
-golang.org/x/sys v0.0.0-20200728102440-3e129f6d46b1/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20200803210538-64077c9b5642/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
-golang.org/x/sys v0.0.0-20200817155316-9781c653f443/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
+golang.org/x/sys v0.0.0-20200814200057-3d37ad5750ed/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20200905004654-be1d3432aa8f/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
-golang.org/x/sys v0.0.0-20200909081042-eff7692f9009/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
-golang.org/x/sys v0.0.0-20200916030750-2334cc1a136f/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
-golang.org/x/sys v0.0.0-20200922070232-aee5d888a860/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
-golang.org/x/sys v0.0.0-20200923182605-d9f96fdee20d/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20200930185726-fdedc70b468f/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
-golang.org/x/sys v0.0.0-20201112073958-5cba982894dd/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
-golang.org/x/sys v0.0.0-20201117170446-d9b008d0a637/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20201119102817-f84b799fce68/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20201201145000-ef89a241ccb3/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
-golang.org/x/sys v0.0.0-20201202213521-69691e467435/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20210104204734-6f8348627aad/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20210112080510-489259a85091/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20210119212857-b64e53b001e4/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
@@ -1753,14 +1407,11 @@ golang.org/x/sys v0.0.0-20210124154548-22da62e12c0c/go.mod h1:h1NjWce9XRLGQEsW7w
golang.org/x/sys v0.0.0-20210220050731-9a76102bfb43/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20210225134936-a50acf3fe073/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20210305230114-8fe3ee5dd75b/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
-golang.org/x/sys v0.0.0-20210309074719-68d13333faf2/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20210315160823-c6e025ad8005/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20210320140829-1e4c9ba3b0c4/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
-golang.org/x/sys v0.0.0-20210324051608-47abb6519492/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20210330210617-4fbd30eecc44/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20210423082822-04245dca01da/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20210423185535-09eb48e85fd7/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
-golang.org/x/sys v0.0.0-20210426230700-d19ff857e887/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20210510120138-977fb7262007/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/sys v0.0.0-20210514084401-e8d321eab015/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/sys v0.0.0-20210603125802-9665404d3644/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
@@ -1773,7 +1424,7 @@ golang.org/x/sys v0.0.0-20210819135213-f52c844e1c1c/go.mod h1:oPkhp1MJrh7nUepCBc
golang.org/x/sys v0.0.0-20210823070655-63515b42dcdf/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/sys v0.0.0-20210906170528-6f6e22806c34/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/sys v0.0.0-20210908233432-aa78b53d3365/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
-golang.org/x/sys v0.0.0-20211007075335-d3039528d8ac/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
+golang.org/x/sys v0.0.0-20210927094055-39ccf1dd6fa6/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/sys v0.0.0-20211025201205-69cdffdb9359/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/sys v0.0.0-20211116061358-0a5406a5449c/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/sys v0.0.0-20211124211545-fe61309f8881/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
@@ -1792,6 +1443,7 @@ golang.org/x/sys v0.0.0-20220520151302-bc2c85ada10a/go.mod h1:oPkhp1MJrh7nUepCBc
golang.org/x/sys v0.0.0-20220610221304-9f5ed59c137d/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/sys v0.0.0-20220615213510-4f61da869c0c/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/sys v0.0.0-20220624220833-87e55d714810/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
+golang.org/x/sys v0.0.0-20220704084225-05e143d24a9e/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/sys v0.0.0-20220715151400-c0bba94af5f8/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/sys v0.0.0-20220722155257-8c9f86f7a55f/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/sys v0.0.0-20220728004956-3c1f35247d10/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
@@ -1799,14 +1451,14 @@ golang.org/x/sys v0.0.0-20220811171246-fbc7d0a398ab/go.mod h1:oPkhp1MJrh7nUepCBc
golang.org/x/sys v0.0.0-20220908164124-27713097b956/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/sys v0.0.0-20221010170243-090e33056c14/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/sys v0.1.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
-golang.org/x/sys v0.5.0 h1:MUK/U/4lj1t1oPg0HfuXDN/Z1wv31ZJ/YcPiGccS4DU=
-golang.org/x/sys v0.5.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
-golang.org/x/term v0.0.0-20201117132131-f5c789dd3221/go.mod h1:Nr5EML6q2oocZ2LXRh80K7BxOlk5/8JxuGnuhpl+muw=
+golang.org/x/sys v0.6.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
+golang.org/x/sys v0.11.0 h1:eG7RXZHdqOJ1i+0lgLgCpSXAp6M3LYlAo6osgSi0xOM=
+golang.org/x/sys v0.11.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/term v0.0.0-20201126162022-7de9c90e9dd1/go.mod h1:bj7SfCRtBDWHUb9snDiAeCFNEtKQo2Wmx5Cou7ajbmo=
golang.org/x/term v0.0.0-20210927222741-03fcf44c2211/go.mod h1:jbD1KX2456YbFQfuXm/mYQcufACuNUgVhRMnK/tPxf8=
golang.org/x/term v0.1.0/go.mod h1:jbD1KX2456YbFQfuXm/mYQcufACuNUgVhRMnK/tPxf8=
-golang.org/x/term v0.5.0 h1:n2a8QNdAb0sZNpU9R1ALUXBbY+w51fCQDN+7EdxNBsY=
-golang.org/x/term v0.5.0/go.mod h1:jMB1sMXY+tzblOD4FWmEbocvup2/aLOaQEp7JmGp78k=
+golang.org/x/term v0.10.0 h1:3R7pNqamzBraeqj/Tj8qt1aQ2HpmlC+Cx/qL/7hn4/c=
+golang.org/x/term v0.10.0/go.mod h1:lpqdcUyK/oCiQxvxVrppt5ggO2KCZ5QblwqPnfZ6d5o=
golang.org/x/text v0.0.0-20170915032832-14c0d48ead0c/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ=
golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ=
golang.org/x/text v0.3.1-0.20180807135948-17ff2d5776d2/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ=
@@ -1816,19 +1468,17 @@ golang.org/x/text v0.3.4/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ=
golang.org/x/text v0.3.5/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ=
golang.org/x/text v0.3.6/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ=
golang.org/x/text v0.3.7/go.mod h1:u+2+/6zg+i71rQMx5EYifcz6MCKuco9NR6JIITiCfzQ=
+golang.org/x/text v0.3.8/go.mod h1:E6s5w1FMmriuDzIBO73fBruAKo1PCIq6d2Q6DHfQ8WQ=
golang.org/x/text v0.4.0/go.mod h1:mrYo+phRRbMaCq/xk9113O4dZlRixOauAjOtrjsXDZ8=
-golang.org/x/text v0.7.0 h1:4BRB4x83lYWy72KwLD/qYDuTu7q9PjSagHvijDw7cLo=
-golang.org/x/text v0.7.0/go.mod h1:mrYo+phRRbMaCq/xk9113O4dZlRixOauAjOtrjsXDZ8=
+golang.org/x/text v0.12.0 h1:k+n5B8goJNdU7hSvEtMUz3d1Q6D/XW4COJSJR6fN0mc=
+golang.org/x/text v0.12.0/go.mod h1:TvPlkZtksWOMsz7fbANvkp4WM8x/WCo/om8BMLbz+aE=
golang.org/x/time v0.0.0-20180412165947-fbb02b2291d2/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ=
golang.org/x/time v0.0.0-20181108054448-85acf8d2951c/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ=
golang.org/x/time v0.0.0-20190308202827-9d24e82272b4/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ=
golang.org/x/time v0.0.0-20191024005414-555d28b269f0/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ=
-golang.org/x/time v0.0.0-20200416051211-89c76fbcd5d1/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ=
-golang.org/x/time v0.0.0-20200630173020-3af7569d3a1e/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ=
-golang.org/x/time v0.1.0 h1:xYY+Bajn2a7VBmTM5GikTmnK8ZuX8YgnQCqZpbBNtmA=
+golang.org/x/time v0.3.0 h1:rg5rLMjNzMS1RkNLzCG38eapWhnYLFYXDXj2gOlr8j4=
golang.org/x/tools v0.0.0-20180828015842-6cd1fcedba52/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ=
golang.org/x/tools v0.0.0-20180917221912-90fa682c2a6e/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ=
-golang.org/x/tools v0.0.0-20181011042414-1f849cf54d09/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ=
golang.org/x/tools v0.0.0-20190114222345-bf090417da8b/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ=
golang.org/x/tools v0.0.0-20190226205152-f727befe758c/go.mod h1:9Yl7xja0Znq3iFh3HoIrodX9oNMXvdceNzlUR8zjMvY=
golang.org/x/tools v0.0.0-20190311212946-11955173bddd/go.mod h1:LCzVGOaR6xXOjkQ3onu1FJEFr0SW1gC7cKk1uF8kGRs=
@@ -1839,11 +1489,8 @@ golang.org/x/tools v0.0.0-20190425150028-36563e24a262/go.mod h1:RgjU9mgBXZiqYHBn
golang.org/x/tools v0.0.0-20190506145303-2d16b83fe98c/go.mod h1:RgjU9mgBXZiqYHBnxXauZ1Gv1EHHAz9KjViQ78xBX0Q=
golang.org/x/tools v0.0.0-20190524140312-2c0ae7006135/go.mod h1:RgjU9mgBXZiqYHBnxXauZ1Gv1EHHAz9KjViQ78xBX0Q=
golang.org/x/tools v0.0.0-20190606124116-d0a3d012864b/go.mod h1:/rFqwRUd4F7ZHNgwSSTFct+R/Kf4OFW1sUzUTQQTgfc=
-golang.org/x/tools v0.0.0-20190614205625-5aca471b1d59/go.mod h1:/rFqwRUd4F7ZHNgwSSTFct+R/Kf4OFW1sUzUTQQTgfc=
golang.org/x/tools v0.0.0-20190621195816-6e04913cbbac/go.mod h1:/rFqwRUd4F7ZHNgwSSTFct+R/Kf4OFW1sUzUTQQTgfc=
-golang.org/x/tools v0.0.0-20190624222133-a101b041ded4/go.mod h1:/rFqwRUd4F7ZHNgwSSTFct+R/Kf4OFW1sUzUTQQTgfc=
golang.org/x/tools v0.0.0-20190628153133-6cdbf07be9d0/go.mod h1:/rFqwRUd4F7ZHNgwSSTFct+R/Kf4OFW1sUzUTQQTgfc=
-golang.org/x/tools v0.0.0-20190706070813-72ffa07ba3db/go.mod h1:jcCCGcm9btYwXyDqrUWc6MKQKKGJCWEQ3AfLSRIbEuI=
golang.org/x/tools v0.0.0-20190816200558-6889da9d5479/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo=
golang.org/x/tools v0.0.0-20190911174233-4f2ddba30aff/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo=
golang.org/x/tools v0.0.0-20191012152004-8de300cfc20a/go.mod h1:b+2E5dAYhXwXZwtnZ6UAqBI28+e2cm9otk0dWdXHAEo=
@@ -1869,19 +1516,15 @@ golang.org/x/tools v0.0.0-20200304193943-95d2e580d8eb/go.mod h1:o4KQGtdN14AW+yjs
golang.org/x/tools v0.0.0-20200312045724-11d5b4c81c7d/go.mod h1:o4KQGtdN14AW+yjsvvwRTJJuXz8XRtIHtEnmAXLyFUw=
golang.org/x/tools v0.0.0-20200331025713-a30bf2db82d4/go.mod h1:Sl4aGygMT6LrqrWclx+PTx3U+LnKx/seiNR+3G19Ar8=
golang.org/x/tools v0.0.0-20200501065659-ab2804fb9c9d/go.mod h1:EkVYQZoAsY45+roYkvgYkIh4xh/qjgUK9TdY2XT94GE=
-golang.org/x/tools v0.0.0-20200505023115-26f46d2f7ef8/go.mod h1:EkVYQZoAsY45+roYkvgYkIh4xh/qjgUK9TdY2XT94GE=
golang.org/x/tools v0.0.0-20200512131952-2bc93b1c0c88/go.mod h1:EkVYQZoAsY45+roYkvgYkIh4xh/qjgUK9TdY2XT94GE=
golang.org/x/tools v0.0.0-20200515010526-7d3b6ebf133d/go.mod h1:EkVYQZoAsY45+roYkvgYkIh4xh/qjgUK9TdY2XT94GE=
-golang.org/x/tools v0.0.0-20200616133436-c1934b75d054/go.mod h1:EkVYQZoAsY45+roYkvgYkIh4xh/qjgUK9TdY2XT94GE=
golang.org/x/tools v0.0.0-20200618134242-20370b0cb4b2/go.mod h1:EkVYQZoAsY45+roYkvgYkIh4xh/qjgUK9TdY2XT94GE=
golang.org/x/tools v0.0.0-20200619180055-7c47624df98f/go.mod h1:EkVYQZoAsY45+roYkvgYkIh4xh/qjgUK9TdY2XT94GE=
golang.org/x/tools v0.0.0-20200729194436-6467de6f59a7/go.mod h1:njjCfa9FT2d7l9Bc6FUM5FLjQPp3cFF28FI3qnDFljA=
golang.org/x/tools v0.0.0-20200804011535-6c149bb5ef0d/go.mod h1:njjCfa9FT2d7l9Bc6FUM5FLjQPp3cFF28FI3qnDFljA=
golang.org/x/tools v0.0.0-20200825202427-b303f430e36d/go.mod h1:njjCfa9FT2d7l9Bc6FUM5FLjQPp3cFF28FI3qnDFljA=
golang.org/x/tools v0.0.0-20200904185747-39188db58858/go.mod h1:Cj7w3i3Rnn0Xh82ur9kSqwfTHTeVxaDqrfMjpcNT6bE=
-golang.org/x/tools v0.0.0-20200916195026-c9a70fc28ce3/go.mod h1:z6u4i615ZeAfBE4XtMziQW1fSVJXACjjbWkB/mvPzlU=
golang.org/x/tools v0.0.0-20201110124207-079ba7bd75cd/go.mod h1:emZCQorbCU4vsT4fOWvOPXz4eW1wZW4PmDk9uLelYpA=
-golang.org/x/tools v0.0.0-20201124115921-2c860bdd6e78/go.mod h1:emZCQorbCU4vsT4fOWvOPXz4eW1wZW4PmDk9uLelYpA=
golang.org/x/tools v0.0.0-20201201161351-ac6f37ff4c2a/go.mod h1:emZCQorbCU4vsT4fOWvOPXz4eW1wZW4PmDk9uLelYpA=
golang.org/x/tools v0.0.0-20201208233053-a543418bbed2/go.mod h1:emZCQorbCU4vsT4fOWvOPXz4eW1wZW4PmDk9uLelYpA=
golang.org/x/tools v0.0.0-20201224043029-2b0845dc783e/go.mod h1:emZCQorbCU4vsT4fOWvOPXz4eW1wZW4PmDk9uLelYpA=
@@ -1895,8 +1538,8 @@ golang.org/x/tools v0.1.3/go.mod h1:o0xws9oXOQQZyjljx8fwUC0k7L1pTE6eaCbjGeHmOkk=
golang.org/x/tools v0.1.4/go.mod h1:o0xws9oXOQQZyjljx8fwUC0k7L1pTE6eaCbjGeHmOkk=
golang.org/x/tools v0.1.5/go.mod h1:o0xws9oXOQQZyjljx8fwUC0k7L1pTE6eaCbjGeHmOkk=
golang.org/x/tools v0.1.12/go.mod h1:hNGJHUnrk76NpqgfD5Aqm5Crs+Hm0VOH/i9J2+nxYbc=
-golang.org/x/tools v0.6.0 h1:BOw41kyTf3PuCW1pVQf8+Cyg8pMlkYB1oo9iJ6D/lKM=
-golang.org/x/tools v0.6.0/go.mod h1:Xwgl3UAJ/d3gWutnCtw505GrjyAbvKui8lOU390QaIU=
+golang.org/x/tools v0.9.3 h1:Gn1I8+64MsuTb/HpH+LmQtNas23LhUVr3rYZ0eKuaMM=
+golang.org/x/tools v0.9.3/go.mod h1:owI94Op576fPu3cIGQeHs3joujW/2Oc6MtlxbF5dfNc=
golang.org/x/xerrors v0.0.0-20190717185122-a985d3407aa7/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
golang.org/x/xerrors v0.0.0-20191011141410-1b5146add898/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
@@ -1906,7 +1549,6 @@ golang.org/x/xerrors v0.0.0-20220517211312-f3a8303e98df/go.mod h1:K8+ghG5WaK9qNq
golang.org/x/xerrors v0.0.0-20220609144429-65e65417b02f/go.mod h1:K8+ghG5WaK9qNqU5K3HdILfMLy1f3aNYFI/wnl100a8=
golang.org/x/xerrors v0.0.0-20220907171357-04be3eba64a2 h1:H2TDz8ibqkAF6YGhCdN3jS9O0/s90v0rJh3X/OLHEUk=
golang.org/x/xerrors v0.0.0-20220907171357-04be3eba64a2/go.mod h1:K8+ghG5WaK9qNqU5K3HdILfMLy1f3aNYFI/wnl100a8=
-google.golang.org/api v0.0.0-20160322025152-9bf6e6e569ff/go.mod h1:4mhQ8q/RsB7i+udVvVy5NUi08OU8ZlA0gRVgrF7VFY0=
google.golang.org/api v0.3.1/go.mod h1:6wY9I6uQWHQ8EM57III9mq/AjF+i8G65rmVagqKMtkk=
google.golang.org/api v0.4.0/go.mod h1:8k5glujaEP+g9n7WNsDg8QP6cUVNI86fCNMcbazEtwE=
google.golang.org/api v0.7.0/go.mod h1:WtwebWUNSVBH/HAw79HIFXZNqEvBhG+Ra+ax0hx3E3M=
@@ -1956,8 +1598,8 @@ google.golang.org/api v0.96.0/go.mod h1:w7wJQLTM+wvQpNf5JyEcBoxK0RH7EDrh/L4qfsuJ
google.golang.org/api v0.97.0/go.mod h1:w7wJQLTM+wvQpNf5JyEcBoxK0RH7EDrh/L4qfsuJ13s=
google.golang.org/api v0.98.0/go.mod h1:w7wJQLTM+wvQpNf5JyEcBoxK0RH7EDrh/L4qfsuJ13s=
google.golang.org/api v0.100.0/go.mod h1:ZE3Z2+ZOr87Rx7dqFsdRQkRBk36kDtp/h+QpHbB7a70=
-google.golang.org/api v0.110.0 h1:l+rh0KYUooe9JGbGVx71tbFo4SMbMTXK3I3ia2QSEeU=
-google.golang.org/api v0.110.0/go.mod h1:7FC4Vvx1Mooxh8C5HWjzZHcavuS2f6pmJpZx60ca7iI=
+google.golang.org/api v0.126.0 h1:q4GJq+cAdMAC7XP7njvQ4tvohGLiSlytuL4BQxbIZ+o=
+google.golang.org/api v0.126.0/go.mod h1:mBwVAtz+87bEN6CbA1GtZPDOqY2R5ONPqJeIlvyo4Aw=
google.golang.org/appengine v1.1.0/go.mod h1:EbEs0AVv82hx2wNQdGPgUI5lhzA/G0D9YwlJXL52JkM=
google.golang.org/appengine v1.2.0/go.mod h1:xpcJRLb0r/rnEns0DIKYYv+WjYCduHsrkT7/EB5XEv4=
google.golang.org/appengine v1.4.0/go.mod h1:xpcJRLb0r/rnEns0DIKYYv+WjYCduHsrkT7/EB5XEv4=
@@ -1967,14 +1609,12 @@ google.golang.org/appengine v1.6.5/go.mod h1:8WjMMxjGQR8xUklV/ARdw2HLXBOI7O7uCID
google.golang.org/appengine v1.6.6/go.mod h1:8WjMMxjGQR8xUklV/ARdw2HLXBOI7O7uCIDZVag1xfc=
google.golang.org/appengine v1.6.7 h1:FZR1q0exgwxzPzp/aF+VccGrSfxfPpkBqjIIEq3ru6c=
google.golang.org/appengine v1.6.7/go.mod h1:8WjMMxjGQR8xUklV/ARdw2HLXBOI7O7uCIDZVag1xfc=
-google.golang.org/cloud v0.0.0-20151119220103-975617b05ea8/go.mod h1:0H1ncTHf11KCFhTc/+EFRbzSCOZx+VUbRMk55Yv5MYk=
google.golang.org/genproto v0.0.0-20180817151627-c66870c02cf8/go.mod h1:JiN7NxoALGmiZfu7CAH4rXhgtRTLTxftemlI0sWmxmc=
google.golang.org/genproto v0.0.0-20180831171423-11092d34479b/go.mod h1:JiN7NxoALGmiZfu7CAH4rXhgtRTLTxftemlI0sWmxmc=
google.golang.org/genproto v0.0.0-20190307195333-5fe7a883aa19/go.mod h1:VzzqZJRnGkLBvHegQrXjBqPurQTc5/KpmUdxsrq26oE=
google.golang.org/genproto v0.0.0-20190418145605-e7d98fc518a7/go.mod h1:VzzqZJRnGkLBvHegQrXjBqPurQTc5/KpmUdxsrq26oE=
google.golang.org/genproto v0.0.0-20190425155659-357c62f0e4bb/go.mod h1:VzzqZJRnGkLBvHegQrXjBqPurQTc5/KpmUdxsrq26oE=
google.golang.org/genproto v0.0.0-20190502173448-54afdca5d873/go.mod h1:VzzqZJRnGkLBvHegQrXjBqPurQTc5/KpmUdxsrq26oE=
-google.golang.org/genproto v0.0.0-20190522204451-c2c4e71fbf69/go.mod h1:z3L6/3dTEVtUr6QSP8miRzeRqwQOioJ9I66odjN4I7s=
google.golang.org/genproto v0.0.0-20190530194941-fb225487d101/go.mod h1:z3L6/3dTEVtUr6QSP8miRzeRqwQOioJ9I66odjN4I7s=
google.golang.org/genproto v0.0.0-20190801165951-fa694d86fc64/go.mod h1:DMBHOl98Agz4BDEuKkezgsaosCRResVns1a3J2ZsMNc=
google.golang.org/genproto v0.0.0-20190819201941-24fa4b261c55/go.mod h1:DMBHOl98Agz4BDEuKkezgsaosCRResVns1a3J2ZsMNc=
@@ -1984,7 +1624,6 @@ google.golang.org/genproto v0.0.0-20191115194625-c23dd37a84c9/go.mod h1:n3cpQtvx
google.golang.org/genproto v0.0.0-20191216164720-4f79533eabd1/go.mod h1:n3cpQtvxv34hfy77yVDNjmbRyujviMdxYliBSkLhpCc=
google.golang.org/genproto v0.0.0-20191230161307-f3c370f40bfb/go.mod h1:n3cpQtvxv34hfy77yVDNjmbRyujviMdxYliBSkLhpCc=
google.golang.org/genproto v0.0.0-20200115191322-ca5a22157cba/go.mod h1:n3cpQtvxv34hfy77yVDNjmbRyujviMdxYliBSkLhpCc=
-google.golang.org/genproto v0.0.0-20200117163144-32f20d992d24/go.mod h1:n3cpQtvxv34hfy77yVDNjmbRyujviMdxYliBSkLhpCc=
google.golang.org/genproto v0.0.0-20200122232147-0452cf42e150/go.mod h1:n3cpQtvxv34hfy77yVDNjmbRyujviMdxYliBSkLhpCc=
google.golang.org/genproto v0.0.0-20200204135345-fa8e72b47b90/go.mod h1:GmwEX6Z4W5gMy59cAlVYjN9JhxgbQH6Gn+gFDQe2lzA=
google.golang.org/genproto v0.0.0-20200212174721-66ed5ce911ce/go.mod h1:55QSHmfGQM9UVYDPBsyGGes0y52j32PQ3BqQfXhyH3c=
@@ -2000,14 +1639,12 @@ google.golang.org/genproto v0.0.0-20200511104702-f5ebc3bea380/go.mod h1:55QSHmfG
google.golang.org/genproto v0.0.0-20200513103714-09dca8ec2884/go.mod h1:55QSHmfGQM9UVYDPBsyGGes0y52j32PQ3BqQfXhyH3c=
google.golang.org/genproto v0.0.0-20200515170657-fc4c6c6a6587/go.mod h1:YsZOwe1myG/8QRHRsmBRE1LrgQY60beZKjly0O1fX9U=
google.golang.org/genproto v0.0.0-20200526211855-cb27e3aa2013/go.mod h1:NbSheEEYHJ7i3ixzK3sjbqSGDJWnxyFXZblF3eUsNvo=
-google.golang.org/genproto v0.0.0-20200527145253-8367513e4ece/go.mod h1:jDfRM7FcilCzHH/e9qn6dsT145K34l5v+OpcnNgKAAA=
google.golang.org/genproto v0.0.0-20200618031413-b414f8b61790/go.mod h1:jDfRM7FcilCzHH/e9qn6dsT145K34l5v+OpcnNgKAAA=
google.golang.org/genproto v0.0.0-20200729003335-053ba62fc06f/go.mod h1:FWY/as6DDZQgahTzZj3fqbO1CbirC29ZNUFHwi0/+no=
google.golang.org/genproto v0.0.0-20200804131852-c06518451d9c/go.mod h1:FWY/as6DDZQgahTzZj3fqbO1CbirC29ZNUFHwi0/+no=
google.golang.org/genproto v0.0.0-20200825200019-8632dd797987/go.mod h1:FWY/as6DDZQgahTzZj3fqbO1CbirC29ZNUFHwi0/+no=
google.golang.org/genproto v0.0.0-20200904004341-0bd0a958aa1d/go.mod h1:FWY/as6DDZQgahTzZj3fqbO1CbirC29ZNUFHwi0/+no=
google.golang.org/genproto v0.0.0-20201109203340-2640f1f9cdfb/go.mod h1:FWY/as6DDZQgahTzZj3fqbO1CbirC29ZNUFHwi0/+no=
-google.golang.org/genproto v0.0.0-20201110150050-8816d57aaa9a/go.mod h1:FWY/as6DDZQgahTzZj3fqbO1CbirC29ZNUFHwi0/+no=
google.golang.org/genproto v0.0.0-20201201144952-b05cb90ed32e/go.mod h1:FWY/as6DDZQgahTzZj3fqbO1CbirC29ZNUFHwi0/+no=
google.golang.org/genproto v0.0.0-20201210142538-e3217bee35cc/go.mod h1:FWY/as6DDZQgahTzZj3fqbO1CbirC29ZNUFHwi0/+no=
google.golang.org/genproto v0.0.0-20201214200347-8c77b98c765d/go.mod h1:FWY/as6DDZQgahTzZj3fqbO1CbirC29ZNUFHwi0/+no=
@@ -2081,9 +1718,12 @@ google.golang.org/genproto v0.0.0-20221010155953-15ba04fc1c0e/go.mod h1:3526vdqw
google.golang.org/genproto v0.0.0-20221014173430-6e2ab493f96b/go.mod h1:1vXfmgAz9N9Jx0QA82PqRVauvCz1SGSz739p0f183jM=
google.golang.org/genproto v0.0.0-20221014213838-99cd37c6964a/go.mod h1:1vXfmgAz9N9Jx0QA82PqRVauvCz1SGSz739p0f183jM=
google.golang.org/genproto v0.0.0-20221025140454-527a21cfbd71/go.mod h1:9qHF0xnpdSfF6knlcsnpzUu5y+rpwgbvsyGAZPBMg4s=
-google.golang.org/genproto v0.0.0-20230216225411-c8e22ba71e44 h1:EfLuoKW5WfkgVdDy7dTK8qSbH37AX5mj/MFh+bGPz14=
-google.golang.org/genproto v0.0.0-20230216225411-c8e22ba71e44/go.mod h1:8B0gmkoRebU8ukX6HP+4wrVQUY1+6PkQ44BSyIlflHA=
-google.golang.org/grpc v0.0.0-20160317175043-d3ddb4469d5a/go.mod h1:yo6s7OP7yaDglbqo1J04qKzAhqBH6lvTonzMVmEdcZw=
+google.golang.org/genproto v0.0.0-20230706204954-ccb25ca9f130 h1:Au6te5hbKUV8pIYWHqOUZ1pva5qK/rwbIhoXEUB9Lu8=
+google.golang.org/genproto v0.0.0-20230706204954-ccb25ca9f130/go.mod h1:O9kGHb51iE/nOGvQaDUuadVYqovW56s5emA88lQnj6Y=
+google.golang.org/genproto/googleapis/api v0.0.0-20230629202037-9506855d4529 h1:s5YSX+ZH5b5vS9rnpGymvIyMpLRJizowqDlOuyjXnTk=
+google.golang.org/genproto/googleapis/api v0.0.0-20230629202037-9506855d4529/go.mod h1:vHYtlOoi6TsQ3Uk2yxR7NI5z8uoV+3pZtR4jmHIkRig=
+google.golang.org/genproto/googleapis/rpc v0.0.0-20230711160842-782d3b101e98 h1:bVf09lpb+OJbByTj913DRJioFFAjf/ZGxEz7MajTp2U=
+google.golang.org/genproto/googleapis/rpc v0.0.0-20230711160842-782d3b101e98/go.mod h1:TUfxEVdsvPg18p6AslUXFoLdpED4oBnGwyqk3dV1XzM=
google.golang.org/grpc v1.17.0/go.mod h1:6QZJwpn2B+Zp71q/5VxRsJ6NXXVCE5NRUHRo+f3cWCs=
google.golang.org/grpc v1.19.0/go.mod h1:mqu4LbDTu4XGKhr4mRzUsmM4RtVoemTSY81AxZiDr8c=
google.golang.org/grpc v1.20.0/go.mod h1:chYK+tFQF0nDUGJgXMSgLCQk3phJEuONr2DCgLDdAQM=
@@ -2093,7 +1733,6 @@ google.golang.org/grpc v1.21.1/go.mod h1:oYelfM1adQP15Ek0mdvEgi9Df8B9CZIaU1084ij
google.golang.org/grpc v1.22.1/go.mod h1:Y5yQAOtifL1yxbo5wqy6BxZv8vAUGQwXBOALyacEbxg=
google.golang.org/grpc v1.23.0/go.mod h1:Y5yQAOtifL1yxbo5wqy6BxZv8vAUGQwXBOALyacEbxg=
google.golang.org/grpc v1.23.1/go.mod h1:Y5yQAOtifL1yxbo5wqy6BxZv8vAUGQwXBOALyacEbxg=
-google.golang.org/grpc v1.24.0/go.mod h1:XDChyiUovWa60DnaeDeZmSW86xtLtjtZbwvSiRnRtcA=
google.golang.org/grpc v1.25.1/go.mod h1:c3i+UQWmh7LiEpx4sFZnkU36qjEYZ0imhYfXVyQciAY=
google.golang.org/grpc v1.26.0/go.mod h1:qbnxyOmOxrQa7FizSgH+ReBfzJrCY1pSN7KXBS8abTk=
google.golang.org/grpc v1.27.0/go.mod h1:qbnxyOmOxrQa7FizSgH+ReBfzJrCY1pSN7KXBS8abTk=
@@ -2126,8 +1765,8 @@ google.golang.org/grpc v1.48.0/go.mod h1:vN9eftEi1UMyUsIF80+uQXhHjbXYbm0uXoFCACu
google.golang.org/grpc v1.49.0/go.mod h1:ZgQEeidpAuNRZ8iRrlBKXZQP1ghovWIVhdJRyCDK+GI=
google.golang.org/grpc v1.50.0/go.mod h1:ZgQEeidpAuNRZ8iRrlBKXZQP1ghovWIVhdJRyCDK+GI=
google.golang.org/grpc v1.50.1/go.mod h1:ZgQEeidpAuNRZ8iRrlBKXZQP1ghovWIVhdJRyCDK+GI=
-google.golang.org/grpc v1.53.0 h1:LAv2ds7cmFV/XTS3XG1NneeENYrXGmorPxsBbptIjNc=
-google.golang.org/grpc v1.53.0/go.mod h1:OnIrk0ipVdj4N5d9IUoFUx72/VlD7+jUsHwZgwSMQpw=
+google.golang.org/grpc v1.56.2 h1:fVRFRnXvU+x6C4IlHZewvJOVHoOv1TUuQyoRsYnB4bI=
+google.golang.org/grpc v1.56.2/go.mod h1:I9bI3vqKfayGqPUAwGdOSu7kt6oIJLixfffKrpXqQ9s=
google.golang.org/grpc/cmd/protoc-gen-go-grpc v1.1.0/go.mod h1:6Kw0yEErY5E/yWrBtf03jp27GLLJujG4z/JK95pnjjw=
google.golang.org/protobuf v0.0.0-20200109180630-ec00e32a8dfd/go.mod h1:DFci5gLYBciE7Vtevhsrf46CRTquxDuWsQurQQe4oz8=
google.golang.org/protobuf v0.0.0-20200221191635-4d8936d0db64/go.mod h1:kwYJMbMJ01Woi6D6+Kah6886xMZcty6N08ah7+eCXa0=
@@ -2144,15 +1783,12 @@ google.golang.org/protobuf v1.26.0/go.mod h1:9q0QmTI4eRPtz6boOQmLYwt+qCgq0jsYwAQ
google.golang.org/protobuf v1.27.1/go.mod h1:9q0QmTI4eRPtz6boOQmLYwt+qCgq0jsYwAQnmE0givc=
google.golang.org/protobuf v1.28.0/go.mod h1:HV8QOd/L58Z+nl8r43ehVNZIU/HEI6OcFqwMG9pJV4I=
google.golang.org/protobuf v1.28.1/go.mod h1:HV8QOd/L58Z+nl8r43ehVNZIU/HEI6OcFqwMG9pJV4I=
-google.golang.org/protobuf v1.28.2-0.20230208135220-49eaa78c6c9c h1:gDe3xeLH/W6iv5d9xQBo6IwJbCdVcZRiV8xuix6FJW8=
-google.golang.org/protobuf v1.28.2-0.20230208135220-49eaa78c6c9c/go.mod h1:HV8QOd/L58Z+nl8r43ehVNZIU/HEI6OcFqwMG9pJV4I=
-gopkg.in/airbrake/gobrake.v2 v2.0.9/go.mod h1:/h5ZAUhDkGaJfjzjKLSjv6zCL6O0LLBxU4K+aSYdM/U=
+google.golang.org/protobuf v1.31.0 h1:g0LDEJHgrBl9N9r17Ru3sqWhkIx2NB67okBHPwC7hs8=
+google.golang.org/protobuf v1.31.0/go.mod h1:HV8QOd/L58Z+nl8r43ehVNZIU/HEI6OcFqwMG9pJV4I=
gopkg.in/alecthomas/kingpin.v2 v2.2.6/go.mod h1:FMv+mEhP44yOT+4EoQTLFTRgOQ1FBLkstjWtayDeSgw=
gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
-gopkg.in/check.v1 v1.0.0-20141024133853-64131543e789/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
gopkg.in/check.v1 v1.0.0-20180628173108-788fd7840127/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
gopkg.in/check.v1 v1.0.0-20190902080502-41f04d3bba15/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
-gopkg.in/check.v1 v1.0.0-20200227125254-8fa46927fb4f/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
gopkg.in/check.v1 v1.0.0-20200902074654-038fdea0a05b/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
gopkg.in/check.v1 v1.0.0-20201130134442-10cb98267c6c h1:Hei/4ADfdWqJk1ZMxUNpqntNwaWcugrBjAiHlqqRiVk=
gopkg.in/cheggaaa/pb.v1 v1.0.25/go.mod h1:V/YB90LKu/1FcN3WVnfiiE5oMCibMjukxqG/qStrOgw=
@@ -2160,17 +1796,11 @@ gopkg.in/cheggaaa/pb.v1 v1.0.27/go.mod h1:V/YB90LKu/1FcN3WVnfiiE5oMCibMjukxqG/qS
gopkg.in/errgo.v2 v2.1.0/go.mod h1:hNsd1EY+bozCKY1Ytp96fpM3vjJbqLJn88ws8XvfDNI=
gopkg.in/fsnotify.v1 v1.4.7/go.mod h1:Tz8NjZHkW78fSQdbUxIjBTcgA1z1m8ZHf0WmKUhAMys=
gopkg.in/gcfg.v1 v1.2.3/go.mod h1:yesOnuUOFQAhST5vPY4nbZsb/huCgGGXlipJsBn0b3o=
-gopkg.in/gemnasium/logrus-airbrake-hook.v2 v2.1.2/go.mod h1:Xk6kEKp8OKb+X14hQBKWaSkCsqBpgog8nAV2xsGOxlo=
-gopkg.in/inf.v0 v0.9.1/go.mod h1:cWUDdTG/fYaXco+Dcufb5Vnc6Gp2YChqWtbxRZE0mXw=
gopkg.in/ini.v1 v1.67.0 h1:Dgnx+6+nfE+IfzjUEISNeydPJh9AXNNsWbGP9KzCsOA=
gopkg.in/ini.v1 v1.67.0/go.mod h1:pNLf8WUiyNEtQjuu5G5vTm06TEv9tsIgeAvK8hOrP4k=
-gopkg.in/natefinch/lumberjack.v2 v2.0.0/go.mod h1:l0ndWWf7gzL7RNwBG7wST/UCcT4T24xpD6X8LsfU/+k=
gopkg.in/natefinch/npipe.v2 v2.0.0-20160621034901-c1b8fa8bdcce h1:+JknDZhAj8YMt7GC73Ei8pv4MzjDUNPHgQWJdtMAaDU=
gopkg.in/natefinch/npipe.v2 v2.0.0-20160621034901-c1b8fa8bdcce/go.mod h1:5AcXVHNjg+BDxry382+8OKon8SEWiKktQR07RKPsv1c=
gopkg.in/resty.v1 v1.12.0/go.mod h1:mDo4pnntr5jdWRML875a/NmxYqAlA73dVijT2AXvQQo=
-gopkg.in/square/go-jose.v2 v2.2.2/go.mod h1:M9dMgbHiYLoDGQrXy7OpJDJWiKiU//h+vD76mk0e1AI=
-gopkg.in/square/go-jose.v2 v2.3.1/go.mod h1:M9dMgbHiYLoDGQrXy7OpJDJWiKiU//h+vD76mk0e1AI=
-gopkg.in/square/go-jose.v2 v2.5.1/go.mod h1:M9dMgbHiYLoDGQrXy7OpJDJWiKiU//h+vD76mk0e1AI=
gopkg.in/tomb.v1 v1.0.0-20141024135613-dd632973f1e7 h1:uRGJdciOHaEIrze2W8Q3AKkepLTh2hOroT7a+7czfdQ=
gopkg.in/tomb.v1 v1.0.0-20141024135613-dd632973f1e7/go.mod h1:dt/ZhP58zS4L8KSrWDmTeBkI65Dw0HsyUHuEVlX15mw=
gopkg.in/warnings.v0 v0.1.2/go.mod h1:jksf8JmL6Qr/oQM2OXTHunEvvTAsrWBLb6OOjuVWRNI=
@@ -2189,10 +1819,7 @@ gopkg.in/yaml.v3 v3.0.0-20210107192922-496545a6307b/go.mod h1:K4uyk7z7BCEPqu6E+C
gopkg.in/yaml.v3 v3.0.1 h1:fxVm/GzAzEWqLHuvctI91KS9hhNmmWOoWu0XTYJS7CA=
gopkg.in/yaml.v3 v3.0.1/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=
gotest.tools v2.2.0+incompatible h1:VsBPFP1AI068pPrMxtb/S8Zkgf9xEmTLJjfM+P5UIEo=
-gotest.tools v2.2.0+incompatible/go.mod h1:DsYFclhRJ6vuDpmuTbkuFWG+y2sxOXAzmJt81HFBacw=
-gotest.tools/v3 v3.0.2/go.mod h1:3SzNCllyD9/Y+b5r9JIKQ474KzkZyqLqEfYqMsX94Bk=
-gotest.tools/v3 v3.0.3/go.mod h1:Z7Lb0S5l+klDB31fvDQX8ss/FlKDxtlFlw3Oa8Ymbl8=
-gotest.tools/v3 v3.4.0 h1:ZazjZUfuVeZGLAmlKKuyv3IKP5orXcwtOwDQH6YVr6o=
+gotest.tools/v3 v3.5.0 h1:Ljk6PdHdOhAb5aDMWXjDLMMhph+BpztA4v1QdqEW2eY=
honnef.co/go/tools v0.0.0-20180728063816-88497007e858/go.mod h1:rf3lG4BRIbNafJWhAfAdb/ePZxsR/4RtNHQocxwk9r4=
honnef.co/go/tools v0.0.0-20190102054323-c2f93a96b099/go.mod h1:rf3lG4BRIbNafJWhAfAdb/ePZxsR/4RtNHQocxwk9r4=
honnef.co/go/tools v0.0.0-20190106161140-3f1c8253044a/go.mod h1:rf3lG4BRIbNafJWhAfAdb/ePZxsR/4RtNHQocxwk9r4=
@@ -2201,73 +1828,34 @@ honnef.co/go/tools v0.0.0-20190523083050-ea95bdfd59fc/go.mod h1:rf3lG4BRIbNafJWh
honnef.co/go/tools v0.0.1-2019.2.3/go.mod h1:a3bituU0lyd329TUQxRnasdCoJDkEUEAqEt0JzvZhAg=
honnef.co/go/tools v0.0.1-2020.1.3/go.mod h1:X/FiERA/W4tHapMX5mGpAtMSVEeEUOyHaw9vFzvIQ3k=
honnef.co/go/tools v0.0.1-2020.1.4/go.mod h1:X/FiERA/W4tHapMX5mGpAtMSVEeEUOyHaw9vFzvIQ3k=
-k8s.io/api v0.20.1/go.mod h1:KqwcCVogGxQY3nBlRpwt+wpAMF/KjaCc7RpywacvqUo=
-k8s.io/api v0.20.4/go.mod h1:++lNL1AJMkDymriNniQsWRkMDzRaX2Y/POTUi8yvqYQ=
-k8s.io/api v0.20.6/go.mod h1:X9e8Qag6JV/bL5G6bU8sdVRltWKmdHsFUGS3eVndqE8=
-k8s.io/apimachinery v0.20.1/go.mod h1:WlLqWAHZGg07AeltaI0MV5uk1Omp8xaN0JGLY6gkRpU=
-k8s.io/apimachinery v0.20.4/go.mod h1:WlLqWAHZGg07AeltaI0MV5uk1Omp8xaN0JGLY6gkRpU=
-k8s.io/apimachinery v0.20.6/go.mod h1:ejZXtW1Ra6V1O5H8xPBGz+T3+4gfkTCeExAHKU57MAc=
-k8s.io/apiserver v0.20.1/go.mod h1:ro5QHeQkgMS7ZGpvf4tSMx6bBOgPfE+f52KwvXfScaU=
-k8s.io/apiserver v0.20.4/go.mod h1:Mc80thBKOyy7tbvFtB4kJv1kbdD0eIH8k8vianJcbFM=
-k8s.io/apiserver v0.20.6/go.mod h1:QIJXNt6i6JB+0YQRNcS0hdRHJlMhflFmsBDeSgT1r8Q=
-k8s.io/client-go v0.20.1/go.mod h1:/zcHdt1TeWSd5HoUe6elJmHSQ6uLLgp4bIJHVEuy+/Y=
-k8s.io/client-go v0.20.4/go.mod h1:LiMv25ND1gLUdBeYxBIwKpkSC5IsozMMmOOeSJboP+k=
-k8s.io/client-go v0.20.6/go.mod h1:nNQMnOvEUEsOzRRFIIkdmYOjAZrC8bgq0ExboWSU1I0=
-k8s.io/code-generator v0.19.7/go.mod h1:lwEq3YnLYb/7uVXLorOJfxg+cUu2oihFhHZ0n9NIla0=
-k8s.io/component-base v0.20.1/go.mod h1:guxkoJnNoh8LNrbtiQOlyp2Y2XFCZQmrcg2n/DeYNLk=
-k8s.io/component-base v0.20.4/go.mod h1:t4p9EdiagbVCJKrQ1RsA5/V4rFQNDfRlevJajlGwgjI=
-k8s.io/component-base v0.20.6/go.mod h1:6f1MPBAeI+mvuts3sIdtpjljHWBQ2cIy38oBIWMYnrM=
-k8s.io/cri-api v0.17.3/go.mod h1:X1sbHmuXhwaHs9xxYffLqJogVsnI+f6cPRcgPel7ywM=
-k8s.io/cri-api v0.20.1/go.mod h1:2JRbKt+BFLTjtrILYVqQK5jqhI+XNdF6UiGMgczeBCI=
-k8s.io/cri-api v0.20.4/go.mod h1:2JRbKt+BFLTjtrILYVqQK5jqhI+XNdF6UiGMgczeBCI=
-k8s.io/cri-api v0.20.6/go.mod h1:ew44AjNXwyn1s0U4xCKGodU7J1HzBeZ1MpGrpa5r8Yc=
-k8s.io/gengo v0.0.0-20200413195148-3a45101e95ac/go.mod h1:ezvh/TsK7cY6rbqRK0oQQ8IAqLxYwwyPxAX1Pzy0ii0=
-k8s.io/gengo v0.0.0-20200428234225-8167cfdcfc14/go.mod h1:ezvh/TsK7cY6rbqRK0oQQ8IAqLxYwwyPxAX1Pzy0ii0=
-k8s.io/gengo v0.0.0-20201113003025-83324d819ded/go.mod h1:FiNAH4ZV3gBg2Kwh89tzAEV2be7d5xI0vBa/VySYy3E=
-k8s.io/klog/v2 v2.0.0/go.mod h1:PBfzABfn139FHAV07az/IF9Wp1bkk3vpT2XSJ76fSDE=
-k8s.io/klog/v2 v2.2.0/go.mod h1:Od+F08eJP+W3HUb4pSrPpgp9DGU4GzlpG/TmITuYh/Y=
-k8s.io/klog/v2 v2.4.0/go.mod h1:Od+F08eJP+W3HUb4pSrPpgp9DGU4GzlpG/TmITuYh/Y=
-k8s.io/kube-openapi v0.0.0-20200805222855-6aeccd4b50c6/go.mod h1:UuqjUnNftUyPE5H64/qeyjQoUZhGpeFDVdxjTeEVN2o=
-k8s.io/kube-openapi v0.0.0-20201113171705-d219536bb9fd/go.mod h1:WOJ3KddDSol4tAGcJo0Tvi+dK12EcqSLqcWsryKMpfM=
-k8s.io/kubernetes v1.13.0/go.mod h1:ocZa8+6APFNC2tX1DZASIbocyYT5jHzqFVsY5aoB7Jk=
-k8s.io/utils v0.0.0-20201110183641-67b214c5f920/go.mod h1:jPW/WVKK9YHAvNhRxK0md/EJ228hCsBRufyofKtW8HA=
-lukechampine.com/blake3 v1.1.6 h1:H3cROdztr7RCfoaTpGZFQsrqvweFLrqS73j7L7cmR5c=
-lukechampine.com/blake3 v1.1.6/go.mod h1:tkKEOtDkNtklkXtLNEOGNq5tcV90tJiA1vAA12R78LA=
-lukechampine.com/uint128 v1.1.1 h1:pnxCASz787iMf+02ssImqk6OLt+Z5QHMoZyUXR4z6JU=
-lukechampine.com/uint128 v1.1.1/go.mod h1:c4eWIwlEGaxC/+H1VguhU4PHXNWDCDMUlWdIWl2j1gk=
-modernc.org/cc/v3 v3.36.0 h1:0kmRkTmqNidmu3c7BNDSdVHCxXCkWLmWmCIVX4LUboo=
-modernc.org/cc/v3 v3.36.0/go.mod h1:NFUHyPn4ekoC/JHeZFfZurN6ixxawE1BnVonP/oahEI=
-modernc.org/ccgo/v3 v3.0.0-20220428102840-41399a37e894/go.mod h1:eI31LL8EwEBKPpNpA4bU1/i+sKOwOrQy8D87zWUcRZc=
-modernc.org/ccgo/v3 v3.0.0-20220430103911-bc99d88307be/go.mod h1:bwdAnOoaIt8Ax9YdWGjxWsdkPcZyRPHqrOvJxaKAKGw=
-modernc.org/ccgo/v3 v3.16.4/go.mod h1:tGtX0gE9Jn7hdZFeU88slbTh1UtCYKusWOoCJuvkWsQ=
-modernc.org/ccgo/v3 v3.16.6 h1:3l18poV+iUemQ98O3X5OMr97LOqlzis+ytivU4NqGhA=
-modernc.org/ccgo/v3 v3.16.6/go.mod h1:tGtX0gE9Jn7hdZFeU88slbTh1UtCYKusWOoCJuvkWsQ=
+launchpad.net/gocheck v0.0.0-20140225173054-000000000087 h1:Izowp2XBH6Ya6rv+hqbceQyw/gSGoXfH/UPoTGduL54=
+launchpad.net/gocheck v0.0.0-20140225173054-000000000087/go.mod h1:hj7XX3B/0A+80Vse0e+BUHsHMTEhd0O4cpUHr/e/BUM=
+lukechampine.com/blake3 v1.1.7 h1:GgRMhmdsuK8+ii6UZFDL8Nb+VyMwadAgcJyfYHxG6n0=
+lukechampine.com/blake3 v1.1.7/go.mod h1:tkKEOtDkNtklkXtLNEOGNq5tcV90tJiA1vAA12R78LA=
+lukechampine.com/uint128 v1.2.0 h1:mBi/5l91vocEN8otkC5bDLhi2KdCticRiwbdB0O+rjI=
+lukechampine.com/uint128 v1.2.0/go.mod h1:c4eWIwlEGaxC/+H1VguhU4PHXNWDCDMUlWdIWl2j1gk=
+modernc.org/cc/v3 v3.40.0 h1:P3g79IUS/93SYhtoeaHW+kRCIrYaxJ27MFPv+7kaTOw=
+modernc.org/cc/v3 v3.40.0/go.mod h1:/bTg4dnWkSXowUO6ssQKnOV0yMVxDYNIsIrzqTFDGH0=
+modernc.org/ccgo/v3 v3.16.13 h1:Mkgdzl46i5F/CNR/Kj80Ri59hC8TKAhZrYSaqvkwzUw=
+modernc.org/ccgo/v3 v3.16.13/go.mod h1:2Quk+5YgpImhPjv2Qsob1DnZ/4som1lJTodubIcoUkY=
modernc.org/ccorpus v1.11.6 h1:J16RXiiqiCgua6+ZvQot4yUuUy8zxgqbqEEUuGPlISk=
-modernc.org/ccorpus v1.11.6/go.mod h1:2gEUTrWqdpH2pXsmTM1ZkjeSrUWDpjMu2T6m29L/ErQ=
modernc.org/httpfs v1.0.6 h1:AAgIpFZRXuYnkjftxTAZwMIiwEqAfk8aVB2/oA6nAeM=
-modernc.org/httpfs v1.0.6/go.mod h1:7dosgurJGp0sPaRanU53W4xZYKh14wfzX420oZADeHM=
-modernc.org/libc v0.0.0-20220428101251-2d5f3daf273b/go.mod h1:p7Mg4+koNjc8jkqwcoFBJx7tXkpj00G77X7A72jXPXA=
-modernc.org/libc v1.16.0/go.mod h1:N4LD6DBE9cf+Dzf9buBlzVJndKr/iJHG97vGLHYnb5A=
-modernc.org/libc v1.16.1/go.mod h1:JjJE0eu4yeK7tab2n4S1w8tlWd9MxXLRzheaRnAKymU=
-modernc.org/libc v1.16.7 h1:qzQtHhsZNpVPpeCu+aMIQldXeV1P0vRhSqCL0nOIJOA=
-modernc.org/libc v1.16.7/go.mod h1:hYIV5VZczAmGZAnG15Vdngn5HSF5cSkbvfz2B7GRuVU=
-modernc.org/mathutil v1.2.2/go.mod h1:mZW8CKdRPY1v87qxC/wUdX5O1qDzXMP5TH3wjfpga6E=
-modernc.org/mathutil v1.4.1 h1:ij3fYGe8zBF4Vu+g0oT7mB06r8sqGWKuJu1yXeR4by8=
-modernc.org/mathutil v1.4.1/go.mod h1:mZW8CKdRPY1v87qxC/wUdX5O1qDzXMP5TH3wjfpga6E=
-modernc.org/memory v1.1.1 h1:bDOL0DIDLQv7bWhP3gMvIrnoFw+Eo6F7a2QK9HPDiFU=
-modernc.org/memory v1.1.1/go.mod h1:/0wo5ibyrQiaoUoH7f9D8dnglAmILJ5/cxZlRECf+Nw=
-modernc.org/opt v0.1.1 h1:/0RX92k9vwVeDXj+Xn23DKp2VJubL7k8qNffND6qn3A=
-modernc.org/opt v0.1.1/go.mod h1:WdSiB5evDcignE70guQKxYUl14mgWtbClRi5wmkkTX0=
-modernc.org/sqlite v1.17.3 h1:iE+coC5g17LtByDYDWKpR6m2Z9022YrSh3bumwOnIrI=
-modernc.org/sqlite v1.17.3/go.mod h1:10hPVYar9C0kfXuTWGz8s0XtB8uAGymUy51ZzStYe3k=
-modernc.org/strutil v1.1.1 h1:xv+J1BXY3Opl2ALrBwyfEikFAj8pmqcpnfmuwUwcozs=
-modernc.org/strutil v1.1.1/go.mod h1:DE+MQQ/hjKBZS2zNInV5hhcipt5rLPWkmpbGeW5mmdw=
-modernc.org/tcl v1.13.1 h1:npxzTwFTZYM8ghWicVIX1cRWzj7Nd8i6AqqX2p+IYao=
-modernc.org/tcl v1.13.1/go.mod h1:XOLfOwzhkljL4itZkK6T72ckMgvj0BDsnKNdZVUOecw=
-modernc.org/token v1.0.0 h1:a0jaWiNMDhDUtqOj09wvjWWAqd3q7WpBulmL9H2egsk=
-modernc.org/token v1.0.0/go.mod h1:UGzOrNV1mAFSEB63lOFHIpNRUVMvYTc6yu1SMY/XTDM=
-modernc.org/z v1.5.1 h1:RTNHdsrOpeoSeOF4FbzTo8gBYByaJ5xT7NgZ9ZqRiJM=
-modernc.org/z v1.5.1/go.mod h1:eWFB510QWW5Th9YGZT81s+LwvaAs3Q2yr4sP0rmLkv8=
+modernc.org/libc v1.22.5 h1:91BNch/e5B0uPbJFgqbxXuOnxBQjlS//icfQEGmvyjE=
+modernc.org/libc v1.22.5/go.mod h1:jj+Z7dTNX8fBScMVNRAYZ/jF91K8fdT2hYMThc3YjBY=
+modernc.org/mathutil v1.5.0 h1:rV0Ko/6SfM+8G+yKiyI830l3Wuz1zRutdslNoQ0kfiQ=
+modernc.org/mathutil v1.5.0/go.mod h1:mZW8CKdRPY1v87qxC/wUdX5O1qDzXMP5TH3wjfpga6E=
+modernc.org/memory v1.5.0 h1:N+/8c5rE6EqugZwHii4IFsaJ7MUhoWX07J5tC/iI5Ds=
+modernc.org/memory v1.5.0/go.mod h1:PkUhL0Mugw21sHPeskwZW4D6VscE/GQJOnIpCnW6pSU=
+modernc.org/opt v0.1.3 h1:3XOZf2yznlhC+ibLltsDGzABUGVx8J6pnFMS3E4dcq4=
+modernc.org/opt v0.1.3/go.mod h1:WdSiB5evDcignE70guQKxYUl14mgWtbClRi5wmkkTX0=
+modernc.org/sqlite v1.23.0 h1:MWTFBI5H1WLnXpNBh/BTruBVqzzoh28DA0iOnlkkRaM=
+modernc.org/sqlite v1.23.0/go.mod h1:OrDj17Mggn6MhE+iPbBNf7RGKODDE9NFT0f3EwDzJqk=
+modernc.org/strutil v1.1.3 h1:fNMm+oJklMGYfU9Ylcywl0CO5O6nTfaowNsh2wpPjzY=
+modernc.org/strutil v1.1.3/go.mod h1:MEHNA7PdEnEwLvspRMtWTNnp2nnyvMfkimT1NKNAGbw=
+modernc.org/tcl v1.15.2 h1:C4ybAYCGJw968e+Me18oW55kD/FexcHbqH2xak1ROSY=
+modernc.org/token v1.0.1 h1:A3qvTqOwexpfZZeyI0FeGPDlSWX5pjZu9hF4lU+EKWg=
+modernc.org/token v1.0.1/go.mod h1:UGzOrNV1mAFSEB63lOFHIpNRUVMvYTc6yu1SMY/XTDM=
+modernc.org/z v1.7.3 h1:zDJf6iHjrnB+WRD88stbXokugjyc0/pB91ri1gO6LZY=
nhooyr.io/websocket v1.8.6 h1:s+C3xAMLwGmlI31Nyn/eAehUlZPwfYZu2JXM621Q5/k=
nhooyr.io/websocket v1.8.6/go.mod h1:B70DZP8IakI65RVQ51MsWP/8jndNma26DVA/nFSCgW0=
pgregory.net/rapid v0.5.5 h1:jkgx1TjbQPD/feRoK+S/mXw9e1uj6WilpHrXJowi6oA=
@@ -2275,13 +1863,7 @@ pgregory.net/rapid v0.5.5/go.mod h1:PY5XlDGj0+V1FCq0o192FdRhpKHGTRIWBgqjDBTrq04=
rsc.io/binaryregexp v0.2.0/go.mod h1:qTv7/COck+e2FymRvadv62gMdZztPaShugOCi3I+8D8=
rsc.io/quote/v3 v3.1.0/go.mod h1:yEA65RcK8LyAZtP9Kv3t0HmxON59tX3rD+tICJqUlj0=
rsc.io/sampler v1.3.0/go.mod h1:T1hPZKmBbMNahiBKFy5HrXp6adAjACjK9JXDnKaTXpA=
-sigs.k8s.io/apiserver-network-proxy/konnectivity-client v0.0.14/go.mod h1:LEScyzhFmoF5pso/YSeBstl57mOzx9xlU9n85RGrDQg=
-sigs.k8s.io/apiserver-network-proxy/konnectivity-client v0.0.15/go.mod h1:LEScyzhFmoF5pso/YSeBstl57mOzx9xlU9n85RGrDQg=
-sigs.k8s.io/structured-merge-diff/v4 v4.0.1/go.mod h1:bJZC9H9iH24zzfZ/41RGcq60oK1F7G282QMXDPYydCw=
-sigs.k8s.io/structured-merge-diff/v4 v4.0.2/go.mod h1:bJZC9H9iH24zzfZ/41RGcq60oK1F7G282QMXDPYydCw=
-sigs.k8s.io/structured-merge-diff/v4 v4.0.3/go.mod h1:bJZC9H9iH24zzfZ/41RGcq60oK1F7G282QMXDPYydCw=
sigs.k8s.io/yaml v1.1.0/go.mod h1:UJmg0vDUVViEyp3mgSv9WPwZCDxu4rQW1olrI1uml+o=
-sigs.k8s.io/yaml v1.2.0/go.mod h1:yfXDCHCao9+ENCvLSE62v9VSji2MKu5jeNfTrofGhJc=
sigs.k8s.io/yaml v1.3.0 h1:a2VclLzOGrwOHDiV8EfBGhvjHvP46CtW5j6POvhYGGo=
sigs.k8s.io/yaml v1.3.0/go.mod h1:GeOyir5tyXNByN85N/dRIT9es5UQNerPYEKK56eTBm8=
sourcegraph.com/sourcegraph/appdash v0.0.0-20190731080439-ebfcffb1b5c0/go.mod h1:hI742Nqp5OhwiqlzhgfbWU4mW4yO10fP+LoT9WOswdU=
diff --git a/interchaintest/ibc_test.go b/interchaintest/ibc_test.go
index 6ee722104..81140ba74 100644
--- a/interchaintest/ibc_test.go
+++ b/interchaintest/ibc_test.go
@@ -48,10 +48,11 @@ func TestRelayerInProcess(t *testing.T) {
func TestRelayerDockerEventProcessor(t *testing.T) {
t.Parallel()
+ image := relayerinterchaintest.BuildRelayerImage(t)
rf := interchaintest.NewBuiltinRelayerFactory(
ibc.CosmosRly,
zaptest.NewLogger(t),
- interchaintestrelayer.CustomDockerImage(relayerinterchaintest.RelayerImageName, "latest", "100:1000"),
+ interchaintestrelayer.CustomDockerImage(image, "latest", "100:1000"),
interchaintestrelayer.ImagePull(false),
interchaintestrelayer.StartupFlags("--processor", "events", "--block-history", "100"),
)
@@ -64,12 +65,12 @@ func TestRelayerDockerEventProcessor(t *testing.T) {
// Relayer runs using the legacy processor.
func TestRelayerDockerLegacyProcessor(t *testing.T) {
t.Parallel()
- relayerinterchaintest.BuildRelayerImage(t)
+ image := relayerinterchaintest.BuildRelayerImage(t)
rf := interchaintest.NewBuiltinRelayerFactory(
ibc.CosmosRly,
zaptest.NewLogger(t),
- interchaintestrelayer.CustomDockerImage(relayerinterchaintest.RelayerImageName, "latest", "100:1000"),
+ interchaintestrelayer.CustomDockerImage(image, "latest", "100:1000"),
interchaintestrelayer.ImagePull(false),
interchaintestrelayer.StartupFlags("--processor", "legacy"),
)
diff --git a/interchaintest/ica_channel_close_test.go b/interchaintest/ica_channel_close_test.go
new file mode 100644
index 000000000..6eac44b64
--- /dev/null
+++ b/interchaintest/ica_channel_close_test.go
@@ -0,0 +1,334 @@
+package interchaintest_test
+
+import (
+ "context"
+ "encoding/json"
+ "strconv"
+ "testing"
+ "time"
+
+ "github.com/cosmos/cosmos-sdk/crypto/keyring"
+ chantypes "github.com/cosmos/ibc-go/v7/modules/core/04-channel/types"
+ relayerinterchaintest "github.com/cosmos/relayer/v2/interchaintest"
+ interchaintest "github.com/strangelove-ventures/interchaintest/v7"
+ "github.com/strangelove-ventures/interchaintest/v7/chain/cosmos"
+ "github.com/strangelove-ventures/interchaintest/v7/ibc"
+ "github.com/strangelove-ventures/interchaintest/v7/testreporter"
+ "github.com/strangelove-ventures/interchaintest/v7/testutil"
+ "github.com/stretchr/testify/require"
+ "go.uber.org/zap/zaptest"
+)
+
+// TestScenarioICAChannelClose is very similar to the TestScenarioInterchainAccounts,
+// but instead it tests manually closing the channel using the relayer CLI.
+func TestScenarioICAChannelClose(t *testing.T) {
+ if testing.Short() {
+ t.Skip("skipping in short mode")
+ }
+
+ client, network := interchaintest.DockerSetup(t)
+
+ rep := testreporter.NewNopReporter()
+ eRep := rep.RelayerExecReporter(t)
+
+ ctx := context.Background()
+
+ // Get both chains
+ nf := 0
+ nv := 1
+ cf := interchaintest.NewBuiltinChainFactory(zaptest.NewLogger(t), []*interchaintest.ChainSpec{
+ {
+ Name: "icad",
+ NumValidators: &nv,
+ NumFullNodes: &nf,
+ ChainConfig: ibc.ChainConfig{
+ Images: []ibc.DockerImage{{Repository: "ghcr.io/cosmos/ibc-go-icad", Version: "v0.5.0"}},
+ UsingNewGenesisCommand: true,
+ },
+ },
+ {
+ Name: "icad",
+ NumValidators: &nv,
+ NumFullNodes: &nf,
+ ChainConfig: ibc.ChainConfig{
+ Images: []ibc.DockerImage{{Repository: "ghcr.io/cosmos/ibc-go-icad", Version: "v0.5.0"}},
+ UsingNewGenesisCommand: true,
+ },
+ },
+ })
+
+ chains, err := cf.Chains(t.Name())
+ require.NoError(t, err)
+
+ chain1, chain2 := chains[0].(*cosmos.CosmosChain), chains[1].(*cosmos.CosmosChain)
+
+ // Get a relayer instance
+ r := relayerinterchaintest.
+ NewRelayerFactory(relayerinterchaintest.RelayerConfig{}).
+ Build(t, client, network)
+
+ // Build the network; spin up the chains and configure the relayer
+ const pathName = "test-path"
+ const relayerName = "relayer"
+
+ ic := interchaintest.NewInterchain().
+ AddChain(chain1).
+ AddChain(chain2).
+ AddRelayer(r, relayerName).
+ AddLink(interchaintest.InterchainLink{
+ Chain1: chain1,
+ Chain2: chain2,
+ Relayer: r,
+ Path: pathName,
+ })
+
+ require.NoError(t, ic.Build(ctx, eRep, interchaintest.InterchainBuildOptions{
+ TestName: t.Name(),
+ Client: client,
+ NetworkID: network,
+ SkipPathCreation: true,
+ // Uncomment this to load blocks, txs, msgs, and events into sqlite db as test runs
+ // BlockDatabaseFile: interchaintest.DefaultBlockDatabaseFilepath(),
+ }))
+
+ t.Parallel()
+
+ // Fund a user account on chain1 and chain2
+ const userFunds = int64(10_000_000_000)
+ users := interchaintest.GetAndFundTestUsers(t, ctx, t.Name(), userFunds, chain1, chain2)
+ chain1User := users[0]
+ chain2User := users[1]
+
+ // Generate a new IBC path
+ err = r.GeneratePath(ctx, eRep, chain1.Config().ChainID, chain2.Config().ChainID, pathName)
+ require.NoError(t, err)
+
+ // Create new clients
+ err = r.CreateClients(ctx, eRep, pathName, ibc.CreateClientOptions{TrustingPeriod: "330h"})
+ require.NoError(t, err)
+
+ err = testutil.WaitForBlocks(ctx, 2, chain1, chain2)
+ require.NoError(t, err)
+
+ // Create a new connection
+ err = r.CreateConnections(ctx, eRep, pathName)
+ require.NoError(t, err)
+
+ err = testutil.WaitForBlocks(ctx, 2, chain1, chain2)
+ require.NoError(t, err)
+
+ // Query for the newly created connection
+ connections, err := r.GetConnections(ctx, eRep, chain1.Config().ChainID)
+ require.NoError(t, err)
+ require.Equal(t, 1, len(connections))
+
+ // Start the relayer and set the cleanup function.
+ err = r.StartRelayer(ctx, eRep, pathName)
+ require.NoError(t, err)
+
+ t.Cleanup(
+ func() {
+ err := r.StopRelayer(ctx, eRep)
+ if err != nil {
+ t.Logf("an error occurred while stopping the relayer: %s", err)
+ }
+ },
+ )
+
+ // Register a new interchain account on chain2, on behalf of the user acc on chain1
+ chain1Addr := chain1User.(*cosmos.CosmosWallet).FormattedAddressWithPrefix(chain1.Config().Bech32Prefix)
+
+ registerICA := []string{
+ chain1.Config().Bin, "tx", "intertx", "register",
+ "--from", chain1Addr,
+ "--connection-id", connections[0].ID,
+ "--chain-id", chain1.Config().ChainID,
+ "--home", chain1.HomeDir(),
+ "--node", chain1.GetRPCAddress(),
+ "--keyring-backend", keyring.BackendTest,
+ "-y",
+ }
+ _, _, err = chain1.Exec(ctx, registerICA, nil)
+ require.NoError(t, err)
+
+ ir := cosmos.DefaultEncoding().InterfaceRegistry
+
+ c2h, err := chain2.Height(ctx)
+ require.NoError(t, err)
+
+ channelFound := func(found *chantypes.MsgChannelOpenConfirm) bool {
+ return found.PortId == "icahost"
+ }
+
+ // Wait for channel open confirm
+ _, err = cosmos.PollForMessage(ctx, chain2, ir,
+ c2h, c2h+30, channelFound)
+ require.NoError(t, err)
+
+ // Query for the newly registered interchain account
+ queryICA := []string{
+ chain1.Config().Bin, "query", "intertx", "interchainaccounts", connections[0].ID, chain1Addr,
+ "--chain-id", chain1.Config().ChainID,
+ "--home", chain1.HomeDir(),
+ "--node", chain1.GetRPCAddress(),
+ }
+ stdout, _, err := chain1.Exec(ctx, queryICA, nil)
+ require.NoError(t, err)
+
+ icaAddr := parseInterchainAccountField(stdout)
+ require.NotEmpty(t, icaAddr)
+
+ // Get initial account balances
+ chain2Addr := chain2User.(*cosmos.CosmosWallet).FormattedAddressWithPrefix(chain2.Config().Bech32Prefix)
+
+ chain2OrigBal, err := chain2.GetBalance(ctx, chain2Addr, chain2.Config().Denom)
+ require.NoError(t, err)
+
+ icaOrigBal, err := chain2.GetBalance(ctx, icaAddr, chain2.Config().Denom)
+ require.NoError(t, err)
+
+ // Send funds to ICA from user account on chain2
+ const transferAmount = 10000
+ transfer := ibc.WalletAmount{
+ Address: icaAddr,
+ Denom: chain2.Config().Denom,
+ Amount: transferAmount,
+ }
+ err = chain2.SendFunds(ctx, chain2User.KeyName(), transfer)
+ require.NoError(t, err)
+
+ chain2Bal, err := chain2.GetBalance(ctx, chain2Addr, chain2.Config().Denom)
+ require.NoError(t, err)
+ require.Equal(t, chain2OrigBal-transferAmount, chain2Bal)
+
+ icaBal, err := chain2.GetBalance(ctx, icaAddr, chain2.Config().Denom)
+ require.NoError(t, err)
+ require.Equal(t, icaOrigBal+transferAmount, icaBal)
+
+ // Build bank transfer msg
+ rawMsg, err := json.Marshal(map[string]any{
+ "@type": "/cosmos.bank.v1beta1.MsgSend",
+ "from_address": icaAddr,
+ "to_address": chain2Addr,
+ "amount": []map[string]any{
+ {
+ "denom": chain2.Config().Denom,
+ "amount": strconv.Itoa(transferAmount),
+ },
+ },
+ })
+ require.NoError(t, err)
+
+ // Send bank transfer msg to ICA on chain2 from the user account on chain1
+ sendICATransfer := []string{
+ chain1.Config().Bin, "tx", "intertx", "submit", string(rawMsg),
+ "--connection-id", connections[0].ID,
+ "--from", chain1Addr,
+ "--chain-id", chain1.Config().ChainID,
+ "--home", chain1.HomeDir(),
+ "--node", chain1.GetRPCAddress(),
+ "--keyring-backend", keyring.BackendTest,
+ "-y",
+ }
+ _, _, err = chain1.Exec(ctx, sendICATransfer, nil)
+ require.NoError(t, err)
+
+ c1h, err := chain1.Height(ctx)
+ require.NoError(t, err)
+
+ ackFound := func(found *chantypes.MsgAcknowledgement) bool {
+ return found.Packet.Sequence == 1 &&
+ found.Packet.SourcePort == "icacontroller-"+chain1Addr &&
+ found.Packet.DestinationPort == "icahost"
+ }
+
+ // Wait for ack
+ _, err = cosmos.PollForMessage(ctx, chain1, ir,
+ c1h, c1h+25, ackFound)
+ require.NoError(t, err)
+
+ // Assert that the funds have been received by the user account on chain2
+ chain2Bal, err = chain2.GetBalance(ctx, chain2Addr, chain2.Config().Denom)
+ require.NoError(t, err)
+ require.Equal(t, chain2OrigBal, chain2Bal)
+
+ // Assert that the funds have been removed from the ICA on chain2
+ icaBal, err = chain2.GetBalance(ctx, icaAddr, chain2.Config().Denom)
+ require.NoError(t, err)
+ require.Equal(t, icaOrigBal, icaBal)
+
+ // Stop the relayer and wait for the process to terminate
+ err = r.StopRelayer(ctx, eRep)
+ require.NoError(t, err)
+
+ // Send another bank transfer msg to ICA on chain2 from the user account on chain1.
+ // This message should timeout and the channel will be closed when we re-start the relayer.
+ _, _, err = chain1.Exec(ctx, sendICATransfer, nil)
+ require.NoError(t, err)
+
+ // Wait for approximately one minute to allow packet timeout threshold to be hit
+ time.Sleep(70 * time.Second)
+
+ chain1Chans, err := r.GetChannels(ctx, eRep, chain1.Config().ChainID)
+ require.NoError(t, err)
+ require.Equal(t, 1, len(chain1Chans))
+
+ // Close the channel using the channel close CLI method
+ res := r.Exec(ctx, eRep, []string{"tx", "channel-close", pathName, chain1Chans[0].ChannelID, chain1Chans[0].PortID}, nil)
+ require.NoError(t, res.Err)
+ require.Zero(t, res.ExitCode)
+
+ // Assert that the packet timed out and that the acc balances are correct
+ chain2Bal, err = chain2.GetBalance(ctx, chain2Addr, chain2.Config().Denom)
+ require.NoError(t, err)
+ require.Equal(t, chain2OrigBal, chain2Bal)
+
+ icaBal, err = chain2.GetBalance(ctx, icaAddr, chain2.Config().Denom)
+ require.NoError(t, err)
+ require.Equal(t, icaOrigBal, icaBal)
+
+ // Assert that the channel ends are both closed
+ chain1Chans, err = r.GetChannels(ctx, eRep, chain1.Config().ChainID)
+ require.NoError(t, err)
+ require.Equal(t, 1, len(chain1Chans))
+ require.Subset(t, []string{"STATE_CLOSED", "Closed"}, []string{chain1Chans[0].State})
+
+ chain2Chans, err := r.GetChannels(ctx, eRep, chain2.Config().ChainID)
+ require.NoError(t, err)
+ require.Equal(t, 1, len(chain2Chans))
+ require.Subset(t, []string{"STATE_CLOSED", "Closed"}, []string{chain2Chans[0].State})
+
+ // Restart the relayer for the next channel handshake
+ err = r.StartRelayer(ctx, eRep, pathName)
+ require.NoError(t, err)
+
+ // Attempt to open another channel for the same ICA
+ _, _, err = chain1.Exec(ctx, registerICA, nil)
+ require.NoError(t, err)
+
+ c2h, err = chain2.Height(ctx)
+ require.NoError(t, err)
+
+ // Wait for channel open confirm
+ _, err = cosmos.PollForMessage(ctx, chain2, ir,
+ c2h, c2h+40, channelFound)
+ require.NoError(t, err)
+
+ // Assert that a new channel has been opened and the same ICA is in use
+ stdout, _, err = chain1.Exec(ctx, queryICA, nil)
+ require.NoError(t, err)
+
+ newICA := parseInterchainAccountField(stdout)
+ require.NotEmpty(t, newICA)
+ require.Equal(t, icaAddr, newICA)
+
+ chain1Chans, err = r.GetChannels(ctx, eRep, chain1.Config().ChainID)
+ require.NoError(t, err)
+ require.Equal(t, 2, len(chain1Chans))
+ require.Subset(t, []string{"STATE_OPEN", "Open"}, []string{chain1Chans[1].State})
+
+ chain2Chans, err = r.GetChannels(ctx, eRep, chain2.Config().ChainID)
+ require.NoError(t, err)
+ require.Equal(t, 2, len(chain2Chans))
+ require.Subset(t, []string{"STATE_OPEN", "Open"}, []string{chain2Chans[1].State})
+}
diff --git a/interchaintest/interchain_accounts_test.go b/interchaintest/interchain_accounts_test.go
new file mode 100644
index 000000000..0ec0a1df5
--- /dev/null
+++ b/interchaintest/interchain_accounts_test.go
@@ -0,0 +1,349 @@
+package interchaintest_test
+
+import (
+ "context"
+ "encoding/json"
+ "strconv"
+ "strings"
+ "testing"
+ "time"
+
+ "github.com/cosmos/cosmos-sdk/crypto/keyring"
+ chantypes "github.com/cosmos/ibc-go/v7/modules/core/04-channel/types"
+ relayerinterchaintest "github.com/cosmos/relayer/v2/interchaintest"
+ interchaintest "github.com/strangelove-ventures/interchaintest/v7"
+ "github.com/strangelove-ventures/interchaintest/v7/chain/cosmos"
+ "github.com/strangelove-ventures/interchaintest/v7/ibc"
+ "github.com/strangelove-ventures/interchaintest/v7/testreporter"
+ "github.com/strangelove-ventures/interchaintest/v7/testutil"
+ "github.com/stretchr/testify/require"
+ "go.uber.org/zap/zaptest"
+)
+
+// TestScenarioInterchainAccounts is a test case that performs simulations and assertions around some basic
+// features and packet flows surrounding interchain accounts. See: https://github.com/cosmos/interchain-accounts-demo
+func TestScenarioInterchainAccounts(t *testing.T) {
+ if testing.Short() {
+ t.Skip("skipping in short mode")
+ }
+
+ client, network := interchaintest.DockerSetup(t)
+
+ rep := testreporter.NewNopReporter()
+ eRep := rep.RelayerExecReporter(t)
+
+ ctx := context.Background()
+
+ // Get both chains
+ nf := 0
+ nv := 1
+ cf := interchaintest.NewBuiltinChainFactory(zaptest.NewLogger(t), []*interchaintest.ChainSpec{
+ {
+ Name: "icad",
+ NumValidators: &nv,
+ NumFullNodes: &nf,
+ ChainConfig: ibc.ChainConfig{
+ Images: []ibc.DockerImage{{Repository: "ghcr.io/cosmos/ibc-go-icad", Version: "v0.5.0"}},
+ UsingNewGenesisCommand: true,
+ },
+ },
+ {
+ Name: "icad",
+ NumValidators: &nv,
+ NumFullNodes: &nf,
+ ChainConfig: ibc.ChainConfig{
+ Images: []ibc.DockerImage{{Repository: "ghcr.io/cosmos/ibc-go-icad", Version: "v0.5.0"}},
+ UsingNewGenesisCommand: true,
+ },
+ },
+ })
+
+ chains, err := cf.Chains(t.Name())
+ require.NoError(t, err)
+
+ chain1, chain2 := chains[0].(*cosmos.CosmosChain), chains[1].(*cosmos.CosmosChain)
+
+ // Get a relayer instance
+ r := relayerinterchaintest.
+ NewRelayerFactory(relayerinterchaintest.RelayerConfig{}).
+ Build(t, client, network)
+
+ // Build the network; spin up the chains and configure the relayer
+ const pathName = "test-path"
+ const relayerName = "relayer"
+
+ ic := interchaintest.NewInterchain().
+ AddChain(chain1).
+ AddChain(chain2).
+ AddRelayer(r, relayerName).
+ AddLink(interchaintest.InterchainLink{
+ Chain1: chain1,
+ Chain2: chain2,
+ Relayer: r,
+ Path: pathName,
+ })
+
+ require.NoError(t, ic.Build(ctx, eRep, interchaintest.InterchainBuildOptions{
+ TestName: t.Name(),
+ Client: client,
+ NetworkID: network,
+ SkipPathCreation: true,
+ // Uncomment this to load blocks, txs, msgs, and events into sqlite db as test runs
+ // BlockDatabaseFile: interchaintest.DefaultBlockDatabaseFilepath(),
+ }))
+
+ t.Parallel()
+
+ // Fund a user account on chain1 and chain2
+ const userFunds = int64(10_000_000_000)
+ users := interchaintest.GetAndFundTestUsers(t, ctx, t.Name(), userFunds, chain1, chain2)
+ chain1User := users[0]
+ chain2User := users[1]
+
+ // Generate a new IBC path
+ err = r.GeneratePath(ctx, eRep, chain1.Config().ChainID, chain2.Config().ChainID, pathName)
+ require.NoError(t, err)
+
+ // Create new clients
+ err = r.CreateClients(ctx, eRep, pathName, ibc.CreateClientOptions{TrustingPeriod: "330h"})
+ require.NoError(t, err)
+
+ err = testutil.WaitForBlocks(ctx, 2, chain1, chain2)
+ require.NoError(t, err)
+
+ // Create a new connection
+ err = r.CreateConnections(ctx, eRep, pathName)
+ require.NoError(t, err)
+
+ err = testutil.WaitForBlocks(ctx, 2, chain1, chain2)
+ require.NoError(t, err)
+
+ // Query for the newly created connection
+ connections, err := r.GetConnections(ctx, eRep, chain1.Config().ChainID)
+ require.NoError(t, err)
+ require.Equal(t, 1, len(connections))
+
+ // Start the relayer and set the cleanup function.
+ err = r.StartRelayer(ctx, eRep, pathName)
+ require.NoError(t, err)
+
+ t.Cleanup(
+ func() {
+ err := r.StopRelayer(ctx, eRep)
+ if err != nil {
+ t.Logf("an error occured while stopping the relayer: %s", err)
+ }
+ },
+ )
+
+ // Register a new interchain account on chain2, on behalf of the user acc on chain1
+ chain1Addr := chain1User.(*cosmos.CosmosWallet).FormattedAddressWithPrefix(chain1.Config().Bech32Prefix)
+
+ registerICA := []string{
+ chain1.Config().Bin, "tx", "intertx", "register",
+ "--from", chain1Addr,
+ "--connection-id", connections[0].ID,
+ "--chain-id", chain1.Config().ChainID,
+ "--home", chain1.HomeDir(),
+ "--node", chain1.GetRPCAddress(),
+ "--keyring-backend", keyring.BackendTest,
+ "-y",
+ }
+ _, _, err = chain1.Exec(ctx, registerICA, nil)
+ require.NoError(t, err)
+
+ ir := cosmos.DefaultEncoding().InterfaceRegistry
+
+ c2h, err := chain2.Height(ctx)
+ require.NoError(t, err)
+
+ channelFound := func(found *chantypes.MsgChannelOpenConfirm) bool {
+ return found.PortId == "icahost"
+ }
+
+ // Wait for channel open confirm
+ _, err = cosmos.PollForMessage(ctx, chain2, ir,
+ c2h, c2h+30, channelFound)
+ require.NoError(t, err)
+
+ // Query for the newly registered interchain account
+ queryICA := []string{
+ chain1.Config().Bin, "query", "intertx", "interchainaccounts", connections[0].ID, chain1Addr,
+ "--chain-id", chain1.Config().ChainID,
+ "--home", chain1.HomeDir(),
+ "--node", chain1.GetRPCAddress(),
+ }
+ stdout, _, err := chain1.Exec(ctx, queryICA, nil)
+ require.NoError(t, err)
+
+ icaAddr := parseInterchainAccountField(stdout)
+ require.NotEmpty(t, icaAddr)
+
+ // Get initial account balances
+ chain2Addr := chain2User.(*cosmos.CosmosWallet).FormattedAddressWithPrefix(chain2.Config().Bech32Prefix)
+
+ chain2OrigBal, err := chain2.GetBalance(ctx, chain2Addr, chain2.Config().Denom)
+ require.NoError(t, err)
+
+ icaOrigBal, err := chain2.GetBalance(ctx, icaAddr, chain2.Config().Denom)
+ require.NoError(t, err)
+
+ // Send funds to ICA from user account on chain2
+ const transferAmount = 10000
+ transfer := ibc.WalletAmount{
+ Address: icaAddr,
+ Denom: chain2.Config().Denom,
+ Amount: transferAmount,
+ }
+ err = chain2.SendFunds(ctx, chain2User.KeyName(), transfer)
+ require.NoError(t, err)
+
+ chain2Bal, err := chain2.GetBalance(ctx, chain2Addr, chain2.Config().Denom)
+ require.NoError(t, err)
+ require.Equal(t, chain2OrigBal-transferAmount, chain2Bal)
+
+ icaBal, err := chain2.GetBalance(ctx, icaAddr, chain2.Config().Denom)
+ require.NoError(t, err)
+ require.Equal(t, icaOrigBal+transferAmount, icaBal)
+
+ // Build bank transfer msg
+ rawMsg, err := json.Marshal(map[string]any{
+ "@type": "/cosmos.bank.v1beta1.MsgSend",
+ "from_address": icaAddr,
+ "to_address": chain2Addr,
+ "amount": []map[string]any{
+ {
+ "denom": chain2.Config().Denom,
+ "amount": strconv.Itoa(transferAmount),
+ },
+ },
+ })
+ require.NoError(t, err)
+
+ // Send bank transfer msg to ICA on chain2 from the user account on chain1
+ sendICATransfer := []string{
+ chain1.Config().Bin, "tx", "intertx", "submit", string(rawMsg),
+ "--connection-id", connections[0].ID,
+ "--from", chain1Addr,
+ "--chain-id", chain1.Config().ChainID,
+ "--home", chain1.HomeDir(),
+ "--node", chain1.GetRPCAddress(),
+ "--keyring-backend", keyring.BackendTest,
+ "-y",
+ }
+ _, _, err = chain1.Exec(ctx, sendICATransfer, nil)
+ require.NoError(t, err)
+
+ c1h, err := chain1.Height(ctx)
+ require.NoError(t, err)
+
+ ackFound := func(found *chantypes.MsgAcknowledgement) bool {
+ return found.Packet.Sequence == 1 &&
+ found.Packet.SourcePort == "icacontroller-"+chain1Addr &&
+ found.Packet.DestinationPort == "icahost"
+ }
+
+ // Wait for ack
+ _, err = cosmos.PollForMessage(ctx, chain1, ir,
+ c1h, c1h+10, ackFound)
+ require.NoError(t, err)
+
+ // Assert that the funds have been received by the user account on chain2
+ chain2Bal, err = chain2.GetBalance(ctx, chain2Addr, chain2.Config().Denom)
+ require.NoError(t, err)
+ require.Equal(t, chain2OrigBal, chain2Bal)
+
+ // Assert that the funds have been removed from the ICA on chain2
+ icaBal, err = chain2.GetBalance(ctx, icaAddr, chain2.Config().Denom)
+ require.NoError(t, err)
+ require.Equal(t, icaOrigBal, icaBal)
+
+ // Stop the relayer and wait for the process to terminate
+ err = r.StopRelayer(ctx, eRep)
+ require.NoError(t, err)
+
+ // Send another bank transfer msg to ICA on chain2 from the user account on chain1.
+ // This message should timeout and the channel will be closed when we re-start the relayer.
+ _, _, err = chain1.Exec(ctx, sendICATransfer, nil)
+ require.NoError(t, err)
+
+ // Wait for approximately one minute to allow packet timeout threshold to be hit
+ time.Sleep(70 * time.Second)
+
+ // Restart the relayer and wait for NextSeqRecv proof to be delivered and packet timed out
+ err = r.StartRelayer(ctx, eRep, pathName)
+ require.NoError(t, err)
+
+ c2h, err = chain2.Height(ctx)
+ require.NoError(t, err)
+
+ chanCloseFound := func(found *chantypes.MsgChannelCloseConfirm) bool {
+ return found.PortId == "icahost"
+ }
+
+ // Wait for channel close confirm
+ _, err = cosmos.PollForMessage(ctx, chain2, ir, c2h, c2h+30, chanCloseFound)
+ require.NoError(t, err)
+
+ // Assert that the packet timed out and that the acc balances are correct
+ chain2Bal, err = chain2.GetBalance(ctx, chain2Addr, chain2.Config().Denom)
+ require.NoError(t, err)
+ require.Equal(t, chain2OrigBal, chain2Bal)
+
+ icaBal, err = chain2.GetBalance(ctx, icaAddr, chain2.Config().Denom)
+ require.NoError(t, err)
+ require.Equal(t, icaOrigBal, icaBal)
+
+ // Assert that the channel ends are both closed
+ chain1Chans, err := r.GetChannels(ctx, eRep, chain1.Config().ChainID)
+ require.NoError(t, err)
+ require.Equal(t, 1, len(chain1Chans))
+ require.Subset(t, []string{"STATE_CLOSED", "Closed"}, []string{chain1Chans[0].State})
+
+ chain2Chans, err := r.GetChannels(ctx, eRep, chain2.Config().ChainID)
+ require.NoError(t, err)
+ require.Equal(t, 1, len(chain2Chans))
+ require.Subset(t, []string{"STATE_CLOSED", "Closed"}, []string{chain2Chans[0].State})
+
+ // Attempt to open another channel for the same ICA
+ _, _, err = chain1.Exec(ctx, registerICA, nil)
+ require.NoError(t, err)
+
+ // Wait for channel handshake to finish
+ c2h, err = chain2.Height(ctx)
+ require.NoError(t, err)
+
+ // Wait for channel open confirm
+ _, err = cosmos.PollForMessage(ctx, chain2, ir,
+ c2h, c2h+30, channelFound)
+ require.NoError(t, err)
+
+ // Assert that a new channel has been opened and the same ICA is in use
+ stdout, _, err = chain1.Exec(ctx, queryICA, nil)
+ require.NoError(t, err)
+
+ newICA := parseInterchainAccountField(stdout)
+ require.NotEmpty(t, newICA)
+ require.Equal(t, icaAddr, newICA)
+
+ chain1Chans, err = r.GetChannels(ctx, eRep, chain1.Config().ChainID)
+ require.NoError(t, err)
+ require.Equal(t, 2, len(chain1Chans))
+ require.Subset(t, []string{"STATE_OPEN", "Open"}, []string{chain1Chans[1].State})
+
+ chain2Chans, err = r.GetChannels(ctx, eRep, chain2.Config().ChainID)
+ require.NoError(t, err)
+ require.Equal(t, 2, len(chain2Chans))
+ require.Subset(t, []string{"STATE_OPEN", "Open"}, []string{chain2Chans[1].State})
+}
+
+// parseInterchainAccountField takes a slice of bytes which should be returned when querying for an ICA via
+// the 'intertx interchainaccounts' cmd and splices out the actual address portion.
+func parseInterchainAccountField(stdout []byte) string {
+ // After querying an ICA the stdout should look like the following,
+ // interchain_account_address: cosmos1p76n3mnanllea4d3av0v0e42tjj03cae06xq8fwn9at587rqp23qvxsv0j
+ // So we split the string at the : and then grab the address and return.
+ parts := strings.SplitN(string(stdout), ":", 2)
+ icaAddr := strings.TrimSpace(parts[1])
+ return icaAddr
+}
diff --git a/interchaintest/localhost_client_test.go b/interchaintest/localhost_client_test.go
new file mode 100644
index 000000000..24a9ec11d
--- /dev/null
+++ b/interchaintest/localhost_client_test.go
@@ -0,0 +1,472 @@
+package interchaintest_test
+
+import (
+ "context"
+ "encoding/json"
+ "fmt"
+ "strconv"
+ "testing"
+
+ transfertypes "github.com/cosmos/ibc-go/v7/modules/apps/transfer/types"
+ ibcexported "github.com/cosmos/ibc-go/v7/modules/core/exported"
+ relayertest "github.com/cosmos/relayer/v2/interchaintest"
+ "github.com/strangelove-ventures/interchaintest/v7"
+ "github.com/strangelove-ventures/interchaintest/v7/chain/cosmos"
+ "github.com/strangelove-ventures/interchaintest/v7/ibc"
+ "github.com/strangelove-ventures/interchaintest/v7/testreporter"
+ "github.com/strangelove-ventures/interchaintest/v7/testutil"
+ "github.com/stretchr/testify/require"
+ "go.uber.org/zap/zaptest"
+)
+
+func TestLocalhost_TokenTransfers(t *testing.T) {
+ if testing.Short() {
+ t.Skip()
+ }
+
+ t.Parallel()
+
+ numVals := 1
+ numFullNodes := 0
+ image := ibc.DockerImage{
+ Repository: "ghcr.io/cosmos/ibc-go-simd",
+ Version: "v7.1.0-rc0",
+ UidGid: "",
+ }
+ cdc := cosmos.DefaultEncoding()
+ cf := interchaintest.NewBuiltinChainFactory(zaptest.NewLogger(t), []*interchaintest.ChainSpec{
+ {
+ Name: "ibc-go-simd",
+ ChainName: "simd",
+ Version: "main",
+ NumValidators: &numVals,
+ NumFullNodes: &numFullNodes,
+ ChainConfig: ibc.ChainConfig{
+ Type: "cosmos",
+ Name: "simd",
+ ChainID: "chain-a",
+ Images: []ibc.DockerImage{image},
+ Bin: "simd",
+ Bech32Prefix: "cosmos",
+ Denom: "stake",
+ CoinType: "118",
+ GasPrices: "0.0stake",
+ GasAdjustment: 1.1,
+ EncodingConfig: &cdc,
+ UsingNewGenesisCommand: true,
+ }}},
+ )
+
+ chains, err := cf.Chains(t.Name())
+ require.NoError(t, err)
+ chainA := chains[0].(*cosmos.CosmosChain)
+
+ ctx := context.Background()
+ client, network := interchaintest.DockerSetup(t)
+
+ rf := relayertest.NewRelayerFactory(relayertest.RelayerConfig{InitialBlockHistory: 50})
+ r := rf.Build(t, client, network)
+
+ const pathLocalhost = "chainA-localhost"
+
+ ic := interchaintest.NewInterchain().
+ AddChain(chainA).
+ AddRelayer(r, "relayer")
+
+ rep := testreporter.NewNopReporter()
+ eRep := rep.RelayerExecReporter(t)
+
+ require.NoError(t, ic.Build(ctx, eRep, interchaintest.InterchainBuildOptions{
+ TestName: t.Name(),
+ Client: client,
+ NetworkID: network,
+ BlockDatabaseFile: interchaintest.DefaultBlockDatabaseFilepath(),
+ SkipPathCreation: true,
+ }))
+
+ t.Cleanup(func() {
+ _ = ic.Close()
+ })
+
+ const relayerKey = "relayer-key"
+ const mnemonic = "all unit ordinary card sword document left illegal frog chuckle assume gift south settle can explain wagon beef story praise gorilla arch close good"
+
+ // initialize a new acc for the relayer along with a couple user accs
+ initBal := int64(10_000_000)
+ _, err = interchaintest.GetAndFundTestUserWithMnemonic(ctx, relayerKey, mnemonic, initBal, chainA)
+ require.NoError(t, err)
+
+ users := interchaintest.GetAndFundTestUsers(t, ctx, "test-key", initBal, chainA, chainA)
+ err = testutil.WaitForBlocks(ctx, 5, chainA)
+ require.NoError(t, err)
+
+ userA, userB := users[0], users[1]
+
+ // assert initial balances are correct
+ userABal, err := chainA.GetBalance(ctx, userA.FormattedAddress(), chainA.Config().Denom)
+ require.NoError(t, err)
+ require.Equal(t, initBal, userABal)
+
+ userBBal, err := chainA.GetBalance(ctx, userB.FormattedAddress(), chainA.Config().Denom)
+ require.NoError(t, err)
+ require.Equal(t, initBal, userBBal)
+
+ // configure the relayer for a localhost connection
+ err = r.AddChainConfiguration(ctx, eRep, chainA.Config(), relayerKey, chainA.GetHostRPCAddress(), chainA.GetHostGRPCAddress())
+ require.NoError(t, err)
+
+ err = r.RestoreKey(ctx, eRep, chainA.Config(), relayerKey, mnemonic)
+ require.NoError(t, err)
+
+ err = r.GeneratePath(ctx, eRep, chainA.Config().ChainID, chainA.Config().ChainID, pathLocalhost)
+ require.NoError(t, err)
+
+ updateCmd := []string{
+ "paths", "update", pathLocalhost,
+ "--src-client-id", ibcexported.LocalhostClientID,
+ "--src-connection-id", ibcexported.LocalhostConnectionID,
+ "--dst-client-id", ibcexported.LocalhostClientID,
+ "--dst-connection-id", ibcexported.LocalhostConnectionID,
+ }
+ res := r.Exec(ctx, eRep, updateCmd, nil)
+ require.NoError(t, res.Err)
+
+ // initialize new channels
+ err = r.CreateChannel(ctx, eRep, pathLocalhost, ibc.DefaultChannelOpts())
+ require.NoError(t, err)
+
+ err = testutil.WaitForBlocks(ctx, 10, chainA)
+ require.NoError(t, err)
+
+ channels, err := r.GetChannels(ctx, eRep, chainA.Config().ChainID)
+ require.NoError(t, err)
+ require.Equal(t, 2, len(channels))
+
+ channel := channels[0]
+
+ // compose the ibc denom for balance assertions
+ denom := transfertypes.GetPrefixedDenom(channel.Counterparty.PortID, channel.Counterparty.ChannelID, chainA.Config().Denom)
+ trace := transfertypes.ParseDenomTrace(denom)
+
+ // start the relayer
+ require.NoError(t, r.StartRelayer(ctx, eRep, pathLocalhost))
+
+ t.Cleanup(
+ func() {
+ err := r.StopRelayer(ctx, eRep)
+ if err != nil {
+ panic(fmt.Errorf("an error occured while stopping the relayer: %s", err))
+ }
+ },
+ )
+
+ // compose and send a localhost IBC transfer which should be successful
+ const transferAmount = int64(1_000)
+ transfer := ibc.WalletAmount{
+ Address: userB.FormattedAddress(),
+ Denom: chainA.Config().Denom,
+ Amount: transferAmount,
+ }
+
+ cmd := []string{
+ chainA.Config().Bin, "tx", "ibc-transfer", "transfer", "transfer",
+ channel.ChannelID,
+ transfer.Address,
+ fmt.Sprintf("%d%s", transfer.Amount, transfer.Denom),
+ "--from", userA.FormattedAddress(),
+ "--gas-prices", "0.0stake",
+ "--gas-adjustment", "1.2",
+ "--keyring-backend", "test",
+ "--absolute-timeouts",
+ "--packet-timeout-timestamp", "9999999999999999999",
+ "--output", "json",
+ "-y",
+ "--home", chainA.HomeDir(),
+ "--node", chainA.GetRPCAddress(),
+ "--chain-id", chainA.Config().ChainID,
+ }
+ _, _, err = chainA.Exec(ctx, cmd, nil)
+ require.NoError(t, err)
+
+ err = testutil.WaitForBlocks(ctx, 5, chainA)
+ require.NoError(t, err)
+
+ // assert that the updated balances are correct
+ newBalA, err := chainA.GetBalance(ctx, userA.FormattedAddress(), chainA.Config().Denom)
+ require.NoError(t, err)
+ require.Equal(t, userABal-transferAmount, newBalA)
+
+ newBalB, err := chainA.GetBalance(ctx, userB.FormattedAddress(), trace.IBCDenom())
+ require.NoError(t, err)
+ require.Equal(t, transferAmount, newBalB)
+
+ // compose and send another localhost IBC transfer which should succeed
+ cmd = []string{
+ chainA.Config().Bin, "tx", "ibc-transfer", "transfer", "transfer",
+ channel.ChannelID,
+ transfer.Address,
+ fmt.Sprintf("%d%s", transfer.Amount, transfer.Denom),
+ "--from", userA.FormattedAddress(),
+ "--gas-prices", "0.0stake",
+ "--gas-adjustment", "1.2",
+ "--keyring-backend", "test",
+ "--absolute-timeouts",
+ "--packet-timeout-timestamp", "9999999999999999999",
+ "--output", "json",
+ "-y",
+ "--home", chainA.HomeDir(),
+ "--node", chainA.GetRPCAddress(),
+ "--chain-id", chainA.Config().ChainID,
+ }
+ _, _, err = chainA.Exec(ctx, cmd, nil)
+ require.NoError(t, err)
+
+ err = testutil.WaitForBlocks(ctx, 5, chainA)
+ require.NoError(t, err)
+
+ // assert that the balances are updated
+ tmpBalA := newBalA
+ newBalA, err = chainA.GetBalance(ctx, userA.FormattedAddress(), chainA.Config().Denom)
+ require.NoError(t, err)
+ require.Equal(t, tmpBalA-transferAmount, newBalA)
+
+ tmpBalB := newBalB
+ newBalB, err = chainA.GetBalance(ctx, userB.FormattedAddress(), trace.IBCDenom())
+ require.NoError(t, err)
+ require.Equal(t, tmpBalB+transferAmount, newBalB)
+}
+
+func TestLocalhost_InterchainAccounts(t *testing.T) {
+ if testing.Short() {
+ t.Skip()
+ }
+
+ t.Parallel()
+
+ numVals := 1
+ numFullNodes := 0
+ image := ibc.DockerImage{
+ Repository: "ghcr.io/cosmos/ibc-go-simd",
+ Version: "v7.1.0-rc0",
+ UidGid: "",
+ }
+ cdc := cosmos.DefaultEncoding()
+ cf := interchaintest.NewBuiltinChainFactory(zaptest.NewLogger(t), []*interchaintest.ChainSpec{
+ {
+ Name: "ibc-go-simd",
+ ChainName: "simd",
+ Version: "main",
+ NumValidators: &numVals,
+ NumFullNodes: &numFullNodes,
+ ChainConfig: ibc.ChainConfig{
+ Type: "cosmos",
+ Name: "simd",
+ ChainID: "chain-a",
+ Images: []ibc.DockerImage{image},
+ Bin: "simd",
+ Bech32Prefix: "cosmos",
+ Denom: "stake",
+ CoinType: "118",
+ GasPrices: "0.0stake",
+ GasAdjustment: 1.1,
+ EncodingConfig: &cdc,
+ UsingNewGenesisCommand: true,
+ }}},
+ )
+
+ chains, err := cf.Chains(t.Name())
+ require.NoError(t, err)
+ chainA := chains[0].(*cosmos.CosmosChain)
+
+ ctx := context.Background()
+ client, network := interchaintest.DockerSetup(t)
+
+ rf := relayertest.NewRelayerFactory(relayertest.RelayerConfig{InitialBlockHistory: 50})
+ r := rf.Build(t, client, network)
+
+ const pathLocalhost = "chainA-localhost"
+
+ ic := interchaintest.NewInterchain().
+ AddChain(chainA).
+ AddRelayer(r, "relayer")
+
+ rep := testreporter.NewNopReporter()
+ eRep := rep.RelayerExecReporter(t)
+
+ require.NoError(t, ic.Build(ctx, eRep, interchaintest.InterchainBuildOptions{
+ TestName: t.Name(),
+ Client: client,
+ NetworkID: network,
+ BlockDatabaseFile: interchaintest.DefaultBlockDatabaseFilepath(),
+ SkipPathCreation: true,
+ }))
+
+ t.Cleanup(func() {
+ _ = ic.Close()
+ })
+
+ const (
+ relayerKey = "relayer-key"
+ mnemonic = "all unit ordinary card sword document left illegal frog chuckle assume gift south settle can explain wagon beef story praise gorilla arch close good"
+ )
+
+ // initialize a new acc for the relayer along with a new user acc
+ const initBal = int64(10_000_000)
+ _, err = interchaintest.GetAndFundTestUserWithMnemonic(ctx, relayerKey, mnemonic, initBal, chainA)
+ require.NoError(t, err)
+
+ users := interchaintest.GetAndFundTestUsers(t, ctx, "test-key", initBal, chainA)
+ userA := users[0]
+
+ err = testutil.WaitForBlocks(ctx, 5, chainA)
+ require.NoError(t, err)
+
+ // assert initial balance is correct
+ userABal, err := chainA.GetBalance(ctx, userA.FormattedAddress(), chainA.Config().Denom)
+ require.NoError(t, err)
+ require.Equal(t, initBal, userABal)
+
+ // configure the relayer for a localhost connection
+ err = r.AddChainConfiguration(ctx, eRep, chainA.Config(), relayerKey, chainA.GetHostRPCAddress(), chainA.GetHostGRPCAddress())
+ require.NoError(t, err)
+
+ err = r.RestoreKey(ctx, eRep, chainA.Config(), relayerKey, mnemonic)
+ require.NoError(t, err)
+
+ err = r.GeneratePath(ctx, eRep, chainA.Config().ChainID, chainA.Config().ChainID, pathLocalhost)
+ require.NoError(t, err)
+
+ updateCmd := []string{
+ "paths", "update", pathLocalhost,
+ "--src-client-id", ibcexported.LocalhostClientID,
+ "--src-connection-id", ibcexported.LocalhostConnectionID,
+ "--dst-client-id", ibcexported.LocalhostClientID,
+ "--dst-connection-id", ibcexported.LocalhostConnectionID,
+ }
+ res := r.Exec(ctx, eRep, updateCmd, nil)
+ require.NoError(t, res.Err)
+
+ // start the relayer
+ require.NoError(t, r.StartRelayer(ctx, eRep, pathLocalhost))
+
+ t.Cleanup(
+ func() {
+ err := r.StopRelayer(ctx, eRep)
+ if err != nil {
+ panic(fmt.Errorf("an error occured while stopping the relayer: %s", err))
+ }
+ },
+ )
+
+ // register a new interchain account
+ registerCmd := []string{
+ chainA.Config().Bin, "tx", "interchain-accounts", "controller", "register", ibcexported.LocalhostConnectionID,
+ "--from", userA.FormattedAddress(),
+ "--gas-prices", "0.0stake",
+ "--gas-adjustment", "1.2",
+ "--keyring-backend", "test",
+ "--output", "json",
+ "-y",
+ "--home", chainA.HomeDir(),
+ "--node", chainA.GetRPCAddress(),
+ "--chain-id", chainA.Config().ChainID,
+ }
+
+ _, _, err = chainA.Exec(ctx, registerCmd, nil)
+ require.NoError(t, err)
+
+ err = testutil.WaitForBlocks(ctx, 10, chainA)
+ require.NoError(t, err)
+
+ channels, err := r.GetChannels(ctx, eRep, chainA.Config().ChainID)
+ require.NoError(t, err)
+ require.Equal(t, 2, len(channels))
+
+ // query for the newly created ica
+ queryCmd := []string{
+ chainA.Config().Bin, "q", "interchain-accounts", "controller", "interchain-account",
+ userA.FormattedAddress(), ibcexported.LocalhostConnectionID,
+ "--home", chainA.HomeDir(),
+ "--node", chainA.GetRPCAddress(),
+ "--chain-id", chainA.Config().ChainID,
+ }
+ stdout, _, err := chainA.Exec(ctx, queryCmd, nil)
+ require.NoError(t, err)
+
+ icaAddr := parseInterchainAccountField(stdout)
+ require.NotEmpty(t, icaAddr)
+
+ // asser the ICA balance, send some funds to the ICA, then re-assert balances
+ icaBal, err := chainA.GetBalance(ctx, icaAddr, chainA.Config().Denom)
+ require.NoError(t, err)
+ require.Equal(t, int64(0), icaBal)
+
+ const transferAmount = 1000
+ transfer := ibc.WalletAmount{
+ Address: icaAddr,
+ Denom: chainA.Config().Denom,
+ Amount: transferAmount,
+ }
+ err = chainA.SendFunds(ctx, userA.KeyName(), transfer)
+ require.NoError(t, err)
+
+ err = testutil.WaitForBlocks(ctx, 5, chainA)
+ require.NoError(t, err)
+
+ newBalICA, err := chainA.GetBalance(ctx, icaAddr, chainA.Config().Denom)
+ require.NoError(t, err)
+ require.Equal(t, int64(transferAmount), newBalICA)
+
+ newBalA, err := chainA.GetBalance(ctx, userA.FormattedAddress(), chainA.Config().Denom)
+ require.NoError(t, err)
+ require.Equal(t, userABal-transferAmount, newBalA)
+
+ // compose msg to send to ICA
+ rawMsg, err := json.Marshal(map[string]any{
+ "@type": "/cosmos.bank.v1beta1.MsgSend",
+ "from_address": icaAddr,
+ "to_address": userA.FormattedAddress(),
+ "amount": []map[string]any{
+ {
+ "denom": chainA.Config().Denom,
+ "amount": strconv.Itoa(transferAmount),
+ },
+ },
+ })
+ require.NoError(t, err)
+
+ generateCmd := []string{
+ chainA.Config().Bin, "tx", "interchain-accounts", "host", "generate-packet-data", string(rawMsg),
+ }
+ msgBz, _, err := chainA.Exec(ctx, generateCmd, nil)
+ require.NoError(t, err)
+
+ // send tx to our ICA
+ sendCmd := []string{
+ chainA.Config().Bin, "tx", "interchain-accounts", "controller", "send-tx",
+ ibcexported.LocalhostConnectionID, string(msgBz),
+ "--from", userA.FormattedAddress(),
+ "--gas-prices", "0.0stake",
+ "--gas-adjustment", "1.2",
+ "--keyring-backend", "test",
+ "--output", "json",
+ "-y",
+ "--home", chainA.HomeDir(),
+ "--node", chainA.GetRPCAddress(),
+ "--chain-id", chainA.Config().ChainID,
+ }
+ _, _, err = chainA.Exec(ctx, sendCmd, nil)
+ require.NoError(t, err)
+
+ err = testutil.WaitForBlocks(ctx, 5, chainA)
+ require.NoError(t, err)
+
+ // assert updated balances are correct
+ finalBalICA, err := chainA.GetBalance(ctx, icaAddr, chainA.Config().Denom)
+ require.NoError(t, err)
+ require.Equal(t, newBalICA-transferAmount, finalBalICA)
+
+ finalBalA, err := chainA.GetBalance(ctx, userA.FormattedAddress(), chainA.Config().Denom)
+ require.NoError(t, err)
+ require.Equal(t, newBalA+int64(transferAmount), finalBalA)
+}
diff --git a/interchaintest/misbehaviour_test.go b/interchaintest/misbehaviour_test.go
index 6d10003e9..9c99c5504 100644
--- a/interchaintest/misbehaviour_test.go
+++ b/interchaintest/misbehaviour_test.go
@@ -14,12 +14,15 @@ import (
cometprotoversion "github.com/cometbft/cometbft/proto/tendermint/version"
comettypes "github.com/cometbft/cometbft/types"
cometversion "github.com/cometbft/cometbft/version"
+ codectypes "github.com/cosmos/cosmos-sdk/codec/types"
sdked25519 "github.com/cosmos/cosmos-sdk/crypto/keys/ed25519"
"github.com/cosmos/cosmos-sdk/std"
sdk "github.com/cosmos/cosmos-sdk/types"
banktypes "github.com/cosmos/cosmos-sdk/x/bank/types"
+ "github.com/cosmos/gogoproto/proto"
transfertypes "github.com/cosmos/ibc-go/v7/modules/apps/transfer/types"
clienttypes "github.com/cosmos/ibc-go/v7/modules/core/02-client/types"
+ "github.com/cosmos/ibc-go/v7/modules/core/exported"
ibctypes "github.com/cosmos/ibc-go/v7/modules/core/types"
ibccomettypes "github.com/cosmos/ibc-go/v7/modules/light-clients/07-tendermint"
ibctesting "github.com/cosmos/ibc-go/v7/testing"
@@ -32,21 +35,22 @@ import (
"github.com/strangelove-ventures/interchaintest/v7/testreporter"
"github.com/strangelove-ventures/interchaintest/v7/testutil"
"github.com/stretchr/testify/require"
+ "go.uber.org/zap"
"go.uber.org/zap/zaptest"
)
-func TestScenarioMisbehaviourDetection(t *testing.T) {
+func TestRelayerMisbehaviourDetection(t *testing.T) {
if testing.Short() {
t.Skip()
}
- t.Parallel()
-
numVals := 1
numFullNodes := 0
- cf := interchaintest.NewBuiltinChainFactory(zaptest.NewLogger(t), []*interchaintest.ChainSpec{
- {Name: "gaia", Version: "v9.0.0-rc1", NumValidators: &numVals, NumFullNodes: &numFullNodes, ChainConfig: ibc.ChainConfig{ChainID: "chain-a", GasPrices: "0.0uatom"}},
- {Name: "gaia", Version: "v9.0.0-rc1", NumValidators: &numVals, NumFullNodes: &numFullNodes, ChainConfig: ibc.ChainConfig{ChainID: "chain-b", GasPrices: "0.0uatom"}}},
+ logger := zaptest.NewLogger(t)
+
+ cf := interchaintest.NewBuiltinChainFactory(logger, []*interchaintest.ChainSpec{
+ {Name: "gaia", Version: "v9.0.0-rc1", NumValidators: &numVals, NumFullNodes: &numFullNodes, ChainConfig: ibc.ChainConfig{ChainID: "chain-a", GasPrices: "0.0uatom", Bech32Prefix: "cosmos"}},
+ {Name: "gaia", Version: "v9.0.0-rc1", NumValidators: &numVals, NumFullNodes: &numFullNodes, ChainConfig: ibc.ChainConfig{ChainID: "chain-b", GasPrices: "0.0uatom", Bech32Prefix: "cosmos"}}},
)
chains, err := cf.Chains(t.Name())
@@ -83,6 +87,8 @@ func TestScenarioMisbehaviourDetection(t *testing.T) {
SkipPathCreation: false,
}))
+ t.Parallel()
+
t.Cleanup(func() {
_ = ic.Close()
})
@@ -90,6 +96,7 @@ func TestScenarioMisbehaviourDetection(t *testing.T) {
// create a new user account and wait a few blocks for it to be created on chain
user := interchaintest.GetAndFundTestUsers(t, ctx, "user-1", 10_000_000, chainA)[0]
err = testutil.WaitForBlocks(ctx, 5, chainA)
+ require.NoError(t, err)
// Start the relayer
require.NoError(t, r.StartRelayer(ctx, eRep, pathChainAChainB))
@@ -171,9 +178,19 @@ func TestScenarioMisbehaviourDetection(t *testing.T) {
// attempt to update client with duplicate header
b := cosmos.NewBroadcaster(t, chainA)
- msg, err := clienttypes.NewMsgUpdateClient(clientID, newHeader, user.FormattedAddress())
+ m, ok := newHeader.(proto.Message)
+ require.True(t, ok)
+
+ protoAny, err := codectypes.NewAnyWithValue(m)
require.NoError(t, err)
+ msg := &clienttypes.MsgUpdateClient{
+ ClientId: clientID,
+ ClientMessage: protoAny,
+ Signer: user.FormattedAddress(),
+ }
+ logger.Info("Misbehaviour test, MsgUpdateClient", zap.String("Signer", user.FormattedAddress()))
+
resp, err := cosmos.BroadcastTx(ctx, b, user, msg)
require.NoError(t, err)
assertTransactionIsValid(t, resp)
@@ -200,6 +217,7 @@ func TestScenarioMisbehaviourDetection(t *testing.T) {
}
func assertTransactionIsValid(t *testing.T, resp sdk.TxResponse) {
+ t.Helper()
require.NotNil(t, resp)
require.NotEqual(t, 0, resp.GasUsed)
require.NotEqual(t, 0, resp.GasWanted)
@@ -209,7 +227,13 @@ func assertTransactionIsValid(t *testing.T, resp sdk.TxResponse) {
require.NotEmpty(t, resp.Events)
}
-func queryHeaderAtHeight(ctx context.Context, t *testing.T, height int64, chain *cosmos.CosmosChain) (*ibccomettypes.Header, error) {
+func queryHeaderAtHeight(
+ ctx context.Context,
+ t *testing.T,
+ height int64,
+ chain *cosmos.CosmosChain,
+) (*ibccomettypes.Header, error) {
+ t.Helper()
var (
page = 1
perPage = 100000
@@ -239,7 +263,8 @@ func createTMClientHeader(
tmValSet, tmTrustedVals *comettypes.ValidatorSet,
signers []comettypes.PrivValidator,
oldHeader *ibccomettypes.Header,
-) *ibccomettypes.Header {
+) exported.ClientMessage {
+ t.Helper()
var (
valSet *cometproto.ValidatorSet
trustedVals *cometproto.ValidatorSet
diff --git a/interchaintest/multi_channel_test.go b/interchaintest/multi_channel_test.go
index 6904f5751..ad123f756 100644
--- a/interchaintest/multi_channel_test.go
+++ b/interchaintest/multi_channel_test.go
@@ -18,13 +18,13 @@ import (
)
func TestMultipleChannelsOneConnection(t *testing.T) {
- relayerinterchaintest.BuildRelayerImage(t)
+ image := relayerinterchaintest.BuildRelayerImage(t)
client, network := interchaintest.DockerSetup(t)
r := interchaintest.NewBuiltinRelayerFactory(
ibc.CosmosRly,
zaptest.NewLogger(t),
- interchaintestrelayer.CustomDockerImage(relayerinterchaintest.RelayerImageName, "latest", "100:1000"),
+ interchaintestrelayer.CustomDockerImage(image, "latest", "100:1000"),
interchaintestrelayer.ImagePull(false),
).Build(t, client, network)
diff --git a/interchaintest/path_filter_test.go b/interchaintest/path_filter_test.go
index 7889587d2..3ef7b9215 100644
--- a/interchaintest/path_filter_test.go
+++ b/interchaintest/path_filter_test.go
@@ -21,7 +21,6 @@ import (
// TestScenarioPathFilterAllow tests the channel allowlist
func TestScenarioPathFilterAllow(t *testing.T) {
- t.Parallel()
ctx := context.Background()
nv := 1
@@ -43,6 +42,8 @@ func TestScenarioPathFilterAllow(t *testing.T) {
InitialBlockHistory: 100,
}).Build(t, nil, "")
+ t.Parallel()
+
// Prep Interchain
const ibcPath = "gaia-osmosis"
ic := interchaintest.NewInterchain().
@@ -89,6 +90,14 @@ func TestScenarioPathFilterAllow(t *testing.T) {
gaiaUser, osmosisUser := users[0].(*cosmos.CosmosWallet), users[1].(*cosmos.CosmosWallet)
r.StartRelayer(ctx, eRep, ibcPath)
+ t.Cleanup(
+ func() {
+ err := r.StopRelayer(ctx, eRep)
+ if err != nil {
+ t.Logf("an error occured while stopping the relayer: %s", err)
+ }
+ },
+ )
// Send Transaction
amountToSend := int64(1_000_000)
@@ -159,7 +168,6 @@ func TestScenarioPathFilterAllow(t *testing.T) {
// TestScenarioPathFilterDeny tests the channel denylist
func TestScenarioPathFilterDeny(t *testing.T) {
- t.Parallel()
ctx := context.Background()
nv := 1
@@ -208,6 +216,8 @@ func TestScenarioPathFilterDeny(t *testing.T) {
SkipPathCreation: false,
}))
+ t.Parallel()
+
// Get Channel ID
gaiaChans, err := r.GetChannels(ctx, eRep, gaia.Config().ChainID)
require.NoError(t, err)
@@ -226,6 +236,14 @@ func TestScenarioPathFilterDeny(t *testing.T) {
gaiaUser, osmosisUser := users[0].(*cosmos.CosmosWallet), users[1].(*cosmos.CosmosWallet)
r.StartRelayer(ctx, eRep, ibcPath)
+ t.Cleanup(
+ func() {
+ err := r.StopRelayer(ctx, eRep)
+ if err != nil {
+ t.Logf("an error occured while stopping the relayer: %s", err)
+ }
+ },
+ )
// Send Transaction
amountToSend := int64(1_000_000)
diff --git a/interchaintest/relay_many_test.go b/interchaintest/relay_many_test.go
index 49bb530ca..65859f487 100644
--- a/interchaintest/relay_many_test.go
+++ b/interchaintest/relay_many_test.go
@@ -86,10 +86,11 @@ func TestRelayerMultiplePathsSingleProcess(t *testing.T) {
client, network := interchaintest.DockerSetup(t)
require.NoError(t, ic.Build(ctx, eRep, interchaintest.InterchainBuildOptions{
- TestName: t.Name(),
- Client: client,
- NetworkID: network,
- BlockDatabaseFile: interchaintest.DefaultBlockDatabaseFilepath(),
+ TestName: t.Name(),
+ Client: client,
+ NetworkID: network,
+ // Uncomment this to load blocks, txs, msgs, and events into sqlite db as test runs
+ // BlockDatabaseFile: interchaintest.DefaultBlockDatabaseFilepath(),
SkipPathCreation: false,
}))
diff --git a/interchaintest/relayer.go b/interchaintest/relayer.go
index 7c5a0e81c..8641830bc 100644
--- a/interchaintest/relayer.go
+++ b/interchaintest/relayer.go
@@ -17,7 +17,7 @@ import (
"github.com/cosmos/relayer/v2/relayer/provider"
interchaintestcosmos "github.com/strangelove-ventures/interchaintest/v7/chain/cosmos"
"github.com/strangelove-ventures/interchaintest/v7/ibc"
- "github.com/stretchr/testify/require"
+ "github.com/strangelove-ventures/interchaintest/v7/relayer/rly"
"go.uber.org/zap"
"go.uber.org/zap/zaptest"
)
@@ -38,6 +38,9 @@ func NewRelayer(
t *testing.T,
config RelayerConfig,
) ibc.Relayer {
+ //prevent incorrect bech32 address prefixed addresses when calling AccAddress.String()
+ types.SetAddrCacheEnabled(false)
+
r := &Relayer{
t: t,
home: t.TempDir(),
@@ -85,13 +88,13 @@ func (r *Relayer) AddChainConfiguration(ctx context.Context, _ ibc.RelayerExecRe
return nil
}
-func (r *Relayer) AddKey(ctx context.Context, _ ibc.RelayerExecReporter, chainID, keyName string, coinType string) (ibc.Wallet, error) {
+func (r *Relayer) AddKey(ctx context.Context, _ ibc.RelayerExecReporter, chainID, keyName, coinType string) (ibc.Wallet, error) {
res := r.sys().RunC(ctx, r.log(), "keys", "add", chainID, keyName, "--coin-type", coinType)
if res.Err != nil {
return nil, res.Err
}
- var w ibc.Wallet
+ var w *interchaintestcosmos.CosmosWallet
if err := json.Unmarshal(res.Stdout.Bytes(), &w); err != nil {
return nil, err
}
@@ -99,8 +102,8 @@ func (r *Relayer) AddKey(ctx context.Context, _ ibc.RelayerExecReporter, chainID
return w, nil
}
-func (r *Relayer) RestoreKey(ctx context.Context, _ ibc.RelayerExecReporter, chainID, keyName, coinType, mnemonic string) error {
- res := r.sys().RunC(ctx, r.log(), "keys", "restore", chainID, keyName, mnemonic, "--coin-type", coinType)
+func (r *Relayer) RestoreKey(ctx context.Context, _ ibc.RelayerExecReporter, cfg ibc.ChainConfig, keyName, mnemonic string) error {
+ res := r.sys().RunC(ctx, r.log(), "keys", "restore", cfg.ChainID, keyName, mnemonic, "--coin-type", cfg.CoinType)
if res.Err != nil {
return res.Err
}
@@ -158,7 +161,7 @@ func (r *Relayer) GetClients(ctx context.Context, _ ibc.RelayerExecReporter, cha
if strings.TrimSpace(client) == "" {
continue
}
- var clientOutput *ibc.ClientOutput
+ clientOutput := &ibc.ClientOutput{}
if err := json.Unmarshal([]byte(client), clientOutput); err != nil {
return nil, fmt.Errorf("failed to parse client %q: %w", client, err)
}
@@ -338,26 +341,21 @@ func (r *Relayer) GetWallet(chainID string) (ibc.Wallet, bool) {
}
address := strings.TrimSpace(res.Stdout.String())
- var chainCfg ibc.ChainConfig
var keyName string
config := r.sys().MustGetConfig(r.t)
for _, v := range config.ProviderConfigs {
if c, ok := v.Value.(cosmos.CosmosProviderConfig); ok {
if c.ChainID == chainID {
keyName = c.Key
- chainCfg = ibc.ChainConfig{
- Type: v.Type,
- Name: c.ChainName,
- ChainID: c.ChainID,
- Bech32Prefix: c.AccountPrefix,
- GasPrices: c.GasPrices,
- GasAdjustment: c.GasAdjustment,
- }
}
}
}
+ return rly.NewWallet(keyName, address, ""), true
+}
- addressBz, err := types.GetFromBech32(address, chainCfg.Bech32Prefix)
- require.NoError(r.t, err, "failed to decode bech32 wallet")
- return interchaintestcosmos.NewWallet(keyName, addressBz, "", chainCfg), true
+// SetClientContractHash sets the wasm client contract hash in the chain's config if the counterparty chain in a path used 08-wasm
+// to instantiate the client.
+func (r *Relayer) SetClientContractHash(ctx context.Context, rep ibc.RelayerExecReporter, cfg ibc.ChainConfig, hash string) error {
+ //TODO implement me
+ panic("implement me")
}
diff --git a/interchaintest/relayer_factory.go b/interchaintest/relayer_factory.go
index 9349a72a3..c833591bc 100644
--- a/interchaintest/relayer_factory.go
+++ b/interchaintest/relayer_factory.go
@@ -5,7 +5,6 @@ import (
"github.com/docker/docker/client"
"github.com/strangelove-ventures/interchaintest/v7/ibc"
- "github.com/strangelove-ventures/interchaintest/v7/label"
interchaintestrelayer "github.com/strangelove-ventures/interchaintest/v7/relayer"
)
@@ -41,8 +40,4 @@ func (RelayerFactory) Capabilities() map[interchaintestrelayer.Capability]bool {
return interchaintestrelayer.FullCapabilities()
}
-func (RelayerFactory) Labels() []label.Relayer {
- return []label.Relayer{label.Rly}
-}
-
func (RelayerFactory) Name() string { return "github.com/cosmos/relayer" }
diff --git a/interchaintest/relayer_override_test.go b/interchaintest/relayer_override_test.go
index 4774ce5a6..d729cc719 100644
--- a/interchaintest/relayer_override_test.go
+++ b/interchaintest/relayer_override_test.go
@@ -23,13 +23,13 @@ import (
// is a client-id present in the relative path config. If the override flag is present, the relayer should always
// attempt to create a new light client and then overwrite the config file if successful.
func TestClientOverrideFlag(t *testing.T) {
- relayerinterchaintest.BuildRelayerImage(t)
+ image := relayerinterchaintest.BuildRelayerImage(t)
client, network := interchaintest.DockerSetup(t)
r := interchaintest.NewBuiltinRelayerFactory(
ibc.CosmosRly,
zaptest.NewLogger(t),
- interchaintestrelayer.CustomDockerImage(relayerinterchaintest.RelayerImageName, "latest", "100:1000"),
+ interchaintestrelayer.CustomDockerImage(image, "latest", "100:1000"),
interchaintestrelayer.ImagePull(false),
).Build(t, client, network)
@@ -73,10 +73,11 @@ func TestClientOverrideFlag(t *testing.T) {
})
require.NoError(t, ic.Build(ctx, eRep, interchaintest.InterchainBuildOptions{
- TestName: t.Name(),
- Client: client,
- NetworkID: network,
- BlockDatabaseFile: interchaintest.DefaultBlockDatabaseFilepath(),
+ TestName: t.Name(),
+ Client: client,
+ NetworkID: network,
+ // Uncomment this to load blocks, txs, msgs, and events into sqlite db as test runs
+ // BlockDatabaseFile: interchaintest.DefaultBlockDatabaseFilepath(),
SkipPathCreation: true,
}))
diff --git a/interchaintest/stride/stride_icq_test.go b/interchaintest/stride/stride_icq_test.go
index 00a42c609..ac9a067e4 100644
--- a/interchaintest/stride/stride_icq_test.go
+++ b/interchaintest/stride/stride_icq_test.go
@@ -16,6 +16,7 @@ import (
"github.com/strangelove-ventures/interchaintest/v7/testreporter"
"github.com/strangelove-ventures/interchaintest/v7/testutil"
"github.com/stretchr/testify/require"
+ "go.uber.org/zap"
"go.uber.org/zap/zaptest"
"golang.org/x/sync/errgroup"
)
@@ -26,9 +27,6 @@ func TestScenarioStrideICAandICQ(t *testing.T) {
if testing.Short() {
t.Skip()
}
-
- t.Parallel()
-
client, network := interchaintest.DockerSetup(t)
rep := testreporter.NewNopReporter()
@@ -38,9 +36,10 @@ func TestScenarioStrideICAandICQ(t *testing.T) {
nf := 0
nv := 1
+ logger := zaptest.NewLogger(t)
// Define chains involved in test
- cf := interchaintest.NewBuiltinChainFactory(zaptest.NewLogger(t), []*interchaintest.ChainSpec{
+ cf := interchaintest.NewBuiltinChainFactory(logger, []*interchaintest.ChainSpec{
{
Name: "stride",
ChainName: "stride",
@@ -113,10 +112,15 @@ func TestScenarioStrideICAandICQ(t *testing.T) {
SkipPathCreation: false,
}))
+
+ t.Parallel()
+
t.Cleanup(func() {
_ = ic.Close()
})
+ logger.Info("TestScenarioStrideICAandICQ [1]")
+
// Fund user accounts, so we can query balances and make assertions.
const userFunds = int64(10_000_000_000_000)
users := interchaintest.GetAndFundTestUsers(t, ctx, t.Name(), userFunds, stride, gaia)
@@ -128,6 +132,8 @@ func TestScenarioStrideICAandICQ(t *testing.T) {
err = r.StartRelayer(ctx, eRep, pathStrideGaia)
require.NoError(t, err)
+ logger.Info("TestScenarioStrideICAandICQ [2]")
+
t.Cleanup(
func() {
err := r.StopRelayer(ctx, eRep)
@@ -147,6 +153,8 @@ func TestScenarioStrideICAandICQ(t *testing.T) {
strideAdminAddr, err := types.Bech32ifyAddressBytes(strideCfg.Bech32Prefix, strideAdminAddrBytes)
require.NoError(t, err)
+ logger.Info("TestScenarioStrideICAandICQ [3]")
+
err = stride.SendFunds(ctx, interchaintest.FaucetAccountKeyName, ibc.WalletAmount{
Address: strideAdminAddr,
Amount: userFunds,
@@ -154,12 +162,16 @@ func TestScenarioStrideICAandICQ(t *testing.T) {
})
require.NoError(t, err, "failed to fund stride admin account")
+ logger.Info("TestScenarioStrideICAandICQ [4]")
+
// get native chain user addresses
strideAddr := strideUser.FormattedAddress()
require.NotEmpty(t, strideAddr)
+ logger.Info("TestScenarioStrideICAandICQ [5]", zap.String("stride addr", strideAddr))
gaiaAddress := gaiaUser.FormattedAddress()
require.NotEmpty(t, gaiaAddress)
+ logger.Info("TestScenarioStrideICAandICQ [6]", zap.String("gaia addr", gaiaAddress))
// get ibc paths
gaiaConns, err := r.GetConnections(ctx, eRep, gaiaCfg.ChainID)
@@ -168,6 +180,8 @@ func TestScenarioStrideICAandICQ(t *testing.T) {
gaiaChans, err := r.GetChannels(ctx, eRep, gaiaCfg.ChainID)
require.NoError(t, err)
+ logger.Info("TestScenarioStrideICAandICQ [7]")
+
atomIBCDenom := transfertypes.ParseDenomTrace(
transfertypes.GetPrefixedDenom(
gaiaChans[0].Counterparty.PortID,
@@ -182,6 +196,8 @@ func TestScenarioStrideICAandICQ(t *testing.T) {
gaiaHeight, err := gaia.Height(ctx)
require.NoError(t, err)
+ logger.Info("TestScenarioStrideICAandICQ [8]")
+
// Fund stride user with ibc denom atom
tx, err := gaia.SendIBCTransfer(ctx, gaiaChans[0].ChannelID, gaiaUser.KeyName(), ibc.WalletAmount{
Amount: 1_000_000_000_000,
@@ -190,13 +206,19 @@ func TestScenarioStrideICAandICQ(t *testing.T) {
}, ibc.TransferOptions{})
require.NoError(t, err)
- _, err = testutil.PollForAck(ctx, gaia, gaiaHeight, gaiaHeight+10, tx.Packet)
+ logger.Info("TestScenarioStrideICAandICQ [9]")
+
+ _, err = testutil.PollForAck(ctx, gaia, gaiaHeight, gaiaHeight+40, tx.Packet)
require.NoError(t, err)
+ logger.Info("TestScenarioStrideICAandICQ [10]")
+
require.NoError(t, eg.Wait())
+ logger.Info("TestScenarioStrideICAandICQ [11]")
+
// Register gaia host zone
- _, err = strideFullNode.ExecTx(ctx, StrideAdminAccount,
+ res, err := strideFullNode.ExecTx(ctx, StrideAdminAccount,
"stakeibc", "register-host-zone",
gaiaConns[0].Counterparty.ConnectionId, gaiaCfg.Denom, gaiaCfg.Bech32Prefix,
atomIBCDenom, gaiaChans[0].Counterparty.ChannelID, "1",
@@ -204,30 +226,40 @@ func TestScenarioStrideICAandICQ(t *testing.T) {
)
require.NoError(t, err)
+ logger.Info("TestScenarioStrideICAandICQ [12]", zap.String("execTx res", res))
+
gaiaHeight, err = gaia.Height(ctx)
require.NoError(t, err)
+ logger.Info("TestScenarioStrideICAandICQ [13]")
+
// Wait for the ICA accounts to be setup
// Poll for 4 MsgChannelOpenConfirm with timeout after 15 blocks.
chanCount := 0
_, err = cosmos.PollForMessage(
- ctx, gaia, gaiaCfg.EncodingConfig.InterfaceRegistry, gaiaHeight, gaiaHeight+15,
+ ctx, gaia, gaiaCfg.EncodingConfig.InterfaceRegistry, gaiaHeight, gaiaHeight+40,
func(found *chantypes.MsgChannelOpenConfirm) bool { chanCount++; return chanCount == 4 },
)
require.NoError(t, err)
+ logger.Info("TestScenarioStrideICAandICQ [14]")
+
// Get validator address
gaiaVal1Address, err := gaia.Validators[0].KeyBech32(ctx, "validator", "val")
require.NoError(t, err)
+ logger.Info("TestScenarioStrideICAandICQ [15]")
+
// Add gaia validator
- _, err = strideFullNode.ExecTx(ctx, StrideAdminAccount,
+ res, err = strideFullNode.ExecTx(ctx, StrideAdminAccount,
"stakeibc", "add-validator",
gaiaCfg.ChainID, "gval1", gaiaVal1Address,
"10", "5",
)
require.NoError(t, err)
+ logger.Info("TestScenarioStrideICAandICQ [16]", zap.String("execTx res", res))
+
var gaiaHostZone HostZoneWrapper
// query gaia host zone
@@ -238,20 +270,31 @@ func TestScenarioStrideICAandICQ(t *testing.T) {
err = json.Unmarshal(stdout, &gaiaHostZone)
require.NoError(t, err)
+ logger.Info("TestScenarioStrideICAandICQ [17]", zap.String("execQuery res", string(stdout)))
+
// Liquid stake some atom
- _, err = strideFullNode.ExecTx(ctx, strideUser.KeyName(),
+ res, err = strideFullNode.ExecTx(ctx, strideUser.KeyName(),
"stakeibc", "liquid-stake",
"1000000000000", gaiaCfg.Denom,
)
require.NoError(t, err)
+ logger.Info("TestScenarioStrideICAandICQ [18]", zap.String("execTx res", res))
+
strideHeight, err := stride.Height(ctx)
require.NoError(t, err)
+ logger.Info("TestScenarioStrideICAandICQ [19]")
+
// Poll for MsgSubmitQueryResponse with timeout after 20 blocks
- _, err = cosmos.PollForMessage(
- ctx, stride, strideCfg.EncodingConfig.InterfaceRegistry, strideHeight, strideHeight+20,
+ resp, err := cosmos.PollForMessage(
+ ctx, stride, strideCfg.EncodingConfig.InterfaceRegistry, strideHeight, strideHeight+40,
func(found *rlystride.MsgSubmitQueryResponse) bool { return true },
)
+
+ logger.Info("TestScenarioStrideICAandICQ [20]", zap.String("[poll for msg] resp", resp.String()))
+ if err != nil {
+ logger.Info("error poll: " + err.Error())
+ }
require.NoError(t, err)
}
diff --git a/interchaintest/tendermint_v0.37_boundary_test.go b/interchaintest/tendermint_v0.37_boundary_test.go
index 7833eb489..04a7a8c47 100644
--- a/interchaintest/tendermint_v0.37_boundary_test.go
+++ b/interchaintest/tendermint_v0.37_boundary_test.go
@@ -18,8 +18,6 @@ func TestScenarioTendermint37Boundary(t *testing.T) {
t.Skip("skipping in short mode")
}
- t.Parallel()
-
nv := 1
nf := 0
@@ -58,6 +56,8 @@ func TestScenarioTendermint37Boundary(t *testing.T) {
})
r := rf.Build(t, client, network)
+ t.Parallel()
+
ic := interchaintest.NewInterchain().
AddChain(chain).
AddChain(counterpartyChain).
@@ -74,11 +74,12 @@ func TestScenarioTendermint37Boundary(t *testing.T) {
rep := testreporter.NewNopReporter()
require.NoError(t, ic.Build(ctx, rep.RelayerExecReporter(t), interchaintest.InterchainBuildOptions{
- TestName: t.Name(),
- Client: client,
- NetworkID: network,
- BlockDatabaseFile: interchaintest.DefaultBlockDatabaseFilepath(),
- SkipPathCreation: false,
+ TestName: t.Name(),
+ Client: client,
+ NetworkID: network,
+ // Uncomment this to load blocks, txs, msgs, and events into sqlite db as test runs
+ // BlockDatabaseFile: interchaintest.DefaultBlockDatabaseFilepath(),
+ SkipPathCreation: false,
}))
t.Cleanup(func() {
_ = ic.Close()
diff --git a/internal/relayertest/system.go b/internal/relayertest/system.go
index 0e1641b34..6b917b653 100644
--- a/internal/relayertest/system.go
+++ b/internal/relayertest/system.go
@@ -15,6 +15,7 @@ import (
"github.com/stretchr/testify/require"
"go.uber.org/zap"
"go.uber.org/zap/zaptest"
+ "gopkg.in/yaml.v3"
)
// System is a system under test.
@@ -129,10 +130,10 @@ func (s *System) MustAddChain(t *testing.T, chainName string, pcw cmd.ProviderCo
func (s *System) MustGetConfig(t *testing.T) (config cmd.ConfigInputWrapper) {
t.Helper()
- configBz, err := os.ReadFile(filepath.Join(s.HomeDir, "config.yaml"))
+ configBz, err := os.ReadFile(filepath.Join(s.HomeDir, "config", "config.yaml"))
require.NoError(t, err, "failed to read config file")
- err = json.Unmarshal(configBz, &config)
+ err = yaml.Unmarshal(configBz, &config)
require.NoError(t, err, "failed to unmarshal config file")
return config
diff --git a/local.Dockerfile b/local.Dockerfile
index 9a66c5a6e..42e30e564 100644
--- a/local.Dockerfile
+++ b/local.Dockerfile
@@ -1,4 +1,4 @@
-FROM golang:1.19-alpine3.16 AS build-env
+FROM golang:1.20-alpine3.16 AS build-env
RUN apk add --update --no-cache curl make git libc-dev bash gcc linux-headers eudev-dev
diff --git a/main.go b/main.go
index 2dd1b6e4d..958a04ad7 100644
--- a/main.go
+++ b/main.go
@@ -1,7 +1,15 @@
package main
-import "github.com/cosmos/relayer/v2/cmd"
+import (
+ sdk "github.com/cosmos/cosmos-sdk/types"
+ "github.com/cosmos/relayer/v2/cmd"
+)
func main() {
cmd.Execute()
}
+
+func init() {
+ //prevent incorrect bech32 address prefixed addresses when calling AccAddress.String()
+ sdk.SetAddrCacheEnabled(false)
+}
diff --git a/proto/buf.gen.gogo.yaml b/proto/buf.gen.gogo.yaml
index fc6e4fc51..b071dd1bb 100644
--- a/proto/buf.gen.gogo.yaml
+++ b/proto/buf.gen.gogo.yaml
@@ -2,3 +2,7 @@ version: v1
plugins:
- name: gocosmos
out: .
+ opt: plugins=grpc,Mgoogle/protobuf/any.proto=github.com/cosmos/cosmos-sdk/codec/types
+ - name: grpc-gateway
+ out: .
+ opt: logtostderr=true,allow_colon_final_segments=true
diff --git a/proto/buf.gen.penumbra.yaml b/proto/buf.gen.penumbra.yaml
new file mode 100644
index 000000000..781eea262
--- /dev/null
+++ b/proto/buf.gen.penumbra.yaml
@@ -0,0 +1,13 @@
+version: v1
+managed:
+ enabled: true
+ go_package_prefix:
+ default: github.com/cosmos/relayer/v2/relayer/chains
+ except:
+ - buf.build/cosmos/ibc
+ - github.com/cometbft/cometbft
+ - buf.build/cosmos/cosmos-sdk
+plugins:
+ - name: gocosmos
+ out: .
+ opt: plugins=grpc,Mgoogle/protobuf/any.proto=github.com/cosmos/cosmos-sdk/codec/types
diff --git a/proto/buf.lock b/proto/buf.lock
new file mode 100644
index 000000000..40983632a
--- /dev/null
+++ b/proto/buf.lock
@@ -0,0 +1,31 @@
+# Generated by buf. DO NOT EDIT.
+version: v1
+deps:
+ - remote: buf.build
+ owner: cosmos
+ repository: cosmos-proto
+ commit: 1935555c206d4afb9e94615dfd0fad31
+ - remote: buf.build
+ owner: cosmos
+ repository: cosmos-sdk
+ commit: 7c06e7f6f43c406185136100bfd7b848
+ - remote: buf.build
+ owner: cosmos
+ repository: gogo-proto
+ commit: 34d970b699f84aa382f3c29773a60836
+ - remote: buf.build
+ owner: cosmos
+ repository: ibc
+ commit: 6e966f8dba714d108a52ffabbcb0e5c3
+ - remote: buf.build
+ owner: cosmos
+ repository: ics23
+ commit: 55085f7c710a45f58fa09947208eb70b
+ - remote: buf.build
+ owner: googleapis
+ repository: googleapis
+ commit: 75b4300737fb4efca0831636be94e517
+ - remote: buf.build
+ owner: penumbra-zone
+ repository: penumbra
+ commit: 42619f653f4d470291f3d8b68d7ae7ae
diff --git a/proto/buf.yaml b/proto/buf.yaml
new file mode 100644
index 000000000..008d82060
--- /dev/null
+++ b/proto/buf.yaml
@@ -0,0 +1,7 @@
+version: v1
+deps:
+ - buf.build/penumbra-zone/penumbra
+ - buf.build/cosmos/cosmos-sdk
+ - buf.build/cosmos/cosmos-proto
+ - buf.build/cosmos/gogo-proto
+ - buf.build/googleapis/googleapis
\ No newline at end of file
diff --git a/proto/cosmos/crypto/sr25519/keys.proto b/proto/cosmos/crypto/sr25519/keys.proto
new file mode 100644
index 000000000..384cafe3a
--- /dev/null
+++ b/proto/cosmos/crypto/sr25519/keys.proto
@@ -0,0 +1,21 @@
+syntax = "proto3";
+
+// buf:lint:ignore PACKAGE_VERSION_SUFFIX
+package cosmos.crypto.sr25519;
+
+import "gogoproto/gogo.proto";
+
+// Originally github.com/cosmos/cosmos-sdk/crypto/keys/sr25519
+option go_package = "github.com/cosmos/relayer/v2/relayer/chains/cosmos/keys/sr25519";
+
+option (gogoproto.messagename_all) = true;
+option (gogoproto.goproto_stringer_all) = false;
+option (gogoproto.goproto_getters_all) = false;
+
+// PubKey defines a sr25519 ECDSA public key.
+message PubKey {
+ option (gogoproto.goproto_stringer) = false;
+
+ bytes key = 1 [ (gogoproto.casttype) =
+ "github.com/cometbft/cometbft/crypto/sr25519.PubKey" ];
+}
diff --git a/relayer/chain.go b/relayer/chain.go
index 3dafdba99..d7948786a 100644
--- a/relayer/chain.go
+++ b/relayer/chain.go
@@ -8,6 +8,7 @@ import (
"time"
"github.com/avast/retry-go/v4"
+ "github.com/cosmos/cosmos-sdk/crypto/hd"
clienttypes "github.com/cosmos/ibc-go/v7/modules/core/02-client/types"
"github.com/cosmos/relayer/v2/relayer/provider"
"go.uber.org/zap"
@@ -20,6 +21,7 @@ var (
RtyErr = retry.LastErrorOnly(true)
defaultCoinType uint32 = 118
+ defaultAlgo string = string(hd.Secp256k1Type)
)
// Chain represents the necessary data for connecting to and identifying a chain and its counterparties
@@ -65,6 +67,7 @@ func ValidateConnectionPaths(src, dst *Chain) error {
if err := dst.PathEnd.Vconn(); err != nil {
return err
}
+
return nil
}
@@ -146,7 +149,7 @@ func (c *Chain) CreateTestKey() error {
if c.ChainProvider.KeyExists(c.ChainProvider.Key()) {
return fmt.Errorf("key {%s} exists for chain {%s}", c.ChainProvider.Key(), c.ChainID())
}
- _, err := c.ChainProvider.AddKey(c.ChainProvider.Key(), defaultCoinType)
+ _, err := c.ChainProvider.AddKey(c.ChainProvider.Key(), defaultCoinType, defaultAlgo, "")
return err
}
diff --git a/relayer/chains/cosmos/codec.go b/relayer/chains/cosmos/codec.go
index 38f6d3d72..6cecfda29 100644
--- a/relayer/chains/cosmos/codec.go
+++ b/relayer/chains/cosmos/codec.go
@@ -10,8 +10,6 @@ import (
"github.com/cosmos/cosmos-sdk/x/auth/tx"
authz "github.com/cosmos/cosmos-sdk/x/authz/module"
"github.com/cosmos/cosmos-sdk/x/bank"
- "github.com/cosmos/cosmos-sdk/x/capability"
- "github.com/cosmos/cosmos-sdk/x/crisis"
"github.com/cosmos/cosmos-sdk/x/distribution"
feegrant "github.com/cosmos/cosmos-sdk/x/feegrant/module"
"github.com/cosmos/cosmos-sdk/x/gov"
@@ -21,8 +19,9 @@ import (
paramsclient "github.com/cosmos/cosmos-sdk/x/params/client"
"github.com/cosmos/cosmos-sdk/x/slashing"
"github.com/cosmos/cosmos-sdk/x/staking"
- "github.com/cosmos/cosmos-sdk/x/upgrade"
upgradeclient "github.com/cosmos/cosmos-sdk/x/upgrade/client"
+ "github.com/cosmos/ibc-go/modules/capability"
+ ibcfee "github.com/cosmos/ibc-go/v7/modules/apps/29-fee"
"github.com/cosmos/ibc-go/v7/modules/apps/transfer"
ibc "github.com/cosmos/ibc-go/v7/modules/core"
@@ -46,18 +45,19 @@ var ModuleBasics = []module.AppModuleBasic{
upgradeclient.LegacyCancelProposalHandler,
},
),
- crisis.AppModuleBasic{},
+ // crisis.AppModuleBasic{},
distribution.AppModuleBasic{},
feegrant.AppModuleBasic{},
mint.AppModuleBasic{},
params.AppModuleBasic{},
slashing.AppModuleBasic{},
staking.AppModuleBasic{},
- upgrade.AppModuleBasic{},
+ // upgrade.AppModuleBasic{},
transfer.AppModuleBasic{},
ibc.AppModuleBasic{},
cosmosmodule.AppModuleBasic{},
stride.AppModuleBasic{},
+ ibcfee.AppModuleBasic{},
}
type Codec struct {
diff --git a/relayer/chains/cosmos/cosmos_chain_processor.go b/relayer/chains/cosmos/cosmos_chain_processor.go
index bf594165b..26c4577c2 100644
--- a/relayer/chains/cosmos/cosmos_chain_processor.go
+++ b/relayer/chains/cosmos/cosmos_chain_processor.go
@@ -12,6 +12,7 @@ import (
clienttypes "github.com/cosmos/ibc-go/v7/modules/core/02-client/types"
conntypes "github.com/cosmos/ibc-go/v7/modules/core/03-connection/types"
chantypes "github.com/cosmos/ibc-go/v7/modules/core/04-channel/types"
+ ibcexported "github.com/cosmos/ibc-go/v7/modules/core/exported"
"github.com/cosmos/relayer/v2/relayer/processor"
"github.com/cosmos/relayer/v2/relayer/provider"
@@ -70,6 +71,7 @@ func NewCosmosChainProcessor(log *zap.Logger, provider *CosmosProvider, metrics
const (
queryTimeout = 5 * time.Second
+ queryStateTimeout = 60 * time.Second
blockResultsQueryTimeout = 2 * time.Minute
latestHeightQueryRetryDelay = 1 * time.Second
latestHeightQueryRetries = 5
@@ -77,6 +79,7 @@ const (
defaultMinQueryLoopDuration = 1 * time.Second
defaultBalanceUpdateWaitDuration = 60 * time.Second
inSyncNumBlocksThreshold = 2
+ blockMaxRetries = 5
)
// latestClientState is a map of clientID to the latest clientInfo for that client.
@@ -165,35 +168,55 @@ func (ccp *CosmosChainProcessor) clientState(ctx context.Context, clientID strin
if state, ok := ccp.latestClientState[clientID]; ok && state.TrustingPeriod > 0 {
return state, nil
}
- cs, err := ccp.chainProvider.queryTMClientState(ctx, int64(ccp.latestBlock.Height), clientID)
- if err != nil {
- return provider.ClientState{}, err
- }
- clientState := provider.ClientState{
- ClientID: clientID,
- ConsensusHeight: cs.GetLatestHeight().(clienttypes.Height),
- TrustingPeriod: cs.TrustingPeriod,
+
+ var clientState provider.ClientState
+ if clientID == ibcexported.LocalhostClientID {
+ cs, err := ccp.chainProvider.queryLocalhostClientState(ctx, int64(ccp.latestBlock.Height))
+ if err != nil {
+ return provider.ClientState{}, err
+ }
+ clientState = provider.ClientState{
+ ClientID: clientID,
+ ConsensusHeight: cs.GetLatestHeight().(clienttypes.Height),
+ }
+ } else {
+ cs, err := ccp.chainProvider.queryTMClientState(ctx, int64(ccp.latestBlock.Height), clientID)
+ if err != nil {
+ return provider.ClientState{}, err
+ }
+ clientState = provider.ClientState{
+ ClientID: clientID,
+ ConsensusHeight: cs.GetLatestHeight().(clienttypes.Height),
+ TrustingPeriod: cs.TrustingPeriod,
+ }
}
+
ccp.latestClientState[clientID] = clientState
return clientState, nil
}
// queryCyclePersistence hold the variables that should be retained across queryCycles.
type queryCyclePersistence struct {
- latestHeight int64
- latestQueriedBlock int64
- minQueryLoopDuration time.Duration
- lastBalanceUpdate time.Time
- balanceUpdateWaitDuration time.Duration
+ latestHeight int64
+ latestQueriedBlock int64
+ retriesAtLatestQueriedBlock int
+ minQueryLoopDuration time.Duration
+ lastBalanceUpdate time.Time
+ balanceUpdateWaitDuration time.Duration
}
// Run starts the query loop for the chain which will gather applicable ibc messages and push events out to the relevant PathProcessors.
// The initialBlockHistory parameter determines how many historical blocks should be fetched and processed before continuing with current blocks.
// ChainProcessors should obey the context and return upon context cancellation.
func (ccp *CosmosChainProcessor) Run(ctx context.Context, initialBlockHistory uint64) error {
+ minQueryLoopDuration := ccp.chainProvider.PCfg.MinLoopDuration
+ if minQueryLoopDuration == 0 {
+ minQueryLoopDuration = defaultMinQueryLoopDuration
+ }
+
// this will be used for persistence across query cycle loop executions
persistence := queryCyclePersistence{
- minQueryLoopDuration: defaultMinQueryLoopDuration,
+ minQueryLoopDuration: minQueryLoopDuration,
lastBalanceUpdate: time.Unix(0, 0),
balanceUpdateWaitDuration: defaultBalanceUpdateWaitDuration,
}
@@ -255,9 +278,17 @@ func (ccp *CosmosChainProcessor) Run(ctx context.Context, initialBlockHistory ui
}
}
+func (ccp *CosmosChainProcessor) SnapshotHeight(height int64) {
+ panic("Not implemented for Cosmos")
+}
+
+func (ccp *CosmosChainProcessor) StartFromHeight(ctx context.Context) int64 {
+ panic("Not implemented for Cosmos")
+}
+
// initializeConnectionState will bootstrap the connectionStateCache with the open connection state.
func (ccp *CosmosChainProcessor) initializeConnectionState(ctx context.Context) error {
- ctx, cancel := context.WithTimeout(ctx, queryTimeout)
+ ctx, cancel := context.WithTimeout(ctx, queryStateTimeout)
defer cancel()
connections, err := ccp.chainProvider.QueryConnections(ctx)
if err != nil {
@@ -277,7 +308,7 @@ func (ccp *CosmosChainProcessor) initializeConnectionState(ctx context.Context)
// initializeChannelState will bootstrap the channelStateCache with the open channel state.
func (ccp *CosmosChainProcessor) initializeChannelState(ctx context.Context) error {
- ctx, cancel := context.WithTimeout(ctx, queryTimeout)
+ ctx, cancel := context.WithTimeout(ctx, queryStateTimeout)
defer cancel()
channels, err := ccp.chainProvider.QueryChannels(ctx)
if err != nil {
@@ -293,12 +324,13 @@ func (ccp *CosmosChainProcessor) initializeChannelState(ctx context.Context) err
continue
}
ccp.channelConnections[ch.ChannelId] = ch.ConnectionHops[0]
- ccp.channelStateCache[processor.ChannelKey{
+ k := processor.ChannelKey{
ChannelID: ch.ChannelId,
PortID: ch.PortId,
CounterpartyChannelID: ch.Counterparty.ChannelId,
CounterpartyPortID: ch.Counterparty.PortId,
- }] = ch.State == chantypes.OPEN
+ }
+ ccp.channelStateCache.SetOpen(k, ch.State == chantypes.OPEN, ch.Ordering)
}
return nil
}
@@ -318,9 +350,10 @@ func (ccp *CosmosChainProcessor) queryCycle(ctx context.Context, persistence *qu
persistence.latestHeight = status.SyncInfo.LatestBlockHeight
ccp.chainProvider.setCometVersion(ccp.log, status.NodeInfo.Version)
- ccp.log.Debug("Queried latest height",
- zap.Int64("latest_height", persistence.latestHeight),
- )
+ // This debug log is very noisy, but is helpful when debugging new chains.
+ // ccp.log.Debug("Queried latest height",
+ // zap.Int64("latest_height", persistence.latestHeight),
+ // )
if ccp.metrics != nil {
ccp.CollectMetrics(ctx, persistence)
@@ -363,20 +396,48 @@ func (ccp *CosmosChainProcessor) queryCycle(ctx context.Context, persistence *qu
queryCtx, cancelQueryCtx := context.WithTimeout(ctx, blockResultsQueryTimeout)
defer cancelQueryCtx()
blockRes, err = ccp.chainProvider.RPCClient.BlockResults(queryCtx, &i)
+ if err != nil && ccp.metrics != nil {
+ ccp.metrics.IncBlockQueryFailure(chainID, "RPC Client")
+ }
return err
})
eg.Go(func() (err error) {
queryCtx, cancelQueryCtx := context.WithTimeout(ctx, queryTimeout)
defer cancelQueryCtx()
ibcHeader, err = ccp.chainProvider.QueryIBCHeader(queryCtx, i)
+ if err != nil && ccp.metrics != nil {
+ ccp.metrics.IncBlockQueryFailure(chainID, "IBC Header")
+ }
return err
})
if err := eg.Wait(); err != nil {
- ccp.log.Warn("Error querying block data", zap.Error(err))
+ ccp.log.Debug(
+ "Error querying block data",
+ zap.Int64("height", i),
+ zap.Error(err),
+ )
+
+ persistence.retriesAtLatestQueriedBlock++
+ if persistence.retriesAtLatestQueriedBlock >= blockMaxRetries {
+ ccp.log.Warn("Reached max retries querying for block, skipping", zap.Int64("height", i))
+ // skip this block. now depends on flush to pickup anything missed in the block.
+ persistence.latestQueriedBlock = i
+ persistence.retriesAtLatestQueriedBlock = 0
+ continue
+ }
break
}
+ ccp.log.Debug(
+ "Queried block",
+ zap.Int64("height", i),
+ zap.Int64("latest", persistence.latestHeight),
+ zap.Int64("delta", persistence.latestHeight-i),
+ )
+
+ persistence.retriesAtLatestQueriedBlock = 0
+
latestHeader = ibcHeader.(provider.TendermintIBCHeader)
heightUint64 := uint64(i)
@@ -486,22 +547,25 @@ func (ccp *CosmosChainProcessor) CurrentRelayerBalance(ctx context.Context) {
}
// Get the balance for the chain provider's key
- relayerWalletBalance, err := ccp.chainProvider.QueryBalance(ctx, ccp.chainProvider.Key())
+ relayerWalletBalances, err := ccp.chainProvider.QueryBalance(ctx, ccp.chainProvider.Key())
if err != nil {
ccp.log.Error(
"Failed to query relayer balance",
zap.Error(err),
)
}
-
+ address, err := ccp.chainProvider.Address()
+ if err != nil {
+ ccp.log.Error(
+ "Failed to get relayer bech32 wallet addresss",
+ zap.Error(err),
+ )
+ }
// Print the relevant gas prices
for _, gasDenom := range *ccp.parsedGasPrices {
- for _, balance := range relayerWalletBalance {
- if balance.Denom == gasDenom.Denom {
- // Convert to a big float to get a float64 for metrics
- f, _ := big.NewFloat(0.0).SetInt(balance.Amount.BigInt()).Float64()
- ccp.metrics.SetWalletBalance(ccp.chainProvider.ChainId(), ccp.chainProvider.Key(), balance.Denom, f)
- }
- }
+ bal := relayerWalletBalances.AmountOf(gasDenom.Denom)
+ // Convert to a big float to get a float64 for metrics
+ f, _ := big.NewFloat(0.0).SetInt(bal.BigInt()).Float64()
+ ccp.metrics.SetWalletBalance(ccp.chainProvider.ChainId(), ccp.chainProvider.PCfg.GasPrices, ccp.chainProvider.Key(), address, gasDenom.Denom, f)
}
}
diff --git a/relayer/chains/cosmos/event_parser.go b/relayer/chains/cosmos/event_parser.go
index 38ef47288..45902b0bf 100644
--- a/relayer/chains/cosmos/event_parser.go
+++ b/relayer/chains/cosmos/event_parser.go
@@ -43,14 +43,14 @@ func (ccp *CosmosChainProcessor) ibcMessagesFromBlockEvents(
func parseBase64Event(log *zap.Logger, event abci.Event) sdk.StringEvent {
evt := sdk.StringEvent{Type: event.Type}
for _, attr := range event.Attributes {
- key, err := base64.StdEncoding.DecodeString(attr.Key)
+ key, err := base64.StdEncoding.DecodeString(string(attr.Key))
if err != nil {
- log.Error("Failed to decode legacy key as base64", zap.String("base64", attr.Key), zap.Error(err))
+ log.Error("Failed to decode legacy key as base64", zap.String("base64", string(attr.Key)), zap.Error(err))
continue
}
- value, err := base64.StdEncoding.DecodeString(attr.Value)
+ value, err := base64.StdEncoding.DecodeString(string(attr.Value))
if err != nil {
- log.Error("Failed to decode legacy value as base64", zap.String("base64", attr.Value), zap.Error(err))
+ log.Error("Failed to decode legacy value as base64", zap.String("base64", string(attr.Value)), zap.Error(err))
continue
}
evt.Attributes = append(evt.Attributes, sdk.Attribute{
diff --git a/relayer/chains/cosmos/event_parser_test.go b/relayer/chains/cosmos/event_parser_test.go
index 95106356b..69039e69d 100644
--- a/relayer/chains/cosmos/event_parser_test.go
+++ b/relayer/chains/cosmos/event_parser_test.go
@@ -4,7 +4,6 @@ import (
"encoding/hex"
"testing"
- abci "github.com/cometbft/cometbft/abci/types"
sdk "github.com/cosmos/cosmos-sdk/types"
clienttypes "github.com/cosmos/ibc-go/v7/modules/core/02-client/types"
conntypes "github.com/cosmos/ibc-go/v7/modules/core/03-connection/types"
@@ -217,145 +216,145 @@ func TestParseEventLogs(t *testing.T) {
testPacketDstChannel = "channel-1"
testPacketDstPort = "port-1"
)
- events := []abci.Event{
-
- {
- Type: clienttypes.EventTypeUpdateClient,
- Attributes: []abci.EventAttribute{
- {
- Key: clienttypes.AttributeKeyClientID,
- Value: testClientID1,
- },
- {
- Key: clienttypes.AttributeKeyConsensusHeight,
- Value: testClientConsensusHeight,
- },
- },
- },
- {
- Type: chantypes.EventTypeRecvPacket,
- Attributes: []abci.EventAttribute{
- {
- Key: chantypes.AttributeKeySequence,
- Value: testPacketSequence,
- },
- {
- Key: chantypes.AttributeKeyDataHex,
- Value: testPacketDataHex,
- },
- {
- Key: chantypes.AttributeKeyTimeoutHeight,
- Value: testPacketTimeoutHeight,
- },
- {
- Key: chantypes.AttributeKeyTimeoutTimestamp,
- Value: testPacketTimeoutTimestamp,
- },
- {
- Key: chantypes.AttributeKeySrcChannel,
- Value: testPacketSrcChannel,
- },
- {
- Key: chantypes.AttributeKeySrcPort,
- Value: testPacketSrcPort,
- },
- {
- Key: chantypes.AttributeKeyDstChannel,
- Value: testPacketDstChannel,
- },
- {
- Key: chantypes.AttributeKeyDstPort,
- Value: testPacketDstPort,
- },
- },
- },
- {
- Type: chantypes.EventTypeWriteAck,
- Attributes: []abci.EventAttribute{
- {
- Key: chantypes.AttributeKeySequence,
- Value: testPacketSequence,
- },
- {
- Key: chantypes.AttributeKeyAckHex,
- Value: testPacketAckHex,
- },
- {
- Key: chantypes.AttributeKeySrcChannel,
- Value: testPacketSrcChannel,
- },
- {
- Key: chantypes.AttributeKeySrcPort,
- Value: testPacketSrcPort,
- },
- {
- Key: chantypes.AttributeKeyDstChannel,
- Value: testPacketDstChannel,
- },
- {
- Key: chantypes.AttributeKeyDstPort,
- Value: testPacketDstPort,
- },
- },
- },
- }
-
- ibcMessages := ibcMessagesFromEvents(zap.NewNop(), events, "", 0, false)
-
- require.Len(t, ibcMessages, 3)
-
- msgUpdateClient := ibcMessages[0]
- require.Equal(t, clienttypes.EventTypeUpdateClient, msgUpdateClient.eventType)
-
- clientInfoParsed, isClientInfo := msgUpdateClient.info.(*clientInfo)
- require.True(t, isClientInfo, "messageInfo is not clientInfo")
-
- require.Empty(t, cmp.Diff(*clientInfoParsed, clientInfo{
- clientID: testClientID1,
- consensusHeight: clienttypes.Height{
- RevisionNumber: uint64(1),
- RevisionHeight: uint64(1023),
- },
- }, cmp.AllowUnexported(clientInfo{}, clienttypes.Height{})), "parsed client info does not match expected")
-
- msgRecvPacket := ibcMessages[1]
- require.Equal(t, chantypes.EventTypeRecvPacket, msgRecvPacket.eventType, "message event is not recv_packet")
-
- packetInfoParsed, isPacketInfo := msgRecvPacket.info.(*packetInfo)
- require.True(t, isPacketInfo, "recv_packet messageInfo is not packetInfo")
-
- msgWriteAcknowledgement := ibcMessages[2]
- require.Equal(t, chantypes.EventTypeWriteAck, msgWriteAcknowledgement.eventType, "message event is not write_acknowledgement")
-
- ackPacketInfoParsed, isPacketInfo := msgWriteAcknowledgement.info.(*packetInfo)
- require.True(t, isPacketInfo, "ack messageInfo is not packetInfo")
-
- packetAck, err := hex.DecodeString(testPacketAckHex)
- require.NoError(t, err, "error decoding test packet ack")
-
- packetData, err := hex.DecodeString(testPacketDataHex)
- require.NoError(t, err, "error decoding test packet data")
-
- require.Empty(t, cmp.Diff(provider.PacketInfo(*packetInfoParsed), provider.PacketInfo{
- Sequence: uint64(1),
- Data: packetData,
- TimeoutHeight: clienttypes.Height{
- RevisionNumber: uint64(1),
- RevisionHeight: uint64(1245),
- },
- TimeoutTimestamp: uint64(1654033235600000000),
- SourceChannel: testPacketSrcChannel,
- SourcePort: testPacketSrcPort,
- DestChannel: testPacketDstChannel,
- DestPort: testPacketDstPort,
- }), "parsed packet info does not match expected")
-
- require.Empty(t, cmp.Diff(provider.PacketInfo(*ackPacketInfoParsed), provider.PacketInfo{
- Sequence: uint64(1),
- SourceChannel: testPacketSrcChannel,
- SourcePort: testPacketSrcPort,
- DestChannel: testPacketDstChannel,
- DestPort: testPacketDstPort,
- Ack: packetAck,
- }), "parsed packet info does not match expected")
+ // events := []abci.Event{
+ //
+ // {
+ // Type: clienttypes.EventTypeUpdateClient,
+ // Attributes: []abci.EventAttribute{
+ // {
+ // Key: clienttypes.AttributeKeyClientID,
+ // Value: testClientID1,
+ // },
+ // {
+ // Key: clienttypes.AttributeKeyConsensusHeight,
+ // Value: testClientConsensusHeight,
+ // },
+ // },
+ // },
+ // {
+ // Type: chantypes.EventTypeRecvPacket,
+ // Attributes: []abci.EventAttribute{
+ // {
+ // Key: chantypes.AttributeKeySequence,
+ // Value: testPacketSequence,
+ // },
+ // {
+ // Key: chantypes.AttributeKeyDataHex,
+ // Value: testPacketDataHex,
+ // },
+ // {
+ // Key: chantypes.AttributeKeyTimeoutHeight,
+ // Value: testPacketTimeoutHeight,
+ // },
+ // {
+ // Key: chantypes.AttributeKeyTimeoutTimestamp,
+ // Value: testPacketTimeoutTimestamp,
+ // },
+ // {
+ // Key: chantypes.AttributeKeySrcChannel,
+ // Value: testPacketSrcChannel,
+ // },
+ // {
+ // Key: chantypes.AttributeKeySrcPort,
+ // Value: testPacketSrcPort,
+ // },
+ // {
+ // Key: chantypes.AttributeKeyDstChannel,
+ // Value: testPacketDstChannel,
+ // },
+ // {
+ // Key: chantypes.AttributeKeyDstPort,
+ // Value: testPacketDstPort,
+ // },
+ // },
+ // },
+ // {
+ // Type: chantypes.EventTypeWriteAck,
+ // Attributes: []abci.EventAttribute{
+ // {
+ // Key: chantypes.AttributeKeySequence,
+ // Value: testPacketSequence,
+ // },
+ // {
+ // Key: chantypes.AttributeKeyAckHex,
+ // Value: testPacketAckHex,
+ // },
+ // {
+ // Key: chantypes.AttributeKeySrcChannel,
+ // Value: testPacketSrcChannel,
+ // },
+ // {
+ // Key: chantypes.AttributeKeySrcPort,
+ // Value: testPacketSrcPort,
+ // },
+ // {
+ // Key: chantypes.AttributeKeyDstChannel,
+ // Value: testPacketDstChannel,
+ // },
+ // {
+ // Key: chantypes.AttributeKeyDstPort,
+ // Value: testPacketDstPort,
+ // },
+ // },
+ // },
}
+
+// ibcMessages := ibcMessagesFromEvents(zap.NewNop(), events, "", 0, false)
+
+// require.Len(t, ibcMessages, 3)
+
+// msgUpdateClient := ibcMessages[0]
+// require.Equal(t, clienttypes.EventTypeUpdateClient, msgUpdateClient.eventType)
+
+// clientInfoParsed, isClientInfo := msgUpdateClient.info.(*clientInfo)
+// require.True(t, isClientInfo, "messageInfo is not clientInfo")
+
+// require.Empty(t, cmp.Diff(*clientInfoParsed, clientInfo{
+// clientID: testClientID1,
+// consensusHeight: clienttypes.Height{
+// RevisionNumber: uint64(1),
+// RevisionHeight: uint64(1023),
+// },
+// }, cmp.AllowUnexported(clientInfo{}, clienttypes.Height{})), "parsed client info does not match expected")
+
+// msgRecvPacket := ibcMessages[1]
+// require.Equal(t, chantypes.EventTypeRecvPacket, msgRecvPacket.eventType, "message event is not recv_packet")
+
+// packetInfoParsed, isPacketInfo := msgRecvPacket.info.(*packetInfo)
+// require.True(t, isPacketInfo, "recv_packet messageInfo is not packetInfo")
+
+// msgWriteAcknowledgement := ibcMessages[2]
+// require.Equal(t, chantypes.EventTypeWriteAck, msgWriteAcknowledgement.eventType, "message event is not write_acknowledgement")
+
+// ackPacketInfoParsed, isPacketInfo := msgWriteAcknowledgement.info.(*packetInfo)
+// require.True(t, isPacketInfo, "ack messageInfo is not packetInfo")
+
+// packetAck, err := hex.DecodeString(testPacketAckHex)
+// require.NoError(t, err, "error decoding test packet ack")
+
+// packetData, err := hex.DecodeString(testPacketDataHex)
+// require.NoError(t, err, "error decoding test packet data")
+
+// require.Empty(t, cmp.Diff(provider.PacketInfo(*packetInfoParsed), provider.PacketInfo{
+// Sequence: uint64(1),
+// Data: packetData,
+// TimeoutHeight: clienttypes.Height{
+// RevisionNumber: uint64(1),
+// RevisionHeight: uint64(1245),
+// },
+// TimeoutTimestamp: uint64(1654033235600000000),
+// SourceChannel: testPacketSrcChannel,
+// SourcePort: testPacketSrcPort,
+// DestChannel: testPacketDstChannel,
+// DestPort: testPacketDstPort,
+// }), "parsed packet info does not match expected")
+
+// require.Empty(t, cmp.Diff(provider.PacketInfo(*ackPacketInfoParsed), provider.PacketInfo{
+// Sequence: uint64(1),
+// SourceChannel: testPacketSrcChannel,
+// SourcePort: testPacketSrcPort,
+// DestChannel: testPacketDstChannel,
+// DestPort: testPacketDstPort,
+// Ack: packetAck,
+// }), "parsed packet info does not match expected")
+// }
diff --git a/relayer/chains/cosmos/feegrant.go b/relayer/chains/cosmos/feegrant.go
new file mode 100644
index 000000000..b5ccce31f
--- /dev/null
+++ b/relayer/chains/cosmos/feegrant.go
@@ -0,0 +1,516 @@
+package cosmos
+
+import (
+ "context"
+ "errors"
+ "fmt"
+ "regexp"
+ "strconv"
+ "time"
+
+ "github.com/cosmos/cosmos-sdk/client"
+ "github.com/cosmos/cosmos-sdk/crypto/hd"
+ "github.com/cosmos/cosmos-sdk/types"
+ sdk "github.com/cosmos/cosmos-sdk/types"
+ txtypes "github.com/cosmos/cosmos-sdk/types/tx"
+ "github.com/cosmos/cosmos-sdk/x/feegrant"
+)
+
+// Searches for valid, existing BasicAllowance grants for the ChainClient's configured Feegranter.
+// Expired grants are ignored. Other grant types are ignored.
+func (cc *CosmosProvider) GetValidBasicGrants() ([]*feegrant.Grant, error) {
+ validGrants := []*feegrant.Grant{}
+
+ if cc.PCfg.FeeGrants == nil {
+ return nil, errors.New("no feegrant configuration for chainclient")
+ }
+
+ keyNameOrAddress := cc.PCfg.FeeGrants.GranterKey
+ address, err := cc.AccountFromKeyOrAddress(keyNameOrAddress)
+ if err != nil {
+ return nil, err
+ }
+
+ encodedAddr := cc.MustEncodeAccAddr(address)
+ grants, err := cc.QueryFeegrantsByGranter(encodedAddr, nil)
+ if err != nil {
+ return nil, err
+ }
+
+ for _, grant := range grants {
+ switch grant.Allowance.TypeUrl {
+ case "/cosmos.feegrant.v1beta1.BasicAllowance":
+ //var feegrantAllowance feegrant.BasicAllowance
+ var feegrantAllowance feegrant.FeeAllowanceI
+ e := cc.Cdc.InterfaceRegistry.UnpackAny(grant.Allowance, &feegrantAllowance)
+ if e != nil {
+ return nil, e
+ }
+ //feegrantAllowance := grant.Allowance.GetCachedValue().(*feegrant.BasicAllowance)
+ if isValidGrant(feegrantAllowance.(*feegrant.BasicAllowance)) {
+ validGrants = append(validGrants, grant)
+ }
+ default:
+ fmt.Printf("Ignoring grant type %s for granter %s and grantee %s\n", grant.Allowance.TypeUrl, grant.Granter, grant.Grantee)
+ }
+ }
+
+ return validGrants, nil
+}
+
+// Searches for valid, existing BasicAllowance grants for the given grantee & ChainClient's configured granter.
+// Expired grants are ignored. Other grant types are ignored.
+func (cc *CosmosProvider) GetGranteeValidBasicGrants(granteeKey string) ([]*feegrant.Grant, error) {
+ validGrants := []*feegrant.Grant{}
+
+ if cc.PCfg.FeeGrants == nil {
+ return nil, errors.New("no feegrant configuration for chainclient")
+ }
+
+ granterAddr, err := cc.AccountFromKeyOrAddress(cc.PCfg.FeeGrants.GranterKey)
+ if err != nil {
+ return nil, err
+ }
+ granterEncodedAddr := cc.MustEncodeAccAddr(granterAddr)
+
+ address, err := cc.AccountFromKeyOrAddress(granteeKey)
+ if err != nil {
+ return nil, err
+ }
+
+ encodedAddr := cc.MustEncodeAccAddr(address)
+ grants, err := cc.QueryFeegrantsByGrantee(encodedAddr, nil)
+ if err != nil {
+ return nil, err
+ }
+
+ for _, grant := range grants {
+ if grant.Granter == granterEncodedAddr {
+ switch grant.Allowance.TypeUrl {
+ case "/cosmos.feegrant.v1beta1.BasicAllowance":
+ var feegrantAllowance feegrant.FeeAllowanceI
+ e := cc.Cdc.InterfaceRegistry.UnpackAny(grant.Allowance, &feegrantAllowance)
+ if e != nil {
+ return nil, e
+ }
+ if isValidGrant(feegrantAllowance.(*feegrant.BasicAllowance)) {
+ validGrants = append(validGrants, grant)
+ }
+ default:
+ fmt.Printf("Ignoring grant type %s for granter %s and grantee %s\n", grant.Allowance.TypeUrl, grant.Granter, grant.Grantee)
+ }
+ }
+ }
+
+ return validGrants, nil
+}
+
+// True if the grant has not expired and all coins have positive balances, false otherwise
+// Note: technically, any single coin with a positive balance makes the grant usable
+func isValidGrant(a *feegrant.BasicAllowance) bool {
+ //grant expired due to time limit
+ if a.Expiration != nil && time.Now().After(*a.Expiration) {
+ return false
+ }
+
+ //feegrant without a spending limit specified allows unlimited fees to be spent
+ valid := true
+
+ //spending limit is specified, check if there are funds remaining on every coin
+ if a.SpendLimit != nil {
+ for _, coin := range a.SpendLimit {
+ if coin.Amount.LTE(types.ZeroInt()) {
+ valid = false
+ }
+ }
+ }
+
+ return valid
+}
+
+func (cc *CosmosProvider) ConfigureFeegrants(numGrantees int, granterKey string) error {
+ cc.PCfg.FeeGrants = &FeeGrantConfiguration{
+ GranteesWanted: numGrantees,
+ GranterKey: granterKey,
+ ManagedGrantees: []string{},
+ }
+
+ return cc.PCfg.FeeGrants.AddGranteeKeys(cc)
+}
+
+func (cc *CosmosProvider) ConfigureWithGrantees(grantees []string, granterKey string) error {
+ if len(grantees) == 0 {
+ return errors.New("list of grantee names cannot be empty")
+ }
+
+ cc.PCfg.FeeGrants = &FeeGrantConfiguration{
+ GranteesWanted: len(grantees),
+ GranterKey: granterKey,
+ ManagedGrantees: grantees,
+ }
+
+ for _, newGrantee := range grantees {
+ if !cc.KeyExists(newGrantee) {
+ //Add another key to the chain client for the grantee
+ _, err := cc.AddKey(newGrantee, sdk.CoinType, string(hd.Secp256k1Type), "")
+ if err != nil {
+ return err
+ }
+ }
+ }
+
+ return nil
+}
+
+func (fg *FeeGrantConfiguration) AddGranteeKeys(cc *CosmosProvider) error {
+ for i := len(fg.ManagedGrantees); i < fg.GranteesWanted; i++ {
+ newGranteeIdx := strconv.Itoa(len(fg.ManagedGrantees) + 1)
+ newGrantee := "grantee" + newGranteeIdx
+
+ //Add another key to the chain client for the grantee
+ _, err := cc.AddKey(newGrantee, sdk.CoinType, string(hd.Secp256k1Type), "")
+ if err != nil {
+ return err
+ }
+
+ fg.ManagedGrantees = append(fg.ManagedGrantees, newGrantee)
+ }
+
+ return nil
+}
+
+// Get the feegrant params to use for the next TX. If feegrants are not configured for the chain client, the default key will be used for TX signing.
+// Otherwise, a configured feegrantee will be chosen for TX signing in round-robin fashion.
+func (cc *CosmosProvider) GetTxFeeGrant() (txSignerKey string, feeGranterKey string) {
+ //By default, we should sign TXs with the ChainClient's default key
+ txSignerKey = cc.PCfg.Key
+
+ if cc.PCfg.FeeGrants == nil {
+ fmt.Printf("cc.Config.FeeGrants == nil\n")
+ return
+ }
+
+ // Use the ChainClient's configured Feegranter key for the next TX.
+ feeGranterKey = cc.PCfg.FeeGrants.GranterKey
+
+ // The ChainClient Feegrant configuration has never been verified on chain.
+ // Don't use Feegrants as it could cause the TX to fail on chain.
+ if feeGranterKey == "" || cc.PCfg.FeeGrants.BlockHeightVerified <= 0 {
+ fmt.Printf("cc.Config.FeeGrants.BlockHeightVerified <= 0\n")
+ feeGranterKey = ""
+ return
+ }
+
+ //Pick the next managed grantee in the list as the TX signer
+ lastGranteeIdx := cc.PCfg.FeeGrants.GranteeLastSignerIndex
+
+ if lastGranteeIdx >= 0 && lastGranteeIdx <= len(cc.PCfg.FeeGrants.ManagedGrantees)-1 {
+ txSignerKey = cc.PCfg.FeeGrants.ManagedGrantees[lastGranteeIdx]
+ cc.PCfg.FeeGrants.GranteeLastSignerIndex = cc.PCfg.FeeGrants.GranteeLastSignerIndex + 1
+
+ //Restart the round robin at 0 if we reached the end of the list of grantees
+ if cc.PCfg.FeeGrants.GranteeLastSignerIndex == len(cc.PCfg.FeeGrants.ManagedGrantees) {
+ cc.PCfg.FeeGrants.GranteeLastSignerIndex = 0
+ }
+ }
+
+ return
+}
+
+// Ensure all Basic Allowance grants are in place for the given ChainClient.
+// This will query (RPC) for existing grants and create new grants if they don't exist.
+func (cc *CosmosProvider) EnsureBasicGrants(ctx context.Context, memo string) (*sdk.TxResponse, error) {
+ if cc.PCfg.FeeGrants == nil {
+ return nil, errors.New("ChainClient must be a FeeGranter to establish grants")
+ } else if len(cc.PCfg.FeeGrants.ManagedGrantees) == 0 {
+ return nil, errors.New("ChainClient is a FeeGranter, but is not managing any Grantees")
+ }
+
+ granterKey := cc.PCfg.FeeGrants.GranterKey
+ if granterKey == "" {
+ granterKey = cc.PCfg.Key
+ }
+
+ granterAcc, err := cc.GetKeyAddressForKey(granterKey)
+ if err != nil {
+ fmt.Printf("Retrieving key '%s': ChainClient FeeGranter misconfiguration: %s", granterKey, err.Error())
+ return nil, err
+ }
+
+ granterAddr, granterAddrErr := cc.EncodeBech32AccAddr(granterAcc)
+ if granterAddrErr != nil {
+ return nil, granterAddrErr
+ }
+
+ validGrants, err := cc.GetValidBasicGrants()
+ failedLookupGrantsByGranter := err != nil
+
+ msgs := []sdk.Msg{}
+ numGrantees := len(cc.PCfg.FeeGrants.ManagedGrantees)
+ grantsNeeded := 0
+
+ for _, grantee := range cc.PCfg.FeeGrants.ManagedGrantees {
+
+ //Searching for all grants with the given granter failed, so we will search by the grantee.
+ //Reason this lookup sometimes fails is because the 'Search by granter' request is in SDK v0.46+
+ if failedLookupGrantsByGranter {
+ validGrants, err = cc.GetGranteeValidBasicGrants(grantee)
+ if err != nil {
+ return nil, err
+ }
+ }
+
+ granteeAcc, err := cc.GetKeyAddressForKey(grantee)
+ if err != nil {
+ fmt.Printf("Misconfiguration for grantee key %s. Error: %s\n", grantee, err.Error())
+ return nil, err
+ }
+
+ granteeAddr, granteeAddrErr := cc.EncodeBech32AccAddr(granteeAcc)
+ if granteeAddrErr != nil {
+ return nil, granteeAddrErr
+ }
+
+ hasGrant := false
+ for _, basicGrant := range validGrants {
+ if basicGrant.Grantee == granteeAddr {
+ fmt.Printf("Valid grant found for granter %s, grantee %s\n", basicGrant.Granter, basicGrant.Grantee)
+ hasGrant = true
+ }
+ }
+
+ if !hasGrant {
+ grantsNeeded += 1
+ fmt.Printf("Grant will be created on chain for granter %s and grantee %s\n", granterAddr, granteeAddr)
+ grantMsg, err := cc.getMsgGrantBasicAllowance(granterAcc, granteeAcc)
+ if err != nil {
+ return nil, err
+ }
+ msgs = append(msgs, grantMsg)
+ }
+ }
+
+ if len(msgs) > 0 {
+ cliCtx := client.Context{}.WithClient(cc.RPCClient).
+ WithInterfaceRegistry(cc.Cdc.InterfaceRegistry).
+ WithChainID(cc.PCfg.ChainID).
+ WithCodec(cc.Cdc.Marshaler).
+ WithFromAddress(granterAcc)
+
+ granterExists := cc.EnsureExists(cliCtx, granterAcc) == nil
+
+ //Feegranter exists on chain
+ if granterExists {
+ txResp, err := cc.SubmitTxAwaitResponse(ctx, msgs, memo, 0, granterKey)
+ if err != nil {
+ fmt.Printf("Error: SubmitTxAwaitResponse: %s", err.Error())
+ return nil, err
+ } else if txResp != nil && txResp.TxResponse != nil && txResp.TxResponse.Code != 0 {
+ fmt.Printf("Submitting grants for granter %s failed. Code: %d, TX hash: %s\n", granterKey, txResp.TxResponse.Code, txResp.TxResponse.TxHash)
+ return nil, fmt.Errorf("could not configure feegrant for granter %s", granterKey)
+ }
+
+ fmt.Printf("TX succeeded, %d new grants configured, %d grants already in place. TX hash: %s\n", grantsNeeded, numGrantees-grantsNeeded, txResp.TxResponse.TxHash)
+ return txResp.TxResponse, err
+ } else {
+ return nil, fmt.Errorf("granter %s does not exist on chain", granterKey)
+ }
+ } else {
+ fmt.Printf("All grantees (%d total) already had valid feegrants. Feegrant configuration verified.\n", numGrantees)
+ }
+
+ return nil, nil
+}
+
+func getGasTokenDenom(gasPrices string) (string, error) {
+ r := regexp.MustCompile(`(?P[0-9.]*)(?P.*)`)
+ submatches := r.FindStringSubmatch(gasPrices)
+ if len(submatches) != 3 {
+ return "", errors.New("could not find fee denom")
+ }
+
+ return submatches[2], nil
+}
+
+// GrantBasicAllowance Send a feegrant with the basic allowance type.
+// This function does not check for existing feegrant authorizations.
+// TODO: check for existing authorizations prior to attempting new one.
+func (cc *CosmosProvider) GrantAllGranteesBasicAllowance(ctx context.Context, gas uint64) error {
+ if cc.PCfg.FeeGrants == nil {
+ return errors.New("ChainClient must be a FeeGranter to establish grants")
+ } else if len(cc.PCfg.FeeGrants.ManagedGrantees) == 0 {
+ return errors.New("ChainClient is a FeeGranter, but is not managing any Grantees")
+ }
+
+ granterKey := cc.PCfg.FeeGrants.GranterKey
+ if granterKey == "" {
+ granterKey = cc.PCfg.Key
+ }
+ granterAddr, err := cc.GetKeyAddressForKey(granterKey)
+ if err != nil {
+ fmt.Printf("ChainClient FeeGranter misconfiguration: %s", err.Error())
+ return err
+ }
+
+ for _, grantee := range cc.PCfg.FeeGrants.ManagedGrantees {
+ granteeAddr, err := cc.GetKeyAddressForKey(grantee)
+
+ if err != nil {
+ fmt.Printf("Misconfiguration for grantee %s. Error: %s\n", grantee, err.Error())
+ return err
+ }
+
+ grantResp, err := cc.GrantBasicAllowance(ctx, granterAddr, granterKey, granteeAddr, gas)
+ if err != nil {
+ return err
+ } else if grantResp != nil && grantResp.TxResponse != nil && grantResp.TxResponse.Code != 0 {
+ fmt.Printf("grantee %s and granter %s. Code: %d\n", granterAddr.String(), granteeAddr.String(), grantResp.TxResponse.Code)
+ return fmt.Errorf("could not configure feegrant for granter %s and grantee %s", granterAddr.String(), granteeAddr.String())
+ }
+ }
+ return nil
+}
+
+// GrantBasicAllowance Send a feegrant with the basic allowance type.
+// This function does not check for existing feegrant authorizations.
+// TODO: check for existing authorizations prior to attempting new one.
+func (cc *CosmosProvider) GrantAllGranteesBasicAllowanceWithExpiration(ctx context.Context, gas uint64, expiration time.Time) error {
+ if cc.PCfg.FeeGrants == nil {
+ return errors.New("ChainClient must be a FeeGranter to establish grants")
+ } else if len(cc.PCfg.FeeGrants.ManagedGrantees) == 0 {
+ return errors.New("ChainClient is a FeeGranter, but is not managing any Grantees")
+ }
+
+ granterKey := cc.PCfg.FeeGrants.GranterKey
+ if granterKey == "" {
+ granterKey = cc.PCfg.Key
+ }
+
+ granterAddr, err := cc.GetKeyAddressForKey(granterKey)
+ if err != nil {
+ fmt.Printf("ChainClient FeeGranter misconfiguration: %s", err.Error())
+ return err
+ }
+
+ for _, grantee := range cc.PCfg.FeeGrants.ManagedGrantees {
+ granteeAddr, err := cc.GetKeyAddressForKey(grantee)
+
+ if err != nil {
+ fmt.Printf("Misconfiguration for grantee %s. Error: %s\n", grantee, err.Error())
+ return err
+ }
+
+ grantResp, err := cc.GrantBasicAllowanceWithExpiration(ctx, granterAddr, granterKey, granteeAddr, gas, expiration)
+ if err != nil {
+ return err
+ } else if grantResp != nil && grantResp.TxResponse != nil && grantResp.TxResponse.Code != 0 {
+ fmt.Printf("grantee %s and granter %s. Code: %d\n", granterAddr.String(), granteeAddr.String(), grantResp.TxResponse.Code)
+ return fmt.Errorf("could not configure feegrant for granter %s and grantee %s", granterAddr.String(), granteeAddr.String())
+ }
+ }
+ return nil
+}
+
+func (cc *CosmosProvider) getMsgGrantBasicAllowanceWithExpiration(granter sdk.AccAddress, grantee sdk.AccAddress, expiration time.Time) (sdk.Msg, error) {
+ //thirtyMin := time.Now().Add(30 * time.Minute)
+ feeGrantBasic := &feegrant.BasicAllowance{
+ Expiration: &expiration,
+ }
+ msgGrantAllowance, err := feegrant.NewMsgGrantAllowance(feeGrantBasic, granter, grantee)
+ if err != nil {
+ fmt.Printf("Error: GrantBasicAllowance.NewMsgGrantAllowance: %s", err.Error())
+ return nil, err
+ }
+
+ //Due to the way Lens configures the SDK, addresses will have the 'cosmos' prefix which
+ //doesn't necessarily match the chain prefix of the ChainClient config. So calling the internal
+ //'NewMsgGrantAllowance' function will return the *incorrect* 'cosmos' prefixed bech32 address.
+
+ //Update the Grant to ensure the correct chain-specific granter is set
+ granterAddr, granterAddrErr := cc.EncodeBech32AccAddr(granter)
+ if granterAddrErr != nil {
+ fmt.Printf("EncodeBech32AccAddr: %s", granterAddrErr.Error())
+ return nil, granterAddrErr
+ }
+
+ //Update the Grant to ensure the correct chain-specific grantee is set
+ granteeAddr, granteeAddrErr := cc.EncodeBech32AccAddr(grantee)
+ if granteeAddrErr != nil {
+ fmt.Printf("EncodeBech32AccAddr: %s", granteeAddrErr.Error())
+ return nil, granteeAddrErr
+ }
+
+ //override the 'cosmos' prefixed bech32 addresses with the correct chain prefix
+ msgGrantAllowance.Grantee = granteeAddr
+ msgGrantAllowance.Granter = granterAddr
+
+ return msgGrantAllowance, nil
+}
+
+func (cc *CosmosProvider) getMsgGrantBasicAllowance(granter sdk.AccAddress, grantee sdk.AccAddress) (sdk.Msg, error) {
+ //thirtyMin := time.Now().Add(30 * time.Minute)
+ feeGrantBasic := &feegrant.BasicAllowance{
+ //Expiration: &thirtyMin,
+ }
+ msgGrantAllowance, err := feegrant.NewMsgGrantAllowance(feeGrantBasic, granter, grantee)
+ if err != nil {
+ fmt.Printf("Error: GrantBasicAllowance.NewMsgGrantAllowance: %s", err.Error())
+ return nil, err
+ }
+
+ //Due to the way Lens configures the SDK, addresses will have the 'cosmos' prefix which
+ //doesn't necessarily match the chain prefix of the ChainClient config. So calling the internal
+ //'NewMsgGrantAllowance' function will return the *incorrect* 'cosmos' prefixed bech32 address.
+
+ //Update the Grant to ensure the correct chain-specific granter is set
+ granterAddr, granterAddrErr := cc.EncodeBech32AccAddr(granter)
+ if granterAddrErr != nil {
+ fmt.Printf("EncodeBech32AccAddr: %s", granterAddrErr.Error())
+ return nil, granterAddrErr
+ }
+
+ //Update the Grant to ensure the correct chain-specific grantee is set
+ granteeAddr, granteeAddrErr := cc.EncodeBech32AccAddr(grantee)
+ if granteeAddrErr != nil {
+ fmt.Printf("EncodeBech32AccAddr: %s", granteeAddrErr.Error())
+ return nil, granteeAddrErr
+ }
+
+ //override the 'cosmos' prefixed bech32 addresses with the correct chain prefix
+ msgGrantAllowance.Grantee = granteeAddr
+ msgGrantAllowance.Granter = granterAddr
+
+ return msgGrantAllowance, nil
+}
+
+func (cc *CosmosProvider) GrantBasicAllowance(ctx context.Context, granter sdk.AccAddress, granterKeyName string, grantee sdk.AccAddress, gas uint64) (*txtypes.GetTxResponse, error) {
+ msgGrantAllowance, err := cc.getMsgGrantBasicAllowance(granter, grantee)
+ if err != nil {
+ return nil, err
+ }
+
+ msgs := []sdk.Msg{msgGrantAllowance}
+ txResp, err := cc.SubmitTxAwaitResponse(ctx, msgs, "", gas, granterKeyName)
+ if err != nil {
+ fmt.Printf("Error: GrantBasicAllowance.SubmitTxAwaitResponse: %s", err.Error())
+ return nil, err
+ }
+
+ return txResp, nil
+}
+
+func (cc *CosmosProvider) GrantBasicAllowanceWithExpiration(ctx context.Context, granter sdk.AccAddress, granterKeyName string, grantee sdk.AccAddress, gas uint64, expiration time.Time) (*txtypes.GetTxResponse, error) {
+ msgGrantAllowance, err := cc.getMsgGrantBasicAllowanceWithExpiration(granter, grantee, expiration)
+ if err != nil {
+ return nil, err
+ }
+
+ msgs := []sdk.Msg{msgGrantAllowance}
+ txResp, err := cc.SubmitTxAwaitResponse(ctx, msgs, "", gas, granterKeyName)
+ if err != nil {
+ fmt.Printf("Error: GrantBasicAllowance.SubmitTxAwaitResponse: %s", err.Error())
+ return nil, err
+ }
+
+ return txResp, nil
+}
diff --git a/relayer/chains/cosmos/grpc_query.go b/relayer/chains/cosmos/grpc_query.go
index dec0c84a8..33f274e8d 100644
--- a/relayer/chains/cosmos/grpc_query.go
+++ b/relayer/chains/cosmos/grpc_query.go
@@ -177,7 +177,7 @@ func (cc *CosmosProvider) TxServiceBroadcast(ctx context.Context, req *tx.Broadc
wg.Add(1)
- if err := cc.broadcastTx(ctx, req.TxBytes, nil, nil, ctx, blockTimeout, callback); err != nil {
+ if err := cc.broadcastTx(ctx, req.TxBytes, nil, nil, ctx, blockTimeout, []func(*provider.RelayerTxResponse, error){callback}); err != nil {
return nil, err
}
diff --git a/relayer/chains/cosmos/keys.go b/relayer/chains/cosmos/keys.go
index 272c96b30..e43cf45ae 100644
--- a/relayer/chains/cosmos/keys.go
+++ b/relayer/chains/cosmos/keys.go
@@ -9,6 +9,7 @@ import (
"github.com/cosmos/cosmos-sdk/crypto/keyring"
sdk "github.com/cosmos/cosmos-sdk/types"
"github.com/cosmos/go-bip39"
+ "github.com/cosmos/relayer/v2/relayer/chains/cosmos/keys/sr25519"
"github.com/cosmos/relayer/v2/relayer/codecs/ethermint"
"github.com/cosmos/relayer/v2/relayer/codecs/injective"
"github.com/cosmos/relayer/v2/relayer/provider"
@@ -19,12 +20,14 @@ const ethereumCoinType = uint32(60)
var (
// SupportedAlgorithms defines the list of signing algorithms used on Evmos:
// - secp256k1 (Cosmos)
- // - eth_secp256k1 (Ethereum)
- SupportedAlgorithms = keyring.SigningAlgoList{hd.Secp256k1, ethermint.EthSecp256k1, injective.EthSecp256k1}
+ // - sr25519 (Cosmos)
+ // - eth_secp256k1 (Ethereum, Injective)
+ SupportedAlgorithms = keyring.SigningAlgoList{hd.Secp256k1, sr25519.Sr25519, ethermint.EthSecp256k1, injective.EthSecp256k1}
// SupportedAlgorithmsLedger defines the list of signing algorithms used on Evmos for the Ledger device:
// - secp256k1 (Cosmos)
- // - eth_secp256k1 (Ethereum)
- SupportedAlgorithmsLedger = keyring.SigningAlgoList{hd.Secp256k1, ethermint.EthSecp256k1, injective.EthSecp256k1}
+ // - sr25519 (Cosmos)
+ // - eth_secp256k1 (Ethereum, Injective)
+ SupportedAlgorithmsLedger = keyring.SigningAlgoList{hd.Secp256k1, sr25519.Sr25519, ethermint.EthSecp256k1, injective.EthSecp256k1}
)
// KeyringAlgoOptions defines a function keys options for the ethereum Secp256k1 curve.
@@ -58,8 +61,8 @@ func (cc *CosmosProvider) KeystoreCreated(path string) bool {
// AddKey generates a new mnemonic which is then converted to a private key and BIP-39 HD Path and persists it to the keystore.
// It fails if there is an existing key with the same address.
-func (cc *CosmosProvider) AddKey(name string, coinType uint32) (output *provider.KeyOutput, err error) {
- ko, err := cc.KeyAddOrRestore(name, coinType)
+func (cc *CosmosProvider) AddKey(name string, coinType uint32, signingAlgorithm string, password string) (output *provider.KeyOutput, err error) {
+ ko, err := cc.KeyAddOrRestore(name, coinType, signingAlgorithm)
if err != nil {
return nil, err
}
@@ -68,8 +71,8 @@ func (cc *CosmosProvider) AddKey(name string, coinType uint32) (output *provider
// RestoreKey converts a mnemonic to a private key and BIP-39 HD Path and persists it to the keystore.
// It fails if there is an existing key with the same address.
-func (cc *CosmosProvider) RestoreKey(name, mnemonic string, coinType uint32) (address string, err error) {
- ko, err := cc.KeyAddOrRestore(name, coinType, mnemonic)
+func (cc *CosmosProvider) RestoreKey(name, mnemonic string, coinType uint32, signingAlgorithm string) (address string, err error) {
+ ko, err := cc.KeyAddOrRestore(name, coinType, signingAlgorithm, mnemonic)
if err != nil {
return "", err
}
@@ -78,10 +81,17 @@ func (cc *CosmosProvider) RestoreKey(name, mnemonic string, coinType uint32) (ad
// KeyAddOrRestore either generates a new mnemonic or uses the specified mnemonic and converts it to a private key
// and BIP-39 HD Path which is then persisted to the keystore. It fails if there is an existing key with the same address.
-func (cc *CosmosProvider) KeyAddOrRestore(keyName string, coinType uint32, mnemonic ...string) (*provider.KeyOutput, error) {
+func (cc *CosmosProvider) KeyAddOrRestore(keyName string, coinType uint32, signingAlgorithm string, mnemonic ...string) (*provider.KeyOutput, error) {
var mnemonicStr string
var err error
- algo := keyring.SignatureAlgo(hd.Secp256k1)
+
+ var algo keyring.SignatureAlgo
+ switch signingAlgorithm {
+ case string(hd.Sr25519Type):
+ algo = sr25519.Sr25519
+ default:
+ algo = hd.Secp256k1
+ }
if len(mnemonic) > 0 {
mnemonicStr = mnemonic[0]
@@ -182,8 +192,8 @@ func (cc *CosmosProvider) ExportPrivKeyArmor(keyName string) (armor string, err
}
// GetKeyAddress returns the account address representation for the currently configured key.
-func (cc *CosmosProvider) GetKeyAddress() (sdk.AccAddress, error) {
- info, err := cc.Keybase.Key(cc.PCfg.Key)
+func (cc *CosmosProvider) GetKeyAddress(key string) (sdk.AccAddress, error) {
+ info, err := cc.Keybase.Key(key)
if err != nil {
return nil, err
}
@@ -209,3 +219,34 @@ func CreateMnemonic() (string, error) {
func (cc *CosmosProvider) EncodeBech32AccAddr(addr sdk.AccAddress) (string, error) {
return sdk.Bech32ifyAddressBytes(cc.PCfg.AccountPrefix, addr)
}
+
+func (cc *CosmosProvider) DecodeBech32AccAddr(addr string) (sdk.AccAddress, error) {
+ return sdk.GetFromBech32(addr, cc.PCfg.AccountPrefix)
+}
+
+func (cc *CosmosProvider) GetKeyAddressForKey(key string) (sdk.AccAddress, error) {
+ info, err := cc.Keybase.Key(key)
+ if err != nil {
+ return nil, err
+ }
+ return info.GetAddress()
+}
+
+func (cc *CosmosProvider) KeyFromKeyOrAddress(keyOrAddress string) (string, error) {
+ switch {
+ case keyOrAddress == "":
+ return cc.PCfg.Key, nil
+ case cc.KeyExists(keyOrAddress):
+ return keyOrAddress, nil
+ default:
+ acc, err := cc.DecodeBech32AccAddr(keyOrAddress)
+ if err != nil {
+ return "", err
+ }
+ kr, err := cc.Keybase.KeyByAddress(acc)
+ if err != nil {
+ return "", err
+ }
+ return kr.Name, nil
+ }
+}
diff --git a/relayer/chains/cosmos/keys/sr25519/algo.go b/relayer/chains/cosmos/keys/sr25519/algo.go
new file mode 100644
index 000000000..d0c0eca96
--- /dev/null
+++ b/relayer/chains/cosmos/keys/sr25519/algo.go
@@ -0,0 +1,46 @@
+package sr25519
+
+import (
+ bip39 "github.com/cosmos/go-bip39"
+
+ tmsr25519 "github.com/cometbft/cometbft/crypto/sr25519"
+ "github.com/cosmos/cosmos-sdk/crypto/hd"
+ "github.com/cosmos/cosmos-sdk/crypto/types"
+)
+
+var Sr25519 = sr25519Algo{}
+
+type sr25519Algo struct {
+}
+
+func (s sr25519Algo) Name() hd.PubKeyType {
+ return hd.Sr25519Type
+}
+
+// Derive derives and returns the sr25519 private key for the given seed and HD path.
+func (s sr25519Algo) Derive() hd.DeriveFn {
+ return func(mnemonic string, bip39Passphrase, hdPath string) ([]byte, error) {
+ seed, err := bip39.NewSeedWithErrorChecking(mnemonic, bip39Passphrase)
+ if err != nil {
+ return nil, err
+ }
+
+ masterPriv, ch := hd.ComputeMastersFromSeed(seed)
+ if len(hdPath) == 0 {
+ return masterPriv[:], nil
+ }
+ derivedKey, err := hd.DerivePrivateKeyForPath(masterPriv, ch, hdPath)
+
+ return derivedKey, err
+ }
+}
+
+// Generate generates a sr25519 private key from the given bytes.
+func (s sr25519Algo) Generate() hd.GenerateFn {
+ return func(bz []byte) types.PrivKey {
+ var bzArr = make([]byte, 32)
+ copy(bzArr, bz)
+
+ return &PrivKey{PrivKey: tmsr25519.GenPrivKeyFromSecret(bzArr)}
+ }
+}
diff --git a/relayer/chains/cosmos/keys/sr25519/keys.pb.go b/relayer/chains/cosmos/keys/sr25519/keys.pb.go
new file mode 100644
index 000000000..9d6762141
--- /dev/null
+++ b/relayer/chains/cosmos/keys/sr25519/keys.pb.go
@@ -0,0 +1,320 @@
+// Code generated by protoc-gen-gogo. DO NOT EDIT.
+// source: cosmos/crypto/sr25519/keys.proto
+
+// buf:lint:ignore PACKAGE_VERSION_SUFFIX
+
+package sr25519
+
+import (
+ fmt "fmt"
+ github_com_cometbft_cometbft_crypto_sr25519 "github.com/cometbft/cometbft/crypto/sr25519"
+ _ "github.com/cosmos/gogoproto/gogoproto"
+ proto "github.com/cosmos/gogoproto/proto"
+ io "io"
+ math "math"
+ math_bits "math/bits"
+)
+
+// Reference imports to suppress errors if they are not otherwise used.
+var _ = proto.Marshal
+var _ = fmt.Errorf
+var _ = math.Inf
+
+// This is a compile-time assertion to ensure that this generated file
+// is compatible with the proto package it is being compiled against.
+// A compilation error at this line likely means your copy of the
+// proto package needs to be updated.
+const _ = proto.GoGoProtoPackageIsVersion3 // please upgrade the proto package
+
+// PubKey defines a sr25519 ECDSA public key.
+type PubKey struct {
+ Key github_com_cometbft_cometbft_crypto_sr25519.PubKey `protobuf:"bytes,1,opt,name=key,proto3,casttype=github.com/cometbft/cometbft/crypto/sr25519.PubKey" json:"key,omitempty"`
+}
+
+func (m *PubKey) Reset() { *m = PubKey{} }
+func (*PubKey) ProtoMessage() {}
+func (*PubKey) Descriptor() ([]byte, []int) {
+ return fileDescriptor_daddabaf35039fbd, []int{0}
+}
+func (m *PubKey) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *PubKey) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_PubKey.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *PubKey) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_PubKey.Merge(m, src)
+}
+func (m *PubKey) XXX_Size() int {
+ return m.Size()
+}
+func (m *PubKey) XXX_DiscardUnknown() {
+ xxx_messageInfo_PubKey.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_PubKey proto.InternalMessageInfo
+
+func (*PubKey) XXX_MessageName() string {
+ return "cosmos.crypto.sr25519.PubKey"
+}
+func init() {
+ proto.RegisterType((*PubKey)(nil), "cosmos.crypto.sr25519.PubKey")
+}
+
+func init() { proto.RegisterFile("cosmos/crypto/sr25519/keys.proto", fileDescriptor_daddabaf35039fbd) }
+
+var fileDescriptor_daddabaf35039fbd = []byte{
+ // 222 bytes of a gzipped FileDescriptorProto
+ 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xe2, 0x52, 0x48, 0xce, 0x2f, 0xce,
+ 0xcd, 0x2f, 0xd6, 0x4f, 0x2e, 0xaa, 0x2c, 0x28, 0xc9, 0xd7, 0x2f, 0x2e, 0x32, 0x32, 0x35, 0x35,
+ 0xb4, 0xd4, 0xcf, 0x4e, 0xad, 0x2c, 0xd6, 0x2b, 0x28, 0xca, 0x2f, 0xc9, 0x17, 0x12, 0x85, 0xa8,
+ 0xd0, 0x83, 0xa8, 0xd0, 0x83, 0xaa, 0x90, 0x12, 0x49, 0xcf, 0x4f, 0xcf, 0x07, 0xab, 0xd0, 0x07,
+ 0xb1, 0x20, 0x8a, 0x95, 0x22, 0xb8, 0xd8, 0x02, 0x4a, 0x93, 0xbc, 0x53, 0x2b, 0x85, 0x3c, 0xb8,
+ 0x98, 0xb3, 0x53, 0x2b, 0x25, 0x18, 0x15, 0x18, 0x35, 0x78, 0x9c, 0xcc, 0x7e, 0xdd, 0x93, 0x37,
+ 0x4a, 0xcf, 0x2c, 0xc9, 0x28, 0x4d, 0xd2, 0x4b, 0xce, 0xcf, 0xd5, 0x4f, 0xce, 0xcf, 0x4d, 0x2d,
+ 0x49, 0x4a, 0x2b, 0x41, 0x62, 0xa0, 0xd8, 0xaf, 0x07, 0x31, 0x24, 0x08, 0x64, 0x84, 0x15, 0xcb,
+ 0x8c, 0x05, 0xf2, 0x0c, 0x4e, 0xa9, 0x27, 0x1e, 0xca, 0x31, 0xdc, 0x78, 0x28, 0xc7, 0x70, 0xe2,
+ 0x91, 0x1c, 0xe3, 0x85, 0x47, 0x72, 0x8c, 0x0f, 0x1e, 0xc9, 0x31, 0x4e, 0x78, 0x2c, 0xc7, 0x70,
+ 0xe2, 0xb1, 0x1c, 0xe3, 0x85, 0xc7, 0x72, 0x0c, 0x37, 0x1e, 0xcb, 0x31, 0x44, 0xd9, 0xa3, 0x58,
+ 0x02, 0xf6, 0x59, 0x51, 0x6a, 0x4e, 0x62, 0x65, 0x6a, 0x91, 0x7e, 0x99, 0x11, 0x9c, 0x99, 0x9c,
+ 0x91, 0x98, 0x99, 0x57, 0x0c, 0x53, 0x00, 0xf2, 0x2b, 0xcc, 0xe2, 0x24, 0x36, 0xb0, 0x3f, 0x8c,
+ 0x01, 0x01, 0x00, 0x00, 0xff, 0xff, 0x24, 0xfd, 0x40, 0x0e, 0x18, 0x01, 0x00, 0x00,
+}
+
+func (m *PubKey) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *PubKey) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *PubKey) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.Key) > 0 {
+ i -= len(m.Key)
+ copy(dAtA[i:], m.Key)
+ i = encodeVarintKeys(dAtA, i, uint64(len(m.Key)))
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func encodeVarintKeys(dAtA []byte, offset int, v uint64) int {
+ offset -= sovKeys(v)
+ base := offset
+ for v >= 1<<7 {
+ dAtA[offset] = uint8(v&0x7f | 0x80)
+ v >>= 7
+ offset++
+ }
+ dAtA[offset] = uint8(v)
+ return base
+}
+func (m *PubKey) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ l = len(m.Key)
+ if l > 0 {
+ n += 1 + l + sovKeys(uint64(l))
+ }
+ return n
+}
+
+func sovKeys(x uint64) (n int) {
+ return (math_bits.Len64(x|1) + 6) / 7
+}
+func sozKeys(x uint64) (n int) {
+ return sovKeys(uint64((x << 1) ^ uint64((int64(x) >> 63))))
+}
+func (m *PubKey) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowKeys
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: PubKey: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: PubKey: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Key", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowKeys
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthKeys
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthKeys
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Key = append(m.Key[:0], dAtA[iNdEx:postIndex]...)
+ if m.Key == nil {
+ m.Key = []byte{}
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipKeys(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthKeys
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func skipKeys(dAtA []byte) (n int, err error) {
+ l := len(dAtA)
+ iNdEx := 0
+ depth := 0
+ for iNdEx < l {
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return 0, ErrIntOverflowKeys
+ }
+ if iNdEx >= l {
+ return 0, io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= (uint64(b) & 0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ wireType := int(wire & 0x7)
+ switch wireType {
+ case 0:
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return 0, ErrIntOverflowKeys
+ }
+ if iNdEx >= l {
+ return 0, io.ErrUnexpectedEOF
+ }
+ iNdEx++
+ if dAtA[iNdEx-1] < 0x80 {
+ break
+ }
+ }
+ case 1:
+ iNdEx += 8
+ case 2:
+ var length int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return 0, ErrIntOverflowKeys
+ }
+ if iNdEx >= l {
+ return 0, io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ length |= (int(b) & 0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if length < 0 {
+ return 0, ErrInvalidLengthKeys
+ }
+ iNdEx += length
+ case 3:
+ depth++
+ case 4:
+ if depth == 0 {
+ return 0, ErrUnexpectedEndOfGroupKeys
+ }
+ depth--
+ case 5:
+ iNdEx += 4
+ default:
+ return 0, fmt.Errorf("proto: illegal wireType %d", wireType)
+ }
+ if iNdEx < 0 {
+ return 0, ErrInvalidLengthKeys
+ }
+ if depth == 0 {
+ return iNdEx, nil
+ }
+ }
+ return 0, io.ErrUnexpectedEOF
+}
+
+var (
+ ErrInvalidLengthKeys = fmt.Errorf("proto: negative length found during unmarshaling")
+ ErrIntOverflowKeys = fmt.Errorf("proto: integer overflow")
+ ErrUnexpectedEndOfGroupKeys = fmt.Errorf("proto: unexpected end of group")
+)
diff --git a/relayer/chains/cosmos/keys/sr25519/privkey.go b/relayer/chains/cosmos/keys/sr25519/privkey.go
new file mode 100644
index 000000000..b7b6efae3
--- /dev/null
+++ b/relayer/chains/cosmos/keys/sr25519/privkey.go
@@ -0,0 +1,47 @@
+package sr25519
+
+import (
+ tmsr25519 "github.com/cometbft/cometbft/crypto/sr25519"
+ cryptotypes "github.com/cosmos/cosmos-sdk/crypto/types"
+)
+
+const (
+ PrivKeySize = 32
+ PrivKeyName = "tendermint/PrivKeySr25519"
+)
+
+type PrivKey struct {
+ tmsr25519.PrivKey
+}
+
+// type conversion
+func (m *PrivKey) PubKey() cryptotypes.PubKey {
+ pk, ok := m.PrivKey.PubKey().(tmsr25519.PubKey)
+ if !ok {
+ panic("invalid public key type for sr25519 private key")
+ }
+ return &PubKey{Key: pk}
+}
+
+// type conversion
+func (m *PrivKey) Equals(other cryptotypes.LedgerPrivKey) bool {
+ sk2, ok := other.(*PrivKey)
+ if !ok {
+ return false
+ }
+ return m.PrivKey.Equals(sk2.PrivKey)
+}
+
+func (m *PrivKey) ProtoMessage() {}
+
+func (m *PrivKey) Reset() {
+ m.PrivKey = tmsr25519.PrivKey{}
+}
+
+func (m *PrivKey) String() string {
+ return string(m.Bytes())
+}
+
+func GenPrivKey() *PrivKey {
+ return &PrivKey{tmsr25519.GenPrivKey()}
+}
diff --git a/relayer/chains/cosmos/keys/sr25519/pubkey.go b/relayer/chains/cosmos/keys/sr25519/pubkey.go
new file mode 100644
index 000000000..6325f9960
--- /dev/null
+++ b/relayer/chains/cosmos/keys/sr25519/pubkey.go
@@ -0,0 +1,38 @@
+package sr25519
+
+import (
+ "bytes"
+
+ "github.com/cometbft/cometbft/crypto"
+ cryptotypes "github.com/cosmos/cosmos-sdk/crypto/types"
+)
+
+const PubKeyName = "tendermint/PubKeySr25519"
+
+func (m *PubKey) Equals(other cryptotypes.PubKey) bool {
+ pk2, ok := other.(*PubKey)
+ if !ok {
+ return false
+ }
+ return bytes.Equal(m.Key, pk2.Key)
+}
+
+func (m *PubKey) Address() crypto.Address {
+ return m.Key.Address()
+}
+
+func (m PubKey) Bytes() []byte {
+ return m.Key.Bytes()
+}
+
+func (m PubKey) String() string {
+ return m.Key.String()
+}
+
+func (m PubKey) Type() string {
+ return "sr25519"
+}
+
+func (m PubKey) VerifySignature(msg []byte, sigBytes []byte) bool {
+ return m.Key.VerifySignature(msg, sigBytes)
+}
diff --git a/relayer/chains/cosmos/keys_test.go b/relayer/chains/cosmos/keys_test.go
new file mode 100644
index 000000000..987931041
--- /dev/null
+++ b/relayer/chains/cosmos/keys_test.go
@@ -0,0 +1,104 @@
+package cosmos_test
+
+import (
+ "path/filepath"
+ "testing"
+
+ "github.com/cosmos/relayer/v2/relayer/chains/cosmos"
+ "github.com/cosmos/relayer/v2/relayer/provider"
+ "github.com/stretchr/testify/require"
+ "go.uber.org/zap"
+)
+
+func testProviderWithKeystore(t *testing.T, accountPrefix string, extraCodecs []string) provider.ChainProvider {
+ homePath := t.TempDir()
+ cfg := cosmos.CosmosProviderConfig{
+ ChainID: "test",
+ KeyDirectory: filepath.Join(homePath, "keys"),
+ KeyringBackend: "test",
+ Timeout: "10s",
+ AccountPrefix: accountPrefix,
+ ExtraCodecs: extraCodecs,
+ }
+ p, err := cfg.NewProvider(zap.NewNop(), homePath, true, "test_chain")
+ if err != nil {
+ t.Fatalf("Error creating provider: %v", err)
+ }
+ err = p.CreateKeystore(homePath)
+ if err != nil {
+ t.Fatalf("Error creating keystore: %v", err)
+ }
+ return p
+}
+
+// TestKeyRestore restores a test mnemonic
+func TestKeyRestore(t *testing.T) {
+ const (
+ keyName = "test_key"
+ signatureAlgorithm = "secp256k1"
+ mnemonic = "blind master acoustic speak victory lend kiss grab glad help demand hood roast zone lend sponsor level cheap truck kingdom apology token hover reunion"
+ accountPrefix = "cosmos"
+ expectedAddress = "cosmos15cw268ckjj2hgq8q3jf68slwjjcjlvxy57je2u"
+ coinType = uint32(118)
+ )
+
+ p := testProviderWithKeystore(t, accountPrefix, nil)
+
+ address, err := p.RestoreKey(keyName, mnemonic, coinType, signatureAlgorithm)
+ require.NoError(t, err)
+ require.Equal(t, expectedAddress, address)
+}
+
+// TestKeyRestoreEth restores a test mnemonic
+func TestKeyRestoreEth(t *testing.T) {
+ const (
+ keyName = "test_key"
+ signatureAlgorithm = "secp256k1"
+ mnemonic = "three elevator silk family street child flip also leaf inmate call frame shock little legal october vivid enable fetch siege sell burger dolphin green"
+ accountPrefix = "evmos"
+ expectedAddress = "evmos1dea7vlekr9e34vugwkvesulglt8fx4e457vk9z"
+ coinType = uint32(60)
+ )
+
+ p := testProviderWithKeystore(t, accountPrefix, []string{"ethermint"})
+
+ address, err := p.RestoreKey(keyName, mnemonic, coinType, signatureAlgorithm)
+ require.NoError(t, err)
+ require.Equal(t, expectedAddress, address)
+}
+
+// TestKeyRestoreInj restores a test mnemonic
+func TestKeyRestoreInj(t *testing.T) {
+ const (
+ keyName = "inj_key"
+ signatureAlgorithm = "secp256k1"
+ mnemonic = "three elevator silk family street child flip also leaf inmate call frame shock little legal october vivid enable fetch siege sell burger dolphin green"
+ accountPrefix = "inj"
+ expectedAddress = "inj1dea7vlekr9e34vugwkvesulglt8fx4e4uk2udj"
+ coinType = uint32(60)
+ )
+
+ p := testProviderWithKeystore(t, accountPrefix, []string{"injective"})
+
+ address, err := p.RestoreKey(keyName, mnemonic, coinType, signatureAlgorithm)
+ require.NoError(t, err)
+ require.Equal(t, expectedAddress, address)
+}
+
+// TestKeyRestoreSr25519 restores a test mnemonic
+func TestKeyRestoreSr25519(t *testing.T) {
+ const (
+ keyName = "sei_key"
+ signatureAlgorithm = "sr25519"
+ mnemonic = "three elevator silk family street child flip also leaf inmate call frame shock little legal october vivid enable fetch siege sell burger dolphin green"
+ accountPrefix = "sei"
+ expectedAddress = "sei1nmlj0guznnt0qyfj4yl6q5g4xuvgly4qw0w026"
+ coinType = uint32(118)
+ )
+
+ p := testProviderWithKeystore(t, accountPrefix, nil)
+
+ address, err := p.RestoreKey(keyName, mnemonic, coinType, signatureAlgorithm)
+ require.NoError(t, err)
+ require.Equal(t, expectedAddress, address)
+}
diff --git a/relayer/chains/cosmos/log.go b/relayer/chains/cosmos/log.go
index 75e43a982..22342e549 100644
--- a/relayer/chains/cosmos/log.go
+++ b/relayer/chains/cosmos/log.go
@@ -1,13 +1,17 @@
package cosmos
import (
+ "errors"
"reflect"
"github.com/cosmos/cosmos-sdk/codec/types"
sdk "github.com/cosmos/cosmos-sdk/types"
typestx "github.com/cosmos/cosmos-sdk/types/tx"
+ feetypes "github.com/cosmos/ibc-go/v7/modules/apps/29-fee/types"
transfertypes "github.com/cosmos/ibc-go/v7/modules/apps/transfer/types"
+
clienttypes "github.com/cosmos/ibc-go/v7/modules/core/02-client/types"
+ chantypes "github.com/cosmos/ibc-go/v7/modules/core/04-channel/types"
"github.com/cosmos/relayer/v2/relayer/provider"
"go.uber.org/zap"
"go.uber.org/zap/zapcore"
@@ -52,6 +56,12 @@ func (cc *CosmosProvider) LogFailedTx(res *provider.RelayerTxResponse, err error
fields = append(fields, msgTypesField(msgs))
if err != nil {
+
+ if errors.Is(err, chantypes.ErrRedundantTx) {
+ cc.log.Debug("Redundant message(s)", fields...)
+ return
+ }
+
// Make a copy since we may continue to the warning
errorFields := append(fields, zap.Error(err))
cc.log.Error(
@@ -154,6 +164,19 @@ func getFeePayer(tx *typestx.Tx) string {
case *clienttypes.MsgUpdateClient:
// Same failure mode as MsgCreateClient.
return firstMsg.Signer
+ case *clienttypes.MsgUpgradeClient:
+ return firstMsg.Signer
+ case *clienttypes.MsgSubmitMisbehaviour:
+ // Same failure mode as MsgCreateClient.
+ return firstMsg.Signer
+ case *feetypes.MsgRegisterPayee:
+ return firstMsg.Relayer
+ case *feetypes.MsgRegisterCounterpartyPayee:
+ return firstMsg.Relayer
+ case *feetypes.MsgPayPacketFee:
+ return firstMsg.Signer
+ case *feetypes.MsgPayPacketFeeAsync:
+ return firstMsg.PacketFee.RefundAddress
default:
return firstMsg.GetSigners()[0].String()
}
diff --git a/relayer/chains/cosmos/message_handlers.go b/relayer/chains/cosmos/message_handlers.go
index f9a9bd0f9..029ddd652 100644
--- a/relayer/chains/cosmos/message_handlers.go
+++ b/relayer/chains/cosmos/message_handlers.go
@@ -40,7 +40,7 @@ func (ccp *CosmosChainProcessor) handlePacketMessage(eventType string, pi provid
}
if eventType == chantypes.EventTypeTimeoutPacket && pi.ChannelOrder == chantypes.ORDERED.String() {
- ccp.channelStateCache[k] = false
+ ccp.channelStateCache.SetOpen(k, false, chantypes.ORDERED)
}
if !c.PacketFlow.ShouldRetainSequence(ccp.pathProcessors, k, ccp.chainProvider.ChainId(), eventType, pi.Sequence) {
@@ -78,18 +78,19 @@ func (ccp *CosmosChainProcessor) handleChannelMessage(eventType string, ci provi
}
}
if !found {
- ccp.channelStateCache[channelKey] = false
+ ccp.channelStateCache.SetOpen(channelKey, false, ci.Order)
}
} else {
switch eventType {
case chantypes.EventTypeChannelOpenTry:
- ccp.channelStateCache[channelKey] = false
+ ccp.channelStateCache.SetOpen(channelKey, false, ci.Order)
case chantypes.EventTypeChannelOpenAck, chantypes.EventTypeChannelOpenConfirm:
- ccp.channelStateCache[channelKey] = true
+ ccp.channelStateCache.SetOpen(channelKey, true, ci.Order)
+ ccp.logChannelOpenMessage(eventType, ci)
case chantypes.EventTypeChannelCloseConfirm:
for k := range ccp.channelStateCache {
if k.PortID == ci.PortID && k.ChannelID == ci.ChannelID {
- ccp.channelStateCache[k] = false
+ ccp.channelStateCache.SetOpen(channelKey, false, ci.Order)
break
}
}
@@ -182,6 +183,16 @@ func (ccp *CosmosChainProcessor) logChannelMessage(message string, ci provider.C
)
}
+func (ccp *CosmosChainProcessor) logChannelOpenMessage(message string, ci provider.ChannelInfo) {
+ fields := []zap.Field{
+
+ zap.String("channel_id", ci.ChannelID),
+ zap.String("connection_id", ci.ConnID),
+ zap.String("port_id", ci.PortID),
+ }
+ ccp.log.Info("Successfully created new channel", fields...)
+}
+
func (ccp *CosmosChainProcessor) logConnectionMessage(message string, ci provider.ConnectionInfo) {
ccp.logObservedIBCMessage(message,
zap.String("client_id", ci.ClientID),
diff --git a/relayer/chains/cosmos/message_handlers_test.go b/relayer/chains/cosmos/message_handlers_test.go
index 10ebc9771..8038b3e5e 100644
--- a/relayer/chains/cosmos/message_handlers_test.go
+++ b/relayer/chains/cosmos/message_handlers_test.go
@@ -128,7 +128,7 @@ func TestChannelStateCache(t *testing.T) {
// The channel state is not open, but the entry should exist in the channelStateCache.
// MsgInitKey returns the ChannelKey with an empty counterparty channel ID.
- require.False(t, ccp.channelStateCache[k.MsgInitKey()])
+ require.False(t, ccp.channelStateCache[k.MsgInitKey()].Open)
// Observe MsgChannelOpenAck, which does have counterparty channel ID.
ccp.handleChannelMessage(chantypes.EventTypeChannelOpenAck, msgOpenAck, c)
@@ -139,7 +139,7 @@ func TestChannelStateCache(t *testing.T) {
// The fully populated ChannelKey should now be the only entry for this channel.
// The channel now open.
- require.True(t, ccp.channelStateCache[k])
+ require.True(t, ccp.channelStateCache[k].Open)
})
t.Run("handshake already occurred", func(t *testing.T) {
@@ -156,7 +156,7 @@ func TestChannelStateCache(t *testing.T) {
// Initialize channelStateCache with populated channel ID and counterparty channel ID.
// This emulates initializeChannelState after a recent channel handshake has completed
- ccp.channelStateCache[k] = true
+ ccp.channelStateCache.SetOpen(k, true, chantypes.NONE)
// Observe MsgChannelOpenInit, which does not have counterparty channel ID.
ccp.handleChannelMessage(chantypes.EventTypeChannelOpenInit, msgOpenInit, c)
@@ -166,7 +166,7 @@ func TestChannelStateCache(t *testing.T) {
// The fully populated ChannelKey should still be the only entry for this channel.
// The channel is still marked open since it was open during initializeChannelState.
- require.True(t, ccp.channelStateCache[k])
+ require.True(t, ccp.channelStateCache[k].Open)
// Observe MsgChannelOpenAck, which does have counterparty channel ID.
ccp.handleChannelMessage(chantypes.EventTypeChannelOpenAck, msgOpenAck, c)
@@ -175,6 +175,6 @@ func TestChannelStateCache(t *testing.T) {
require.Len(t, ccp.channelStateCache, 1)
// The fully populated ChannelKey should still be the only entry for this channel.
- require.True(t, ccp.channelStateCache[k])
+ require.True(t, ccp.channelStateCache[k].Open)
})
}
diff --git a/relayer/chains/cosmos/module/app_module.go b/relayer/chains/cosmos/module/app_module.go
index 94119092a..39e6ea36b 100644
--- a/relayer/chains/cosmos/module/app_module.go
+++ b/relayer/chains/cosmos/module/app_module.go
@@ -5,6 +5,7 @@ import (
"github.com/cosmos/cosmos-sdk/codec"
codectypes "github.com/cosmos/cosmos-sdk/codec/types"
solomachine "github.com/cosmos/ibc-go/v7/modules/light-clients/06-solomachine"
+ localhost "github.com/cosmos/ibc-go/v7/modules/light-clients/09-localhost"
"github.com/grpc-ecosystem/grpc-gateway/runtime"
"github.com/spf13/cobra"
@@ -26,7 +27,7 @@ func (AppModuleBasic) RegisterLegacyAminoCodec(*codec.LegacyAmino) {}
func (AppModuleBasic) RegisterInterfaces(registry codectypes.InterfaceRegistry) {
tmlightclient.RegisterInterfaces(registry)
solomachine.RegisterInterfaces(registry)
- // TODO: add the localhost light client when ibc-go v7.1.0 is available
+ localhost.RegisterInterfaces(registry)
}
// RegisterGRPCGatewayRoutes registers the gRPC Gateway routes for the ibc module.
diff --git a/relayer/chains/cosmos/msg.go b/relayer/chains/cosmos/msg.go
index 54ef33340..c80722d10 100644
--- a/relayer/chains/cosmos/msg.go
+++ b/relayer/chains/cosmos/msg.go
@@ -10,21 +10,21 @@ import (
"go.uber.org/zap/zapcore"
)
-var _ provider.RelayerMessage = &CosmosMessage{}
-
type CosmosMessage struct {
- Msg sdk.Msg
+ Msg sdk.Msg
+ SetSigner func(string) //callback to update the Msg Signer field
+ FeegrantDisabled bool //marks whether this message type should ALWAYS disable feegranting (use the default signer)
}
-func NewCosmosMessage(msg sdk.Msg) provider.RelayerMessage {
+func NewCosmosMessage(msg sdk.Msg, optionalSetSigner func(string)) provider.RelayerMessage {
return CosmosMessage{
- Msg: msg,
+ Msg: msg,
+ SetSigner: optionalSetSigner,
}
}
func CosmosMsg(rm provider.RelayerMessage) sdk.Msg {
if val, ok := rm.(CosmosMessage); !ok {
- fmt.Printf("got data of type %T but wanted provider.CosmosMessage \n", val)
return nil
} else {
return val.Msg
@@ -35,7 +35,7 @@ func CosmosMsgs(rm ...provider.RelayerMessage) []sdk.Msg {
sdkMsgs := make([]sdk.Msg, 0)
for _, rMsg := range rm {
if val, ok := rMsg.(CosmosMessage); !ok {
- fmt.Printf("got data of type %T but wanted provider.CosmosMessage \n", val)
+ fmt.Printf("got data of type %T but wanted provider.CosmosMessage \n", rMsg)
return nil
} else {
sdkMsgs = append(sdkMsgs, val.Msg)
diff --git a/relayer/chains/cosmos/provider.go b/relayer/chains/cosmos/provider.go
index b56bcdc61..8a704431a 100644
--- a/relayer/chains/cosmos/provider.go
+++ b/relayer/chains/cosmos/provider.go
@@ -35,25 +35,46 @@ var (
const cometEncodingThreshold = "v0.37.0-alpha"
type CosmosProviderConfig struct {
- KeyDirectory string `json:"key-directory" yaml:"key-directory"`
- Key string `json:"key" yaml:"key"`
- ChainName string `json:"-" yaml:"-"`
- ChainID string `json:"chain-id" yaml:"chain-id"`
- RPCAddr string `json:"rpc-addr" yaml:"rpc-addr"`
- AccountPrefix string `json:"account-prefix" yaml:"account-prefix"`
- KeyringBackend string `json:"keyring-backend" yaml:"keyring-backend"`
- GasAdjustment float64 `json:"gas-adjustment" yaml:"gas-adjustment"`
- GasPrices string `json:"gas-prices" yaml:"gas-prices"`
- MinGasAmount uint64 `json:"min-gas-amount" yaml:"min-gas-amount"`
- Debug bool `json:"debug" yaml:"debug"`
- Timeout string `json:"timeout" yaml:"timeout"`
- BlockTimeout string `json:"block-timeout" yaml:"block-timeout"`
- OutputFormat string `json:"output-format" yaml:"output-format"`
- SignModeStr string `json:"sign-mode" yaml:"sign-mode"`
- ExtraCodecs []string `json:"extra-codecs" yaml:"extra-codecs"`
- Modules []module.AppModuleBasic `json:"-" yaml:"-"`
- Slip44 int `json:"coin-type" yaml:"coin-type"`
- Broadcast provider.BroadcastMode `json:"broadcast-mode" yaml:"broadcast-mode"`
+ KeyDirectory string `json:"key-directory" yaml:"key-directory"`
+ Key string `json:"key" yaml:"key"`
+ ChainName string `json:"-" yaml:"-"`
+ ChainID string `json:"chain-id" yaml:"chain-id"`
+ RPCAddr string `json:"rpc-addr" yaml:"rpc-addr"`
+ AccountPrefix string `json:"account-prefix" yaml:"account-prefix"`
+ KeyringBackend string `json:"keyring-backend" yaml:"keyring-backend"`
+ GasAdjustment float64 `json:"gas-adjustment" yaml:"gas-adjustment"`
+ GasPrices string `json:"gas-prices" yaml:"gas-prices"`
+ MinGasAmount uint64 `json:"min-gas-amount" yaml:"min-gas-amount"`
+ MaxGasAmount uint64 `json:"max-gas-amount" yaml:"max-gas-amount"`
+ Debug bool `json:"debug" yaml:"debug"`
+ Timeout string `json:"timeout" yaml:"timeout"`
+ BlockTimeout string `json:"block-timeout" yaml:"block-timeout"`
+ OutputFormat string `json:"output-format" yaml:"output-format"`
+ SignModeStr string `json:"sign-mode" yaml:"sign-mode"`
+ ExtraCodecs []string `json:"extra-codecs" yaml:"extra-codecs"`
+ Modules []module.AppModuleBasic `json:"-" yaml:"-"`
+ Slip44 *int `json:"coin-type" yaml:"coin-type"`
+ SigningAlgorithm string `json:"signing-algorithm" yaml:"signing-algorithm"`
+ Broadcast provider.BroadcastMode `json:"broadcast-mode" yaml:"broadcast-mode"`
+ MinLoopDuration time.Duration `json:"min-loop-duration" yaml:"min-loop-duration"`
+ ExtensionOptions []provider.ExtensionOption `json:"extension-options" yaml:"extension-options"`
+
+ //If FeeGrantConfiguration is set, TXs submitted by the ChainClient will be signed by the FeeGrantees in a round-robin fashion by default.
+ FeeGrants *FeeGrantConfiguration `json:"feegrants" yaml:"feegrants"`
+}
+
+// By default, TXs will be signed by the feegrantees 'ManagedGrantees' keys in a round robin fashion.
+// Clients can use other signing keys by invoking 'tx.SendMsgsWith' and specifying the signing key.
+type FeeGrantConfiguration struct {
+ GranteesWanted int `json:"num_grantees" yaml:"num_grantees"`
+ //Normally this is the default ChainClient key
+ GranterKey string `json:"granter" yaml:"granter"`
+ //List of keys (by name) that this FeeGranter manages
+ ManagedGrantees []string `json:"grantees" yaml:"grantees"`
+ //Last checked on chain (0 means grants never checked and may not exist)
+ BlockHeightVerified int64 `json:"block_last_verified" yaml:"block_last_verified"`
+ //Index of the last ManagedGrantee used as a TX signer
+ GranteeLastSignerIndex int
}
func (pc CosmosProviderConfig) Validate() error {
@@ -67,6 +88,14 @@ func (pc CosmosProviderConfig) BroadcastMode() provider.BroadcastMode {
return pc.Broadcast
}
+func (pc CosmosProviderConfig) GetBlockInterval() uint64 {
+ panic("Not implemented for Cosmos")
+}
+
+func (pc CosmosProviderConfig) GetFirstRetryBlockAfter() uint64 {
+ return 1
+}
+
// NewProvider validates the CosmosProviderConfig, instantiates a ChainClient and then instantiates a CosmosProvider
func (pc CosmosProviderConfig) NewProvider(log *zap.Logger, homepath string, debug bool, chainName string) (provider.ChainProvider, error) {
if err := pc.Validate(); err != nil {
@@ -88,6 +117,7 @@ func (pc CosmosProviderConfig) NewProvider(log *zap.Logger, homepath string, deb
KeyringOptions: []keyring.Option{ethermint.EthSecp256k1Option()},
Input: os.Stdin,
Output: os.Stdout,
+ walletStateMap: map[string]*WalletState{},
// TODO: this is a bit of a hack, we should probably have a better way to inject modules
Cdc: MakeCodec(pc.Modules, pc.ExtraCodecs),
@@ -109,8 +139,13 @@ type CosmosProvider struct {
Cdc Codec
// TODO: GRPC Client type?
- nextAccountSeq uint64
- txMu sync.Mutex
+ //nextAccountSeq uint64
+ feegrantMu sync.Mutex
+
+ // the map key is the TX signer, which can either be 'default' (provider key) or a feegrantee
+ // the purpose of the map is to lock on the signer from TX creation through submission,
+ // thus making TX sequencing errors less likely.
+ walletStateMap map[string]*WalletState
// metrics to monitor the provider
TotalFees sdk.Coins
@@ -122,6 +157,11 @@ type CosmosProvider struct {
cometLegacyEncoding bool
}
+type WalletState struct {
+ NextAccountSequence uint64
+ Mu sync.Mutex
+}
+
func (cc *CosmosProvider) ProviderConfig() provider.ProviderConfig {
return cc.PCfg
}
@@ -171,6 +211,28 @@ func (cc *CosmosProvider) Address() (string, error) {
return out, err
}
+func (cc *CosmosProvider) MustEncodeAccAddr(addr sdk.AccAddress) string {
+ enc, err := cc.EncodeBech32AccAddr(addr)
+ if err != nil {
+ panic(err)
+ }
+ return enc
+}
+
+// AccountFromKeyOrAddress returns an account from either a key or an address.
+// If 'keyOrAddress' is the empty string, this returns the default key's address.
+func (cc *CosmosProvider) AccountFromKeyOrAddress(keyOrAddress string) (out sdk.AccAddress, err error) {
+ switch {
+ case keyOrAddress == "":
+ out, err = cc.GetKeyAddress(cc.PCfg.Key)
+ case cc.KeyExists(keyOrAddress):
+ out, err = cc.GetKeyAddress(keyOrAddress)
+ default:
+ out, err = sdk.GetFromBech32(keyOrAddress, cc.PCfg.AccountPrefix)
+ }
+ return
+}
+
func (cc *CosmosProvider) TrustingPeriod(ctx context.Context) (time.Duration, error) {
res, err := cc.QueryStakingParams(ctx)
@@ -293,9 +355,9 @@ func (cc *CosmosProvider) SetMetrics(m *processor.PrometheusMetrics) {
cc.metrics = m
}
-func (cc *CosmosProvider) updateNextAccountSequence(seq uint64) {
- if seq > cc.nextAccountSeq {
- cc.nextAccountSeq = seq
+func (cc *CosmosProvider) updateNextAccountSequence(sequenceGuard *WalletState, seq uint64) {
+ if seq > sequenceGuard.NextAccountSequence {
+ sequenceGuard.NextAccountSequence = seq
}
}
diff --git a/relayer/chains/cosmos/query.go b/relayer/chains/cosmos/query.go
index c4690f6b3..9fa73f78f 100644
--- a/relayer/chains/cosmos/query.go
+++ b/relayer/chains/cosmos/query.go
@@ -8,6 +8,7 @@ import (
"fmt"
"strconv"
"strings"
+ "sync"
"time"
abci "github.com/cometbft/cometbft/abci/types"
@@ -16,8 +17,11 @@ import (
"github.com/cosmos/cosmos-sdk/codec"
sdk "github.com/cosmos/cosmos-sdk/types"
sdkerrors "github.com/cosmos/cosmos-sdk/types/errors"
+ grpctypes "github.com/cosmos/cosmos-sdk/types/grpc"
+ "github.com/cosmos/cosmos-sdk/types/query"
querytypes "github.com/cosmos/cosmos-sdk/types/query"
bankTypes "github.com/cosmos/cosmos-sdk/x/bank/types"
+ "github.com/cosmos/cosmos-sdk/x/feegrant"
"github.com/cosmos/cosmos-sdk/x/params/types/proposal"
stakingtypes "github.com/cosmos/cosmos-sdk/x/staking/types"
upgradetypes "github.com/cosmos/cosmos-sdk/x/upgrade/types"
@@ -27,11 +31,13 @@ import (
chantypes "github.com/cosmos/ibc-go/v7/modules/core/04-channel/types"
commitmenttypes "github.com/cosmos/ibc-go/v7/modules/core/23-commitment/types"
host "github.com/cosmos/ibc-go/v7/modules/core/24-host"
+ "github.com/cosmos/ibc-go/v7/modules/core/exported"
ibcexported "github.com/cosmos/ibc-go/v7/modules/core/exported"
tmclient "github.com/cosmos/ibc-go/v7/modules/light-clients/07-tendermint"
"github.com/cosmos/relayer/v2/relayer/provider"
"go.uber.org/zap"
"golang.org/x/sync/errgroup"
+ "google.golang.org/grpc/metadata"
)
const PaginationDelay = 10 * time.Millisecond
@@ -52,14 +58,55 @@ func (cc *CosmosProvider) queryIBCMessages(ctx context.Context, log *zap.Logger,
return nil, errors.New("limit must greater than 0")
}
- res, err := cc.RPCClient.TxSearch(ctx, query, true, &page, &limit, "")
- if err != nil {
- return nil, err
- }
- var ibcMsgs []ibcMessage
+ var eg errgroup.Group
chainID := cc.ChainId()
- for _, tx := range res.Txs {
- ibcMsgs = append(ibcMsgs, ibcMessagesFromEvents(log, tx.TxResult.Events, chainID, 0, base64Encoded)...)
+ var ibcMsgs []ibcMessage
+ var mu sync.Mutex
+
+ eg.Go(func() error {
+ res, err := cc.RPCClient.BlockSearch(ctx, query, &page, &limit, "")
+ if err != nil {
+ return err
+ }
+
+ var nestedEg errgroup.Group
+
+ for _, b := range res.Blocks {
+ b := b
+ nestedEg.Go(func() error {
+ block, err := cc.RPCClient.BlockResults(ctx, &b.Block.Height)
+ if err != nil {
+ return err
+ }
+
+ mu.Lock()
+ defer mu.Unlock()
+ ibcMsgs = append(ibcMsgs, ibcMessagesFromEvents(log, block.BeginBlockEvents, chainID, 0, base64Encoded)...)
+ ibcMsgs = append(ibcMsgs, ibcMessagesFromEvents(log, block.EndBlockEvents, chainID, 0, base64Encoded)...)
+
+ return nil
+ })
+ }
+ return nestedEg.Wait()
+ })
+
+ eg.Go(func() error {
+ res, err := cc.RPCClient.TxSearch(ctx, query, true, &page, &limit, "")
+ if err != nil {
+ return err
+ }
+
+ mu.Lock()
+ defer mu.Unlock()
+ for _, tx := range res.Txs {
+ ibcMsgs = append(ibcMsgs, ibcMessagesFromEvents(log, tx.TxResult.Events, chainID, 0, base64Encoded)...)
+ }
+
+ return nil
+ })
+
+ if err := eg.Wait(); err != nil {
+ return nil, err
}
return ibcMsgs, nil
@@ -141,6 +188,93 @@ func parseEventsFromResponseDeliverTx(resp abci.ResponseDeliverTx) []provider.Re
return events
}
+// QueryFeegrantsByGrantee returns all requested grants for the given grantee.
+// Default behavior will return all grants.
+func (cc *CosmosProvider) QueryFeegrantsByGrantee(address string, paginator *query.PageRequest) ([]*feegrant.Grant, error) {
+ grants := []*feegrant.Grant{}
+ allPages := paginator == nil
+
+ req := &feegrant.QueryAllowancesRequest{Grantee: address, Pagination: paginator}
+ queryClient := feegrant.NewQueryClient(cc)
+ ctx, cancel := cc.GetQueryContext(0)
+ defer cancel()
+ hasNextPage := true
+
+ for {
+ res, err := queryClient.Allowances(ctx, req)
+ if err != nil {
+ return nil, err
+ }
+
+ if res.Allowances != nil {
+ grants = append(grants, res.Allowances...)
+ }
+
+ if res.Pagination != nil {
+ req.Pagination.Key = res.Pagination.NextKey
+ if len(res.Pagination.NextKey) == 0 {
+ hasNextPage = false
+ }
+ } else {
+ hasNextPage = false
+ }
+
+ if !allPages || !hasNextPage {
+ break
+ }
+ }
+
+ return grants, nil
+}
+
+// Feegrant_GrantsByGranterRPC returns all requested grants for the given Granter.
+// Default behavior will return all grants.
+func (cc *CosmosProvider) QueryFeegrantsByGranter(address string, paginator *query.PageRequest) ([]*feegrant.Grant, error) {
+ grants := []*feegrant.Grant{}
+ allPages := paginator == nil
+
+ req := &feegrant.QueryAllowancesByGranterRequest{Granter: address, Pagination: paginator}
+ queryClient := feegrant.NewQueryClient(cc)
+ ctx, cancel := cc.GetQueryContext(0)
+ defer cancel()
+ hasNextPage := true
+
+ for {
+ res, err := queryClient.AllowancesByGranter(ctx, req)
+ if err != nil {
+ return nil, err
+ }
+
+ if res.Allowances != nil {
+ grants = append(grants, res.Allowances...)
+ }
+
+ if res.Pagination != nil && res.Pagination.NextKey != nil {
+ req.Pagination.Key = res.Pagination.NextKey
+ if len(res.Pagination.NextKey) == 0 {
+ hasNextPage = false
+ }
+ } else {
+ hasNextPage = false
+ }
+
+ if !allPages || !hasNextPage {
+ break
+ }
+ }
+
+ return grants, nil
+}
+
+// GetQueryContext returns a context that includes the height and uses the timeout from the config
+func (cc *CosmosProvider) GetQueryContext(height int64) (context.Context, context.CancelFunc) {
+ timeout, _ := time.ParseDuration(cc.PCfg.Timeout) // Timeout is validated in the config so no error check
+ ctx, cancel := context.WithTimeout(context.Background(), timeout)
+ strHeight := strconv.FormatInt(height, 10)
+ ctx = metadata.AppendToOutgoingContext(ctx, grpctypes.GRPCBlockHeightHeader, strHeight)
+ return ctx, cancel
+}
+
// QueryBalance returns the amount of coins in the relayer account
func (cc *CosmosProvider) QueryBalance(ctx context.Context, keyName string) (sdk.Coins, error) {
addr, err := cc.ShowAddress(keyName)
@@ -587,7 +721,12 @@ func (cc *CosmosProvider) QueryConnectionsUsingClient(ctx context.Context, heigh
return nil, err
}
- connections.Connections = append(connections.Connections, res.Connections...)
+ for _, conn := range res.Connections {
+ if conn.ClientId == clientid {
+ connections.Connections = append(connections.Connections, conn)
+ }
+ }
+
next := res.GetPagination().GetNextKey()
if len(next) == 0 {
break
@@ -642,7 +781,6 @@ func (cc *CosmosProvider) GenerateConnHandshakeProof(ctx context.Context, height
func (cc *CosmosProvider) QueryChannel(ctx context.Context, height int64, channelid, portid string) (chanRes *chantypes.QueryChannelResponse, err error) {
res, err := cc.queryChannelABCI(ctx, height, portid, channelid)
if err != nil && strings.Contains(err.Error(), "not found") {
-
return &chantypes.QueryChannelResponse{
Channel: &chantypes.Channel{
State: chantypes.UNINITIALIZED,
@@ -851,7 +989,6 @@ func (cc *CosmosProvider) QueryUnreceivedPackets(ctx context.Context, height uin
func sendPacketQuery(channelID string, portID string, seq uint64) string {
x := []string{
fmt.Sprintf("%s.packet_src_channel='%s'", spTag, channelID),
- fmt.Sprintf("%s.packet_src_port='%s'", spTag, portID),
fmt.Sprintf("%s.packet_sequence='%d'", spTag, seq),
}
return strings.Join(x, " AND ")
@@ -860,7 +997,6 @@ func sendPacketQuery(channelID string, portID string, seq uint64) string {
func writeAcknowledgementQuery(channelID string, portID string, seq uint64) string {
x := []string{
fmt.Sprintf("%s.packet_dst_channel='%s'", waTag, channelID),
- fmt.Sprintf("%s.packet_dst_port='%s'", waTag, portID),
fmt.Sprintf("%s.packet_sequence='%d'", waTag, seq),
}
return strings.Join(x, " AND ")
@@ -961,6 +1097,29 @@ func (cc *CosmosProvider) QueryNextSeqRecv(ctx context.Context, height int64, ch
}, nil
}
+// QueryNextSeqAck returns the next seqAck for a configured channel
+func (cc *CosmosProvider) QueryNextSeqAck(ctx context.Context, height int64, channelid, portid string) (recvRes *chantypes.QueryNextSequenceReceiveResponse, err error) {
+ key := host.NextSequenceAckKey(portid, channelid)
+
+ value, proofBz, proofHeight, err := cc.QueryTendermintProof(ctx, height, key)
+ if err != nil {
+ return nil, err
+ }
+
+ // check if next sequence receive exists
+ if len(value) == 0 {
+ return nil, sdkerrors.Wrapf(chantypes.ErrChannelNotFound, "portID (%s), channelID (%s)", portid, channelid)
+ }
+
+ sequence := binary.BigEndian.Uint64(value)
+
+ return &chantypes.QueryNextSequenceReceiveResponse{
+ NextSequenceReceive: sequence,
+ Proof: proofBz,
+ ProofHeight: proofHeight,
+ }, nil
+}
+
// QueryPacketCommitment returns the packet commitment proof at a given height
func (cc *CosmosProvider) QueryPacketCommitment(ctx context.Context, height int64, channelid, portid string, seq uint64) (comRes *chantypes.QueryPacketCommitmentResponse, err error) {
key := host.PacketCommitmentKey(portid, channelid, seq)
@@ -1125,3 +1284,8 @@ func (cc *CosmosProvider) QueryConsensusStateABCI(ctx context.Context, clientID
ProofHeight: proofHeight,
}, nil
}
+
+func (ap *CosmosProvider) QueryClientPrevConsensusStateHeight(ctx context.Context, chainHeight int64, clientId string, clientHeight int64) (exported.Height, error) {
+ panic("QueryClientPrevConsensusStateHeight not implemented")
+
+}
diff --git a/relayer/chains/cosmos/relayer_packets.go b/relayer/chains/cosmos/relayer_packets.go
index 168b6be9a..ad7779c6a 100644
--- a/relayer/chains/cosmos/relayer_packets.go
+++ b/relayer/chains/cosmos/relayer_packets.go
@@ -66,7 +66,9 @@ func (rp relayMsgTimeout) Msg(src provider.ChainProvider, srcPortId, srcChanId,
Signer: addr,
}
- return NewCosmosMessage(msg), nil
+ return NewCosmosMessage(msg, func(signer string) {
+ msg.Signer = signer
+ }), nil
}
type relayMsgRecvPacket struct {
@@ -129,7 +131,9 @@ func (rp relayMsgRecvPacket) Msg(src provider.ChainProvider, srcPortId, srcChanI
Signer: addr,
}
- return NewCosmosMessage(msg), nil
+ return NewCosmosMessage(msg, func(signer string) {
+ msg.Signer = signer
+ }), nil
}
type relayMsgPacketAck struct {
@@ -184,5 +188,7 @@ func (rp relayMsgPacketAck) Msg(src provider.ChainProvider, srcPortId, srcChanId
Signer: addr,
}
- return NewCosmosMessage(msg), nil
+ return NewCosmosMessage(msg, func(signer string) {
+ msg.Signer = signer
+ }), nil
}
diff --git a/relayer/chains/cosmos/stride/messages.pb.go b/relayer/chains/cosmos/stride/messages.pb.go
index d99e7cc34..6c438a3fa 100644
--- a/relayer/chains/cosmos/stride/messages.pb.go
+++ b/relayer/chains/cosmos/stride/messages.pb.go
@@ -7,8 +7,8 @@ import (
fmt "fmt"
crypto "github.com/cometbft/cometbft/proto/tendermint/crypto"
_ "github.com/cosmos/cosmos-proto"
+ _ "github.com/cosmos/gogoproto/gogoproto"
proto "github.com/cosmos/gogoproto/proto"
- _ "github.com/gogo/protobuf/gogoproto"
io "io"
math "math"
math_bits "math/bits"
@@ -78,32 +78,32 @@ func init() {
var fileDescriptor_25adad4f8ed32400 = []byte{
// 415 bytes of a gzipped FileDescriptorProto
- 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x5c, 0x92, 0xbf, 0xae, 0xd3, 0x30,
- 0x14, 0x87, 0xe3, 0x7b, 0xa1, 0xb7, 0x4d, 0x8b, 0x80, 0x50, 0xa1, 0xb4, 0x48, 0x49, 0x94, 0x29,
- 0x0c, 0x24, 0x2a, 0x48, 0x0c, 0x65, 0x22, 0x5b, 0x25, 0x10, 0x25, 0xdd, 0x58, 0xa2, 0xfc, 0x71,
- 0x13, 0x4b, 0x4d, 0x1c, 0x6c, 0xa7, 0x52, 0xde, 0x80, 0x91, 0x91, 0xb1, 0x0f, 0xc1, 0x43, 0x30,
- 0x56, 0x4c, 0x4c, 0x15, 0x6a, 0x07, 0x98, 0xfb, 0x04, 0xc8, 0x76, 0x52, 0xa1, 0x4e, 0x39, 0x39,
- 0xdf, 0xe7, 0x1c, 0xff, 0xec, 0xa8, 0x0e, 0x65, 0x04, 0xa5, 0xd0, 0x43, 0x25, 0x83, 0x24, 0xc9,
- 0x23, 0x54, 0x7e, 0xae, 0x21, 0x69, 0xbc, 0xed, 0xcc, 0x2b, 0x20, 0xa5, 0x51, 0x06, 0xa9, 0x5b,
- 0x11, 0xcc, 0xb0, 0x36, 0x91, 0xa6, 0x7b, 0x65, 0xba, 0xdb, 0xd9, 0x74, 0x9c, 0xe1, 0x0c, 0x0b,
- 0xcb, 0xe3, 0x95, 0x5c, 0x30, 0x9d, 0x24, 0x98, 0x16, 0x98, 0x86, 0x12, 0xc8, 0x97, 0x16, 0x3d,
- 0x4b, 0x70, 0x01, 0x59, 0xbc, 0x66, 0x5e, 0x42, 0x9a, 0x8a, 0x61, 0xaf, 0x22, 0x18, 0xaf, 0x25,
- 0xb4, 0xff, 0xdc, 0xa8, 0x4f, 0xdf, 0xd3, 0x6c, 0x55, 0xc7, 0x05, 0x62, 0x1f, 0xf9, 0x8c, 0x00,
- 0xd2, 0x0a, 0x97, 0x14, 0x6a, 0xae, 0xda, 0x17, 0x93, 0x43, 0x94, 0xea, 0xc0, 0x02, 0xce, 0xc0,
- 0x7f, 0x72, 0x3e, 0x98, 0x0f, 0x9b, 0xa8, 0xd8, 0xcc, 0xed, 0x8e, 0xd8, 0xc1, 0x9d, 0x28, 0x17,
- 0x29, 0xf7, 0xc5, 0x26, 0xb9, 0x7f, 0x73, 0xed, 0x77, 0xc4, 0x0e, 0xee, 0x44, 0xb9, 0x48, 0xb5,
- 0xe7, 0x6a, 0x8f, 0x40, 0x5a, 0x6f, 0x98, 0x7e, 0x6b, 0x01, 0x67, 0xe4, 0x3f, 0x3e, 0x1f, 0xcc,
- 0x07, 0xd2, 0x96, 0x7d, 0x3b, 0x68, 0x05, 0xed, 0x9d, 0x3a, 0x10, 0x9b, 0x0e, 0x71, 0x45, 0xf5,
- 0x7b, 0x16, 0x70, 0x86, 0x2f, 0x27, 0x6e, 0x17, 0xcb, 0x95, 0xb1, 0xdc, 0x25, 0x37, 0x3e, 0x54,
- 0xd4, 0x1f, 0x9f, 0x0f, 0xe6, 0x23, 0xf9, 0xa1, 0xcb, 0x2a, 0x3b, 0xe8, 0x57, 0x2d, 0xe7, 0x83,
- 0x73, 0x88, 0xb2, 0x9c, 0xe9, 0xf7, 0x2d, 0xe0, 0xdc, 0xfe, 0x3f, 0x58, 0xf6, 0xed, 0xa0, 0x15,
- 0xb4, 0x37, 0xea, 0x68, 0x4d, 0x70, 0x11, 0x46, 0x69, 0x4a, 0x20, 0xa5, 0x7a, 0x4f, 0xe4, 0xd2,
- 0x7f, 0x7e, 0x7f, 0x31, 0x6e, 0xcf, 0xf8, 0xad, 0x24, 0x2b, 0x46, 0x50, 0x99, 0x05, 0x43, 0x6e,
- 0xb7, 0xad, 0xf9, 0xe8, 0xcb, 0xce, 0x54, 0xbe, 0xed, 0x4c, 0xf0, 0x77, 0x67, 0x2a, 0xfe, 0xf2,
- 0xc7, 0xd1, 0x00, 0xfb, 0xa3, 0x01, 0x7e, 0x1f, 0x0d, 0xf0, 0xf5, 0x64, 0x28, 0xfb, 0x93, 0xa1,
- 0xfc, 0x3a, 0x19, 0xca, 0xa7, 0xd7, 0x19, 0x62, 0x79, 0x1d, 0xf3, 0x40, 0xed, 0xcd, 0x79, 0x04,
- 0x6e, 0xa2, 0x06, 0x92, 0xcb, 0x53, 0x9c, 0x31, 0xed, 0xa8, 0xfc, 0x39, 0xe2, 0x9e, 0xb8, 0xc2,
- 0x57, 0xff, 0x02, 0x00, 0x00, 0xff, 0xff, 0x72, 0x51, 0x12, 0x90, 0x57, 0x02, 0x00, 0x00,
+ 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x5c, 0x92, 0x3f, 0x0f, 0x93, 0x40,
+ 0x18, 0x87, 0xb9, 0x56, 0xfb, 0x87, 0xd6, 0xa8, 0xd8, 0x18, 0x5a, 0x23, 0x10, 0x26, 0x1c, 0x3c,
+ 0x52, 0x4d, 0x1c, 0xea, 0x24, 0x5b, 0x07, 0xb5, 0xd2, 0xcd, 0x85, 0x50, 0xb8, 0xc2, 0x25, 0x85,
+ 0xc3, 0xbb, 0xa3, 0x09, 0xdf, 0xc0, 0xd1, 0xd1, 0xb1, 0x1f, 0xc2, 0x0f, 0xe1, 0xd8, 0x38, 0x39,
+ 0x35, 0xa6, 0x5d, 0x74, 0xed, 0x27, 0x30, 0xdc, 0xd1, 0x6a, 0x3a, 0xf1, 0xf2, 0x3e, 0xcf, 0xf1,
+ 0xbb, 0xf7, 0x0e, 0xd5, 0x61, 0x9c, 0xe2, 0x18, 0xb9, 0x38, 0xe7, 0x88, 0x46, 0x69, 0x88, 0xf3,
+ 0x4f, 0x25, 0xa2, 0x95, 0xbb, 0x9d, 0xba, 0x19, 0x62, 0x2c, 0x4c, 0x10, 0x83, 0x05, 0x25, 0x9c,
+ 0x68, 0x63, 0x69, 0xc2, 0x1b, 0x13, 0x6e, 0xa7, 0x93, 0x51, 0x42, 0x12, 0x22, 0x2c, 0xb7, 0xae,
+ 0xe4, 0x82, 0xc9, 0x38, 0x22, 0x2c, 0x23, 0x2c, 0x90, 0x40, 0xbe, 0x34, 0xe8, 0x29, 0x47, 0x79,
+ 0x8c, 0x68, 0x86, 0x73, 0xee, 0x46, 0xb4, 0x2a, 0x38, 0x71, 0x0b, 0x4a, 0xc8, 0x5a, 0x62, 0xfb,
+ 0x4f, 0x4b, 0x7d, 0xfc, 0x96, 0x25, 0xcb, 0x72, 0x95, 0x61, 0xfe, 0xa1, 0x4e, 0xf1, 0x11, 0x2b,
+ 0x48, 0xce, 0x90, 0x06, 0xd5, 0x9e, 0xc8, 0x0e, 0x70, 0xac, 0x03, 0x0b, 0x38, 0x7d, 0xef, 0xd1,
+ 0xf9, 0x60, 0xde, 0xaf, 0xc2, 0x6c, 0x33, 0xb3, 0x2f, 0xc4, 0xf6, 0xbb, 0xa2, 0x9c, 0xc7, 0xb5,
+ 0x2f, 0xb6, 0x59, 0xfb, 0xad, 0x5b, 0xff, 0x42, 0x6c, 0xbf, 0x2b, 0xca, 0x79, 0xac, 0x3d, 0x53,
+ 0x3b, 0x14, 0xb1, 0x72, 0xc3, 0xf5, 0xb6, 0x05, 0x9c, 0xa1, 0xf7, 0xf0, 0x7c, 0x30, 0xef, 0x49,
+ 0x5b, 0xf6, 0x6d, 0xbf, 0x11, 0xb4, 0x77, 0x6a, 0x5f, 0x6c, 0x3a, 0x20, 0x05, 0xd3, 0xef, 0x58,
+ 0xc0, 0x19, 0xbc, 0x78, 0x02, 0xff, 0x0d, 0x06, 0xe5, 0x60, 0x70, 0x51, 0x3b, 0xef, 0x0b, 0xe6,
+ 0x8d, 0xce, 0x07, 0xf3, 0x81, 0xfc, 0xd4, 0x75, 0x9d, 0xed, 0xf7, 0x8a, 0x86, 0xd7, 0xd1, 0x29,
+ 0xc2, 0x49, 0xca, 0xf5, 0xbb, 0x16, 0x70, 0xda, 0xff, 0x47, 0xcb, 0xbe, 0xed, 0x37, 0x82, 0xf6,
+ 0x5a, 0x1d, 0xae, 0x29, 0xc9, 0x82, 0x30, 0x8e, 0x29, 0x62, 0x4c, 0xef, 0x88, 0xc9, 0xf4, 0x1f,
+ 0xdf, 0x9e, 0x8f, 0x9a, 0x73, 0x7e, 0x23, 0xc9, 0x92, 0x53, 0x9c, 0x27, 0xfe, 0xa0, 0xb6, 0x9b,
+ 0xd6, 0x6c, 0xf8, 0x79, 0x67, 0x2a, 0x5f, 0x77, 0x26, 0xf8, 0xbd, 0x33, 0x15, 0x6f, 0xf1, 0xfd,
+ 0x68, 0x80, 0xfd, 0xd1, 0x00, 0xbf, 0x8e, 0x06, 0xf8, 0x72, 0x32, 0x94, 0xfd, 0xc9, 0x50, 0x7e,
+ 0x9e, 0x0c, 0xe5, 0xe3, 0xab, 0x04, 0xf3, 0xb4, 0x5c, 0xc1, 0x88, 0x64, 0xcd, 0xed, 0xb9, 0x14,
+ 0x6d, 0xc2, 0x0a, 0xd1, 0xeb, 0x53, 0x9c, 0x32, 0xbb, 0x50, 0xf9, 0x83, 0xac, 0x3a, 0xe2, 0x12,
+ 0x5f, 0xfe, 0x0d, 0x00, 0x00, 0xff, 0xff, 0x5e, 0x6b, 0x0e, 0x66, 0x5b, 0x02, 0x00, 0x00,
}
func (m *MsgSubmitQueryResponse) Marshal() (dAtA []byte, err error) {
diff --git a/relayer/chains/cosmos/tx.go b/relayer/chains/cosmos/tx.go
index f62c11602..761ebac9c 100644
--- a/relayer/chains/cosmos/tx.go
+++ b/relayer/chains/cosmos/tx.go
@@ -4,7 +4,9 @@ import (
"context"
"errors"
"fmt"
+ "math"
"math/big"
+ "math/rand"
"regexp"
"strconv"
"strings"
@@ -13,12 +15,14 @@ import (
"github.com/avast/retry-go/v4"
abci "github.com/cometbft/cometbft/abci/types"
+ "github.com/cometbft/cometbft/libs/bytes"
"github.com/cometbft/cometbft/light"
rpcclient "github.com/cometbft/cometbft/rpc/client"
coretypes "github.com/cometbft/cometbft/rpc/core/types"
tmtypes "github.com/cometbft/cometbft/types"
"github.com/cosmos/cosmos-sdk/client"
"github.com/cosmos/cosmos-sdk/client/tx"
+ "github.com/cosmos/cosmos-sdk/codec/types"
"github.com/cosmos/cosmos-sdk/crypto/keyring"
"github.com/cosmos/cosmos-sdk/crypto/keys/secp256k1"
cryptotypes "github.com/cosmos/cosmos-sdk/crypto/types"
@@ -27,6 +31,7 @@ import (
sdkerrors "github.com/cosmos/cosmos-sdk/types/errors"
txtypes "github.com/cosmos/cosmos-sdk/types/tx"
"github.com/cosmos/cosmos-sdk/types/tx/signing"
+ feetypes "github.com/cosmos/ibc-go/v7/modules/apps/29-fee/types"
transfertypes "github.com/cosmos/ibc-go/v7/modules/apps/transfer/types"
clienttypes "github.com/cosmos/ibc-go/v7/modules/core/02-client/types"
conntypes "github.com/cosmos/ibc-go/v7/modules/core/03-connection/types"
@@ -35,7 +40,9 @@ import (
host "github.com/cosmos/ibc-go/v7/modules/core/24-host"
ibcexported "github.com/cosmos/ibc-go/v7/modules/core/exported"
tmclient "github.com/cosmos/ibc-go/v7/modules/light-clients/07-tendermint"
+ localhost "github.com/cosmos/ibc-go/v7/modules/light-clients/09-localhost"
strideicqtypes "github.com/cosmos/relayer/v2/relayer/chains/cosmos/stride"
+ "github.com/cosmos/relayer/v2/relayer/ethermint"
"github.com/cosmos/relayer/v2/relayer/provider"
"go.uber.org/zap"
"google.golang.org/grpc/codes"
@@ -48,7 +55,7 @@ var (
rtyAtt = retry.Attempts(rtyAttNum)
rtyDel = retry.Delay(time.Millisecond * 400)
rtyErr = retry.LastErrorOnly(true)
- numRegex = regexp.MustCompile("[0-9]+")
+ accountSeqRegex = regexp.MustCompile("account sequence mismatch, expected ([0-9]+), got ([0-9]+)")
defaultBroadcastWaitTimeout = 10 * time.Minute
errUnknown = "unknown"
)
@@ -73,6 +80,26 @@ func (cc *CosmosProvider) SendMessage(ctx context.Context, msg provider.RelayerM
return cc.SendMessages(ctx, []provider.RelayerMessage{msg}, memo)
}
+var seqGuardSingleton sync.Mutex
+
+// Gets the sequence guard. If it doesn't exist, initialized and returns it.
+func ensureSequenceGuard(cc *CosmosProvider, key string) *WalletState {
+ seqGuardSingleton.Lock()
+ defer seqGuardSingleton.Unlock()
+
+ if cc.walletStateMap == nil {
+ cc.walletStateMap = map[string]*WalletState{}
+ }
+
+ sequenceGuard, ok := cc.walletStateMap[key]
+ if !ok {
+ cc.walletStateMap[key] = &WalletState{}
+ return cc.walletStateMap[key]
+ }
+
+ return sequenceGuard
+}
+
// SendMessages attempts to sign, encode, & send a slice of RelayerMessages
// This is used extensively in the relayer as an extension of the Provider interface
//
@@ -96,7 +123,7 @@ func (cc *CosmosProvider) SendMessages(ctx context.Context, msgs []provider.Rela
wg.Add(1)
if err := retry.Do(func() error {
- return cc.SendMessagesToMempool(ctx, msgs, memo, ctx, callback)
+ return cc.SendMessagesToMempool(ctx, msgs, memo, ctx, []func(*provider.RelayerTxResponse, error){callback})
}, retry.Context(ctx), rtyAtt, rtyDel, rtyErr, retry.OnRetry(func(n uint, err error) {
cc.log.Info(
"Error building or broadcasting transaction",
@@ -132,37 +159,183 @@ func (cc *CosmosProvider) SendMessagesToMempool(
memo string,
asyncCtx context.Context,
- asyncCallback func(*provider.RelayerTxResponse, error),
+ asyncCallbacks []func(*provider.RelayerTxResponse, error),
) error {
- // Guard against account sequence number mismatch errors by locking for the specific wallet for
- // the account sequence query all the way through the transaction broadcast success/fail.
- cc.txMu.Lock()
- defer cc.txMu.Unlock()
+ txSignerKey, feegranterKey, err := cc.buildSignerConfig(msgs)
+ if err != nil {
+ return err
+ }
+
+ sequenceGuard := ensureSequenceGuard(cc, txSignerKey)
+ sequenceGuard.Mu.Lock()
+ defer sequenceGuard.Mu.Unlock()
- txBytes, sequence, fees, err := cc.buildMessages(ctx, msgs, memo)
+ txBytes, sequence, fees, err := cc.buildMessages(ctx, msgs, memo, 0, txSignerKey, feegranterKey, sequenceGuard)
if err != nil {
// Account sequence mismatch errors can happen on the simulated transaction also.
if strings.Contains(err.Error(), sdkerrors.ErrWrongSequence.Error()) {
- cc.handleAccountSequenceMismatchError(err)
+ cc.handleAccountSequenceMismatchError(sequenceGuard, err)
}
return err
}
- if err := cc.broadcastTx(ctx, txBytes, msgs, fees, asyncCtx, defaultBroadcastWaitTimeout, asyncCallback); err != nil {
+ if err := cc.broadcastTx(ctx, txBytes, msgs, fees, asyncCtx, defaultBroadcastWaitTimeout, asyncCallbacks); err != nil {
if strings.Contains(err.Error(), sdkerrors.ErrWrongSequence.Error()) {
- cc.handleAccountSequenceMismatchError(err)
+ cc.handleAccountSequenceMismatchError(sequenceGuard, err)
}
return err
}
// we had a successful tx broadcast with this sequence, so update it to the next
- cc.updateNextAccountSequence(sequence + 1)
-
+ cc.updateNextAccountSequence(sequenceGuard, sequence+1)
return nil
}
+func (cc *CosmosProvider) SubmitTxAwaitResponse(ctx context.Context, msgs []sdk.Msg, memo string, gas uint64, signingKeyName string) (*txtypes.GetTxResponse, error) {
+ resp, err := cc.SendMsgsWith(ctx, msgs, memo, gas, signingKeyName, "")
+ if err != nil {
+ return nil, err
+ }
+ fmt.Printf("TX result code: %d. Waiting for TX with hash %s\n", resp.Code, resp.Hash)
+ tx1resp, err := cc.AwaitTx(resp.Hash, 15*time.Second)
+ if err != nil {
+ return nil, err
+ }
+
+ return tx1resp, err
+}
+
+// Get the TX by hash, waiting for it to be included in a block
+func (cc *CosmosProvider) AwaitTx(txHash bytes.HexBytes, timeout time.Duration) (*txtypes.GetTxResponse, error) {
+ var txByHash *txtypes.GetTxResponse
+ var txLookupErr error
+ startTime := time.Now()
+ timeBetweenQueries := 100
+
+ txClient := txtypes.NewServiceClient(cc)
+
+ for txByHash == nil {
+ ctx, cancel := context.WithTimeout(context.Background(), timeout)
+ if time.Since(startTime) > timeout {
+ cancel()
+ return nil, txLookupErr
+ }
+
+ txByHash, txLookupErr = txClient.GetTx(ctx, &txtypes.GetTxRequest{Hash: txHash.String()})
+ if txLookupErr != nil {
+ time.Sleep(time.Duration(timeBetweenQueries) * time.Millisecond)
+ }
+ cancel()
+ }
+
+ return txByHash, nil
+}
+
+// SendMsgs wraps the msgs in a StdTx, signs and sends it. An error is returned if there
+// was an issue sending the transaction. A successfully sent, but failed transaction will
+// not return an error. If a transaction is successfully sent, the result of the execution
+// of that transaction will be logged. A boolean indicating if a transaction was successfully
+// sent and executed successfully is returned.
+//
+// feegranterKey - key name of the address set as the feegranter, empty string will not feegrant
+func (cc *CosmosProvider) SendMsgsWith(ctx context.Context, msgs []sdk.Msg, memo string, gas uint64, signingKey string, feegranterKey string) (*coretypes.ResultBroadcastTx, error) {
+ sdkConfigMutex.Lock()
+ sdkConf := sdk.GetConfig()
+ sdkConf.SetBech32PrefixForAccount(cc.PCfg.AccountPrefix, cc.PCfg.AccountPrefix+"pub")
+ sdkConf.SetBech32PrefixForValidator(cc.PCfg.AccountPrefix+"valoper", cc.PCfg.AccountPrefix+"valoperpub")
+ sdkConf.SetBech32PrefixForConsensusNode(cc.PCfg.AccountPrefix+"valcons", cc.PCfg.AccountPrefix+"valconspub")
+ defer sdkConfigMutex.Unlock()
+
+ rand.Seed(time.Now().UnixNano())
+ feegrantKeyAcc, _ := cc.GetKeyAddressForKey(feegranterKey)
+
+ txf, err := cc.PrepareFactory(cc.TxFactory(), signingKey)
+ if err != nil {
+ return nil, err
+ }
+
+ adjusted := gas
+
+ if gas == 0 {
+ // TODO: Make this work with new CalculateGas method
+ // TODO: This is related to GRPC client stuff?
+ // https://github.com/cosmos/cosmos-sdk/blob/5725659684fc93790a63981c653feee33ecf3225/client/tx/tx.go#L297
+ _, adjusted, err = cc.CalculateGas(ctx, txf, signingKey, msgs...)
+
+ if err != nil {
+ return nil, err
+ }
+
+ adjusted = uint64(float64(adjusted) * cc.PCfg.GasAdjustment)
+ }
+
+ //Cannot feegrant your own TX
+ if signingKey != feegranterKey && feegranterKey != "" {
+ //Must be set in Factory to affect gas calculation (sim tx) as well as real tx
+ txf = txf.WithFeeGranter(feegrantKeyAcc)
+ }
+
+ if memo != "" {
+ txf = txf.WithMemo(memo)
+ }
+
+ // Set the gas amount on the transaction factory
+ txf = txf.WithGas(adjusted)
+
+ // Build the transaction builder
+ txb, err := txf.BuildUnsignedTx(msgs...)
+ if err != nil {
+ return nil, err
+ }
+
+ // Attach the signature to the transaction
+ // c.LogFailedTx(nil, err, msgs)
+ // Force encoding in the chain specific address
+ for _, msg := range msgs {
+ cc.Cdc.Marshaler.MustMarshalJSON(msg)
+ }
+
+ err = func() error {
+ //done := cc.SetSDKContext()
+ // ensure that we allways call done, even in case of an error or panic
+ //defer done()
+
+ if err = tx.Sign(txf, signingKey, txb, false); err != nil {
+ return err
+ }
+ return nil
+ }()
+
+ if err != nil {
+ return nil, err
+ }
+
+ // Generate the transaction bytes
+ txBytes, err := cc.Cdc.TxConfig.TxEncoder()(txb.GetTx())
+ if err != nil {
+ return nil, err
+ }
+
+ res, err := cc.RPCClient.BroadcastTxAsync(ctx, txBytes)
+ if res != nil {
+ fmt.Printf("TX hash: %s\n", res.Hash)
+ }
+ if err != nil {
+ return nil, err
+ }
+
+ // transaction was executed, log the success or failure using the tx response code
+ // NOTE: error is nil, logic should use the returned error to determine if the
+ // transaction was successfully executed.
+ if res.Code != 0 {
+ return res, fmt.Errorf("transaction failed with code: %d", res.Code)
+ }
+
+ return res, nil
+}
+
// sdkError will return the Cosmos SDK registered error for a given codespace/code combo if registered, otherwise nil.
func (cc *CosmosProvider) sdkError(codespace string, code uint32) error {
// ABCIError will return an error other than "unknown" if syncRes.Code is a registered error in syncRes.Codespace
@@ -185,7 +358,7 @@ func (cc *CosmosProvider) broadcastTx(
asyncCtx context.Context, // context for async wait for block inclusion after successful tx broadcast
asyncTimeout time.Duration, // timeout for waiting for block inclusion
- asyncCallback func(*provider.RelayerTxResponse, error), // callback for success/fail of the wait for block inclusion
+ asyncCallbacks []func(*provider.RelayerTxResponse, error), // callback for success/fail of the wait for block inclusion
) error {
res, err := cc.RPCClient.BroadcastTxSync(ctx, tx)
isErr := err != nil
@@ -211,13 +384,19 @@ func (cc *CosmosProvider) broadcastTx(
cc.LogFailedTx(rlyResp, err, msgs)
return err
}
-
- cc.UpdateFeesSpent(cc.ChainId(), cc.Key(), fees)
+ address, err := cc.Address()
+ if err != nil {
+ cc.log.Error(
+ "failed to get relayer bech32 wallet addresss",
+ zap.Error(err),
+ )
+ }
+ cc.UpdateFeesSpent(cc.ChainId(), cc.Key(), address, fees)
// TODO: maybe we need to check if the node has tx indexing enabled?
// if not, we need to find a new way to block until inclusion in a block
- go cc.waitForTx(asyncCtx, res.Hash, msgs, asyncTimeout, asyncCallback)
+ go cc.waitForTx(asyncCtx, res.Hash, msgs, asyncTimeout, asyncCallbacks)
return nil
}
@@ -229,13 +408,16 @@ func (cc *CosmosProvider) waitForTx(
txHash []byte,
msgs []provider.RelayerMessage, // used for logging only
waitTimeout time.Duration,
- callback func(*provider.RelayerTxResponse, error),
+ callbacks []func(*provider.RelayerTxResponse, error),
) {
res, err := cc.waitForBlockInclusion(ctx, txHash, waitTimeout)
if err != nil {
cc.log.Error("Failed to wait for block inclusion", zap.Error(err))
- if callback != nil {
- callback(nil, err)
+ if len(callbacks) > 0 {
+ for _, cb := range callbacks {
+ //Call each callback in order since waitForTx is already invoked asyncronously
+ cb(nil, err)
+ }
}
return
}
@@ -259,15 +441,21 @@ func (cc *CosmosProvider) waitForTx(
if err == nil {
err = fmt.Errorf("transaction failed to execute")
}
- if callback != nil {
- callback(nil, err)
+ if len(callbacks) > 0 {
+ for _, cb := range callbacks {
+ //Call each callback in order since waitForTx is already invoked asyncronously
+ cb(nil, err)
+ }
}
cc.LogFailedTx(rlyResp, nil, msgs)
return
}
- if callback != nil {
- callback(rlyResp, nil)
+ if len(callbacks) > 0 {
+ for _, cb := range callbacks {
+ //Call each callback in order since waitForTx is already invoked asyncronously
+ cb(rlyResp, nil)
+ }
}
cc.LogSuccessTx(res, msgs)
}
@@ -331,12 +519,95 @@ func parseEventsFromTxResponse(resp *sdk.TxResponse) []provider.RelayerEvent {
})
}
}
+
+ // After SDK v0.50, indexed events are no longer provided in the logs on
+ // transaction execution, the response events can be directly used
+ if len(events) == 0 {
+ for _, event := range resp.Events {
+ attributes := make(map[string]string)
+ for _, attribute := range event.Attributes {
+ attributes[attribute.Key] = attribute.Value
+ }
+ events = append(events, provider.RelayerEvent{
+ EventType: event.Type,
+ Attributes: attributes,
+ })
+ }
+ }
+
return events
}
-func (cc *CosmosProvider) buildMessages(ctx context.Context, msgs []provider.RelayerMessage, memo string) ([]byte, uint64, sdk.Coins, error) {
- // Query account details
- txf, err := cc.PrepareFactory(cc.TxFactory())
+func (cc *CosmosProvider) buildSignerConfig(msgs []provider.RelayerMessage) (
+ txSignerKey string,
+ feegranterKey string,
+ err error,
+) {
+ //Guard against race conditions when choosing a signer/feegranter
+ cc.feegrantMu.Lock()
+ defer cc.feegrantMu.Unlock()
+
+ //Some messages have feegranting disabled. If any message in the TX disables feegrants, then the TX will not be feegranted.
+ isFeegrantEligible := cc.PCfg.FeeGrants != nil
+
+ for _, curr := range msgs {
+ if cMsg, ok := curr.(CosmosMessage); ok {
+ if cMsg.FeegrantDisabled {
+ isFeegrantEligible = false
+ }
+ }
+ }
+
+ //By default, we should sign TXs with the provider's default key
+ txSignerKey = cc.PCfg.Key
+
+ if isFeegrantEligible {
+ txSignerKey, feegranterKey = cc.GetTxFeeGrant()
+ signerAcc, addrErr := cc.GetKeyAddressForKey(txSignerKey)
+ if addrErr != nil {
+ err = addrErr
+ return
+ }
+
+ signerAccAddr, encodeErr := cc.EncodeBech32AccAddr(signerAcc)
+ if encodeErr != nil {
+ err = encodeErr
+ return
+ }
+
+ //Overwrite the 'Signer' field in any Msgs that provide an 'optionalSetSigner' callback
+ for _, curr := range msgs {
+ if cMsg, ok := curr.(CosmosMessage); ok {
+ if cMsg.SetSigner != nil {
+ cMsg.SetSigner(signerAccAddr)
+ }
+ }
+ }
+ }
+
+ return
+}
+
+func (cc *CosmosProvider) buildMessages(
+ ctx context.Context,
+ msgs []provider.RelayerMessage,
+ memo string,
+ gas uint64,
+ txSignerKey string,
+ feegranterKey string,
+ sequenceGuard *WalletState,
+) (
+ txBytes []byte,
+ sequence uint64,
+ fees sdk.Coins,
+ err error,
+) {
+ done := cc.SetSDKContext()
+ defer done()
+
+ cMsgs := CosmosMsgs(msgs...)
+
+ txf, err := cc.PrepareFactory(cc.TxFactory(), txSignerKey)
if err != nil {
return nil, 0, sdk.Coins{}, err
}
@@ -345,82 +616,75 @@ func (cc *CosmosProvider) buildMessages(ctx context.Context, msgs []provider.Rel
txf = txf.WithMemo(memo)
}
- sequence := txf.Sequence()
- cc.updateNextAccountSequence(sequence)
- if sequence < cc.nextAccountSeq {
- sequence = cc.nextAccountSeq
+ sequence = txf.Sequence()
+ cc.updateNextAccountSequence(sequenceGuard, sequence)
+ if sequence < sequenceGuard.NextAccountSequence {
+ sequence = sequenceGuard.NextAccountSequence
txf = txf.WithSequence(sequence)
}
- // TODO: Make this work with new CalculateGas method
- // TODO: This is related to GRPC client stuff?
- // https://github.com/cosmos/cosmos-sdk/blob/5725659684fc93790a63981c653feee33ecf3225/client/tx/tx.go#L297
- // If users pass gas adjustment, then calculate gas
- _, adjusted, err := cc.CalculateGas(ctx, txf, CosmosMsgs(msgs...)...)
- if err != nil {
- return nil, 0, sdk.Coins{}, err
- }
+ adjusted := gas
- // Set the gas amount on the transaction factory
- txf = txf.WithGas(adjusted)
+ if gas == 0 {
+ _, adjusted, err = cc.CalculateGas(ctx, txf, txSignerKey, cMsgs...)
- var txb client.TxBuilder
- // Build the transaction builder & retry on failures
- if err := retry.Do(func() error {
- txb, err = txf.BuildUnsignedTx(CosmosMsgs(msgs...)...)
if err != nil {
- return err
+ return nil, 0, sdk.Coins{}, err
}
- return nil
- }, retry.Context(ctx), rtyAtt, rtyDel, rtyErr); err != nil {
- return nil, 0, sdk.Coins{}, err
}
- done := cc.SetSDKContext()
-
- if err := retry.Do(func() error {
- if err := tx.Sign(txf, cc.PCfg.Key, txb, false); err != nil {
- return err
+ //Cannot feegrant your own TX
+ if txSignerKey != feegranterKey && feegranterKey != "" {
+ granterAddr, err := cc.GetKeyAddressForKey(feegranterKey)
+ if err != nil {
+ return nil, 0, sdk.Coins{}, err
}
- return nil
- }, retry.Context(ctx), rtyAtt, rtyDel, rtyErr); err != nil {
+
+ txf = txf.WithFeeGranter(granterAddr)
+ }
+
+ // Set the gas amount on the transaction factory
+ txf = txf.WithGas(adjusted)
+
+ // Build the transaction builder
+ txb, err := txf.BuildUnsignedTx(cMsgs...)
+ if err != nil {
return nil, 0, sdk.Coins{}, err
}
- done()
+ if err = tx.Sign(txf, txSignerKey, txb, false); err != nil {
+ return nil, 0, sdk.Coins{}, err
+ }
tx := txb.GetTx()
- fees := tx.GetFee()
+ fees = tx.GetFee()
- var txBytes []byte
// Generate the transaction bytes
- if err := retry.Do(func() error {
- var err error
- txBytes, err = cc.Cdc.TxConfig.TxEncoder()(tx)
- if err != nil {
- return err
- }
- return nil
- }, retry.Context(ctx), rtyAtt, rtyDel, rtyErr); err != nil {
+ txBytes, err = cc.Cdc.TxConfig.TxEncoder()(tx)
+ if err != nil {
return nil, 0, sdk.Coins{}, err
}
- return txBytes, sequence, fees, nil
+ return txBytes, txf.Sequence(), fees, nil
}
// handleAccountSequenceMismatchError will parse the error string, e.g.:
// "account sequence mismatch, expected 10, got 9: incorrect account sequence"
// and update the next account sequence with the expected value.
-func (cc *CosmosProvider) handleAccountSequenceMismatchError(err error) {
- sequences := numRegex.FindAllString(err.Error(), -1)
- if len(sequences) != 2 {
+func (cc *CosmosProvider) handleAccountSequenceMismatchError(sequenceGuard *WalletState, err error) {
+ if sequenceGuard == nil {
+ panic("sequence guard not configured")
+ }
+
+ matches := accountSeqRegex.FindStringSubmatch(err.Error())
+ if len(matches) == 0 {
return
}
- nextSeq, err := strconv.ParseUint(sequences[0], 10, 64)
+ nextSeq, err := strconv.ParseUint(matches[1], 10, 64)
if err != nil {
return
}
- cc.nextAccountSeq = nextSeq
+ sequenceGuard.NextAccountSequence = nextSeq
}
// MsgCreateClient creates an sdk.Msg to update the client on src with consensus state from dst
@@ -449,7 +713,9 @@ func (cc *CosmosProvider) MsgCreateClient(
Signer: signer,
}
- return NewCosmosMessage(msg), nil
+ return NewCosmosMessage(msg, func(signer string) {
+ msg.Signer = signer
+ }), nil
}
func (cc *CosmosProvider) MsgUpdateClient(srcClientID string, dstHeader ibcexported.ClientMessage) (provider.RelayerMessage, error) {
@@ -467,7 +733,9 @@ func (cc *CosmosProvider) MsgUpdateClient(srcClientID string, dstHeader ibcexpor
ClientMessage: clientMsg,
Signer: acc,
}
- return NewCosmosMessage(msg), nil
+ return NewCosmosMessage(msg, func(signer string) {
+ msg.Signer = signer
+ }), nil
}
func (cc *CosmosProvider) MsgUpgradeClient(srcClientId string, consRes *clienttypes.QueryConsensusStateResponse, clientRes *clienttypes.QueryClientStateResponse) (provider.RelayerMessage, error) {
@@ -478,9 +746,14 @@ func (cc *CosmosProvider) MsgUpgradeClient(srcClientId string, consRes *clientty
if acc, err = cc.Address(); err != nil {
return nil, err
}
- return NewCosmosMessage(&clienttypes.MsgUpgradeClient{ClientId: srcClientId, ClientState: clientRes.ClientState,
+
+ msgUpgradeClient := &clienttypes.MsgUpgradeClient{ClientId: srcClientId, ClientState: clientRes.ClientState,
ConsensusState: consRes.ConsensusState, ProofUpgradeClient: consRes.GetProof(),
- ProofUpgradeConsensusState: consRes.ConsensusState.Value, Signer: acc}), nil
+ ProofUpgradeConsensusState: consRes.ConsensusState.Value, Signer: acc}
+
+ return NewCosmosMessage(msgUpgradeClient, func(signer string) {
+ msgUpgradeClient.Signer = signer
+ }), nil
}
// MsgTransfer creates a new transfer message
@@ -507,7 +780,9 @@ func (cc *CosmosProvider) MsgTransfer(
msg.TimeoutHeight = info.TimeoutHeight
}
- return NewCosmosMessage(msg), nil
+ msgTransfer := NewCosmosMessage(msg, nil).(CosmosMessage)
+ msgTransfer.FeegrantDisabled = true
+ return msgTransfer, nil
}
func (cc *CosmosProvider) ValidatePacket(msgTransfer provider.PacketInfo, latest provider.LatestBlock) error {
@@ -573,7 +848,9 @@ func (cc *CosmosProvider) MsgRecvPacket(
Signer: signer,
}
- return NewCosmosMessage(msg), nil
+ return NewCosmosMessage(msg, func(signer string) {
+ msg.Signer = signer
+ }), nil
}
func (cc *CosmosProvider) PacketAcknowledgement(
@@ -611,7 +888,9 @@ func (cc *CosmosProvider) MsgAcknowledgement(
Signer: signer,
}
- return NewCosmosMessage(msg), nil
+ return NewCosmosMessage(msg, func(signer string) {
+ msg.Signer = signer
+ }), nil
}
func (cc *CosmosProvider) PacketReceipt(
@@ -664,7 +943,13 @@ func (cc *CosmosProvider) MsgTimeout(msgTransfer provider.PacketInfo, proof prov
Signer: signer,
}
- return NewCosmosMessage(assembled), nil
+ return NewCosmosMessage(assembled, func(signer string) {
+ assembled.Signer = signer
+ }), nil
+}
+
+func (cc *CosmosProvider) MsgTimeoutRequest(msgTransfer provider.PacketInfo, proof provider.PacketProof) (provider.RelayerMessage, error) {
+ return nil, fmt.Errorf("not implemented in cosmos module ")
}
func (cc *CosmosProvider) MsgTimeoutOnClose(msgTransfer provider.PacketInfo, proof provider.PacketProof) (provider.RelayerMessage, error) {
@@ -680,7 +965,9 @@ func (cc *CosmosProvider) MsgTimeoutOnClose(msgTransfer provider.PacketInfo, pro
Signer: signer,
}
- return NewCosmosMessage(assembled), nil
+ return NewCosmosMessage(assembled, func(signer string) {
+ assembled.Signer = signer
+ }), nil
}
func (cc *CosmosProvider) MsgConnectionOpenInit(info provider.ConnectionInfo, proof provider.ConnectionProof) (provider.RelayerMessage, error) {
@@ -700,7 +987,9 @@ func (cc *CosmosProvider) MsgConnectionOpenInit(info provider.ConnectionInfo, pr
Signer: signer,
}
- return NewCosmosMessage(msg), nil
+ return NewCosmosMessage(msg, func(signer string) {
+ msg.Signer = signer
+ }), nil
}
func (cc *CosmosProvider) ConnectionHandshakeProof(
@@ -762,7 +1051,9 @@ func (cc *CosmosProvider) MsgConnectionOpenTry(msgOpenInit provider.ConnectionIn
Signer: signer,
}
- return NewCosmosMessage(msg), nil
+ return NewCosmosMessage(msg, func(signer string) {
+ msg.Signer = signer
+ }), nil
}
func (cc *CosmosProvider) MsgConnectionOpenAck(msgOpenTry provider.ConnectionInfo, proof provider.ConnectionProof) (provider.RelayerMessage, error) {
@@ -792,7 +1083,9 @@ func (cc *CosmosProvider) MsgConnectionOpenAck(msgOpenTry provider.ConnectionInf
Signer: signer,
}
- return NewCosmosMessage(msg), nil
+ return NewCosmosMessage(msg, func(signer string) {
+ msg.Signer = signer
+ }), nil
}
func (cc *CosmosProvider) ConnectionProof(
@@ -823,7 +1116,9 @@ func (cc *CosmosProvider) MsgConnectionOpenConfirm(msgOpenAck provider.Connectio
Signer: signer,
}
- return NewCosmosMessage(msg), nil
+ return NewCosmosMessage(msg, func(signer string) {
+ msg.Signer = signer
+ }), nil
}
func (cc *CosmosProvider) MsgChannelOpenInit(info provider.ChannelInfo, proof provider.ChannelProof) (provider.RelayerMessage, error) {
@@ -846,7 +1141,9 @@ func (cc *CosmosProvider) MsgChannelOpenInit(info provider.ChannelInfo, proof pr
Signer: signer,
}
- return NewCosmosMessage(msg), nil
+ return NewCosmosMessage(msg, func(signer string) {
+ msg.Signer = signer
+ }), nil
}
func (cc *CosmosProvider) ChannelProof(
@@ -893,7 +1190,9 @@ func (cc *CosmosProvider) MsgChannelOpenTry(msgOpenInit provider.ChannelInfo, pr
Signer: signer,
}
- return NewCosmosMessage(msg), nil
+ return NewCosmosMessage(msg, func(signer string) {
+ msg.Signer = signer
+ }), nil
}
func (cc *CosmosProvider) MsgChannelOpenAck(msgOpenTry provider.ChannelInfo, proof provider.ChannelProof) (provider.RelayerMessage, error) {
@@ -911,7 +1210,9 @@ func (cc *CosmosProvider) MsgChannelOpenAck(msgOpenTry provider.ChannelInfo, pro
Signer: signer,
}
- return NewCosmosMessage(msg), nil
+ return NewCosmosMessage(msg, func(signer string) {
+ msg.Signer = signer
+ }), nil
}
func (cc *CosmosProvider) MsgChannelOpenConfirm(msgOpenAck provider.ChannelInfo, proof provider.ChannelProof) (provider.RelayerMessage, error) {
@@ -927,7 +1228,9 @@ func (cc *CosmosProvider) MsgChannelOpenConfirm(msgOpenAck provider.ChannelInfo,
Signer: signer,
}
- return NewCosmosMessage(msg), nil
+ return NewCosmosMessage(msg, func(signer string) {
+ msg.Signer = signer
+ }), nil
}
func (cc *CosmosProvider) MsgChannelCloseInit(info provider.ChannelInfo, proof provider.ChannelProof) (provider.RelayerMessage, error) {
@@ -941,7 +1244,9 @@ func (cc *CosmosProvider) MsgChannelCloseInit(info provider.ChannelInfo, proof p
Signer: signer,
}
- return NewCosmosMessage(msg), nil
+ return NewCosmosMessage(msg, func(signer string) {
+ msg.Signer = signer
+ }), nil
}
func (cc *CosmosProvider) MsgChannelCloseConfirm(msgCloseInit provider.ChannelInfo, proof provider.ChannelProof) (provider.RelayerMessage, error) {
@@ -957,7 +1262,9 @@ func (cc *CosmosProvider) MsgChannelCloseConfirm(msgCloseInit provider.ChannelIn
Signer: signer,
}
- return NewCosmosMessage(msg), nil
+ return NewCosmosMessage(msg, func(signer string) {
+ msg.Signer = signer
+ }), nil
}
func (cc *CosmosProvider) MsgUpdateClientHeader(latestHeader provider.IBCHeader, trustedHeight clienttypes.Height, trustedHeader provider.IBCHeader) (ibcexported.ClientMessage, error) {
@@ -1025,7 +1332,9 @@ func (cc *CosmosProvider) MsgSubmitQueryResponse(chainID string, queryID provide
FromAddress: signer,
}
- return NewCosmosMessage(msg), nil
+ submitQueryRespMsg := NewCosmosMessage(msg, nil).(CosmosMessage)
+ submitQueryRespMsg.FeegrantDisabled = true
+ return submitQueryRespMsg, nil
}
func (cc *CosmosProvider) MsgSubmitMisbehaviour(clientID string, misbehaviour ibcexported.ClientMessage) (provider.RelayerMessage, error) {
@@ -1039,7 +1348,9 @@ func (cc *CosmosProvider) MsgSubmitMisbehaviour(clientID string, misbehaviour ib
return nil, err
}
- return NewCosmosMessage(msg), nil
+ return NewCosmosMessage(msg, func(signer string) {
+ msg.Signer = signer
+ }), nil
}
// RelayPacketFromSequence relays a packet with a given seq on src and returns recvPacket msgs, timeoutPacketmsgs and error
@@ -1216,7 +1527,29 @@ func (cc *CosmosProvider) queryTMClientState(ctx context.Context, srch int64, sr
clientState, ok := clientStateExported.(*tmclient.ClientState)
if !ok {
return &tmclient.ClientState{},
- fmt.Errorf("error when casting exported clientstate to tendermint type")
+ fmt.Errorf("error when casting exported clientstate to tendermint type, got(%T)", clientStateExported)
+ }
+
+ return clientState, nil
+}
+
+// queryLocalhostClientState retrieves the latest consensus state for a client in state at a given height
+// and unpacks/cast it to localhost client state.
+func (cc *CosmosProvider) queryLocalhostClientState(ctx context.Context, srch int64) (*localhost.ClientState, error) {
+ clientStateRes, err := cc.QueryClientStateResponse(ctx, srch, ibcexported.LocalhostClientID)
+ if err != nil {
+ return &localhost.ClientState{}, err
+ }
+
+ clientStateExported, err := clienttypes.UnpackClientState(clientStateRes.ClientState)
+ if err != nil {
+ return &localhost.ClientState{}, err
+ }
+
+ clientState, ok := clientStateExported.(*localhost.ClientState)
+ if !ok {
+ return &localhost.ClientState{},
+ fmt.Errorf("error when casting exported clientstate to localhost client type, got(%T)", clientStateExported)
}
return clientState, nil
@@ -1255,7 +1588,7 @@ func (cc *CosmosProvider) NewClientState(
}, nil
}
-func (cc *CosmosProvider) UpdateFeesSpent(chain, key string, fees sdk.Coins) {
+func (cc *CosmosProvider) UpdateFeesSpent(chain, key, address string, fees sdk.Coins) {
// Don't set the metrics in testing
if cc.metrics == nil {
return
@@ -1268,12 +1601,18 @@ func (cc *CosmosProvider) UpdateFeesSpent(chain, key string, fees sdk.Coins) {
for _, fee := range cc.TotalFees {
// Convert to a big float to get a float64 for metrics
f, _ := big.NewFloat(0.0).SetInt(fee.Amount.BigInt()).Float64()
- cc.metrics.SetFeesSpent(chain, key, fee.GetDenom(), f)
+ cc.metrics.SetFeesSpent(chain, cc.PCfg.GasPrices, key, address, fee.GetDenom(), f)
}
}
+// MsgRegisterCounterpartyPayee creates an sdk.Msg to broadcast the counterparty address
+func (cc *CosmosProvider) MsgRegisterCounterpartyPayee(portID, channelID, relayerAddr, counterpartyPayee string) (provider.RelayerMessage, error) {
+ msg := feetypes.NewMsgRegisterCounterpartyPayee(portID, channelID, relayerAddr, counterpartyPayee)
+ return NewCosmosMessage(msg, nil), nil
+}
+
// PrepareFactory mutates the tx factory with the appropriate account number, sequence number, and min gas settings.
-func (cc *CosmosProvider) PrepareFactory(txf tx.Factory) (tx.Factory, error) {
+func (cc *CosmosProvider) PrepareFactory(txf tx.Factory, signingKey string) (tx.Factory, error) {
var (
err error
from sdk.AccAddress
@@ -1282,7 +1621,7 @@ func (cc *CosmosProvider) PrepareFactory(txf tx.Factory) (tx.Factory, error) {
// Get key address and retry if fail
if err = retry.Do(func() error {
- from, err = cc.GetKeyAddress()
+ from, err = cc.GetKeyAddressForKey(signingKey)
if err != nil {
return err
}
@@ -1294,7 +1633,8 @@ func (cc *CosmosProvider) PrepareFactory(txf tx.Factory) (tx.Factory, error) {
cliCtx := client.Context{}.WithClient(cc.RPCClient).
WithInterfaceRegistry(cc.Cdc.InterfaceRegistry).
WithChainID(cc.PCfg.ChainID).
- WithCodec(cc.Cdc.Marshaler)
+ WithCodec(cc.Cdc.Marshaler).
+ WithFromAddress(from)
// Set the account number and sequence on the transaction factory and retry if fail
if err = retry.Do(func() error {
@@ -1332,12 +1672,64 @@ func (cc *CosmosProvider) PrepareFactory(txf tx.Factory) (tx.Factory, error) {
txf = txf.WithGas(cc.PCfg.MinGasAmount)
}
+ txf, err = cc.SetWithExtensionOptions(txf)
+ if err != nil {
+ return tx.Factory{}, err
+ }
return txf, nil
}
+// AdjustEstimatedGas adjusts the estimated gas usage by multiplying it by the gas adjustment factor
+// and bounding the result by the maximum gas amount option. If the gas usage is zero, the adjusted gas
+// is also zero. If the gas adjustment factor produces an infinite result, an error is returned.
+// max-gas-amount is enforced.
+func (cc *CosmosProvider) AdjustEstimatedGas(gasUsed uint64) (uint64, error) {
+ if gasUsed == 0 {
+ return gasUsed, nil
+ }
+ gas := cc.PCfg.GasAdjustment * float64(gasUsed)
+ if math.IsInf(gas, 1) {
+ return 0, fmt.Errorf("infinite gas used")
+ }
+ // Bound the gas estimate by the max_gas option
+ if cc.PCfg.MaxGasAmount > 0 {
+ gas = math.Min(gas, float64(cc.PCfg.MaxGasAmount))
+ }
+ return uint64(gas), nil
+}
+
+// SetWithExtensionOptions sets the dynamic fee extension options on the given
+// transaction factory using the configuration options from the CosmosProvider.
+// The function creates an extension option for each configuration option and
+// serializes it into a byte slice before adding it to the list of extension
+// options. The function returns the updated transaction factory with the new
+// extension options or an error if the serialization fails or an invalid option
+// value is encountered.
+func (cc *CosmosProvider) SetWithExtensionOptions(txf tx.Factory) (tx.Factory, error) {
+ extOpts := make([]*types.Any, 0, len(cc.PCfg.ExtensionOptions))
+ for _, opt := range cc.PCfg.ExtensionOptions {
+ max, ok := sdk.NewIntFromString(opt.Value)
+ if !ok {
+ return txf, fmt.Errorf("invalid opt value")
+ }
+ extensionOption := ethermint.ExtensionOptionDynamicFeeTx{
+ MaxPriorityPrice: max,
+ }
+ extBytes, err := extensionOption.Marshal()
+ if err != nil {
+ return txf, err
+ }
+ extOpts = append(extOpts, &types.Any{
+ TypeUrl: "/ethermint.types.v1.ExtensionOptionDynamicFeeTx",
+ Value: extBytes,
+ })
+ }
+ return txf.WithExtensionOptions(extOpts...), nil
+}
+
// CalculateGas simulates a tx to generate the appropriate gas settings before broadcasting a tx.
-func (cc *CosmosProvider) CalculateGas(ctx context.Context, txf tx.Factory, msgs ...sdk.Msg) (txtypes.SimulateResponse, uint64, error) {
- keyInfo, err := cc.Keybase.Key(cc.PCfg.Key)
+func (cc *CosmosProvider) CalculateGas(ctx context.Context, txf tx.Factory, signingKey string, msgs ...sdk.Msg) (txtypes.SimulateResponse, uint64, error) {
+ keyInfo, err := cc.Keybase.Key(signingKey)
if err != nil {
return txtypes.SimulateResponse{}, 0, err
}
@@ -1375,8 +1767,8 @@ func (cc *CosmosProvider) CalculateGas(ctx context.Context, txf tx.Factory, msgs
if err := simRes.Unmarshal(res.Value); err != nil {
return txtypes.SimulateResponse{}, 0, err
}
-
- return simRes, uint64(txf.GasAdjustment() * float64(simRes.GasInfo.GasUsed)), nil
+ gas, err := cc.AdjustEstimatedGas(simRes.GasInfo.GasUsed)
+ return simRes, gas, err
}
// TxFactory instantiates a new tx factory with the appropriate configuration settings for this chain.
diff --git a/relayer/chains/cosmos/tx_test.go b/relayer/chains/cosmos/tx_test.go
index d02974fb2..25bb02dd2 100644
--- a/relayer/chains/cosmos/tx_test.go
+++ b/relayer/chains/cosmos/tx_test.go
@@ -2,8 +2,16 @@ package cosmos
import (
"fmt"
+ "math"
"testing"
+ "github.com/cosmos/cosmos-sdk/client"
+ "github.com/cosmos/cosmos-sdk/client/tx"
+ "github.com/cosmos/cosmos-sdk/codec/types"
+ sdk "github.com/cosmos/cosmos-sdk/types"
+ "github.com/cosmos/cosmos-sdk/x/auth/migrations/legacytx"
+ "github.com/cosmos/relayer/v2/relayer/ethermint"
+ "github.com/cosmos/relayer/v2/relayer/provider"
"github.com/stretchr/testify/require"
)
@@ -12,12 +20,130 @@ type mockAccountSequenceMismatchError struct {
Actual uint64
}
+// func TestHandleAccountSequenceMismatchError(t *testing.T) {
+// p := &CosmosProvider{}
+// ws := &WalletState{}
+// p.handleAccountSequenceMismatchError(ws, mockAccountSequenceMismatchError{Actual: 9, Expected: 10})
+// require.Equal(t, ws.NextAccountSequence, uint64(10))
+// }
+
+func TestCosmosProvider_AdjustEstimatedGas(t *testing.T) {
+ testCases := []struct {
+ name string
+ gasUsed uint64
+ gasAdjustment float64
+ maxGasAmount uint64
+ expectedGas uint64
+ expectedErr error
+ }{
+ {
+ name: "gas used is zero",
+ gasUsed: 0,
+ gasAdjustment: 1.0,
+ maxGasAmount: 0,
+ expectedGas: 0,
+ expectedErr: nil,
+ },
+ {
+ name: "gas used is non-zero",
+ gasUsed: 50000,
+ gasAdjustment: 1.5,
+ maxGasAmount: 100000,
+ expectedGas: 75000,
+ expectedErr: nil,
+ },
+ {
+ name: "gas used is infinite",
+ gasUsed: 10000,
+ gasAdjustment: math.Inf(1),
+ maxGasAmount: 0,
+ expectedGas: 0,
+ expectedErr: fmt.Errorf("infinite gas used"),
+ },
+ {
+ name: "gas used is non-zero with zero max gas amount as default",
+ gasUsed: 50000,
+ gasAdjustment: 1.5,
+ maxGasAmount: 0,
+ expectedGas: 75000,
+ expectedErr: nil,
+ },
+ }
+
+ for _, tc := range testCases {
+ tc := tc
+ t.Run(tc.name, func(t *testing.T) {
+ cc := &CosmosProvider{PCfg: CosmosProviderConfig{
+ GasAdjustment: tc.gasAdjustment,
+ MaxGasAmount: tc.maxGasAmount,
+ }}
+ adjustedGas, err := cc.AdjustEstimatedGas(tc.gasUsed)
+ if err != nil {
+ require.EqualError(t, err, tc.expectedErr.Error())
+ } else {
+ require.Equal(t, adjustedGas, tc.expectedGas)
+ }
+ })
+ }
+}
+
func (err mockAccountSequenceMismatchError) Error() string {
return fmt.Sprintf("account sequence mismatch, expected %d, got %d: incorrect account sequence", err.Expected, err.Actual)
}
-func TestHandleAccountSequenceMismatchError(t *testing.T) {
- p := &CosmosProvider{}
- p.handleAccountSequenceMismatchError(mockAccountSequenceMismatchError{Actual: 9, Expected: 10})
- require.Equal(t, p.nextAccountSeq, uint64(10))
+type mockTxConfig struct {
+ legacytx.StdTxConfig
+ txBuilder *mockTxBuilder
+}
+
+func (cfg mockTxConfig) NewTxBuilder() client.TxBuilder {
+ if cfg.txBuilder == nil {
+ cfg.txBuilder = &mockTxBuilder{
+ TxBuilder: cfg.StdTxConfig.NewTxBuilder(),
+ }
+ }
+ return cfg.txBuilder
+}
+
+type mockTxBuilder struct {
+ client.TxBuilder
+ extOptions []*types.Any
+}
+
+func (b *mockTxBuilder) SetExtensionOptions(extOpts ...*types.Any) {
+ b.extOptions = extOpts
+}
+
+func TestSetWithExtensionOptions(t *testing.T) {
+ cc := &CosmosProvider{PCfg: CosmosProviderConfig{
+ ExtensionOptions: []provider.ExtensionOption{
+ {Value: "1000000000"},
+ {Value: "2000000000"},
+ },
+ }}
+ txf := tx.Factory{}.
+ WithChainID("chainID").
+ WithTxConfig(mockTxConfig{})
+ updatedTxf, err := cc.SetWithExtensionOptions(txf)
+ require.NoError(t, err)
+ txb, err := updatedTxf.BuildUnsignedTx()
+ require.NoError(t, err)
+ extOptions := txb.(*mockTxBuilder).extOptions
+ actualNumExtOptions := len(extOptions)
+ expectedNumExtOptions := len(cc.PCfg.ExtensionOptions)
+ require.Equal(t, expectedNumExtOptions, actualNumExtOptions)
+ // Check that each extension option was added with the correct type URL and value
+ for i, opt := range cc.PCfg.ExtensionOptions {
+ expectedTypeURL := "/ethermint.types.v1.ExtensionOptionDynamicFeeTx"
+ max, ok := sdk.NewIntFromString(opt.Value)
+ require.True(t, ok)
+ expectedValue, err := (ðermint.ExtensionOptionDynamicFeeTx{
+ MaxPriorityPrice: max,
+ }).Marshal()
+ require.NoError(t, err)
+ actualTypeURL := extOptions[i].TypeUrl
+ actualValue := extOptions[i].Value
+ require.Equal(t, expectedTypeURL, actualTypeURL)
+ require.Equal(t, expectedValue, actualValue)
+ }
}
diff --git a/relayer/chains/icon/client.go b/relayer/chains/icon/client.go
new file mode 100644
index 000000000..034865743
--- /dev/null
+++ b/relayer/chains/icon/client.go
@@ -0,0 +1,640 @@
+package icon
+
+import (
+ "bytes"
+ "context"
+ "encoding/base64"
+ "encoding/json"
+ "fmt"
+ "io"
+ "log"
+ "math/big"
+ "net/http"
+ "reflect"
+ "strconv"
+ "strings"
+ "sync"
+ "time"
+
+ "github.com/cosmos/relayer/v2/relayer/chains/icon/types"
+ "go.uber.org/zap"
+
+ "github.com/gorilla/websocket"
+ "github.com/icon-project/goloop/client"
+ "github.com/icon-project/goloop/common"
+ "github.com/icon-project/goloop/common/codec"
+ "github.com/icon-project/goloop/common/crypto"
+ "github.com/icon-project/goloop/module"
+ "github.com/icon-project/goloop/server/jsonrpc"
+ "github.com/pkg/errors"
+)
+
+const (
+ DefaultSendTransactionRetryInterval = 3 * time.Second //3sec
+ DefaultGetTransactionResultPollingInterval = 500 * time.Millisecond //1.5sec
+)
+
+type Wallet interface {
+ Sign(data []byte) ([]byte, error)
+ Address() string
+}
+
+type IClient interface {
+ Call(p *types.CallParam, r interface{}) error
+ GetBalance(param *types.AddressParam) (*big.Int, error)
+ GetBlockByHeight(p *types.BlockHeightParam) (*types.Block, error)
+ GetBlockHeaderBytesByHeight(p *types.BlockHeightParam) ([]byte, error)
+ GetVotesByHeight(p *types.BlockHeightParam) ([]byte, error)
+ GetDataByHash(p *types.DataHashParam) ([]byte, error)
+ GetProofForResult(p *types.ProofResultParam) ([][]byte, error)
+ GetProofForEvents(p *types.ProofEventsParam) ([][][]byte, error)
+
+ GetBTPHeader(p *types.BTPBlockParam) (string, error)
+ GetBTPMessage(p *types.BTPBlockParam) ([]string, error)
+ GetBTPProof(p *types.BTPBlockParam) (string, error)
+ GetBTPNetworkInfo(p *types.BTPNetworkInfoParam) (*types.BTPNetworkInfo, error)
+
+ MonitorBlock(ctx context.Context, p *types.BlockRequest, cb func(conn *websocket.Conn, v *types.BlockNotification) error, scb func(conn *websocket.Conn), errCb func(*websocket.Conn, error)) error
+ MonitorBTP(ctx context.Context, p *types.BTPRequest, cb func(conn *websocket.Conn, v *types.BTPNotification) error, scb func(conn *websocket.Conn), errCb func(*websocket.Conn, error)) error
+ MonitorEvent(ctx context.Context, p *types.EventRequest, cb func(conn *websocket.Conn, v *types.EventNotification) error, errCb func(*websocket.Conn, error)) error
+ Monitor(ctx context.Context, reqUrl string, reqPtr, respPtr interface{}, cb types.WsReadCallback) error
+ CloseAllMonitor()
+ CloseMonitor(conn *websocket.Conn)
+
+ GetLastBlock() (*types.Block, error)
+ GetBlockHeaderByHeight(height int64) (*types.BlockHeader, error)
+ GetValidatorsByHash(hash common.HexHash) ([]common.Address, error)
+}
+
+type Client struct {
+ *client.JsonRpcClient
+ DebugEndPoint string
+ conns map[string]*websocket.Conn
+ log *zap.Logger
+ mtx sync.Mutex
+}
+
+var txSerializeExcludes = map[string]bool{"signature": true}
+
+func (c *Client) SignTransaction(w module.Wallet, p *types.TransactionParam) error {
+ p.Timestamp = types.NewHexInt(time.Now().UnixNano() / int64(time.Microsecond))
+ js, err := json.Marshal(p)
+ if err != nil {
+ return err
+ }
+
+ bs, err := SerializeJSON(js, nil, txSerializeExcludes)
+ if err != nil {
+ return err
+ }
+ bs = append([]byte("icx_sendTransaction."), bs...)
+ txHash := crypto.SHA3Sum256(bs)
+ p.TxHash = types.NewHexBytes(txHash)
+ sig, err := w.Sign(txHash)
+ if err != nil {
+ return err
+ }
+ p.Signature = base64.StdEncoding.EncodeToString(sig)
+ return nil
+}
+
+func (c *Client) SendTransaction(p *types.TransactionParam) (*types.HexBytes, error) {
+ var result types.HexBytes
+ if _, err := c.Do("icx_sendTransaction", p, &result); err != nil {
+ return nil, err
+ }
+ return &result, nil
+}
+
+func (c *Client) SendTransactionAndWait(p *types.TransactionParam) (*types.HexBytes, error) {
+ var result types.HexBytes
+ if _, err := c.Do("icx_sendTransactionAndWait", p, &result); err != nil {
+ return nil, err
+ }
+ return &result, nil
+}
+
+func (c *Client) GetTransactionResult(p *types.TransactionHashParam) (*types.TransactionResult, error) {
+ tr := &types.TransactionResult{}
+ if _, err := c.Do("icx_getTransactionResult", p, tr); err != nil {
+ return nil, err
+ }
+ return tr, nil
+}
+
+func (c *Client) WaitTransactionResult(p *types.TransactionHashParam) (*types.TransactionResult, error) {
+ tr := &types.TransactionResult{}
+ if _, err := c.Do("icx_waitTransactionResult", p, tr); err != nil {
+ return nil, err
+ }
+ return tr, nil
+}
+
+func (c *Client) Call(p *types.CallParam, r interface{}) error {
+ _, err := c.Do("icx_call", p, r)
+ return err
+}
+
+func (c *Client) WaitForResults(ctx context.Context, thp *types.TransactionHashParam) (txh *types.HexBytes, txr *types.TransactionResult, err error) {
+ ticker := time.NewTicker(time.Duration(DefaultGetTransactionResultPollingInterval) * time.Nanosecond)
+ retryLimit := 20
+ retryCounter := 0
+ txh = &thp.Hash
+ for {
+ defer ticker.Stop()
+ select {
+ case <-ctx.Done():
+ err = errors.New("Context Cancelled ReceiptWait Exiting ")
+ return
+ case <-ticker.C:
+ if retryCounter >= retryLimit {
+ err = errors.New("Retry Limit Exceeded while waiting for results of transaction")
+ return
+ }
+ retryCounter++
+ txr, err = c.GetTransactionResult(thp)
+ if err != nil {
+ switch re := err.(type) {
+ case *jsonrpc.Error:
+ switch re.Code {
+ case types.JsonrpcErrorCodePending, types.JsonrpcErrorCodeNotFound, types.JsonrpcErrorCodeExecuting:
+ continue
+ }
+ }
+ }
+ return
+ }
+ }
+}
+
+func (c *Client) GetLastBlock() (*types.Block, error) {
+ result := &types.Block{}
+ if _, err := c.Do("icx_getLastBlock", struct{}{}, &result); err != nil {
+ return nil, err
+ }
+ return result, nil
+}
+
+func (c *Client) GetBlockByHeight(p *types.BlockHeightParam) (*types.Block, error) {
+ result := &types.Block{}
+ if _, err := c.Do("icx_getBlockByHeight", p, &result); err != nil {
+ return nil, err
+ }
+ return result, nil
+}
+
+func (c *Client) GetBlockHeaderBytesByHeight(p *types.BlockHeightParam) ([]byte, error) {
+ var result []byte
+ if _, err := c.Do("icx_getBlockHeaderByHeight", p, &result); err != nil {
+ return nil, err
+ }
+ return result, nil
+}
+
+func (c *Client) GetVotesByHeight(p *types.BlockHeightParam) ([]byte, error) {
+ var result []byte
+ if _, err := c.Do("icx_getVotesByHeight", p, &result); err != nil {
+ return nil, err
+ }
+ return result, nil
+}
+
+func (c *Client) GetDataByHash(p *types.DataHashParam) ([]byte, error) {
+ var result []byte
+ _, err := c.Do("icx_getDataByHash", p, &result)
+ if err != nil {
+ return nil, err
+ }
+ return result, nil
+}
+
+func (c *Client) GetProofForResult(p *types.ProofResultParam) ([][]byte, error) {
+ var result [][]byte
+ if _, err := c.Do("icx_getProofForResult", p, &result); err != nil {
+ return nil, err
+ }
+ return result, nil
+}
+
+func (c *Client) GetProofForEvents(p *types.ProofEventsParam) ([][][]byte, error) {
+ var result [][][]byte
+ if _, err := c.Do("icx_getProofForEvents", p, &result); err != nil {
+ return nil, err
+ }
+ return result, nil
+}
+
+func (c *Client) GetBTPHeader(p *types.BTPBlockParam) (string, error) {
+ var header string
+ if _, err := c.Do("btp_getHeader", p, &header); err != nil {
+ return "", err
+ }
+ return header, nil
+}
+
+func (c *Client) GetBTPMessage(p *types.BTPBlockParam) ([]string, error) {
+ var result []string
+ if _, err := c.Do("btp_getMessages", p, &result); err != nil {
+ return nil, err
+ }
+ return result, nil
+}
+
+func (c *Client) GetBTPProof(p *types.BTPBlockParam) (string, error) {
+ var result string
+ if _, err := c.Do("btp_getProof", p, &result); err != nil {
+ return "", err
+ }
+ return result, nil
+}
+
+func (c *Client) GetBTPNetworkInfo(p *types.BTPNetworkInfoParam) (*types.BTPNetworkInfo, error) {
+ result := &types.BTPNetworkInfo{}
+ if _, err := c.Do("btp_getNetworkInfo", p, &result); err != nil {
+ return nil, err
+ }
+ return result, nil
+}
+func (c *Client) GetNetworkTypeInfo(height int64, networkId int64) (*types.BTPNetworkTypeInfo, error) {
+ nti := &types.BTPNetworkTypeInfo{}
+ param := &types.BTPQueryParam{
+ Height: types.NewHexInt(height),
+ Id: types.NewHexInt(networkId),
+ }
+ if _, err := c.Do("btp_getNetworkTypeInfo", param, nti); err != nil {
+ return nil, err
+ }
+ return nti, nil
+}
+
+func (c *Client) MonitorBlock(ctx context.Context, p *types.BlockRequest, cb func(conn *websocket.Conn, v *types.BlockNotification) error, scb func(conn *websocket.Conn), errCb func(*websocket.Conn, error)) error {
+ resp := &types.BlockNotification{}
+ return c.Monitor(ctx, "/block", p, resp, func(conn *websocket.Conn, v interface{}) error {
+ switch t := v.(type) {
+ case *types.BlockNotification:
+ if err := cb(conn, t); err != nil {
+ // c.log.Debugf("MonitorBlock callback return err:%+v", err)
+ return err
+ }
+ case types.WSEvent:
+ switch t {
+ case types.WSEventInit:
+ if scb != nil {
+ scb(conn)
+ } else {
+ return errors.New("Second Callback function (scb) is nil ")
+ }
+ }
+ case error:
+ errCb(conn, t)
+ return t
+ default:
+ errCb(conn, fmt.Errorf("not supported type %T", t))
+ return errors.New("Not supported type")
+ }
+ return nil
+ })
+}
+
+func (c *Client) MonitorEvent(ctx context.Context, p *types.EventRequest, cb func(conn *websocket.Conn, v *types.EventNotification) error, errCb func(*websocket.Conn, error)) error {
+ resp := &types.EventNotification{}
+ return c.Monitor(ctx, "/event", p, resp, func(conn *websocket.Conn, v interface{}) error {
+ switch t := v.(type) {
+ case *types.EventNotification:
+ if err := cb(conn, t); err != nil {
+ c.log.Debug(fmt.Sprintf("MonitorEvent callback return err:%+v", err))
+ }
+ case error:
+ errCb(conn, t)
+ default:
+ errCb(conn, fmt.Errorf("not supported type %T", t))
+ }
+ return nil
+ })
+}
+
+func (c *Client) Monitor(ctx context.Context, reqUrl string, reqPtr, respPtr interface{}, cb types.WsReadCallback) error {
+ if cb == nil {
+ return fmt.Errorf("callback function cannot be nil")
+ }
+ conn, err := c.wsConnect(reqUrl, nil)
+ if err != nil {
+ return err
+ }
+ defer func() {
+ c.log.Debug(fmt.Sprintf("Monitor finish %s", conn.LocalAddr().String()))
+ c.wsClose(conn)
+ }()
+ if err = c.wsRequest(conn, reqPtr); err != nil {
+ return err
+ }
+ if err := cb(conn, types.WSEventInit); err != nil {
+ return err
+ }
+ return c.wsReadJSONLoop(ctx, conn, respPtr, cb)
+}
+
+func (c *Client) CloseMonitor(conn *websocket.Conn) {
+ c.log.Debug(fmt.Sprintf("CloseMonitor %s", conn.LocalAddr().String()))
+ c.wsClose(conn)
+}
+
+func (c *Client) CloseAllMonitor() {
+ for _, conn := range c.conns {
+ c.log.Debug(fmt.Sprintf("CloseAllMonitor %s", conn.LocalAddr().String()))
+ c.wsClose(conn)
+ }
+}
+
+func (c *Client) _addWsConn(conn *websocket.Conn) {
+ c.mtx.Lock()
+ defer c.mtx.Unlock()
+
+ la := conn.LocalAddr().String()
+ c.conns[la] = conn
+}
+
+func (c *Client) _removeWsConn(conn *websocket.Conn) {
+ c.mtx.Lock()
+ defer c.mtx.Unlock()
+
+ la := conn.LocalAddr().String()
+ _, ok := c.conns[la]
+ if ok {
+ delete(c.conns, la)
+ }
+}
+
+type wsConnectError struct {
+ error
+ httpResp *http.Response
+}
+
+func (c *Client) wsConnect(reqUrl string, reqHeader http.Header) (*websocket.Conn, error) {
+ wsEndpoint := strings.Replace(c.Endpoint, "http", "ws", 1)
+ conn, httpResp, err := websocket.DefaultDialer.Dial(wsEndpoint+reqUrl, reqHeader)
+ if err != nil {
+ wsErr := wsConnectError{error: err}
+ wsErr.httpResp = httpResp
+ return nil, wsErr
+ }
+ c._addWsConn(conn)
+ return conn, nil
+}
+
+type wsRequestError struct {
+ error
+ wsResp *types.WSResponse
+}
+
+func (c *Client) wsRequest(conn *websocket.Conn, reqPtr interface{}) error {
+ if reqPtr == nil {
+ log.Panicf("reqPtr cannot be nil")
+ }
+ var err error
+ wsResp := &types.WSResponse{}
+ if err = conn.WriteJSON(reqPtr); err != nil {
+ return wsRequestError{fmt.Errorf("fail to WriteJSON err:%+v", err), nil}
+ }
+
+ if err = conn.ReadJSON(wsResp); err != nil {
+ return wsRequestError{fmt.Errorf("fail to ReadJSON err:%+v", err), nil}
+ }
+
+ if wsResp.Code != 0 {
+ return wsRequestError{
+ fmt.Errorf("invalid WSResponse code:%d, message:%s", wsResp.Code, wsResp.Message),
+ wsResp}
+ }
+ return nil
+}
+
+func (c *Client) wsClose(conn *websocket.Conn) {
+ c._removeWsConn(conn)
+ if err := conn.WriteMessage(websocket.CloseMessage, websocket.FormatCloseMessage(websocket.CloseNormalClosure, "")); err != nil {
+ c.log.Debug(fmt.Sprintf("fail to WriteMessage CloseNormalClosure err:%+v", err))
+ }
+ if err := conn.Close(); err != nil {
+ c.log.Debug(fmt.Sprintf("fail to Close err:%+v", err))
+ }
+}
+
+func (c *Client) wsRead(conn *websocket.Conn, respPtr interface{}) error {
+ mt, r, err := conn.NextReader()
+ if err != nil {
+ return err
+ }
+ if mt == websocket.CloseMessage {
+ return io.EOF
+ }
+ return json.NewDecoder(r).Decode(respPtr)
+}
+
+func (c *Client) wsReadJSONLoop(ctx context.Context, conn *websocket.Conn, respPtr interface{}, cb types.WsReadCallback) error {
+ elem := reflect.ValueOf(respPtr).Elem()
+ for {
+ select {
+ case <-ctx.Done():
+ return ctx.Err()
+ default:
+ v := reflect.New(elem.Type())
+ ptr := v.Interface()
+ if _, ok := c.conns[conn.LocalAddr().String()]; !ok {
+ c.log.Debug(fmt.Sprintf("wsReadJSONLoop c.conns[%s] is nil", conn.LocalAddr().String()))
+ return errors.New("wsReadJSONLoop c.conns is nil")
+ }
+ if err := c.wsRead(conn, ptr); err != nil {
+ c.log.Debug(fmt.Sprintf("wsReadJSONLoop c.conns[%s] ReadJSON err:%+v", conn.LocalAddr().String(), err))
+ if cErr, ok := err.(*websocket.CloseError); !ok || cErr.Code != websocket.CloseNormalClosure {
+ cb(conn, err)
+ }
+ return err
+ }
+ if err := cb(conn, ptr); err != nil {
+ return err
+ }
+ }
+
+ }
+}
+
+func (c *Client) GetBlockHeaderByHeight(height int64) (*types.BlockHeader, error) {
+ p := &types.BlockHeightParam{Height: types.NewHexInt(height)}
+ b, err := c.GetBlockHeaderBytesByHeight(p)
+ if err != nil {
+ return nil, err
+ }
+ var blockHeader types.BlockHeader
+ _, err = codec.RLP.UnmarshalFromBytes(b, &blockHeader)
+ if err != nil {
+ return nil, err
+ }
+ return &blockHeader, nil
+}
+
+func (c *Client) GetValidatorsByHash(hash common.HexHash) ([]common.Address, error) {
+ data, err := c.GetDataByHash(&types.DataHashParam{Hash: types.NewHexBytes(hash.Bytes())})
+ if err != nil {
+ return nil, errors.Wrapf(err, "GetDataByHash; %v", err)
+ }
+ if !bytes.Equal(hash, crypto.SHA3Sum256(data)) {
+ return nil, errors.Errorf(
+ "invalid data: hash=%v, data=%v", hash, common.HexBytes(data))
+ }
+ var validators []common.Address
+ _, err = codec.BC.UnmarshalFromBytes(data, &validators)
+ if err != nil {
+ return nil, errors.Wrapf(err, "Unmarshal Validators: %v", err)
+ }
+ return validators, nil
+}
+
+func (c *Client) GetBalance(param *types.AddressParam) (*big.Int, error) {
+ var result types.HexInt
+ _, err := c.Do("icx_getBalance", param, &result)
+ if err != nil {
+ return nil, err
+ }
+ bInt, err := result.BigInt()
+ if err != nil {
+ return nil, err
+ }
+ return bInt, nil
+}
+
+const (
+ HeaderKeyIconOptions = "Icon-Options"
+ IconOptionsDebug = "debug"
+ IconOptionsTimeout = "timeout"
+)
+
+type IconOptions map[string]string
+
+func (opts IconOptions) Set(key, value string) {
+ opts[key] = value
+}
+
+func (opts IconOptions) Get(key string) string {
+ if opts == nil {
+ return ""
+ }
+ v := opts[key]
+ if len(v) == 0 {
+ return ""
+ }
+ return v
+}
+
+func (opts IconOptions) Del(key string) {
+ delete(opts, key)
+}
+
+func (opts IconOptions) SetBool(key string, value bool) {
+ opts.Set(key, strconv.FormatBool(value))
+}
+
+func (opts IconOptions) GetBool(key string) (bool, error) {
+ return strconv.ParseBool(opts.Get(key))
+}
+
+func (opts IconOptions) SetInt(key string, v int64) {
+ opts.Set(key, strconv.FormatInt(v, 10))
+}
+
+func (opts IconOptions) GetInt(key string) (int64, error) {
+ return strconv.ParseInt(opts.Get(key), 10, 64)
+}
+
+func (opts IconOptions) ToHeaderValue() string {
+ if opts == nil {
+ return ""
+ }
+ strs := make([]string, len(opts))
+ i := 0
+ for k, v := range opts {
+ strs[i] = fmt.Sprintf("%s=%s", k, v)
+ i++
+ }
+ return strings.Join(strs, ",")
+}
+
+func NewIconOptionsByHeader(h http.Header) IconOptions {
+ s := h.Get(HeaderKeyIconOptions)
+ if s != "" {
+ kvs := strings.Split(s, ",")
+ m := make(map[string]string)
+ for _, kv := range kvs {
+ if kv != "" {
+ idx := strings.Index(kv, "=")
+ if idx > 0 {
+ m[kv[:idx]] = kv[(idx + 1):]
+ } else {
+ m[kv] = ""
+ }
+ }
+ }
+ return m
+ }
+ return nil
+}
+
+func (c *Client) MonitorBTP(ctx context.Context, p *types.BTPRequest, cb func(conn *websocket.Conn, v *types.BTPNotification) error, scb func(conn *websocket.Conn), errCb func(*websocket.Conn, error)) error {
+ resp := &types.BTPNotification{}
+ return c.Monitor(ctx, "/btp", p, resp, func(conn *websocket.Conn, v interface{}) error {
+ switch t := v.(type) {
+ case *types.BTPNotification:
+ if err := cb(conn, t); err != nil {
+ // c.log.Debug(fmt.Sprintf("MonitorBTP callback return err:%+v", err))
+ return err
+ }
+ case types.WSEvent:
+ c.log.Debug(fmt.Sprintf("MonitorBTP WSEvent %s %+v", conn.LocalAddr().String(), t))
+ switch t {
+ case types.WSEventInit:
+ if scb != nil {
+ scb(conn)
+ } else {
+ return errors.New("Second Callback function (scb) is nil ")
+ }
+ }
+ case error:
+ errCb(conn, t)
+ return t
+ default:
+ errCb(conn, fmt.Errorf("not supported type %T", t))
+ return errors.New("Not supported type")
+ }
+ return nil
+ })
+}
+
+func (c *Client) EstimateStep(param *types.TransactionParamForEstimate) (*types.HexInt, error) {
+ if len(c.DebugEndPoint) == 0 {
+ return nil, errors.New("UnavailableDebugEndPoint")
+ }
+ currTime := time.Now().UnixNano() / time.Hour.Microseconds()
+ param.Timestamp = types.NewHexInt(currTime)
+ var result types.HexInt
+ if _, err := c.DoURL(c.DebugEndPoint,
+ "debug_estimateStep", param, &result); err != nil {
+ return nil, err
+ }
+ return &result, nil
+}
+
+func NewClient(uri string, l *zap.Logger) *Client {
+ //TODO options {MaxRetrySendTx, MaxRetryGetResult, MaxIdleConnsPerHost, Debug, Dump}
+ tr := &http.Transport{MaxIdleConnsPerHost: 1000}
+ cl := &http.Client{Transport: tr}
+ apiClient := client.NewJsonRpcClient(cl, uri)
+ c := &Client{
+ JsonRpcClient: apiClient,
+ DebugEndPoint: guessDebugEndpoint(uri),
+ conns: make(map[string]*websocket.Conn),
+ log: l,
+ }
+ opts := IconOptions{}
+ opts.SetBool(IconOptionsDebug, true)
+ c.CustomHeader[HeaderKeyIconOptions] = opts.ToHeaderValue()
+ return c
+}
diff --git a/relayer/chains/icon/client_test.go b/relayer/chains/icon/client_test.go
new file mode 100644
index 000000000..fe925683a
--- /dev/null
+++ b/relayer/chains/icon/client_test.go
@@ -0,0 +1,188 @@
+package icon
+
+import (
+ "context"
+ "fmt"
+ "io/ioutil"
+ "testing"
+ "time"
+
+ "github.com/cosmos/relayer/v2/relayer/chains/icon/types"
+ "github.com/icon-project/IBC-Integration/libraries/go/common/icon"
+ "github.com/icon-project/goloop/common/codec"
+ "github.com/icon-project/goloop/common/wallet"
+ "github.com/icon-project/goloop/module"
+ "github.com/stretchr/testify/assert"
+ "github.com/stretchr/testify/require"
+ "go.uber.org/zap"
+)
+
+func NewTestClient() *Client {
+ uri := "https://lisbon.net.solidwallet.io/api/v3"
+ l := zap.NewNop()
+ return NewClient(uri, l)
+}
+
+func GetLisbonIconProvider(network_id int, contractAddress string) *IconProvider {
+
+ pcfg := IconProviderConfig{
+ Keystore: "godWallet",
+ KeyDirectory: "../../../env",
+ ChainID: "ibc-icon",
+ Password: "gochain",
+ ICONNetworkID: 2,
+ BTPNetworkID: int64(network_id),
+ BTPNetworkTypeID: 1,
+ IbcHandlerAddress: contractAddress,
+ RPCAddr: "https://lisbon.net.solidwallet.io/api/v3",
+ Timeout: "20s",
+ BlockInterval: 2000,
+ }
+ log, _ := zap.NewProduction()
+ p, _ := pcfg.NewProvider(log, "", false, "icon")
+
+ iconProvider, _ := p.(*IconProvider)
+ return iconProvider
+}
+
+func getTestWallet() (module.Wallet, error) {
+
+ keyStore_file := "../../../env/ibc-icon/godWallet.json"
+ kpass := "gochain"
+
+ keystore_bytes, err := ioutil.ReadFile(keyStore_file)
+ if err != nil {
+ return nil, err
+ }
+
+ wallet, err := wallet.NewFromKeyStore(keystore_bytes, []byte(kpass))
+ if err != nil {
+ return nil, err
+ }
+
+ return wallet, nil
+}
+
+func TestClientSetup(t *testing.T) {
+ l := zap.Logger{}
+ i := NewClient("https://ctz.solidwallet.io/api/v3", &l)
+
+ hash := "0x5306e343d648250f0567e9b549d3c03430aa0ab5a80dffc944cb0db3dbe4ed74"
+ param := &types.TransactionHashParam{Hash: types.HexBytes(hash)}
+ res, err := i.GetTransactionResult(param)
+ require.NoError(t, err)
+ assert.Equal(t, types.HexInt("0x1"), res.Status)
+}
+
+func TestSendMessageToMempool(t *testing.T) {
+ c := GetLisbonIconProvider(1, "cx6e24351b49133f2337a01c968cb864958ffadce8")
+ ctx := context.Background()
+ msg := c.NewIconMessage(map[string]interface{}{}, "sendEvent")
+ resp, _, err := c.SendMessage(ctx, msg, "memo")
+ assert.NoError(t, err)
+ assert.Equal(t, resp.Code, uint32(1))
+}
+
+func TestTransaction(t *testing.T) {
+
+ c := NewTestClient()
+
+ rpcWallet, err := getTestWallet()
+ if err != nil {
+ fmt.Println(err)
+ t.Fail()
+ return
+ }
+
+ txParam := &types.TransactionParam{
+ Version: types.NewHexInt(types.JsonrpcApiVersion),
+ FromAddress: types.Address(rpcWallet.Address().String()),
+ ToAddress: types.Address("cx6e24351b49133f2337a01c968cb864958ffadce8"),
+ Timestamp: types.NewHexInt(time.Now().UnixNano() / int64(time.Microsecond)),
+ NetworkID: types.NewHexInt(2),
+ StepLimit: types.NewHexInt(int64(1000000000)),
+ DataType: "call",
+ Data: types.CallData{
+ Method: "sendEvent",
+ },
+ }
+
+ err = c.SignTransaction(rpcWallet, txParam)
+ if err != nil {
+ t.Log(err)
+ t.Fail()
+ return
+ }
+
+ op, err := c.SendTransaction(txParam)
+ if err != nil {
+ t.Log(err)
+ t.Fail()
+ return
+ }
+
+ time.Sleep(6 * time.Second)
+
+ finalOp, err := c.GetTransactionResult(&types.TransactionHashParam{Hash: *op})
+ if err != nil {
+ t.Fatal(err)
+ }
+ assert.Equal(t, types.HexInt("0x1"), finalOp.Status)
+
+ t.Log(finalOp)
+
+}
+
+func TestCallFunction(t *testing.T) {
+
+ c := NewTestClient()
+
+ w, err := getTestWallet()
+ if err != nil {
+ t.Fatal(err)
+ return
+ }
+ var op types.HexBytes
+ err = c.Call(&types.CallParam{
+ FromAddress: types.Address(w.Address().String()),
+ ToAddress: types.Address("cx6e24351b49133f2337a01c968cb864958ffadce8"),
+ DataType: "call",
+ Data: &types.CallData{
+ Method: "name",
+ },
+ }, &op)
+
+ if err != nil {
+ t.Fatal((err))
+ return
+ }
+
+ assert.Equal(t, types.HexBytes("Handler"), op)
+
+ t.Log(op)
+
+}
+
+func TestGetTransaction(t *testing.T) {
+
+ c := NewTestClient()
+ hashString := "0xa9d333b24d990aeb418582c1467a4e6fd86a1bf9fb57e8fa95a77cb632a52301"
+ op, err := c.GetTransactionResult(&types.TransactionHashParam{Hash: types.HexBytes(hashString)})
+ if err != nil {
+ t.Log(err)
+ return
+ }
+
+ var p icon.Packet
+ packetByte, err := types.HexBytes(op.EventLogs[0].Indexed[1]).Value()
+ if err != nil {
+ t.Fatal(err)
+ }
+ _, err = codec.RLP.UnmarshalFromBytes(packetByte, &p)
+ if err != nil {
+ t.Fatal(err)
+ }
+
+ t.Log("Data:", p)
+
+}
diff --git a/relayer/chains/icon/codec.go b/relayer/chains/icon/codec.go
new file mode 100644
index 000000000..27ed82544
--- /dev/null
+++ b/relayer/chains/icon/codec.go
@@ -0,0 +1,37 @@
+package icon
+
+import (
+ "github.com/cosmos/cosmos-sdk/codec"
+ "github.com/cosmos/cosmos-sdk/codec/types"
+ "github.com/cosmos/cosmos-sdk/std"
+ "github.com/cosmos/cosmos-sdk/types/module"
+ ibc "github.com/cosmos/ibc-go/v7/modules/core"
+ icon_module "github.com/cosmos/relayer/v2/relayer/chains/icon/module"
+)
+
+var ModuleBasics = []module.AppModuleBasic{
+ ibc.AppModuleBasic{},
+ icon_module.AppModuleBasic{},
+}
+
+type Codec struct {
+ InterfaceRegistry types.InterfaceRegistry
+ Marshaler codec.Codec
+}
+
+func MakeCodec(moduleBasics []module.AppModuleBasic, extraCodecs []string) Codec {
+ modBasic := module.NewBasicManager(moduleBasics...)
+ encodingConfig := MakeCodecConfig()
+ std.RegisterInterfaces(encodingConfig.InterfaceRegistry)
+ modBasic.RegisterInterfaces(encodingConfig.InterfaceRegistry)
+ return encodingConfig
+}
+
+func MakeCodecConfig() Codec {
+ interfaceRegistry := types.NewInterfaceRegistry()
+ marshaler := codec.NewProtoCodec(interfaceRegistry)
+ return Codec{
+ InterfaceRegistry: interfaceRegistry,
+ Marshaler: marshaler,
+ }
+}
diff --git a/relayer/chains/icon/codec_test.go b/relayer/chains/icon/codec_test.go
new file mode 100644
index 000000000..4f923c589
--- /dev/null
+++ b/relayer/chains/icon/codec_test.go
@@ -0,0 +1,61 @@
+package icon
+
+import (
+ "encoding/hex"
+ "testing"
+
+ "github.com/cosmos/gogoproto/proto"
+ "github.com/cosmos/ibc-go/v7/modules/core/exported"
+ tmclient "github.com/cosmos/ibc-go/v7/modules/light-clients/07-tendermint"
+ "github.com/icon-project/IBC-Integration/libraries/go/common/icon"
+ tendermint_client "github.com/icon-project/IBC-Integration/libraries/go/common/tendermint"
+ "github.com/stretchr/testify/assert"
+)
+
+func TestCodec(t *testing.T) {
+
+ counterparty := &icon.Counterparty{
+ ClientId: "07-tendermint-0",
+ ConnectionId: "connection-0",
+ Prefix: &icon.MerklePrefix{},
+ }
+
+ byt, e := proto.Marshal(counterparty)
+ assert.NoError(t, e)
+ assert.NotNil(t, byt)
+
+ var co icon.Counterparty
+ e = proto.Unmarshal(byt, &co)
+ assert.NoError(t, e)
+ assert.Equal(t, counterparty, &co)
+}
+
+func TestClientState(t *testing.T) {
+ clS := "0a0469636f6e1204080210031a0310e80722051080b899292a0308d80432003a02105942190a090801180120012a0100120c0a02000110211804200c300142190a090801180120012a0100120c0a020001102018012001300150015801"
+ clB, _ := hex.DecodeString(clS)
+
+ var client tmclient.ClientState
+ err := proto.Unmarshal(clB, &client)
+ assert.NoError(t, err)
+}
+
+func TestCodecEncode(t *testing.T) {
+
+ testData := tendermint_client.ClientState{
+ ChainId: "tendermint",
+ LatestHeight: 40,
+ }
+
+ codec := MakeCodec(ModuleBasics, []string{})
+ data, err := codec.Marshaler.MarshalInterface(&testData)
+ if err != nil {
+ assert.Fail(t, "couldn't marshal interface ")
+ }
+ var ptr exported.ClientState
+ err = codec.Marshaler.UnmarshalInterface(data, &ptr)
+ if err != nil {
+ assert.Fail(t, "Couldn't unmarshal interface ")
+ }
+ assert.Equal(t, ptr.GetLatestHeight().GetRevisionHeight(), uint64(40))
+
+}
diff --git a/relayer/chains/icon/cryptoutils/merkle_proof.go b/relayer/chains/icon/cryptoutils/merkle_proof.go
new file mode 100644
index 000000000..7424dce8b
--- /dev/null
+++ b/relayer/chains/icon/cryptoutils/merkle_proof.go
@@ -0,0 +1,180 @@
+package cryptoutils
+
+import (
+ "bytes"
+ "math/bits"
+
+ "github.com/cosmos/relayer/v2/relayer/chains/icon/types"
+ "github.com/cosmos/relayer/v2/relayer/common"
+ "github.com/icon-project/IBC-Integration/libraries/go/common/icon"
+)
+
+const hashLen = 32
+
+type HashedList [][]byte
+
+func (b HashedList) Len() int {
+ return len(b)
+}
+
+func (b HashedList) Get(i int) []byte {
+ return b[i]
+}
+
+func (b HashedList) FindIndex(target []byte) int {
+ for i, item := range b {
+ if bytes.Equal(item, target) {
+ return i
+ }
+ }
+ return -1
+}
+
+type MerkleHashTree struct {
+ Hashes HashedList
+}
+
+func NewMerkleHashTree(byteList [][]byte) *MerkleHashTree {
+
+ var hashList HashedList
+ for _, b := range byteList {
+ hashList = append(hashList, common.Sha3keccak256(b))
+ }
+ return &MerkleHashTree{
+ Hashes: hashList,
+ }
+}
+
+func AppendHash(out []byte, data []byte) []byte {
+ return common.AppendKeccak256(out, data)
+}
+
+func __merkleRoot(data []byte) []byte {
+ for len(data) > hashLen {
+ i, j := 0, 0
+ for ; i < len(data); i, j = i+hashLen*2, j+hashLen {
+ if i+hashLen*2 <= len(data) {
+ AppendHash(data[:j], data[i:i+hashLen*2])
+ } else {
+ copy(data[j:j+hashLen], data[i:i+hashLen])
+ }
+ }
+ data = data[:j]
+ }
+ return data[:hashLen]
+}
+
+func (m *MerkleHashTree) MerkleRoot() []byte {
+ data := m.Hashes
+ if data.Len() == 0 {
+ return nil
+ }
+ if data.Len() == 1 {
+ return data.Get(0)
+ }
+ dataBuf := make([]byte, 0, data.Len()*hashLen)
+ for i := 0; i < data.Len(); i++ {
+ dataBuf = append(dataBuf, data.Get(i)...)
+ }
+ return __merkleRoot(dataBuf)
+}
+
+func __merkleProof(data []byte, idx int) []*icon.MerkleNode {
+ proof := make([]*icon.MerkleNode, 0, bits.Len(uint(len(data))))
+ for len(data) > hashLen {
+ i, j := 0, 0
+ for ; i < len(data); i, j = i+hashLen*2, j+hashLen {
+ if i+hashLen*2 <= len(data) {
+ var val []byte
+ if idx == i {
+ val = append(val, data[i+hashLen:i+hashLen*2]...)
+ proof = append(
+ proof,
+ &icon.MerkleNode{Dir: int32(types.DirRight), Value: val},
+ )
+ idx = j
+ } else if idx == i+hashLen {
+ val = append(val, data[i:i+hashLen]...)
+ proof = append(
+ proof,
+ &icon.MerkleNode{Dir: int32(types.DirLeft), Value: val},
+ )
+ idx = j
+ }
+ AppendHash(data[:j], data[i:i+hashLen*2])
+ } else {
+ if idx == i {
+ proof = append(
+ proof,
+ &icon.MerkleNode{Dir: int32(types.DirRight), Value: nil},
+ )
+ idx = j
+ }
+ copy(data[j:j+hashLen], data[i:i+hashLen])
+ }
+ }
+ data = data[:j]
+ }
+ return proof
+}
+
+func VerifyMerkleProof(root []byte, value []byte, proof []*icon.MerkleNode) bool {
+ computedHash := make([]byte, len(value))
+ copy(computedHash, value)
+
+ for _, node := range proof {
+ hashBuf := make([]byte, hashLen*2)
+ if node.Dir == int32(types.DirLeft) {
+ copy(hashBuf[:hashLen], node.Value)
+ copy(hashBuf[hashLen:], computedHash)
+ } else {
+ copy(hashBuf[:hashLen], computedHash)
+ if node.Value != nil {
+ copy(hashBuf[hashLen:], node.Value)
+ } else {
+ continue
+ }
+ }
+ AppendHash(computedHash[:0], hashBuf)
+ }
+
+ return bytes.Equal(root, computedHash)
+}
+
+func CalculateRootFromProof(value []byte, proof []*icon.MerkleNode) []byte {
+ computedHash := make([]byte, len(value))
+ copy(computedHash, value)
+
+ for _, node := range proof {
+ hashBuf := make([]byte, hashLen*2)
+ if node.Dir == int32(types.DirLeft) {
+ copy(hashBuf[:hashLen], node.Value)
+ copy(hashBuf[hashLen:], computedHash)
+ } else {
+ copy(hashBuf[:hashLen], computedHash)
+ if node.Value != nil {
+ copy(hashBuf[hashLen:], node.Value)
+ } else {
+ continue
+
+ }
+ }
+ AppendHash(computedHash[:0], hashBuf)
+ }
+ return computedHash
+}
+
+func (m *MerkleHashTree) MerkleProof(idx int) []*icon.MerkleNode {
+ data := m.Hashes
+ if data.Len() == 0 {
+ return nil
+ }
+ if data.Len() == 1 {
+ return nil
+ }
+ dataBuf := make([]byte, 0, data.Len()*hashLen)
+ for i := 0; i < data.Len(); i++ {
+ dataBuf = append(dataBuf, data.Get(i)...)
+ }
+ return __merkleProof(dataBuf, idx*hashLen)
+}
diff --git a/relayer/chains/icon/cryptoutils/merkle_test.go b/relayer/chains/icon/cryptoutils/merkle_test.go
new file mode 100644
index 000000000..3a6470c98
--- /dev/null
+++ b/relayer/chains/icon/cryptoutils/merkle_test.go
@@ -0,0 +1,153 @@
+package cryptoutils
+
+import (
+ "encoding/hex"
+ "testing"
+
+ "github.com/cosmos/relayer/v2/relayer/chains/icon/types"
+ "github.com/cosmos/relayer/v2/relayer/common"
+ "github.com/icon-project/IBC-Integration/libraries/go/common/icon"
+ "github.com/stretchr/testify/assert"
+)
+
+func TestMerkleRoot(t *testing.T) {
+ // Test case data
+ data := HashedList{
+ common.Sha3keccak256([]byte("hello")),
+ common.Sha3keccak256([]byte("world")),
+ common.Sha3keccak256([]byte("testtt")),
+ }
+ expectedRoot := "7435ed3dec3328c4558025351315ff477dd17a544992f8b094a9ac52f58fe5b0"
+
+ // Create Merkle tree
+ tree := &MerkleHashTree{
+ Hashes: data,
+ }
+
+ root := tree.MerkleRoot()
+ assert.Equal(t, hex.EncodeToString(root), expectedRoot)
+}
+
+func TestMerkleProof(t *testing.T) {
+
+ assert := assert.New(t)
+ var h = func(b byte) []byte {
+ return common.Sha3keccak256([]byte{b})
+ }
+ testCase := []struct {
+ exp []*icon.MerkleNode
+ data [][]byte
+ idx int
+ }{
+ {
+ nil,
+ [][]byte{h(0)},
+ 0,
+ },
+ {
+ []*icon.MerkleNode{{int32(types.DirRight), h(1)}},
+ [][]byte{h(0), h(1)},
+ 0,
+ },
+ {
+ []*icon.MerkleNode{{int32(types.DirLeft), h(0)}},
+ [][]byte{h(0), h(1)},
+ 1,
+ },
+ {
+ []*icon.MerkleNode{
+ {int32(types.DirRight), h(1)},
+ {int32(types.DirRight), h(2)},
+ },
+ [][]byte{h(0), h(1), h(2)},
+ 0,
+ },
+ {
+ []*icon.MerkleNode{
+ {int32(types.DirLeft), h(0)},
+ {int32(types.DirRight), h(2)},
+ },
+ [][]byte{h(0), h(1), h(2)},
+ 1,
+ },
+ {
+ []*icon.MerkleNode{
+ {int32(types.DirRight), nil},
+ {int32(types.DirLeft), common.Sha3keccak256(h(0), h(1))},
+ },
+ [][]byte{h(0), h(1), h(2)},
+ 2,
+ },
+ {
+ []*icon.MerkleNode{
+ {int32(types.DirRight), h(1)},
+ {int32(types.DirRight), common.Sha3keccak256(h(2), h(3))},
+ {int32(types.DirRight), h(4)},
+ },
+ [][]byte{h(0), h(1), h(2), h(3), h(4)},
+ 0,
+ },
+ {
+ []*icon.MerkleNode{
+ {int32(types.DirRight), nil},
+ {int32(types.DirRight), nil},
+ {
+ int32(types.DirLeft), common.Sha3keccak256(
+ common.Sha3keccak256(h(0), h(1)),
+ common.Sha3keccak256(h(2), h(3)),
+ ),
+ },
+ },
+ [][]byte{h(0), h(1), h(2), h(3), h(4)},
+ 4,
+ },
+ }
+
+ for i, c := range testCase {
+ tree := MerkleHashTree{
+ Hashes: c.data,
+ }
+ assert.EqualValues(c.exp, tree.MerkleProof(c.idx), "case=%d data=%x idx=%d", i, c.data, c.idx)
+ }
+}
+
+func TestMerkleProofMisMatch(t *testing.T) {
+ data := HashedList{
+ common.Sha3keccak256([]byte("hello")),
+ common.Sha3keccak256([]byte("world")),
+ common.Sha3keccak256([]byte("test")),
+ }
+
+ failcase := common.Sha3keccak256([]byte("should_fail"))
+
+ tree := &MerkleHashTree{
+ Hashes: data,
+ }
+ root := tree.MerkleRoot()
+ proofOfFirstItem := tree.MerkleProof(1)
+ proof := make([]*icon.MerkleNode, 0)
+ for _, p := range proofOfFirstItem {
+ proof = append(proof, p)
+ }
+
+ assert.False(t, VerifyMerkleProof(root, failcase, proof))
+
+}
+
+func TestCalculateRootFromMerkleNode(t *testing.T) {
+ data := HashedList{
+ common.Sha3keccak256([]byte("hello")),
+ common.Sha3keccak256([]byte("world")),
+ common.Sha3keccak256([]byte("test")),
+ common.Sha3keccak256([]byte("tes2")),
+ common.Sha3keccak256([]byte("tes3")),
+ }
+ tree := &MerkleHashTree{
+ Hashes: data,
+ }
+
+ expectedRoot := tree.MerkleRoot()
+ for i, d := range data {
+ assert.True(t, VerifyMerkleProof(expectedRoot, d, tree.MerkleProof(i)), "case=%d data=%x idx=%d", i, d)
+ }
+}
diff --git a/relayer/chains/icon/event_parser.go b/relayer/chains/icon/event_parser.go
new file mode 100644
index 000000000..05642f887
--- /dev/null
+++ b/relayer/chains/icon/event_parser.go
@@ -0,0 +1,211 @@
+package icon
+
+import (
+ "bytes"
+
+ "github.com/cosmos/gogoproto/proto"
+ clienttypes "github.com/cosmos/ibc-go/v7/modules/core/02-client/types"
+ "github.com/cosmos/relayer/v2/relayer/chains/icon/types"
+ "github.com/cosmos/relayer/v2/relayer/provider"
+ "github.com/icon-project/IBC-Integration/libraries/go/common/icon"
+
+ "go.uber.org/zap"
+)
+
+// EventType: EquivalentIBCEvent
+// EventName: IconEventLogSignature
+type ibcMessage struct {
+ eventType string
+ eventName string
+ info ibcMessageInfo
+}
+
+type ibcMessageInfo interface {
+ parseAttrs(log *zap.Logger, event types.EventLog)
+}
+
+type packetInfo provider.PacketInfo
+
+func (pi *packetInfo) parseAttrs(log *zap.Logger, event types.EventLog) {
+ eventName := GetEventLogSignature(event.Indexed)
+
+ packetData := event.Indexed[1]
+ var packet icon.Packet
+ if err := proto.Unmarshal(packetData, &packet); err != nil {
+
+ log.Error("failed to unmarshal packet")
+ // TODO: review return if parseAttrs add panic
+ }
+ pi.SourcePort = packet.SourcePort
+ pi.SourceChannel = packet.SourceChannel
+ pi.DestPort = packet.DestinationPort
+ pi.DestChannel = packet.DestinationChannel
+ pi.Sequence = packet.Sequence
+ pi.Data = packet.Data
+ if packet.TimeoutHeight != nil {
+ pi.TimeoutHeight.RevisionHeight = packet.TimeoutHeight.RevisionHeight
+ pi.TimeoutHeight.RevisionNumber = packet.TimeoutHeight.RevisionNumber
+ } else {
+ log.Info("EventParser: Should specify timeout height")
+ }
+ pi.TimeoutTimestamp = packet.TimeoutTimestamp
+
+ if bytes.Equal(eventName, MustConvertEventNameToBytes(EventTypeWriteAcknowledgement)) {
+ pi.Ack = event.Data[0]
+ }
+
+}
+
+type channelInfo provider.ChannelInfo
+
+func (ch *channelInfo) parseAttrs(log *zap.Logger, event types.EventLog) {
+
+ ch.PortID = string(event.Indexed[1])
+ ch.ChannelID = string(event.Indexed[2])
+
+ protoChannel := event.Data[0]
+ var channel icon.Channel
+
+ if err := proto.Unmarshal(protoChannel, &channel); err != nil {
+ log.Error("Error when unmarshalling the event log")
+ }
+
+ ch.CounterpartyChannelID = channel.Counterparty.GetChannelId()
+ ch.CounterpartyPortID = channel.Counterparty.GetPortId()
+ ch.ConnID = channel.ConnectionHops[0]
+ ch.Version = channel.GetVersion()
+}
+
+type connectionInfo provider.ConnectionInfo
+
+func (co *connectionInfo) parseAttrs(log *zap.Logger, event types.EventLog) {
+ eventLog := parseEventName(log, event, 0)
+ switch eventLog {
+ case EventTypeConnectionOpenInit, EventTypeConnectionOpenTry:
+ co.ClientID = string(event.Indexed[1][:])
+ co.ConnID = string(event.Data[0][:])
+ protoCounterparty := event.Data[1]
+
+ var counterparty icon.Counterparty
+
+ if err := proto.Unmarshal(protoCounterparty, &counterparty); err != nil {
+ log.Error("Error decoding counterparty")
+ }
+
+ co.CounterpartyClientID = counterparty.GetClientId()
+ co.CounterpartyConnID = counterparty.GetConnectionId()
+
+ case EventTypeConnectionOpenAck, EventTypeConnectionOpenConfirm:
+ co.ConnID = string(event.Indexed[1])
+ protoConnection_ := event.Data[0][:]
+ var connection icon.ConnectionEnd
+ if err := proto.Unmarshal(protoConnection_, &connection); err != nil {
+ log.Error("Error decoding counterparty")
+ }
+
+ co.ClientID = connection.GetClientId()
+ co.CounterpartyClientID = connection.Counterparty.ClientId
+ co.CounterpartyConnID = connection.Counterparty.ConnectionId
+ }
+}
+
+type clientInfo struct {
+ clientID string
+ consensusHeight clienttypes.Height
+ header []byte
+}
+
+func (c clientInfo) ClientState() provider.ClientState {
+ return provider.ClientState{
+ ClientID: c.clientID,
+ ConsensusHeight: c.consensusHeight,
+ Header: c.header,
+ }
+}
+
+func (cl *clientInfo) parseAttrs(log *zap.Logger, event types.EventLog) {
+ clientId := event.Indexed[1]
+ cl.clientID = string(clientId[:])
+}
+
+func parseEventName(log *zap.Logger, event types.EventLog, height uint64) string {
+ return string(event.Indexed[0][:])
+}
+
+func parseIdentifier(event types.EventLog) string {
+ return string(event.Indexed[1][:])
+}
+
+func parseIBCMessagesFromEventlog(log *zap.Logger, els []types.EventLog, height uint64) (ibcMessages []*ibcMessage) {
+ for _, el := range els {
+ ibcMessage := parseIBCMessageFromEvent(log, el, uint64(height))
+ ibcMessages = append(ibcMessages, ibcMessage)
+ }
+ return ibcMessages
+}
+
+func parseIBCMessageFromEvent(
+ log *zap.Logger,
+ event types.EventLog,
+ height uint64,
+) *ibcMessage {
+ eventName := string(event.Indexed[0][:])
+ eventType := getEventTypeFromEventName(eventName)
+
+ switch eventName {
+ case EventTypeSendPacket, EventTypeRecvPacket,
+ EventTypeAcknowledgePacket, EventTypeWriteAcknowledgement,
+ EventTypePacketTimeout, EventTypeTimeoutRequest:
+ // EventTypeTimeoutPacketOnClose:
+
+ info := &packetInfo{Height: height}
+ info.parseAttrs(log, event)
+ return &ibcMessage{
+ eventType,
+ eventName,
+ info,
+ }
+ case EventTypeChannelOpenInit, EventTypeChannelOpenTry,
+ EventTypeChannelOpenAck, EventTypeChannelOpenConfirm,
+ EventTypeChannelCloseInit, EventTypeChannelCloseConfirm:
+
+ ci := &channelInfo{Height: height}
+ ci.parseAttrs(log, event)
+
+ return &ibcMessage{
+ eventType: eventType,
+ eventName: eventName,
+ info: ci,
+ }
+ case EventTypeConnectionOpenInit, EventTypeConnectionOpenTry,
+ EventTypeConnectionOpenAck, EventTypeConnectionOpenConfirm:
+ ci := &connectionInfo{Height: height}
+ ci.parseAttrs(log, event)
+
+ return &ibcMessage{
+ eventType: eventType,
+ eventName: eventName,
+ info: ci,
+ }
+ case EventTypeCreateClient, EventTypeUpdateClient:
+
+ ci := &clientInfo{}
+ ci.parseAttrs(log, event)
+
+ return &ibcMessage{
+ eventType: eventType,
+ eventName: eventName,
+ info: ci,
+ }
+
+ }
+ return nil
+}
+
+func getEventTypeFromEventName(eventName string) string {
+ return IconCosmosEventMap[eventName]
+}
+
+func GetEventLogSignature(indexed [][]byte) []byte {
+ return indexed[0][:]
+}
diff --git a/relayer/chains/icon/event_parser_test.go b/relayer/chains/icon/event_parser_test.go
new file mode 100644
index 000000000..bdb4e31a2
--- /dev/null
+++ b/relayer/chains/icon/event_parser_test.go
@@ -0,0 +1,184 @@
+package icon
+
+import (
+ "encoding/hex"
+ "fmt"
+ "testing"
+
+ "github.com/cosmos/gogoproto/proto"
+ "github.com/cosmos/relayer/v2/relayer/chains/icon/types"
+ "github.com/icon-project/IBC-Integration/libraries/go/common/icon"
+ "github.com/stretchr/testify/assert"
+ "go.uber.org/zap"
+)
+
+func TestParseEvent(t *testing.T) {
+ eventData := "0a0f30372d74656e6465726d696e742d34120261611a050a03696263"
+ filtered, _ := hex.DecodeString(eventData)
+
+ p := &icon.Counterparty{}
+ err := proto.Unmarshal(filtered, p)
+ if err != nil {
+ fmt.Println(err)
+ }
+ assert.NoError(t, err)
+ assert.Equal(t, "07-tendermint-4", p.ClientId)
+}
+
+func TestParseCounterParty(t *testing.T) {
+ cp := &icon.Counterparty{
+ ClientId: "07-tendermint-2",
+ ConnectionId: "connection-0",
+ Prefix: &icon.MerklePrefix{
+ KeyPrefix: []byte("ibc"),
+ },
+ }
+ byt, err := proto.Marshal(cp)
+ assert.NoError(t, err)
+ fmt.Printf("%x\n", byt)
+}
+
+func TestEventMap(t *testing.T) {
+ eventName := "BTPMessage(int,int)"
+ assert.Equal(t, IconCosmosEventMap[eventName], "")
+
+ eventName = EventTypeCreateClient
+ assert.Equal(t, IconCosmosEventMap[eventName], "create_client")
+
+}
+
+func TestConnectionOpenInitByte(t *testing.T) {
+ // format of event received from block notification
+ event := types.EventLog{
+ Addr: types.Address("cxc598844f5a0b8997a9f9d280c3f228a20c93e1d5"),
+ Indexed: [][]byte{
+ {67, 111, 110, 110, 101, 99, 116, 105, 111, 110, 79, 112, 101, 110, 73, 110, 105, 116, 40, 115, 116, 114, 44, 115, 116, 114, 44, 98, 121, 116, 101, 115, 41},
+ {48, 55, 45, 116, 101, 110, 100, 101, 114, 109, 105, 110, 116, 45, 48},
+ },
+ Data: [][]byte{
+ {99, 111, 110, 110, 101, 99, 116, 105, 111, 110, 45, 49},
+ {10, 15, 48, 55, 45, 116, 101, 110, 100, 101, 114, 109, 105, 110, 116, 45, 50, 18, 12, 99, 111, 110, 110, 101, 99, 116, 105, 111, 110, 45, 48, 26, 5, 10, 3, 105, 98, 99},
+ },
+ }
+
+ ibcMsg := parseIBCMessageFromEvent(&zap.Logger{}, event, 0)
+ connAttrs := ibcMsg.info.(*connectionInfo)
+ fmt.Printf("%+v", connAttrs)
+}
+
+func TestConnectionOpenInit(t *testing.T) {
+ event := types.EventLog{
+ Addr: types.Address("cxc598844f5a0b8997a9f9d280c3f228a20c93e1d5"),
+ Indexed: [][]byte{
+ {67, 111, 110, 110, 101, 99, 116, 105, 111, 110, 79, 112, 101, 110, 73, 110, 105, 116, 40, 115, 116, 114, 44, 115, 116, 114, 44, 98, 121, 116, 101, 115, 41},
+ {48, 55, 45, 116, 101, 110, 100, 101, 114, 109, 105, 110, 116, 45, 48},
+ },
+ Data: [][]byte{
+ {99, 111, 110, 110, 101, 99, 116, 105, 111, 110, 45, 49},
+ {10, 15, 48, 55, 45, 116, 101, 110, 100, 101, 114, 109, 105, 110, 116, 45, 50, 18, 12, 99, 111, 110, 110, 101, 99, 116, 105, 111, 110, 45, 48, 26, 5, 10, 3, 105, 98, 99},
+ },
+ }
+ evt := types.EventLogStr{
+ Addr: types.Address("cxc598844f5a0b8997a9f9d280c3f228a20c93e1d5"),
+ Indexed: []string{EventTypeConnectionOpenInit, "07-tendermint-0"},
+ Data: []string{"connection-1", "0x0a0f30372d74656e6465726d696e742d32120c636f6e6e656374696f6e2d301a050a03696263"},
+ }
+
+ encodedEvent := ToEventLogBytes(evt)
+
+ assert.Equal(t, event.Addr, encodedEvent.Addr)
+ assert.Equal(t, event.Indexed[0], encodedEvent.Indexed[0])
+ assert.Equal(t, event.Indexed[1], encodedEvent.Indexed[1])
+ assert.Equal(t, event.Data[0], encodedEvent.Data[0])
+ assert.Equal(t, event.Data[1], encodedEvent.Data[1])
+
+ cp := &icon.Counterparty{
+ ClientId: "07-tendermint-0",
+ ConnectionId: "connection-1",
+ Prefix: &icon.MerklePrefix{},
+ }
+
+ ibcMsg := parseIBCMessageFromEvent(&zap.Logger{}, encodedEvent, 0)
+ connAttrs := ibcMsg.info.(*connectionInfo)
+ assert.Equal(t, cp.ClientId, connAttrs.ClientID)
+ assert.Equal(t, cp.ConnectionId, connAttrs.ConnID)
+}
+
+// func TestMonitorEvents(t *testing.T) {
+// provider := IconProviderConfig{
+// Key: "icon",
+// ChainName: "icon",
+// ChainID: "0x1",
+// RPCAddr: "https://ctz.solidwallet.io/api/v3",
+// Timeout: "0",
+// IbcHandlerAddress: "cx997849d3920d338ed81800833fbb270c785e743d",
+// }
+// l := zap.Logger{}
+// ip, _ := provider.NewProvider(&l, "icon", true, "icon")
+// i := ip.(*IconProvider)
+
+// const height int64 = 59489570
+
+// t.Log("test")
+// blockReq := &types.BlockRequest{
+// EventFilters: []*types.EventFilter{{
+// // Addr: types.Address(CONTRACT_ADDRESS),
+// Signature: EventTypeSendPacket,
+// // Indexed: []*string{&dstAddr},
+// }},
+// Height: types.NewHexInt(height),
+// }
+// ctx := context.Background()
+// ctx, cancel := context.WithTimeout(ctx, time.Second*10)
+// defer cancel()
+
+// h, s := int(height), 0
+// var wg sync.WaitGroup
+
+// wg.Add(1)
+
+// go func() {
+// defer wg.Done()
+// t.Log("height")
+
+// err := i.client.MonitorBlock(ctx, blockReq, func(conn *websocket.Conn, v *types.BlockNotification) error {
+// t.Log("height")
+
+// _h, _ := v.Height.Int()
+
+// if _h != h {
+// err := fmt.Errorf("invalid block height: %d, expected: %d", _h, h+1)
+// l.Warn(err.Error())
+// return err
+// }
+// h++
+// s++
+
+// return nil
+// },
+// func(conn *websocket.Conn) {
+// l.Info("Connected")
+// },
+// func(conn *websocket.Conn, err error) {
+// l.Info("Disconnected")
+// _ = conn.Close()
+// })
+// if err.Error() == "context deadline exceeded" {
+// return
+// }
+// }()
+
+// wg.Wait()
+
+// }
+
+func TestChannelHandshakeDataParsing(t *testing.T) {
+
+ data := []string{
+ "080110021a060a046d6f636b220c636f6e6e656374696f6e2d322a0769637332302d31",
+ }
+ d, _ := hex.DecodeString(data[0])
+ var channel icon.Channel
+ proto.Unmarshal(d, &channel)
+ assert.Equal(t, channel.ConnectionHops[0], "connection-2")
+}
diff --git a/relayer/chains/icon/events.go b/relayer/chains/icon/events.go
new file mode 100644
index 000000000..ecff9e8d7
--- /dev/null
+++ b/relayer/chains/icon/events.go
@@ -0,0 +1,166 @@
+package icon
+
+import (
+ "encoding/hex"
+ "strings"
+
+ clienttypes "github.com/cosmos/ibc-go/v7/modules/core/02-client/types"
+ conntypes "github.com/cosmos/ibc-go/v7/modules/core/03-connection/types"
+ chantypes "github.com/cosmos/ibc-go/v7/modules/core/04-channel/types"
+ "github.com/cosmos/relayer/v2/relayer/chains/icon/types"
+ "github.com/cosmos/relayer/v2/relayer/common"
+)
+
+// Events
+var (
+ // Client Events
+ EventTypeCreateClient = "CreateClient(str,bytes)"
+ EventTypeUpdateClient = "UpdateClient(str,bytes,bytes)"
+
+ // Connection Events
+ EventTypeConnectionOpenInit = "ConnectionOpenInit(str,str,bytes)"
+ EventTypeConnectionOpenTry = "ConnectionOpenTry(str,str,bytes)"
+ EventTypeConnectionOpenAck = "ConnectionOpenAck(str,bytes)"
+ EventTypeConnectionOpenConfirm = "ConnectionOpenConfirm(str,bytes)"
+
+ // Channel Events
+ EventTypeChannelOpenInit = "ChannelOpenInit(str,str,bytes)"
+ EventTypeChannelOpenTry = "ChannelOpenTry(str,str,bytes)"
+ EventTypeChannelOpenAck = "ChannelOpenAck(str,str,bytes)"
+ EventTypeChannelOpenConfirm = "ChannelOpenConfirm(str,str,bytes)"
+ EventTypeChannelCloseInit = "ChannelCloseInit(str,str,bytes)"
+ EventTypeChannelCloseConfirm = "ChannelCloseConfirm(str,str,bytes)"
+
+ // Packet Events
+ EventTypeSendPacket = "SendPacket(bytes)"
+ EventTypeRecvPacket = "RecvPacket(bytes)"
+ EventTypeWriteAcknowledgement = "WriteAcknowledgement(bytes,bytes)"
+ EventTypeAcknowledgePacket = "AcknowledgePacket(bytes,bytes)"
+ EventTypeTimeoutRequest = common.EventTimeoutRequest
+ EventTypePacketTimeout = "PacketTimeout(bytes)"
+)
+
+var IconCosmosEventMap = map[string]string{
+ // client events
+ EventTypeCreateClient: clienttypes.EventTypeCreateClient,
+ EventTypeUpdateClient: clienttypes.EventTypeUpdateClient,
+
+ // connection events
+ EventTypeConnectionOpenInit: conntypes.EventTypeConnectionOpenInit,
+ EventTypeConnectionOpenTry: conntypes.EventTypeConnectionOpenTry,
+ EventTypeConnectionOpenAck: conntypes.EventTypeConnectionOpenAck,
+ EventTypeConnectionOpenConfirm: conntypes.EventTypeConnectionOpenConfirm,
+
+ // channel events
+ EventTypeChannelOpenInit: chantypes.EventTypeChannelOpenInit,
+ EventTypeChannelOpenTry: chantypes.EventTypeChannelOpenTry,
+ EventTypeChannelOpenAck: chantypes.EventTypeChannelOpenAck,
+ EventTypeChannelOpenConfirm: chantypes.EventTypeChannelOpenConfirm,
+ EventTypeChannelCloseInit: chantypes.EventTypeChannelCloseInit,
+ EventTypeChannelCloseConfirm: chantypes.EventTypeChannelCloseConfirm,
+
+ // packet events
+ EventTypeSendPacket: chantypes.EventTypeSendPacket,
+ EventTypeRecvPacket: chantypes.EventTypeRecvPacket,
+ EventTypeWriteAcknowledgement: chantypes.EventTypeWriteAck,
+ EventTypeAcknowledgePacket: chantypes.EventTypeAcknowledgePacket,
+ EventTypePacketTimeout: chantypes.EventTypeTimeoutPacket,
+ EventTypeTimeoutRequest: common.EventTimeoutRequest,
+}
+
+func MustConvertEventNameToBytes(eventName string) []byte {
+ return []byte(eventName)
+}
+
+func ToEventLogBytes(evt types.EventLogStr) types.EventLog {
+ indexed := make([][]byte, 0)
+
+ for _, idx := range evt.Indexed {
+ indexed = append(indexed, []byte(idx))
+ }
+
+ data := make([][]byte, 0)
+
+ for _, d := range evt.Data {
+ if isHexString(d) {
+ filtered, _ := hex.DecodeString(strings.TrimPrefix(d, "0x"))
+ data = append(data, filtered)
+ continue
+ }
+ data = append(data, []byte(d))
+ }
+
+ return types.EventLog{
+ Addr: evt.Addr,
+ Indexed: indexed,
+ Data: data,
+ }
+
+}
+
+var BtpHeaderRequiredEvents map[string]struct{} = map[string]struct{}{
+ EventTypeSendPacket: {},
+ EventTypeWriteAcknowledgement: {},
+
+ EventTypeConnectionOpenInit: {},
+ EventTypeConnectionOpenTry: {},
+ EventTypeConnectionOpenAck: {},
+
+ EventTypeChannelOpenInit: {},
+ EventTypeChannelOpenTry: {},
+ EventTypeChannelOpenAck: {},
+ EventTypeChannelCloseInit: {},
+
+ EventTypeTimeoutRequest: {},
+}
+
+var MonitorEvents []string = []string{
+ EventTypeSendPacket,
+ EventTypeWriteAcknowledgement,
+
+ EventTypeConnectionOpenInit,
+ EventTypeConnectionOpenTry,
+ EventTypeConnectionOpenAck,
+ EventTypeConnectionOpenConfirm,
+
+ EventTypeChannelOpenInit,
+ EventTypeChannelOpenTry,
+ EventTypeChannelOpenAck,
+ EventTypeChannelOpenConfirm,
+ EventTypeChannelCloseInit,
+ EventTypeChannelCloseConfirm,
+
+ //no BTP block produced
+ EventTypeRecvPacket,
+ EventTypeAcknowledgePacket,
+ EventTypeUpdateClient,
+
+ // TimeoutRequest
+ EventTypeTimeoutRequest,
+ EventTypePacketTimeout,
+}
+
+func GetMonitorEventFilters(address string) []*types.EventFilter {
+
+ filters := []*types.EventFilter{}
+ if address == "" {
+ return filters
+ }
+
+ for _, event := range MonitorEvents {
+ filters = append(filters, &types.EventFilter{
+ Addr: types.Address(address),
+ Signature: event,
+ })
+ }
+ return filters
+}
+
+func RequiresBtpHeader(els []types.EventLog) bool {
+ for _, el := range els {
+ if _, ok := BtpHeaderRequiredEvents[string(GetEventLogSignature(el.Indexed))]; ok {
+ return true
+ }
+ }
+ return false
+}
diff --git a/relayer/chains/icon/icon_chain_processor.go b/relayer/chains/icon/icon_chain_processor.go
new file mode 100644
index 000000000..956754467
--- /dev/null
+++ b/relayer/chains/icon/icon_chain_processor.go
@@ -0,0 +1,722 @@
+package icon
+
+import (
+ "bytes"
+ "context"
+ "fmt"
+ "sort"
+ "sync"
+ "time"
+
+ "go.uber.org/zap"
+ "golang.org/x/sync/errgroup"
+
+ clienttypes "github.com/cosmos/ibc-go/v7/modules/core/02-client/types"
+ conntypes "github.com/cosmos/ibc-go/v7/modules/core/03-connection/types"
+ chantypes "github.com/cosmos/ibc-go/v7/modules/core/04-channel/types"
+
+ "github.com/cosmos/relayer/v2/relayer/chains/icon/types"
+ rlycommon "github.com/cosmos/relayer/v2/relayer/common"
+ "github.com/cosmos/relayer/v2/relayer/processor"
+ "github.com/cosmos/relayer/v2/relayer/provider"
+ "github.com/gorilla/websocket"
+ "github.com/icon-project/goloop/common"
+ "github.com/icon-project/goloop/common/codec"
+ "github.com/pkg/errors"
+)
+
+const (
+ queryTimeout = 5 * time.Second
+ latestHeightQueryRetryDelay = 1 * time.Second
+ queryRetries = 5
+)
+
+const (
+ notProcessed = "not-processed"
+ processed = "processed"
+)
+
+type IconChainProcessor struct {
+ log *zap.Logger
+ chainProvider *IconProvider
+
+ pathProcessors processor.PathProcessors
+
+ inSync bool
+ firstTime bool
+
+ latestBlock provider.LatestBlock
+ latestBlockMu sync.Mutex
+
+ latestClientState
+
+ // holds open state for known connections
+ connectionStateCache processor.ConnectionStateCache
+
+ // holds open state for known channels
+ channelStateCache processor.ChannelStateCache
+
+ // map of connection ID to client ID
+ connectionClients map[string]string
+
+ // map of channel ID to connection ID
+ channelConnections map[string]string
+
+ // metrics to monitor lifetime of processor
+ metrics *processor.PrometheusMetrics
+
+ verifier *Verifier
+
+ heightSnapshotChan chan struct{}
+}
+
+type Verifier struct {
+ nextProofContext [][]byte
+ verifiedHeight int64
+ prevNetworkSectionHash []byte
+}
+
+func NewIconChainProcessor(log *zap.Logger, provider *IconProvider, metrics *processor.PrometheusMetrics, heightSnapshot chan struct{}) *IconChainProcessor {
+ return &IconChainProcessor{
+ log: log.With(zap.String("chain_name", provider.ChainName()), zap.String("chain_id", provider.ChainId())),
+ chainProvider: provider,
+ latestClientState: make(latestClientState),
+ connectionStateCache: make(processor.ConnectionStateCache),
+ channelStateCache: make(processor.ChannelStateCache),
+ connectionClients: make(map[string]string),
+ channelConnections: make(map[string]string),
+ metrics: metrics,
+ heightSnapshotChan: heightSnapshot,
+ }
+}
+
+// Arrangement For the Latest height
+type latestClientState map[string]provider.ClientState
+
+func (l latestClientState) update(ctx context.Context, clientInfo clientInfo, icp *IconChainProcessor) {
+
+ existingClientInfo, ok := l[clientInfo.clientID]
+ if ok {
+ if clientInfo.consensusHeight.LT(existingClientInfo.ConsensusHeight) {
+ // height is less than latest, so no-op
+ return
+ }
+ }
+
+ clientState := clientInfo.ClientState()
+ l[clientInfo.clientID] = clientState
+}
+
+type btpBlockResponse struct {
+ Height int64
+ Header IconIBCHeader
+ EventLogs []types.EventLog
+ IsProcessed string
+}
+type btpBlockRequest struct {
+ height int64
+ hash types.HexBytes
+ indexes [][]types.HexInt
+ events [][][]types.HexInt
+ err error
+ retry int
+ response *btpBlockResponse
+}
+
+// ************************************************** For persistence **************************************************
+type queryCyclePersistence struct {
+ latestHeight int64
+ latestHeightMu sync.Mutex
+
+ lastQueriedHeight int64
+ latestQueriedHeightMu sync.Mutex
+
+ minQueryLoopDuration time.Duration
+}
+
+func (icp *IconChainProcessor) Run(ctx context.Context, initialBlockHistory uint64) error {
+ persistence := queryCyclePersistence{
+ minQueryLoopDuration: time.Second,
+ }
+
+ var eg errgroup.Group
+
+ eg.Go(func() error {
+ return icp.initializeConnectionState(ctx)
+ })
+ eg.Go(func() error {
+ return icp.initializeChannelState(ctx)
+ })
+ if err := eg.Wait(); err != nil {
+ return err
+ }
+
+ // start_query_cycle
+ icp.log.Debug("Starting query cycle")
+ err := icp.monitoring(ctx, &persistence)
+ return err
+}
+
+func (icp *IconChainProcessor) StartFromHeight(ctx context.Context) int64 {
+ cfg := icp.Provider().ProviderConfig().(*IconProviderConfig)
+
+ if cfg.StartHeight != 0 {
+ return cfg.StartHeight
+ }
+ snapshotHeight, err := rlycommon.LoadSnapshotHeight(icp.Provider().ChainId())
+ if err != nil {
+ icp.log.Warn("Failed to load height from snapshot", zap.Error(err))
+ } else {
+ icp.log.Info("Obtained start height from config", zap.Int64("height", snapshotHeight))
+ }
+ return snapshotHeight
+}
+
+func (icp *IconChainProcessor) getLastSavedHeight() int64 {
+ snapshotHeight, err := rlycommon.LoadSnapshotHeight(icp.Provider().ChainId())
+ if err != nil || snapshotHeight < 0 {
+ return 0
+ }
+ return snapshotHeight
+}
+
+func (icp *IconChainProcessor) initializeConnectionState(ctx context.Context) error {
+ // TODO: review
+ ctx, cancel := context.WithTimeout(ctx, queryTimeout)
+ defer cancel()
+
+ connections, err := icp.chainProvider.QueryConnections(ctx)
+ if err != nil {
+ return fmt.Errorf("error querying connections: %w", err)
+ }
+
+ for _, c := range connections {
+ icp.connectionClients[c.Id] = c.ClientId
+ icp.connectionStateCache[processor.ConnectionKey{
+ ConnectionID: c.Id,
+ ClientID: c.ClientId,
+ CounterpartyConnID: c.Counterparty.ConnectionId,
+ CounterpartyClientID: c.Counterparty.ClientId,
+ }] = c.State == conntypes.OPEN
+
+ icp.log.Debug("Found open connection",
+ zap.String("client-id ", c.ClientId),
+ zap.String("connection-id ", c.Id),
+ )
+ }
+ return nil
+}
+
+func (icp *IconChainProcessor) initializeChannelState(ctx context.Context) error {
+ // TODO:
+ ctx, cancel := context.WithTimeout(ctx, queryTimeout)
+ defer cancel()
+ channels, err := icp.chainProvider.QueryChannels(ctx)
+ if err != nil {
+ return fmt.Errorf("error querying channels: %w", err)
+ }
+ for _, ch := range channels {
+ if len(ch.ConnectionHops) != 1 {
+ icp.log.Error("Found channel using multiple connection hops. Not currently supported, ignoring.",
+ zap.String("channel_id", ch.ChannelId),
+ zap.String("port_id", ch.PortId),
+ zap.Strings("connection_hops", ch.ConnectionHops),
+ )
+ continue
+ }
+
+ icp.channelConnections[ch.ChannelId] = ch.ConnectionHops[0]
+ channelKey := processor.ChannelKey{
+ ChannelID: ch.ChannelId,
+ PortID: ch.PortId,
+ CounterpartyChannelID: ch.Counterparty.ChannelId,
+ CounterpartyPortID: ch.Counterparty.PortId,
+ }
+
+ icp.channelStateCache.SetOpen(channelKey, ch.State == chantypes.OPEN, ch.Ordering)
+
+ icp.log.Debug("Found open channel",
+ zap.String("channel-id", ch.ChannelId),
+ zap.String("port-id ", ch.PortId),
+ zap.String("counterparty-channel-id", ch.Counterparty.ChannelId),
+ zap.String("counterparty-port-id", ch.Counterparty.PortId))
+ }
+
+ return nil
+}
+
+func (icp *IconChainProcessor) Provider() provider.ChainProvider {
+ return icp.chainProvider
+}
+
+func (icp *IconChainProcessor) SetPathProcessors(pathProcessors processor.PathProcessors) {
+ icp.pathProcessors = pathProcessors
+}
+
+func (icp *IconChainProcessor) GetLatestHeight() uint64 {
+ return icp.latestBlock.Height
+}
+
+func (icp *IconChainProcessor) monitoring(ctx context.Context, persistence *queryCyclePersistence) error {
+
+ errCh := make(chan error) // error channel
+ reconnectCh := make(chan struct{}, 1) // reconnect channel
+ btpBlockNotifCh := make(chan *types.BlockNotification, 10) // block notification channel
+ btpBlockRespCh := make(chan *btpBlockResponse, cap(btpBlockNotifCh)) // block result channel
+
+ reconnect := func() {
+ select {
+ case reconnectCh <- struct{}{}:
+ default:
+ }
+ for len(btpBlockRespCh) > 0 || len(btpBlockNotifCh) > 0 {
+ select {
+ case <-btpBlockRespCh: // clear block result channel
+ case <-btpBlockNotifCh: // clear block notification channel
+ }
+ }
+ }
+
+ var err error
+ processedheight := icp.StartFromHeight(ctx)
+ latestHeight, err := icp.chainProvider.QueryLatestHeight(ctx)
+ if err != nil {
+ icp.log.Error("Error fetching block", zap.Error(err))
+ return err
+ }
+ if processedheight > latestHeight {
+ icp.log.Warn("Start height set is greater than latest height",
+ zap.Int64("start height", processedheight),
+ zap.Int64("latest Height", latestHeight),
+ )
+ processedheight = latestHeight
+ }
+ if processedheight <= 0 {
+ processedheight = latestHeight
+ }
+
+ icp.log.Info("Start to query from height", zap.Int64("height", processedheight))
+ // subscribe to monitor block
+ ctxMonitorBlock, cancelMonitorBlock := context.WithCancel(ctx)
+ reconnect()
+
+ ibcHeaderCache := make(processor.IBCHeaderCache)
+
+ icp.firstTime = true
+
+ blockReq := &types.BlockRequest{
+ Height: types.NewHexInt(int64(processedheight)),
+ EventFilters: GetMonitorEventFilters(icp.chainProvider.PCfg.IbcHandlerAddress),
+ }
+
+loop:
+ for {
+ select {
+ case <-ctx.Done():
+ return nil
+ case err := <-errCh:
+ return err
+
+ case <-icp.heightSnapshotChan:
+ icp.SnapshotHeight(icp.getHeightToSave(int64(icp.latestBlock.Height)))
+
+ case <-reconnectCh:
+ cancelMonitorBlock()
+ ctxMonitorBlock, cancelMonitorBlock = context.WithCancel(ctx)
+
+ go func(ctx context.Context, cancel context.CancelFunc) {
+ blockReq.Height = types.NewHexInt(processedheight)
+ icp.log.Debug("Try to reconnect from", zap.Int64("height", processedheight))
+ err := icp.chainProvider.client.MonitorBlock(ctx, blockReq, func(conn *websocket.Conn, v *types.BlockNotification) error {
+ if !errors.Is(ctx.Err(), context.Canceled) {
+ btpBlockNotifCh <- v
+ }
+ return nil
+ }, func(conn *websocket.Conn) {
+ }, func(conn *websocket.Conn, err error) {})
+ if err != nil {
+ ht := icp.getHeightToSave(processedheight)
+ if ht != icp.getLastSavedHeight() {
+ icp.SnapshotHeight(ht)
+ }
+ if errors.Is(err, context.Canceled) {
+ return
+ }
+ time.Sleep(time.Second * 5)
+ reconnect()
+ icp.log.Warn("Error occured during monitor block", zap.Error(err))
+ }
+
+ }(ctxMonitorBlock, cancelMonitorBlock)
+ case br := <-btpBlockRespCh:
+ for ; br != nil; processedheight++ {
+ // verify BTP Block
+ err := icp.verifyBlock(ctx, br.Header)
+ if err != nil {
+ reconnect()
+ icp.log.Warn("Failed to verify BTP block",
+ zap.Int64("height", br.Height),
+ zap.Error(err),
+ )
+ break
+ }
+
+ icp.log.Debug("Verified block ",
+ zap.Int64("height", int64(processedheight)))
+
+ icp.latestBlock = provider.LatestBlock{
+ Height: uint64(processedheight),
+ }
+
+ ibcMessage := parseIBCMessagesFromEventlog(icp.log, br.EventLogs, uint64(br.Height))
+ ibcMessageCache := processor.NewIBCMessagesCache()
+ // message handler
+ for _, m := range ibcMessage {
+ icp.handleMessage(ctx, *m, ibcMessageCache)
+ }
+
+ ibcHeaderCache[uint64(br.Height)] = br.Header
+ icp.log.Debug("Queried block ",
+ zap.Int64("height", br.Height))
+ err = icp.handlePathProcessorUpdate(ctx, br.Header, ibcMessageCache, ibcHeaderCache.Clone())
+ if err != nil {
+ reconnect()
+ icp.log.Warn("Reconnect: error occured during handle block response ",
+ zap.Int64("got", br.Height),
+ )
+ break
+ }
+ time.Sleep(10 * time.Millisecond)
+ if icp.firstTime {
+ time.Sleep(4000 * time.Millisecond)
+ }
+ icp.firstTime = false
+ if br = nil; len(btpBlockRespCh) > 0 {
+ br = <-btpBlockRespCh
+ }
+ }
+ // remove unprocessed blockResponses
+ for len(btpBlockRespCh) > 0 {
+ <-btpBlockRespCh
+ }
+
+ default:
+ select {
+ default:
+ case bn := <-btpBlockNotifCh:
+ requestCh := make(chan *btpBlockRequest, cap(btpBlockNotifCh))
+ for i := int64(0); bn != nil; i++ {
+ height, err := bn.Height.Value()
+
+ if err != nil {
+ return err
+ } else if height != processedheight+i {
+ icp.log.Warn("Reconnect: missing block notification",
+ zap.Int64("got", height),
+ zap.Int64("expected", processedheight+i),
+ )
+ reconnect()
+ continue loop
+ }
+
+ requestCh <- &btpBlockRequest{
+ height: height,
+ hash: bn.Hash,
+ indexes: bn.Indexes,
+ events: bn.Events,
+ retry: queryRetries,
+ }
+ if bn = nil; len(btpBlockNotifCh) > 0 && len(requestCh) < cap(requestCh) {
+ bn = <-btpBlockNotifCh
+ }
+ }
+
+ brs := make([]*btpBlockResponse, 0, len(requestCh))
+ for request := range requestCh {
+ switch {
+ case request.err != nil:
+ if request.retry > 0 {
+ request.retry--
+ request.response, request.err = nil, nil
+ requestCh <- request
+ continue
+ }
+ icp.log.Info("Request error ",
+ zap.Any("height", request.height),
+ zap.Error(request.err))
+ brs = append(brs, nil)
+ if len(brs) == cap(brs) {
+ close(requestCh)
+ }
+ case request.response != nil:
+ brs = append(brs, request.response)
+ if len(brs) == cap(brs) {
+ close(requestCh)
+ }
+ default:
+ go icp.handleBTPBlockRequest(request, requestCh)
+
+ }
+
+ }
+ // filter nil
+ _brs, brs := brs, brs[:0]
+ for _, v := range _brs {
+ if v.IsProcessed == processed {
+ brs = append(brs, v)
+ }
+ }
+
+ // sort and forward notifications
+ if len(brs) > 0 {
+ sort.SliceStable(brs, func(i, j int) bool {
+ return brs[i].Height < brs[j].Height
+ })
+ for i, d := range brs {
+ if d.Height == processedheight+int64(i) {
+ btpBlockRespCh <- d
+ }
+ }
+ }
+
+ }
+ }
+ }
+}
+
+func (icp *IconChainProcessor) getHeightToSave(height int64) int64 {
+ retryAfter := icp.Provider().ProviderConfig().GetFirstRetryBlockAfter()
+ ht := height - int64(retryAfter)
+ if ht < 0 {
+ return 0
+ }
+ return ht
+}
+
+func (icp *IconChainProcessor) SnapshotHeight(height int64) {
+ icp.log.Info("Save height for snapshot", zap.Int64("height", height))
+ err := rlycommon.SnapshotHeight(icp.Provider().ChainId(), height)
+ if err != nil {
+ icp.log.Warn("Failed saving height snapshot for height", zap.Int64("height", height))
+ }
+}
+
+func (icp *IconChainProcessor) verifyBlock(ctx context.Context, ibcHeader provider.IBCHeader) error {
+ header, ok := ibcHeader.(IconIBCHeader)
+ if !ok {
+ return fmt.Errorf("Provided Header is not compatible with IBCHeader")
+ }
+ if icp.firstTime {
+ proofContext, err := icp.chainProvider.GetProofContextByHeight(int64(header.MainHeight) - 1)
+ if err != nil {
+ return err
+ }
+ icp.verifier = &Verifier{
+ nextProofContext: proofContext,
+ verifiedHeight: int64(header.MainHeight) - 1,
+ }
+ }
+
+ if !ibcHeader.IsCompleteBlock() {
+ icp.verifier.nextProofContext = header.Validators
+ icp.verifier.verifiedHeight = int64(header.Height())
+ return nil
+ }
+
+ // prevNetworkSectionHash would be nil for first block
+ if icp.verifier.prevNetworkSectionHash != nil &&
+ !bytes.Equal(icp.verifier.prevNetworkSectionHash, header.Header.PrevNetworkSectionHash) {
+ return fmt.Errorf("failed to match prevNetworkSectionHash")
+ }
+
+ sigs, err := icp.chainProvider.GetBTPProof(int64(header.MainHeight))
+ if err != nil {
+ return err
+ }
+
+ decision := types.NewNetworkTypeSectionDecision(
+ getSrcNetworkId(icp.chainProvider.PCfg.ICONNetworkID),
+ icp.chainProvider.PCfg.BTPNetworkTypeID,
+ int64(header.MainHeight),
+ header.Header.Round,
+ types.NetworkTypeSection{
+ NextProofContextHash: header.Header.NextProofContextHash,
+ NetworkSectionsRoot: GetNetworkSectionRoot(header.Header),
+ })
+
+ valid, err := VerifyBtpProof(decision, sigs, icp.verifier.nextProofContext)
+ if err != nil {
+ return err
+ }
+
+ if !valid {
+ return fmt.Errorf("failed to Verify block")
+ }
+
+ icp.verifier.nextProofContext = header.Validators
+ icp.verifier.verifiedHeight = int64(header.Height())
+ icp.verifier.prevNetworkSectionHash = types.NewNetworkSection(header.Header).Hash()
+ icp.log.Debug("Verified block ",
+ zap.Uint64("height", header.Height()))
+ return nil
+}
+
+func (icp *IconChainProcessor) handleBTPBlockRequest(
+ request *btpBlockRequest, requestCh chan *btpBlockRequest) {
+ defer func() {
+ time.Sleep(500 * time.Millisecond)
+ requestCh <- request
+ }()
+
+ if request.response == nil {
+ request.response = &btpBlockResponse{
+ IsProcessed: notProcessed,
+ Height: request.height,
+ }
+ }
+
+ containsEventlogs := len(request.indexes) > 0 && len(request.events) > 0
+ if containsEventlogs {
+ blockHeader, err := icp.chainProvider.client.GetBlockHeaderByHeight(request.height)
+ if err != nil {
+ request.err = errors.Wrapf(request.err, "getBlockHeader: %v", err)
+ return
+ }
+
+ var receiptHash types.BlockHeaderResult
+ _, err = codec.RLP.UnmarshalFromBytes(blockHeader.Result, &receiptHash)
+ if err != nil {
+ request.err = errors.Wrapf(err, "BlockHeaderResult.UnmarshalFromBytes: %v", err)
+ return
+
+ }
+
+ var eventlogs []types.EventLog
+ for id := 0; id < len(request.indexes); id++ {
+ for i, index := range request.indexes[id] {
+ p := &types.ProofEventsParam{
+ Index: index,
+ BlockHash: request.hash,
+ Events: request.events[id][i],
+ }
+
+ proofs, err := icp.chainProvider.client.GetProofForEvents(p)
+ if err != nil {
+ request.err = errors.Wrapf(err, "GetProofForEvents: %v", err)
+ return
+
+ }
+
+ // Processing receipt index
+ serializedReceipt, err := MptProve(index, proofs[0], receiptHash.ReceiptHash)
+ if err != nil {
+ request.err = errors.Wrapf(err, "MPTProve Receipt: %v", err)
+ return
+
+ }
+ var result types.TxResult
+ _, err = codec.RLP.UnmarshalFromBytes(serializedReceipt, &result)
+ if err != nil {
+ request.err = errors.Wrapf(err, "Unmarshal Receipt: %v", err)
+ return
+ }
+
+ for j := 0; j < len(p.Events); j++ {
+ serializedEventLog, err := MptProve(
+ p.Events[j], proofs[j+1], common.HexBytes(result.EventLogsHash))
+ if err != nil {
+ request.err = errors.Wrapf(err, "event.MPTProve: %v", err)
+ return
+ }
+ var el types.EventLog
+ _, err = codec.RLP.UnmarshalFromBytes(serializedEventLog, &el)
+ if err != nil {
+ request.err = errors.Wrapf(err, "event.UnmarshalFromBytes: %v", err)
+ return
+ }
+ icp.log.Info("Detected eventlog ", zap.Int64("height", request.height),
+ zap.String("eventlog", IconCosmosEventMap[string(el.Indexed[0])]))
+ eventlogs = append(eventlogs, el)
+ }
+
+ }
+ }
+ request.response.EventLogs = eventlogs
+ }
+
+ validators, err := icp.chainProvider.GetProofContextByHeight(request.height)
+ if err != nil {
+ request.err = errors.Wrapf(err, "Failed to get proof context: %v", err)
+ return
+ }
+
+ btpHeader, err := icp.chainProvider.GetBtpHeader(request.height)
+ if err != nil {
+ if RequiresBtpHeader(request.response.EventLogs) {
+ request.err = errors.Wrapf(err, "Btp header required but not present: %v", err)
+ return
+ }
+ if btpBlockNotPresent(err) {
+ request.response.Header = NewIconIBCHeader(nil, validators, (request.height))
+ request.response.IsProcessed = processed
+ return
+ }
+ request.err = errors.Wrapf(err, "Failed to get btp header: %v", err)
+ return
+ }
+ request.response.Header = NewIconIBCHeader(btpHeader, validators, int64(btpHeader.MainHeight))
+ request.response.IsProcessed = processed
+}
+
+func (icp *IconChainProcessor) handlePathProcessorUpdate(ctx context.Context,
+ latestHeader provider.IBCHeader, messageCache processor.IBCMessagesCache,
+ ibcHeaderCache processor.IBCHeaderCache) error {
+
+ chainID := icp.chainProvider.ChainId()
+
+ for _, pp := range icp.pathProcessors {
+ clientID := pp.RelevantClientID(chainID)
+ clientState, err := icp.clientState(ctx, clientID)
+ if err != nil {
+ icp.log.Error("Error fetching client state",
+ zap.String("client_id", clientID),
+ zap.Error(err),
+ )
+ continue
+ }
+
+ pp.HandleNewData(chainID, processor.ChainProcessorCacheData{
+ LatestBlock: icp.latestBlock,
+ LatestHeader: latestHeader,
+ IBCMessagesCache: messageCache,
+ InSync: true,
+ ClientState: clientState,
+ ConnectionStateCache: icp.connectionStateCache.FilterForClient(clientID),
+ ChannelStateCache: icp.channelStateCache.FilterForClient(clientID, icp.channelConnections, icp.connectionClients),
+ IBCHeaderCache: ibcHeaderCache.Clone(),
+ IsGenesis: icp.firstTime,
+ })
+ }
+ return nil
+
+}
+
+// clientState will return the most recent client state if client messages
+// have already been observed for the clientID, otherwise it will query for it.
+func (icp *IconChainProcessor) clientState(ctx context.Context, clientID string) (provider.ClientState, error) {
+ if state, ok := icp.latestClientState[clientID]; ok {
+ return state, nil
+ }
+
+ cs, err := icp.chainProvider.QueryClientStateWithoutProof(ctx, int64(icp.latestBlock.Height), clientID)
+ if err != nil {
+ return provider.ClientState{}, err
+ }
+
+ clientState := provider.ClientState{
+ ClientID: clientID,
+ ConsensusHeight: cs.GetLatestHeight().(clienttypes.Height),
+ }
+ icp.latestClientState[clientID] = clientState
+ return clientState, nil
+}
diff --git a/relayer/chains/icon/keys.go b/relayer/chains/icon/keys.go
new file mode 100644
index 000000000..878422c61
--- /dev/null
+++ b/relayer/chains/icon/keys.go
@@ -0,0 +1,176 @@
+package icon
+
+import (
+ "encoding/json"
+ "fmt"
+ "log"
+ "os"
+ "path"
+ "strings"
+
+ "github.com/cosmos/relayer/v2/relayer/provider"
+ glcrypto "github.com/icon-project/goloop/common/crypto"
+ "github.com/icon-project/goloop/common/wallet"
+ "github.com/icon-project/goloop/module"
+)
+
+func (cp *IconProvider) CreateKeystore(path string) error {
+ _, e := cp.generateKeystoreWithPassword(path, "gochain")
+ return e
+}
+
+func (cp *IconProvider) KeystoreCreated(path string) bool {
+ return false
+}
+
+func (cp *IconProvider) AddKey(name string, coinType uint32, signingAlgorithm string, password string) (output *provider.KeyOutput, err error) {
+ w, err := cp.generateKeystoreWithPassword(name, password)
+ if err != nil {
+ return nil, err
+ }
+ return &provider.KeyOutput{
+ Address: w.Address().String(),
+ Mnemonic: "",
+ }, nil
+}
+
+func (cp *IconProvider) RestoreKey(name, mnemonic string, coinType uint32, signingAlgorithm string) (address string, err error) {
+ return "", fmt.Errorf("not implemented on icon")
+}
+
+func (cp *IconProvider) ShowAddress(name string) (address string, err error) {
+ dirPath := path.Join(cp.PCfg.KeyDirectory, cp.ChainId(), fmt.Sprintf("%s.json", name))
+ return getAddrFromKeystore(dirPath)
+}
+
+func (cp *IconProvider) ListAddresses() (map[string]string, error) {
+ dirPath := path.Join(cp.PCfg.KeyDirectory, cp.ChainId())
+ dirEntry, err := os.ReadDir(dirPath)
+ if err != nil {
+ return nil, err
+ }
+
+ addrMap := make(map[string]string)
+ for _, file := range dirEntry {
+ if !file.IsDir() && strings.HasSuffix(file.Name(), ".json") {
+ ksFile := path.Join(dirPath, file.Name())
+ addr, err := getAddrFromKeystore(ksFile)
+ if err != nil {
+ continue
+ }
+ addrMap[strings.TrimSuffix(file.Name(), ".json")] = addr
+ }
+ }
+ return addrMap, nil
+}
+
+func (cp *IconProvider) DeleteKey(name string) error {
+ ok := cp.KeyExists(name)
+ if !ok {
+ return fmt.Errorf("wallet does not exist")
+ }
+
+ dirPath := path.Join(cp.PCfg.KeyDirectory, cp.ChainId(), fmt.Sprintf("%s.json", name))
+ _, err := os.Stat(dirPath)
+ if err == nil {
+ if err := os.Remove(dirPath); err != nil {
+ return err
+ }
+ return nil
+ }
+ return fmt.Errorf("fail to delete wallet")
+}
+
+func (cp *IconProvider) KeyExists(name string) bool {
+ walletPath := path.Join(cp.PCfg.KeyDirectory, cp.ChainId(), fmt.Sprintf("%s.json", name))
+ _, err := os.ReadFile(walletPath)
+ if err != nil && os.IsNotExist(err) {
+ return false
+ } else if err != nil {
+ panic("key does not exist")
+ }
+ return true
+}
+
+func (cp *IconProvider) ExportPrivKeyArmor(keyName string) (armor string, err error) {
+ return "", fmt.Errorf("not implemented on icon")
+}
+
+func (cp *IconProvider) RestoreIconKeyStore(name string, password []byte) (module.Wallet, error) {
+ walletPath := path.Join(cp.PCfg.KeyDirectory, cp.ChainId(), fmt.Sprintf("%s.json", name))
+ ksByte, err := os.ReadFile(walletPath)
+ if err != nil {
+ return nil, err
+ }
+ w, err := wallet.NewFromKeyStore(ksByte, password)
+ if err != nil {
+ return nil, err
+ }
+ return w, nil
+}
+
+// This method does not save keystore
+func (cp *IconProvider) RestoreFromPrivateKey(name string, pk []byte) (module.Wallet, error) {
+ pKey, err := glcrypto.ParsePrivateKey(pk)
+ if err != nil {
+ return nil, err
+ }
+ w, err := wallet.NewFromPrivateKey(pKey)
+ if err != nil {
+ return nil, err
+ }
+ return w, nil
+}
+
+func (cp *IconProvider) generateKeystoreWithPassword(name string, password string) (module.Wallet, error) {
+ w := wallet.New()
+ ks, err := wallet.KeyStoreFromWallet(w, []byte(password))
+ if err != nil {
+ log.Panicf("Failed to generate keystore. Err %+v", err)
+ return nil, err
+ }
+
+ if err := cp.saveWallet(name, ks); err != nil {
+ return nil, err
+ }
+
+ return w, nil
+}
+
+func (cp *IconProvider) saveWallet(name string, ks []byte) error {
+ dirPath := path.Join(cp.PCfg.KeyDirectory, cp.ChainId())
+ _, err := os.Stat(dirPath)
+ if os.IsNotExist(err) {
+ err := os.MkdirAll(dirPath, 0755)
+ if err != nil {
+ panic(err)
+ }
+ } else if err != nil {
+ return err
+ }
+ if err := os.WriteFile(fmt.Sprintf("%s/%s.json", dirPath, name), ks, 0600); err != nil {
+ log.Panicf("Fail to write keystore err=%+v", err)
+ return err
+ }
+ return nil
+}
+
+type OnlyAddr struct {
+ Address string `json:"address"`
+}
+
+func getAddrFromKeystore(keystorePath string) (string, error) {
+
+ ksFile, err := os.ReadFile(keystorePath)
+ if err != nil {
+ return "", err
+ }
+
+ var a OnlyAddr
+ err = json.Unmarshal(ksFile, &a)
+ if err != nil {
+ return "", err
+ }
+ return a.Address, nil
+
+}
diff --git a/relayer/chains/icon/keys_test.go b/relayer/chains/icon/keys_test.go
new file mode 100644
index 000000000..369787c19
--- /dev/null
+++ b/relayer/chains/icon/keys_test.go
@@ -0,0 +1,65 @@
+package icon
+
+import (
+ "testing"
+
+ "github.com/stretchr/testify/assert"
+ "github.com/stretchr/testify/require"
+ "go.uber.org/zap"
+)
+
+const (
+ ENDPOINT = "https://ctz.solidwallet.io/api/v3/"
+)
+
+func TestCreateKeystore(t *testing.T) {
+ kwName := "testWallet.json"
+ p := &IconProvider{
+ client: NewClient(ENDPOINT, &zap.Logger{}),
+ PCfg: &IconProviderConfig{
+ KeyDirectory: "../../../env",
+ ChainID: "ibc-icon",
+ },
+ }
+ err := p.CreateKeystore(kwName)
+ require.NoError(t, err)
+}
+
+func TestAddIconKeyStore(t *testing.T) {
+ kwName := "testWallet"
+ p := &IconProvider{
+ client: NewClient(ENDPOINT, &zap.Logger{}),
+ PCfg: &IconProviderConfig{
+ KeyDirectory: "../../../env",
+ ChainID: "ibc-icon",
+ },
+ }
+ w, err := p.AddKey(kwName, 0, "", "gochain")
+ require.NoError(t, err, "err creating keystore with password")
+
+ addr, err := p.ShowAddress(kwName)
+ assert.NoError(t, err)
+
+ // assert.Equal(t, w.Address, p.wallet.Address())
+ assert.Equal(t, w.Address, addr)
+}
+
+// func TestRestoreIconKeyStore(t *testing.T) {
+
+// pcfg := &IconProviderConfig{
+// KeyDirectory: "../../../env",
+// Keystore: "testWallet",
+// Password: "gochain",
+// Timeout: "20s",
+// ChainName: "icon",
+// StartHeight: 10,
+// IbcHandlerAddress: "cxb6b5791be0b5ef67063b3c10b840fb81514db2fd",
+// BlockInterval: 2000,
+// }
+// p, err := pcfg.NewProvider(zap.NewNop(), "not_correct", false, "icon")
+// require.NoError(t, err)
+// iconp := p.(*IconProvider)
+// _, err = iconp.RestoreIconKeyStore("testWallet", []byte("gochain"))
+// require.NoError(t, err)
+
+// }
diff --git a/relayer/chains/icon/message_handler.go b/relayer/chains/icon/message_handler.go
new file mode 100644
index 000000000..dd5d681bb
--- /dev/null
+++ b/relayer/chains/icon/message_handler.go
@@ -0,0 +1,182 @@
+package icon
+
+import (
+ "context"
+
+ conntypes "github.com/cosmos/ibc-go/v7/modules/core/03-connection/types"
+ chantypes "github.com/cosmos/ibc-go/v7/modules/core/04-channel/types"
+
+ "github.com/cosmos/relayer/v2/relayer/processor"
+ "github.com/cosmos/relayer/v2/relayer/provider"
+ "go.uber.org/zap"
+ "go.uber.org/zap/zapcore"
+)
+
+func (icp *IconChainProcessor) handleMessage(ctx context.Context, m ibcMessage, c processor.IBCMessagesCache) {
+ switch t := m.info.(type) {
+ case *packetInfo:
+ icp.handlePacketMessage(m.eventType, provider.PacketInfo(*t), c)
+ case *channelInfo:
+ icp.handleChannelMessage(m.eventType, provider.ChannelInfo(*t), c)
+ case *connectionInfo:
+ icp.handleConnectionMessage(m.eventType, provider.ConnectionInfo(*t), c)
+ case *clientInfo:
+ icp.handleClientMessage(ctx, m.eventType, *t)
+ }
+}
+
+func (icp *IconChainProcessor) handlePacketMessage(eventType string, pi provider.PacketInfo, c processor.IBCMessagesCache) {
+ k, err := processor.PacketInfoChannelKey(eventType, pi)
+ if err != nil {
+ icp.log.Error("Unexpected error handling packet message",
+ zap.String("event_type", eventType),
+ zap.Uint64("sequence", pi.Sequence),
+ zap.Inline(k),
+ zap.Error(err),
+ )
+ return
+ }
+
+ if !c.PacketFlow.ShouldRetainSequence(icp.pathProcessors, k, icp.chainProvider.ChainId(), eventType, pi.Sequence) {
+ icp.log.Debug("Not retaining packet message",
+ zap.String("event_type", eventType),
+ zap.Uint64("sequence", pi.Sequence),
+ zap.Inline(k),
+ )
+ return
+ }
+
+ icp.log.Debug("Retaining packet message",
+ zap.String("event_type", eventType),
+ zap.Uint64("sequence", pi.Sequence),
+ zap.Inline(k),
+ )
+
+ c.PacketFlow.Retain(k, eventType, pi)
+ icp.logPacketMessage(eventType, pi)
+
+}
+
+func (icp *IconChainProcessor) handleChannelMessage(eventType string, ci provider.ChannelInfo, ibcMessagesCache processor.IBCMessagesCache) {
+ icp.channelConnections[ci.ChannelID] = ci.ConnID
+ channelKey := processor.ChannelInfoChannelKey(ci)
+
+ if eventType == chantypes.EventTypeChannelOpenInit {
+ found := false
+ for k := range icp.channelStateCache {
+ // Don't add a channelKey to the channelStateCache without counterparty channel ID
+ // since we already have the channelKey in the channelStateCache which includes the
+ // counterparty channel ID.
+ if k.MsgInitKey() == channelKey {
+ found = true
+ break
+ }
+ }
+ if !found {
+ icp.channelStateCache.SetOpen(channelKey, false, ci.Order)
+ }
+ } else {
+ switch eventType {
+ case chantypes.EventTypeChannelOpenTry:
+ icp.channelStateCache.SetOpen(channelKey, false, ci.Order)
+ case chantypes.EventTypeChannelOpenAck, chantypes.EventTypeChannelOpenConfirm:
+ icp.channelStateCache.SetOpen(channelKey, true, ci.Order)
+ case chantypes.EventTypeChannelCloseConfirm:
+ for k := range icp.channelStateCache {
+ if k.PortID == ci.PortID && k.ChannelID == ci.ChannelID {
+ icp.channelStateCache.SetOpen(channelKey, false, ci.Order)
+ break
+ }
+ }
+ }
+ // Clear out MsgInitKeys once we have the counterparty channel ID
+ delete(icp.channelStateCache, channelKey.MsgInitKey())
+ }
+
+ ibcMessagesCache.ChannelHandshake.Retain(channelKey, eventType, ci)
+
+ icp.logChannelMessage(eventType, ci)
+
+}
+
+func (icp *IconChainProcessor) handleConnectionMessage(eventType string, ci provider.ConnectionInfo, ibcMessagesCache processor.IBCMessagesCache) {
+ icp.connectionClients[ci.ConnID] = ci.ClientID
+ connectionKey := processor.ConnectionInfoConnectionKey(ci)
+ if eventType == conntypes.EventTypeConnectionOpenInit {
+ found := false
+ for k := range icp.connectionStateCache {
+ // Don't add a connectionKey to the connectionStateCache without counterparty connection ID
+ // since we already have the connectionKey in the connectionStateCache which includes the
+ // counterparty connection ID.
+ if k.MsgInitKey() == connectionKey {
+ found = true
+ break
+ }
+ }
+ if !found {
+ icp.connectionStateCache[connectionKey] = false
+ }
+ } else {
+ // Clear out MsgInitKeys once we have the counterparty connection ID
+ delete(icp.connectionStateCache, connectionKey.MsgInitKey())
+ open := (eventType == conntypes.EventTypeConnectionOpenAck || eventType == conntypes.EventTypeConnectionOpenConfirm)
+ icp.connectionStateCache[connectionKey] = open
+ }
+ ibcMessagesCache.ConnectionHandshake.Retain(connectionKey, eventType, ci)
+
+ icp.logConnectionMessage(eventType, ci)
+
+}
+
+func (icp *IconChainProcessor) handleClientMessage(ctx context.Context, eventType string, ci clientInfo) {
+ // TODO:
+ icp.latestClientState.update(ctx, ci, icp)
+ icp.logObservedIBCMessage(eventType, zap.String("client_id", ci.clientID))
+
+}
+
+func (ccp *IconChainProcessor) logObservedIBCMessage(m string, fields ...zap.Field) {
+ ccp.log.With(zap.String("event_type", m)).Debug("Observed IBC message", fields...)
+}
+
+func (icp *IconChainProcessor) logPacketMessage(message string, pi provider.PacketInfo) {
+ if !icp.log.Core().Enabled(zapcore.DebugLevel) {
+ return
+ }
+ fields := []zap.Field{
+ zap.Uint64("sequence", pi.Sequence),
+ zap.String("src_channel", pi.SourceChannel),
+ zap.String("src_port", pi.SourcePort),
+ zap.String("dst_channel", pi.DestChannel),
+ zap.String("dst_port", pi.DestPort),
+ }
+ if pi.TimeoutHeight.RevisionHeight > 0 {
+ fields = append(fields, zap.Uint64("timeout_height", pi.TimeoutHeight.RevisionHeight))
+ }
+ if pi.TimeoutHeight.RevisionNumber > 0 {
+ fields = append(fields, zap.Uint64("timeout_height_revision", pi.TimeoutHeight.RevisionNumber))
+ }
+ if pi.TimeoutTimestamp > 0 {
+ fields = append(fields, zap.Uint64("timeout_timestamp", pi.TimeoutTimestamp))
+ }
+ icp.logObservedIBCMessage(message, fields...)
+}
+
+func (icp *IconChainProcessor) logChannelMessage(message string, ci provider.ChannelInfo) {
+ icp.logObservedIBCMessage(message,
+ zap.String("channel_id", ci.ChannelID),
+ zap.String("port_id", ci.PortID),
+ zap.String("counterparty_channel_id", ci.CounterpartyChannelID),
+ zap.String("counterparty_port_id", ci.CounterpartyPortID),
+ zap.String("connection_id", ci.ConnID),
+ )
+}
+
+func (icp *IconChainProcessor) logConnectionMessage(message string, ci provider.ConnectionInfo) {
+ icp.logObservedIBCMessage(message,
+ zap.String("client_id", ci.ClientID),
+ zap.String("counterparty_connection_id", ci.CounterpartyConnID),
+ zap.String("connection_id", ci.ConnID),
+ zap.String("counterparty_client_id", ci.CounterpartyClientID),
+ )
+}
diff --git a/relayer/chains/icon/methods.go b/relayer/chains/icon/methods.go
new file mode 100644
index 000000000..2c5b43db4
--- /dev/null
+++ b/relayer/chains/icon/methods.go
@@ -0,0 +1,45 @@
+package icon
+
+const (
+ MethodRegisterClient = "registerClient"
+ MethodCreateClient = "createClient"
+ MethodUpdateClient = "updateClient"
+
+ MethodConnectionOpenInit = "connectionOpenInit"
+ MethodConnectionOpenTry = "connectionOpenTry"
+ MethodConnectionOpenAck = "connectionOpenAck"
+ MethodConnectionOpenConfirm = "connectionOpenConfirm"
+
+ MethodChannelOpenInit = "channelOpenInit"
+ MethodChannelOpenTry = "channelOpenTry"
+ MethodChannelOpenAck = "channelOpenAck"
+ MethodChannelOpenConfirm = "channelOpenConfirm"
+ MethodChannelCloseInit = "channelCloseInit"
+ MethodChannelCloseConfirm = "channelCloseConfirm"
+
+ MethodRecvPacket = "recvPacket"
+ MethodAckPacket = "acknowledgePacket"
+ MethodWriteAck = "writeAcknowledgement"
+
+ MethodGetPacketCommitment = "getPacketCommitment"
+ MethodGetPacketAcknowledgementCommitment = "getPacketAcknowledgementCommitment"
+ MethodGetPacketReceipt = "getPacketReceipt"
+ MethodGetNextSequenceReceive = "getNextSequenceReceive"
+ MethodGetNextSequenceSend = "getNextSequenceSend"
+ MethodGetNextSequenceAcknowledgement = "getNextSequenceAcknowledgement"
+
+ MethodGetChannel = "getChannel"
+ MethodGetConnection = "getConnection"
+ MethodGetClientState = "getClientState"
+ MethodGetClientConsensusState = "getClientConsensusState"
+ MethodGetConsensusState = "getConsensusState"
+
+ MethodGetNextClientSequence = "getNextClientSequence"
+ MethodGetNextChannelSequence = "getNextChannelSequence"
+ MethodGetNextConnectionSequence = "getNextConnectionSequence"
+
+ MethodRequestTimeout = "requestTimeout"
+ MethodTimeoutPacket = "timeoutPacket"
+
+ MethodGetAllPorts = "getAllPorts"
+)
diff --git a/relayer/chains/icon/module/app_module.go b/relayer/chains/icon/module/app_module.go
new file mode 100644
index 000000000..02690d1ab
--- /dev/null
+++ b/relayer/chains/icon/module/app_module.go
@@ -0,0 +1,67 @@
+package module
+
+import (
+ "github.com/cosmos/cosmos-sdk/client"
+ "github.com/cosmos/cosmos-sdk/codec"
+ codectypes "github.com/cosmos/cosmos-sdk/codec/types"
+ "github.com/cosmos/gogoproto/proto"
+ "github.com/cosmos/ibc-go/v7/modules/core/exported"
+ "github.com/grpc-ecosystem/grpc-gateway/runtime"
+ "github.com/icon-project/IBC-Integration/libraries/go/common/icon"
+ "github.com/icon-project/IBC-Integration/libraries/go/common/tendermint"
+ "github.com/spf13/cobra"
+)
+
+// AppModuleBasic defines the basic application module used by the module.
+type AppModuleBasic struct{}
+
+// Name returns the module's name.
+func (AppModuleBasic) Name() string {
+ return "icon_chain_provider"
+}
+
+// RegisterLegacyAminoCodec does nothing. IBC does not support amino.
+func (AppModuleBasic) RegisterLegacyAminoCodec(*codec.LegacyAmino) {}
+
+type MerkleProofState interface {
+ proto.Message
+}
+
+// RegisterInterfaces registers module concrete types into protobuf Any.
+func (AppModuleBasic) RegisterInterfaces(registry codectypes.InterfaceRegistry) {
+ registry.RegisterImplementations(
+ (*exported.ClientState)(nil),
+ &tendermint.ClientState{},
+ &icon.ClientState{},
+ )
+ registry.RegisterImplementations(
+ (*exported.ConsensusState)(nil),
+ &tendermint.ConsensusState{},
+ &icon.ConsensusState{},
+ )
+ registry.RegisterInterface(
+ "icon.types.v1.MerkleProofs",
+ (*MerkleProofState)(nil),
+ &icon.MerkleProofs{},
+ )
+ registry.RegisterImplementations(
+ (*exported.ClientMessage)(nil),
+ &icon.SignedHeader{},
+ )
+
+}
+
+// RegisterGRPCGatewayRoutes registers the gRPC Gateway routes for the ibc module.
+func (AppModuleBasic) RegisterGRPCGatewayRoutes(clientCtx client.Context, mux *runtime.ServeMux) {
+ panic("not implemented")
+}
+
+// GetTxCmd returns the root tx command for the ibc module.
+func (AppModuleBasic) GetTxCmd() *cobra.Command {
+ panic("not implemented")
+}
+
+// GetQueryCmd returns no root query command for the ibc module.
+func (AppModuleBasic) GetQueryCmd() *cobra.Command {
+ panic("not implemented")
+}
diff --git a/relayer/chains/icon/msg.go b/relayer/chains/icon/msg.go
new file mode 100644
index 000000000..27015d352
--- /dev/null
+++ b/relayer/chains/icon/msg.go
@@ -0,0 +1,32 @@
+package icon
+
+import (
+ "encoding/json"
+
+ "github.com/cosmos/relayer/v2/relayer/provider"
+)
+
+const defaultStepLimit = 13610920010
+
+type IconMessage struct {
+ Params interface{}
+ Method string
+}
+
+func (im *IconMessage) Type() string {
+ return im.Method
+}
+
+func (im *IconMessage) MsgBytes() ([]byte, error) {
+ return json.Marshal(im.Params)
+}
+
+func (icp *IconProvider) NewIconMessage(msg interface{}, method string) provider.RelayerMessage {
+
+ im := &IconMessage{
+ Params: msg,
+ Method: method,
+ }
+
+ return im
+}
diff --git a/relayer/chains/icon/provider.go b/relayer/chains/icon/provider.go
new file mode 100644
index 000000000..45500d536
--- /dev/null
+++ b/relayer/chains/icon/provider.go
@@ -0,0 +1,550 @@
+package icon
+
+import (
+ "context"
+ "encoding/base64"
+ "fmt"
+ "sync"
+ "time"
+
+ "github.com/cosmos/gogoproto/proto"
+ "github.com/cosmos/relayer/v2/relayer/chains/icon/types"
+ "github.com/cosmos/relayer/v2/relayer/common"
+ "github.com/cosmos/relayer/v2/relayer/processor"
+ "github.com/cosmos/relayer/v2/relayer/provider"
+ "github.com/icon-project/IBC-Integration/libraries/go/common/icon"
+ "github.com/icon-project/goloop/module"
+
+ "go.uber.org/zap"
+
+ sdk "github.com/cosmos/cosmos-sdk/types"
+
+ clienttypes "github.com/cosmos/ibc-go/v7/modules/core/02-client/types"
+ chantypes "github.com/cosmos/ibc-go/v7/modules/core/04-channel/types"
+ commitmenttypes "github.com/cosmos/ibc-go/v7/modules/core/23-commitment/types"
+ ibcexported "github.com/cosmos/ibc-go/v7/modules/core/exported"
+ // integration_types "github.com/icon-project/IBC-Integration/libraries/go/common/icon"
+)
+
+var (
+ _ provider.ChainProvider = &IconProvider{}
+ _ provider.KeyProvider = &IconProvider{}
+ _ provider.ProviderConfig = &IconProviderConfig{}
+)
+
+// Default IBC settings
+var (
+ defaultDelayPeriod = types.NewHexInt(0)
+
+ DefaultIBCVersionIdentifier = "1"
+
+ DefaultIBCVersion = &icon.Version{
+ Identifier: DefaultIBCVersionIdentifier,
+ Features: []string{"ORDER_ORDERED", "ORDER_UNORDERED"},
+ }
+
+ NOT_IMPLEMENTED = " :: Not implemented for ICON"
+)
+
+/*
+ * The provider assumes the key is in
+ * KeyDirectory/Keystore.json
+ */
+type IconProviderConfig struct {
+ KeyDirectory string `json:"key-directory" yaml:"key-directory"`
+ ChainName string `json:"-" yaml:"-"`
+ ChainID string `json:"chain-id" yaml:"chain-id"`
+ RPCAddr string `json:"rpc-addr" yaml:"rpc-addr"`
+ Timeout string `json:"timeout" yaml:"timeout"`
+ Keystore string `json:"keystore" yaml:"keystore"`
+ Password string `json:"password" yaml:"password"`
+ ICONNetworkID int64 `json:"icon-network-id" yaml:"icon-network-id" default:"3"`
+ BTPNetworkID int64 `json:"btp-network-id" yaml:"btp-network-id"`
+ BTPNetworkTypeID int64 `json:"btp-network-type-id" yaml:"btp-network-type-id"`
+ StartHeight int64 `json:"start-height" yaml:"start-height"`
+ IbcHandlerAddress string `json:"ibc-handler-address" yaml:"ibc-handler-address"`
+ FirstRetryBlockAfter uint64 `json:"first-retry-block-after" yaml:"first-retry-block-after"`
+ BlockInterval uint64 `json:"block-interval" yaml:"block-interval"`
+}
+
+func (pp *IconProviderConfig) Validate() error {
+ if _, err := time.ParseDuration(pp.Timeout); err != nil {
+ return fmt.Errorf("invalid Timeout: %w", err)
+ }
+
+ if !isValidIconContractAddress(pp.IbcHandlerAddress) {
+ return fmt.Errorf("Ibc handler Address cannot be empty")
+ }
+
+ if pp.BlockInterval == 0 {
+ return fmt.Errorf("Block interval cannot be zero")
+ }
+
+ return nil
+}
+
+func (pp *IconProviderConfig) GetBlockInterval() uint64 {
+ return pp.BlockInterval
+}
+
+func (pp *IconProviderConfig) GetFirstRetryBlockAfter() uint64 {
+ if pp.FirstRetryBlockAfter != 0 {
+ return pp.FirstRetryBlockAfter
+ }
+ return 8
+}
+
+// NewProvider should provide a new Icon provider
+func (pp *IconProviderConfig) NewProvider(log *zap.Logger, homepath string, debug bool, chainName string) (provider.ChainProvider, error) {
+
+ pp.ChainName = chainName
+
+ if err := pp.Validate(); err != nil {
+ return nil, err
+ }
+
+ codec := MakeCodec(ModuleBasics, []string{})
+
+ return &IconProvider{
+ log: log.With(zap.String("chain_id", pp.ChainID)),
+ client: NewClient(pp.getRPCAddr(), log),
+ PCfg: pp,
+ StartHeight: uint64(pp.StartHeight),
+ codec: codec,
+ }, nil
+}
+
+func (pp IconProviderConfig) getRPCAddr() string {
+ return pp.RPCAddr
+}
+
+func (pp IconProviderConfig) BroadcastMode() provider.BroadcastMode {
+ return provider.BroadcastModeBatch
+}
+
+type IconProvider struct {
+ log *zap.Logger
+ PCfg *IconProviderConfig
+ txMu sync.Mutex
+ client *Client
+ metrics *processor.PrometheusMetrics
+ codec Codec
+ StartHeight uint64
+}
+
+type IconIBCHeader struct {
+ Header *types.BTPBlockHeader
+ IsBTPBlock bool
+ Validators [][]byte
+ MainHeight uint64
+}
+
+func NewIconIBCHeader(header *types.BTPBlockHeader, validators [][]byte, height int64) IconIBCHeader {
+ iconIBCHeader := IconIBCHeader{
+ Header: header,
+ Validators: validators,
+ }
+
+ if header == nil {
+ iconIBCHeader.IsBTPBlock = false
+ iconIBCHeader.MainHeight = uint64(height)
+ } else {
+ iconIBCHeader.IsBTPBlock = true
+ iconIBCHeader.MainHeight = header.MainHeight
+ }
+
+ return iconIBCHeader
+}
+
+func (h IconIBCHeader) Height() uint64 {
+ return h.MainHeight
+}
+
+func (h IconIBCHeader) NextValidatorsHash() []byte {
+ // nextproofcontext hash is the nextvalidatorHash in BtpHeader
+ if h.IsBTPBlock {
+ return h.Header.NextProofContextHash
+ }
+ return nil
+}
+
+func (h IconIBCHeader) IsCompleteBlock() bool {
+ return h.IsBTPBlock
+}
+
+func (h IconIBCHeader) ConsensusState() ibcexported.ConsensusState {
+ if h.IsBTPBlock {
+ return &icon.ConsensusState{
+ MessageRoot: h.Header.MessageRoot,
+ NextProofContextHash: h.Header.NextProofContextHash,
+ }
+ }
+ return &icon.ConsensusState{}
+}
+func (h IconIBCHeader) ShouldUpdateWithZeroMessage() bool {
+ if h.Header != nil && h.Header.MessageCount == 0 {
+ return true
+ }
+ return false
+}
+
+//ChainProvider Methods
+
+func (icp *IconProvider) Init(ctx context.Context) error {
+ // if _, err := os.Stat(icp.PCfg.Keystore); err != nil {
+ // return err
+ // }
+
+ // ksByte, err := os.ReadFile(icp.PCfg.Keystore)
+ // if err != nil {
+ // return err
+ // }
+
+ // wallet, err := wallet.NewFromKeyStore(ksByte, []byte(icp.PCfg.Password))
+ // if err != nil {
+ // return err
+ // }
+ // icp.AddWallet(wallet)
+ return nil
+}
+
+func (icp *IconProvider) NewClientState(
+ dstChainID string,
+ dstUpdateHeader provider.IBCHeader,
+ dstTrustingPeriod,
+ dstUbdPeriod time.Duration,
+ allowUpdateAfterExpiry,
+ allowUpdateAfterMisbehaviour bool,
+) (ibcexported.ClientState, error) {
+
+ if !dstUpdateHeader.IsCompleteBlock() {
+ return nil, fmt.Errorf("Not complete block at height:%d", dstUpdateHeader.Height())
+ }
+
+ if icp.PCfg.BlockInterval == 0 {
+ return nil, fmt.Errorf("Blockinterval cannot be empty in Icon config")
+ }
+
+ trustingBlockPeriod := uint64(dstTrustingPeriod) / (icp.PCfg.BlockInterval * uint64(common.NanoToMilliRatio))
+
+ return &icon.ClientState{
+ // In case of Icon: Trusting Period is block Difference // see: light.proto in ibc-integration
+ TrustingPeriod: trustingBlockPeriod,
+ FrozenHeight: 0,
+ MaxClockDrift: 3600,
+ LatestHeight: dstUpdateHeader.Height(),
+ SrcNetworkId: getSrcNetworkId(icp.PCfg.ICONNetworkID),
+ NetworkId: uint64(icp.PCfg.BTPNetworkID),
+ NetworkTypeId: uint64(icp.PCfg.BTPNetworkTypeID),
+ }, nil
+
+}
+
+func (icp *IconProvider) ConnectionHandshakeProof(ctx context.Context, msgOpenInit provider.ConnectionInfo, height uint64) (provider.ConnectionProof, error) {
+ clientState, clientStateProof, consensusStateProof, connStateProof, proofHeight, err := icp.GenerateConnHandshakeProof(ctx, int64(msgOpenInit.Height), msgOpenInit.ClientID, msgOpenInit.ConnID)
+ if err != nil {
+ return provider.ConnectionProof{}, err
+ }
+
+ if len(connStateProof) == 0 {
+ return provider.ConnectionProof{}, fmt.Errorf("Received invalid zero length connection state proof")
+ }
+
+ return provider.ConnectionProof{
+ ClientState: clientState,
+ ClientStateProof: clientStateProof,
+ ConsensusStateProof: consensusStateProof,
+ ConnectionStateProof: connStateProof,
+ ProofHeight: proofHeight.(clienttypes.Height),
+ }, nil
+
+}
+
+func (icp *IconProvider) ConnectionProof(ctx context.Context, msgOpenAck provider.ConnectionInfo, height uint64) (provider.ConnectionProof, error) {
+
+ connState, err := icp.QueryConnection(ctx, int64(msgOpenAck.Height), msgOpenAck.ConnID)
+ if err != nil {
+ return provider.ConnectionProof{}, err
+ }
+ return provider.ConnectionProof{
+ ConnectionStateProof: connState.Proof,
+ ProofHeight: connState.ProofHeight,
+ }, nil
+}
+
+func (icp *IconProvider) ChannelProof(ctx context.Context, msg provider.ChannelInfo, height uint64) (provider.ChannelProof, error) {
+
+ channelResult, err := icp.QueryChannel(ctx, int64(msg.Height), msg.ChannelID, msg.PortID)
+ if err != nil {
+ return provider.ChannelProof{}, nil
+ }
+ return provider.ChannelProof{
+ Proof: channelResult.Proof,
+ ProofHeight: channelResult.ProofHeight,
+ Ordering: chantypes.Order(channelResult.Channel.GetOrdering()),
+ Version: channelResult.Channel.Version,
+ }, nil
+}
+
+func (icp *IconProvider) ValidatePacket(msgTransfer provider.PacketInfo, latestBlock provider.LatestBlock) error {
+ if msgTransfer.Sequence <= 0 {
+ return fmt.Errorf("Refuse to relay packet with sequence 0")
+ }
+ if len(msgTransfer.Data) == 0 {
+ return fmt.Errorf("Refuse to relay packet with empty data")
+ }
+ // This should not be possible, as it violates IBC spec
+ if msgTransfer.TimeoutHeight.IsZero() {
+ return fmt.Errorf("refusing to relay packet without a timeout (height or timestamp must be set)")
+ }
+
+ revision := uint64(0)
+ latestClientTypesHeight := clienttypes.NewHeight(revision, latestBlock.Height)
+
+ if !msgTransfer.TimeoutHeight.IsZero() && latestClientTypesHeight.GTE(msgTransfer.TimeoutHeight) {
+ return provider.NewTimeoutHeightError(latestBlock.Height, msgTransfer.TimeoutHeight.RevisionHeight)
+ }
+ // latestTimestamp := uint64(latestBlock.Time.UnixNano())
+ // if msgTransfer.TimeoutTimestamp > 0 && latestTimestamp > msgTransfer.TimeoutTimestamp {
+ // return provider.NewTimeoutTimestampError(latestTimestamp, msgTransfer.TimeoutTimestamp)
+ // }
+
+ return nil
+}
+
+func (icp *IconProvider) PacketCommitment(ctx context.Context, msgTransfer provider.PacketInfo, height uint64) (provider.PacketProof, error) {
+ packetCommitmentResponse, err := icp.QueryPacketCommitment(
+ ctx, int64(msgTransfer.Height), msgTransfer.SourceChannel, msgTransfer.SourcePort, msgTransfer.Sequence,
+ )
+
+ if err != nil {
+ return provider.PacketProof{}, err
+ }
+ return provider.PacketProof{
+ Proof: packetCommitmentResponse.Proof,
+ ProofHeight: packetCommitmentResponse.ProofHeight,
+ }, nil
+}
+
+func (icp *IconProvider) PacketAcknowledgement(ctx context.Context, msgRecvPacket provider.PacketInfo, height uint64) (provider.PacketProof, error) {
+ packetAckResponse, err := icp.QueryPacketAcknowledgement(ctx, int64(msgRecvPacket.Height), msgRecvPacket.DestChannel, msgRecvPacket.DestPort, msgRecvPacket.Sequence)
+ if err != nil {
+ return provider.PacketProof{}, err
+ }
+ return provider.PacketProof{
+ Proof: packetAckResponse.Proof,
+ ProofHeight: packetAckResponse.ProofHeight,
+ }, nil
+
+}
+
+func (icp *IconProvider) PacketReceipt(ctx context.Context, msgTransfer provider.PacketInfo, height uint64) (provider.PacketProof, error) {
+ packetReceiptResponse, err := icp.QueryPacketReceipt(ctx, int64(msgTransfer.Height), msgTransfer.DestChannel, msgTransfer.DestPort, msgTransfer.Sequence)
+
+ if err != nil {
+ return provider.PacketProof{}, err
+ }
+ return provider.PacketProof{
+ Proof: packetReceiptResponse.Proof,
+ ProofHeight: packetReceiptResponse.ProofHeight,
+ }, nil
+
+}
+
+func (icp *IconProvider) NextSeqRecv(ctx context.Context, msgTransfer provider.PacketInfo, height uint64) (provider.PacketProof, error) {
+ nextSeqRecvResponse, err := icp.QueryNextSeqRecv(ctx, int64(msgTransfer.Height), msgTransfer.DestChannel, msgTransfer.DestPort)
+ if err != nil {
+ return provider.PacketProof{}, err
+ }
+ return provider.PacketProof{
+ Proof: nextSeqRecvResponse.Proof,
+ ProofHeight: nextSeqRecvResponse.ProofHeight,
+ }, nil
+
+}
+
+func (icp *IconProvider) MsgTransfer(dstAddr string, amount sdk.Coin, info provider.PacketInfo) (provider.RelayerMessage, error) {
+ panic(fmt.Sprintf("%s%s", icp.ChainName(), NOT_IMPLEMENTED))
+}
+
+func (icp *IconProvider) QueryICQWithProof(ctx context.Context, msgType string, request []byte, height uint64) (provider.ICQProof, error) {
+ panic(fmt.Sprintf("%s%s", icp.ChainName(), NOT_IMPLEMENTED))
+}
+
+func (icp *IconProvider) MsgSubmitQueryResponse(chainID string, queryID provider.ClientICQQueryID, proof provider.ICQProof) (provider.RelayerMessage, error) {
+ panic(fmt.Sprintf("%s%s", icp.ChainName(), NOT_IMPLEMENTED))
+}
+
+func (icp *IconProvider) RelayPacketFromSequence(ctx context.Context, src provider.ChainProvider, srch, dsth, seq uint64, srcChanID, srcPortID string, order chantypes.Order) (provider.RelayerMessage, provider.RelayerMessage, error) {
+ msg, err := src.QuerySendPacket(ctx, srcChanID, srcPortID, seq)
+ if err != nil {
+ return nil, nil, err
+ }
+ dstTime, err := icp.BlockTime(ctx, int64(dsth))
+ if err != nil {
+ return nil, nil, err
+ }
+
+ if err := icp.ValidatePacket(msg, provider.LatestBlock{
+ Height: dsth,
+ Time: dstTime,
+ }); err != nil {
+ // TODO: handle
+ }
+
+ return nil, nil, nil
+}
+
+func (icp *IconProvider) AcknowledgementFromSequence(ctx context.Context, dst provider.ChainProvider, dsth, seq uint64, dstChanID, dstPortID, srcChanID, srcPortID string) (provider.RelayerMessage, error) {
+ msgRecvPacket, err := dst.QueryRecvPacket(ctx, dst.ChainId(), dstPortID, seq)
+ if err != nil {
+ return nil, err
+ }
+ pp, err := dst.PacketAcknowledgement(ctx, msgRecvPacket, dsth)
+ if err != nil {
+ return nil, err
+ }
+ msg, err := icp.MsgAcknowledgement(msgRecvPacket, pp)
+ if err != nil {
+ return nil, err
+ }
+ return msg, nil
+}
+
+func (icp *IconProvider) MsgSubmitMisbehaviour(clientID string, misbehaviour ibcexported.ClientMessage) (provider.RelayerMessage, error) {
+ panic(fmt.Sprintf("%s%s", icp.ChainName(), NOT_IMPLEMENTED))
+}
+
+func (icp *IconProvider) ChainName() string {
+ return icp.PCfg.ChainName
+}
+
+func (icp *IconProvider) ChainId() string {
+ return icp.PCfg.ChainID
+}
+
+func (icp *IconProvider) Type() string {
+ return common.IconModule
+}
+
+func (icp *IconProvider) ProviderConfig() provider.ProviderConfig {
+ return icp.PCfg
+}
+
+func (icp *IconProvider) CommitmentPrefix() commitmenttypes.MerklePrefix {
+ return commitmenttypes.NewMerklePrefix(nil)
+}
+
+func (icp *IconProvider) Key() string {
+ return icp.PCfg.Keystore
+}
+
+func (icp *IconProvider) Wallet() (module.Wallet, error) {
+ return icp.RestoreIconKeyStore(icp.PCfg.Keystore, []byte(icp.PCfg.Password))
+}
+
+func (icp *IconProvider) Address() (string, error) {
+ return icp.ShowAddress(icp.PCfg.Keystore)
+}
+
+func (icp *IconProvider) Timeout() string {
+ return icp.PCfg.Timeout
+}
+
+func (icp *IconProvider) TrustingPeriod(ctx context.Context) (time.Duration, error) {
+ return 1000, nil
+}
+
+// not required initially
+func (icp *IconProvider) WaitForNBlocks(ctx context.Context, n int64) error {
+ return nil
+}
+
+func (icp *IconProvider) Sprint(toPrint proto.Message) (string, error) {
+ return "", nil
+}
+
+func (icp *IconProvider) GetBtpMessage(height int64) ([][]byte, error) {
+ pr := types.BTPBlockParam{
+ Height: types.NewHexInt(height),
+ NetworkId: types.NewHexInt(icp.PCfg.BTPNetworkID),
+ }
+
+ msgs, err := icp.client.GetBTPMessage(&pr)
+ if err != nil {
+ return nil, err
+ }
+
+ results := make([][]byte, 0)
+ for _, mg := range msgs {
+ m, err := base64.StdEncoding.DecodeString(mg)
+ if err != nil {
+ return nil, err
+ }
+ results = append(results, m)
+ }
+ return results, nil
+}
+
+func (icp *IconProvider) GetBtpHeader(height int64) (*types.BTPBlockHeader, error) {
+ var header types.BTPBlockHeader
+ encoded, err := icp.client.GetBTPHeader(&types.BTPBlockParam{
+ Height: types.NewHexInt(height),
+ NetworkId: types.NewHexInt(icp.PCfg.BTPNetworkID),
+ })
+ if err != nil {
+ return nil, err
+ }
+
+ _, err = Base64ToData(encoded, &header)
+ if err != nil {
+ return nil, err
+ }
+ return &header, nil
+}
+
+func (icp *IconProvider) GetBTPProof(height int64) ([][]byte, error) {
+ var valSigs types.ValidatorSignatures
+ encoded, err := icp.client.GetBTPProof(&types.BTPBlockParam{
+ Height: types.NewHexInt(int64(height)),
+ NetworkId: types.NewHexInt(icp.PCfg.BTPNetworkID),
+ })
+ if err != nil {
+ return nil, err
+ }
+
+ _, err = Base64ToData(encoded, &valSigs)
+ if err != nil {
+ return nil, err
+ }
+ return valSigs.Signatures, nil
+
+}
+
+func (icp *IconProvider) GetProofContextByHeight(height int64) ([][]byte, error) {
+ var validatorList types.ValidatorList
+ info, err := icp.client.GetNetworkTypeInfo(int64(height), icp.PCfg.BTPNetworkTypeID)
+ if err != nil {
+ return nil, err
+ }
+
+ _, err = Base64ToData(string(info.NextProofContext), &validatorList)
+ if err != nil {
+ return nil, err
+ }
+ return validatorList.Validators, nil
+}
+
+func (icp *IconProvider) GetCurrentBtpNetworkStartHeight() (int64, error) {
+ info, err := icp.client.GetBTPNetworkInfo(&types.BTPNetworkInfoParam{
+ Id: types.NewHexInt(icp.PCfg.BTPNetworkID),
+ })
+ if err != nil {
+ return 0, err
+ }
+ return info.StartHeight.Value()
+}
+
+func (icp *IconProvider) MsgRegisterCounterpartyPayee(portID, channelID, relayerAddr, counterpartyPayeeAddr string) (provider.RelayerMessage, error) {
+ panic(fmt.Sprintf("%s%s", icp.ChainName(), NOT_IMPLEMENTED))
+}
diff --git a/relayer/chains/icon/provider_helper.go b/relayer/chains/icon/provider_helper.go
new file mode 100644
index 000000000..0648e6879
--- /dev/null
+++ b/relayer/chains/icon/provider_helper.go
@@ -0,0 +1,68 @@
+package icon
+
+import (
+ "fmt"
+ "strings"
+
+ codectypes "github.com/cosmos/cosmos-sdk/codec/types"
+ clienttypes "github.com/cosmos/ibc-go/v7/modules/core/02-client/types"
+ ibcexported "github.com/cosmos/ibc-go/v7/modules/core/exported"
+ "github.com/cosmos/relayer/v2/relayer/common"
+ "github.com/icon-project/IBC-Integration/libraries/go/common/icon"
+ itm "github.com/icon-project/IBC-Integration/libraries/go/common/tendermint"
+)
+
+// Implement when a new chain is added to ICON IBC Contract
+func (icp *IconProvider) ClientToAny(clientId string, clientStateB []byte) (*codectypes.Any, error) {
+ if strings.Contains(clientId, common.IconLightClient) {
+ var clientState icon.ClientState
+ err := icp.codec.Marshaler.Unmarshal(clientStateB, &clientState)
+ if err != nil {
+ return nil, err
+ }
+ return clienttypes.PackClientState(&clientState)
+ }
+ if strings.Contains(clientId, common.TendermintLightClient) {
+ var clientState itm.ClientState
+ err := icp.codec.Marshaler.Unmarshal(clientStateB, &clientState)
+ if err != nil {
+ return nil, err
+ }
+
+ return clienttypes.PackClientState(&clientState)
+ }
+ return nil, fmt.Errorf("unknown client type")
+}
+
+func (icp *IconProvider) ConsensusToAny(clientId string, cb []byte) (*codectypes.Any, error) {
+ if strings.Contains(clientId, common.IconLightClient) {
+ var consensusState icon.ConsensusState
+ err := icp.codec.Marshaler.Unmarshal(cb, &consensusState)
+ if err != nil {
+ return nil, err
+ }
+ return clienttypes.PackConsensusState(&consensusState)
+ }
+ if strings.Contains(clientId, common.TendermintLightClient) {
+ var consensusState itm.ConsensusState
+ err := icp.codec.Marshaler.Unmarshal(cb, &consensusState)
+ if err != nil {
+ return nil, err
+ }
+
+ return clienttypes.PackConsensusState(&consensusState)
+ }
+ return nil, fmt.Errorf("unknown consensus type")
+}
+
+func (icp *IconProvider) MustReturnIconClientState(cs ibcexported.ClientState) (*icon.ClientState, error) {
+ if !strings.Contains(cs.ClientType(), "icon") {
+ return nil, fmt.Errorf("Is not icon client state")
+ }
+
+ iconClient, ok := cs.(*icon.ClientState)
+ if !ok {
+ return nil, fmt.Errorf("Unable to return client state")
+ }
+ return iconClient, nil
+}
diff --git a/relayer/chains/icon/provider_test.go b/relayer/chains/icon/provider_test.go
new file mode 100644
index 000000000..c52e7e83a
--- /dev/null
+++ b/relayer/chains/icon/provider_test.go
@@ -0,0 +1,479 @@
+package icon
+
+import (
+ "encoding/hex"
+ "fmt"
+ "math/big"
+ "path/filepath"
+ "testing"
+
+ conntypes "github.com/cosmos/ibc-go/v7/modules/core/03-connection/types"
+ "github.com/cosmos/ibc-go/v7/modules/core/exported"
+
+ "github.com/cosmos/relayer/v2/relayer/chains/icon/types"
+ "github.com/cosmos/relayer/v2/relayer/common"
+ "github.com/icon-project/IBC-Integration/libraries/go/common/icon"
+ icn "github.com/icon-project/IBC-Integration/libraries/go/common/icon"
+
+ "github.com/stretchr/testify/assert"
+ "go.uber.org/zap"
+)
+
+const (
+ testCA = "cx58bca8a4110e96b50e1bd9eeb5e429eed5ba94b4"
+)
+
+func TestAddr(t *testing.T) {
+ b := isValidIconContractAddress(testCA)
+ assert.True(t, b)
+
+ assert.False(t, isValidIconContractAddress(testCA[1:]))
+}
+
+func TestConnectionDecode(t *testing.T) {
+
+ input := types.HexBytes("0a0f30372d74656e6465726d696e742d3012230a0131120d4f524445525f4f524445524544120f4f524445525f554e4f524445524544180322200a0f30372d74656e6465726d696e742d30120d636f6e6e656374696f6e2d3533")
+ var conn conntypes.ConnectionEnd
+ _, err := HexBytesToProtoUnmarshal(input, &conn)
+ if err != nil {
+ fmt.Println("error occured", err)
+ return
+ }
+
+ assert.Equal(t, conn.ClientId, "07-tendermint-0")
+}
+
+func GetMockIconProvider(network_id int, contractAddress string) *IconProvider {
+
+ absPath, _ := filepath.Abs("../../../env/godWallet.json")
+
+ pcfg := IconProviderConfig{
+ Keystore: absPath,
+ Password: "gochain",
+ ICONNetworkID: 3,
+ BTPNetworkID: int64(network_id),
+ BTPNetworkTypeID: 1,
+ IbcHandlerAddress: contractAddress,
+ RPCAddr: "http://localhost:9082/api/v3",
+ // RPCAddr: "https://berlin.net.solidwallet.io/api/v3",
+ Timeout: "20s",
+ BlockInterval: 2000,
+ }
+ log, _ := zap.NewProduction()
+ p, _ := pcfg.NewProvider(log, "", false, "icon")
+
+ iconProvider, _ := p.(*IconProvider)
+ return iconProvider
+
+}
+
+func TestNetworkSectionHashCheck(t *testing.T) {
+
+ prevNetworkSectionHash, _ := hex.DecodeString("b791b4b069c561ca31093f825f083f6cc3c8e5ad5135625becd2ff77a8ccfa1e")
+ messageRoot, _ := hex.DecodeString("84d8e19eb09626e4a94212d3a9db54bc16a75dfd791858c0fab3032b944f657a")
+ nextProofContextHash, _ := hex.DecodeString("d090304264eeee3c3562152f2dc355601b0b423a948824fd0a012c11c3fc2fb4")
+ header := types.BTPBlockHeader{
+ MainHeight: 27,
+ Round: 0,
+ NextProofContextHash: nextProofContextHash,
+ NetworkID: 1,
+ UpdateNumber: 0,
+ PrevNetworkSectionHash: prevNetworkSectionHash,
+ MessageCount: 1,
+ MessageRoot: messageRoot,
+ }
+ networkSectionhash := types.NewNetworkSection(&header).Hash()
+ expectNetworkSection, _ := hex.DecodeString("aa517deb1e03f1d461e0f463fa5ebd0126d8a9153fde80778d7d1a1bdfa050fc")
+ assert.Equal(t, networkSectionhash, expectNetworkSection)
+}
+
+func TestMsgOpenTryProof(t *testing.T) {
+ connOpenTry := common.MustHexStrToBytes("0x0a0c69636f6e636c69656e742d301a3f0a1d2f74656e6465726d696e742e6c696768742e436c69656e745374617465121e0a086c6f63616c6e65741204080110031a0508809c9c3938f1574001480122260a0f30372d74656e6465726d696e742d30120c636f6e6e656374696f6e2d301a050a0369626332230a0131120d4f524445525f4f524445524544120f4f524445525f554e4f5244455245443a0410b2e70442280a0208010a22122020e8ad866d375237abaf35961d5086ab95e51a4671d00fb582ecb0171e6509f14a4c0a240801122060a6eacf908ed8c0448ceee36a02bac97e9c269d094ebdeb68d94e0d61e214790a240801122035216273847e1b55f467bfe28faccc9b4cdf7b4fb28e2e78b6aa4a190bafc375524a0a221220fa7a698e60b3ce425bbafba23a24cf7801cdca2ad19419bff6b9ff8e94c92e2e0a240801122035216273847e1b55f467bfe28faccc9b4cdf7b4fb28e2e78b6aa4a190bafc3755a0310f157622e617263687761793164787979787968797035686b7a676c3372776b6a666b63773530333032636137676539647072")
+ msgRoot := common.MustHexStrToBytes("4d9b87ce82ba0a1b32791f085cb2785b9e84a9e17f727a8022457186397ccc0f")
+ // consensusStateByte := common.MustHexStrToBytes("0a0c0896cfc6a30610fd9ac78e0312220a201b6b08c8498a9e9735222491c808b2d34bff22e7e847fb3bb5ca6ab2e506bb741a20e2bdc5125e6de6ff7159ae2618d02488b6c3b78abc51e04b93f46ec8d762bfa7")
+
+ codec := MakeCodec(ModuleBasics, []string{})
+
+ // MsgOpenTry
+ var msgOpenTry conntypes.MsgConnectionOpenTry
+ err := codec.Marshaler.Unmarshal(connOpenTry, &msgOpenTry)
+ assert.NoError(t, err)
+
+ // checking clientState Proof
+
+ fmt.Printf("vlaue is %x : -> \n ", common.GetClientStatePath(msgOpenTry.Counterparty.ClientId))
+ key := common.GetClientStateCommitmentKey(msgOpenTry.Counterparty.ClientId)
+ fmt.Println("clientState value :", msgOpenTry.ClientState.Value)
+
+ approved, err := VerifyProof(key, msgOpenTry.ClientState.Value, msgRoot, msgOpenTry.ProofClient)
+ assert.NoError(t, err)
+ assert.True(t, approved, "failed to verify client state")
+
+ //checking consensus state
+ var cs exported.ClientState
+ err = codec.Marshaler.UnpackAny(msgOpenTry.ClientState, &cs)
+ assert.NoError(t, err)
+ key = common.GetConsensusStateCommitmentKey(msgOpenTry.Counterparty.ClientId,
+ big.NewInt(0),
+ big.NewInt(int64(cs.GetLatestHeight().GetRevisionHeight())))
+
+ // approved, err = VerifyProof(key, consensusStateByte, msgRoot, msgOpenTry.ProofConsensus)
+ // assert.NoError(t, err)
+ // assert.True(t, approved, "failed to validate consensus state")
+
+ // checking connectionState
+ expectedConn := icn.ConnectionEnd{
+ ClientId: msgOpenTry.Counterparty.ClientId,
+ Versions: []*icn.Version{(*icn.Version)(msgOpenTry.CounterpartyVersions[0])},
+ State: icn.ConnectionEnd_STATE_INIT,
+
+ Counterparty: &icn.Counterparty{
+ ClientId: msgOpenTry.ClientId,
+ ConnectionId: "",
+ Prefix: &icon.MerklePrefix{
+ KeyPrefix: []byte("commitments"),
+ },
+ },
+ }
+ key = common.GetConnectionCommitmentKey("connection-0")
+ fmt.Printf("connection Path : %x \n", key)
+ expectedConnByte, err := codec.Marshaler.Marshal(&expectedConn)
+ assert.NoError(t, err)
+ fmt.Printf("connection value: %x \n", expectedConnByte)
+ fmt.Printf("connection value hashed: %x \n", common.Sha3keccak256(expectedConnByte))
+ approved, err = VerifyProof(key, expectedConnByte, msgRoot, msgOpenTry.ProofInit)
+ assert.NoError(t, err)
+}
+
+func TestGetSrcId(t *testing.T) {
+ op := getSrcNetworkId(3)
+ fmt.Printf("test %s", op)
+ assert.Equal(t, op, "0x3.icon")
+}
+
+// func TestConnectionProof(t *testing.T) {
+
+// icp := GetMockIconProvider(1, testCA)
+
+// height := int64(22612)
+// clientID := "07-tendermint-0"
+// connID := "connection-0"
+// ctx := context.Background()
+
+// // proof generation
+// connHandshakeProof, err := icp.ConnectionHandshakeProof(ctx, provider.ConnectionInfo{
+// ClientID: clientID,
+// ConnID: connID,
+// }, uint64(height))
+// assert.NoError(t, err)
+
+// // btpHeader
+// btpHeader, err := icp.GetBtpHeader(height)
+// assert.NoError(t, err)
+// messageRoot := btpHeader.MessageRoot
+
+// // clientState
+// cs, err := icp.QueryClientState(ctx, height, clientID)
+// assert.NoError(t, err)
+
+// // checking the clientstate
+// clientState, err := icp.QueryClientStateResponse(ctx, height, clientID)
+// leaf := getCommitmentHash(common.GetClientStateCommitmentKey(clientID), clientState.ClientState.Value)
+// // checking for the clientState
+// var clientProofs icn.MerkleProofs
+// err = proto.Unmarshal(connHandshakeProof.ClientStateProof, &clientProofs)
+// assert.NoError(t, err)
+// assert.True(t, cryptoutils.VerifyMerkleProof(messageRoot, leaf, clientProofs.Proofs))
+
+// // checking the consensusState
+// consensusHeight := cs.GetLatestHeight()
+// key := common.GetConsensusStateCommitmentKey(clientID,
+// big.NewInt(int64(consensusHeight.GetRevisionNumber())),
+// big.NewInt(int64(consensusHeight.GetRevisionHeight())))
+// consensusState, err := icp.QueryClientConsensusState(ctx, height, clientID, cs.GetLatestHeight())
+// assert.NoError(t, err)
+// fmt.Println("val:", consensusState.ConsensusState)
+
+// commitmentHash := getCommitmentHash(key, consensusState.ConsensusState.Value)
+
+// var consensuProofs icn.MerkleProofs
+// err = proto.Unmarshal(connHandshakeProof.ConsensusStateProof, &consensuProofs)
+// assert.NoError(t, err)
+// assert.True(t, cryptoutils.VerifyMerkleProof(btpHeader.MessageRoot, commitmentHash, consensuProofs.Proofs))
+
+// // checking the connectionState
+// expectedConn := icn.ConnectionEnd{
+// ClientId: clientID,
+// Versions: []*icn.Version{DefaultIBCVersion},
+// State: icn.ConnectionEnd_STATE_INIT,
+// // DelayPeriod: 0,
+
+// Counterparty: &icn.Counterparty{
+// ClientId: "iconclient-0",
+// ConnectionId: "",
+// Prefix: &icn.MerklePrefix{
+// KeyPrefix: []byte("ibc"),
+// },
+// },
+// }
+
+// expectedConnByte, err := proto.Marshal(&expectedConn)
+// assert.NoError(t, err)
+
+// callParam := icp.prepareCallParams(MethodGetConnection, map[string]interface{}{
+// "connectionId": connID,
+// }, callParamsWithHeight(types.NewHexInt(height)))
+
+// var conn_string_ types.HexBytes
+// err = icp.client.Call(callParam, &conn_string_)
+// actual_connection, err := conn_string_.Value()
+// assert.NoError(t, err)
+
+// fmt.Println("exect connection ", conn_string_)
+// fmt.Printf("exect marshal byte %x \n ", expectedConnByte)
+// assert.Equal(t, expectedConnByte, actual_connection)
+// commitmentHash = getCommitmentHash(common.GetConnectionCommitmentKey(connID), expectedConnByte)
+
+// // proofs:
+// var connectionProofs icn.MerkleProofs
+// err = proto.Unmarshal(connHandshakeProof.ConnectionStateProof, &connectionProofs)
+// assert.NoError(t, err)
+// assert.True(t, cryptoutils.VerifyMerkleProof(btpHeader.MessageRoot, commitmentHash, connectionProofs.Proofs))
+// }
+
+// func TestClientProofOnly(t *testing.T) {
+
+// icp := GetMockIconProvider(1, testCA)
+
+// height := int64(22612)
+// clientID := "07-tendermint-0"
+// connID := "connection-0"
+// ctx := context.Background()
+
+// // proof generation
+// connHandshakeProof, err := icp.ConnectionHandshakeProof(ctx, provider.ConnectionInfo{
+// ClientID: clientID,
+// ConnID: connID,
+// }, uint64(height))
+// assert.NoError(t, err)
+
+// // btpHeader
+// btpHeader, err := icp.GetBtpHeader(height)
+// assert.NoError(t, err)
+// messageRoot := btpHeader.MessageRoot
+
+// fmt.Printf("actual root %x \n", messageRoot)
+
+// // checking the clientstate
+// clientState, err := icp.QueryClientStateResponse(ctx, height, clientID)
+// leaf := getCommitmentHash(common.GetClientStateCommitmentKey(clientID), clientState.ClientState.Value)
+// // checking for the clientState
+// fmt.Printf("Commitment path %x \n", common.GetClientStateCommitmentKey(clientID))
+// fmt.Printf("clientState value %x \n", clientState.ClientState.Value)
+// fmt.Printf("Leaf is %x \n", leaf)
+
+// var clientProofs icn.MerkleProofs
+// err = proto.Unmarshal(connHandshakeProof.ClientStateProof, &clientProofs)
+// assert.NoError(t, err)
+// fmt.Printf("calcuated root %x \n", cryptoutils.CalculateRootFromProof(leaf, clientProofs.Proofs))
+// assert.True(t, cryptoutils.VerifyMerkleProof(messageRoot, leaf, clientProofs.Proofs))
+
+// }
+
+// func TestConsensusProofOny(t *testing.T) {
+
+// icp := GetMockIconProvider(1, testCA)
+// height := int64(22612)
+// clientID := "07-tendermint-0"
+// connID := "connection-0"
+// ctx := context.Background()
+
+// // clientState
+// cs, err := icp.QueryClientState(ctx, height, clientID)
+// assert.NoError(t, err)
+
+// // proof generation
+// connHandshakeProof, err := icp.ConnectionHandshakeProof(ctx, provider.ConnectionInfo{
+// ClientID: clientID,
+// ConnID: connID,
+// }, uint64(height))
+// assert.NoError(t, err)
+
+// btpHeader, err := icp.GetBtpHeader(height)
+// assert.NoError(t, err)
+
+// consensusHeight := cs.GetLatestHeight()
+// key := common.GetConsensusStateCommitmentKey(clientID,
+// big.NewInt(int64(consensusHeight.GetRevisionNumber())),
+// big.NewInt(int64(consensusHeight.GetRevisionHeight())))
+// consensusState, err := icp.QueryClientConsensusState(ctx, height, clientID, cs.GetLatestHeight())
+// assert.NoError(t, err)
+
+// commitmentHash := getCommitmentHash(key, consensusState.ConsensusState.Value)
+
+// var consensuProofs icn.MerkleProofs
+// err = proto.Unmarshal(connHandshakeProof.ConsensusStateProof, &consensuProofs)
+// assert.NoError(t, err)
+// assert.True(t, cryptoutils.VerifyMerkleProof(btpHeader.MessageRoot, commitmentHash, consensuProofs.Proofs))
+
+// }
+
+// func TestConnectionProofOny(t *testing.T) {
+
+// icp := GetMockIconProvider(20, testCA)
+// height := int64(82441)
+// clientID := "07-tendermint-0"
+// connID := "connection-0"
+// ctx := context.Background()
+
+// // proof generation
+// connHandshakeProof, err := icp.ConnectionHandshakeProof(ctx, provider.ConnectionInfo{
+// ClientID: clientID,
+// ConnID: connID,
+// }, uint64(height))
+// assert.NoError(t, err)
+
+// btpHeader, err := icp.GetBtpHeader(height)
+// assert.NoError(t, err)
+
+// // checking the connectionState
+// expectedConn := icn.ConnectionEnd{
+// ClientId: clientID,
+// Versions: []*icn.Version{DefaultIBCVersion},
+// State: icn.ConnectionEnd_STATE_INIT,
+// // DelayPeriod: 0,
+
+// Counterparty: &icn.Counterparty{
+// ClientId: "iconclient-0",
+// ConnectionId: "",
+// Prefix: &icn.MerklePrefix{
+// KeyPrefix: []byte("03489bdaa58d7036d4bee2f7aaffcf93853782ba8c96f213c38e11e713a1fcf221000b636f6d6d69746d656e7473"),
+// },
+// },
+// }
+
+// expectedConnByte, err := proto.Marshal(&expectedConn)
+// assert.NoError(t, err)
+
+// callParam := icp.prepareCallParams(MethodGetConnection, map[string]interface{}{
+// "connectionId": connID,
+// }, callParamsWithHeight(types.NewHexInt(height)))
+
+// var conn_string_ types.HexBytes
+// err = icp.client.Call(callParam, &conn_string_)
+// actual_connection, err := conn_string_.Value()
+// assert.NoError(t, err)
+
+// assert.Equal(t, expectedConnByte, actual_connection)
+// commitmentHash := getCommitmentHash(common.GetConnectionCommitmentKey(connID), actual_connection)
+
+// fmt.Printf("test connection commitmenthash %x \n", commitmentHash)
+
+// // proofs:
+// var connectionProofs icn.MerkleProofs
+// err = proto.Unmarshal(connHandshakeProof.ConnectionStateProof, &connectionProofs)
+// assert.NoError(t, err)
+
+// assert.True(t, cryptoutils.VerifyMerkleProof(btpHeader.MessageRoot, commitmentHash, connectionProofs.Proofs))
+
+// }
+
+// func TestChannelOpenTry(t *testing.T) {
+
+// icp := GetMockIconProvider(10, testCA)
+
+// ctx := context.Background()
+// p, err := icp.ChannelProof(ctx, provider.ChannelInfo{Height: 39704, PortID: "mock", ChannelID: "channel-0"}, 39704)
+// assert.NoError(t, err)
+
+// fmt.Println("the proof is ", p)
+// }
+
+// func TestCase(t *testing.T) {
+
+// // var byteArray []byte
+// // str := "[237,251,49,138,154,148,89,201,134,105,90,10,197,188,15,78,147,228,42,239,95,31,53,224,29,119,46,191,132,161,62,222]"
+
+// // err := json.Unmarshal([]byte(str), &byteArray)
+// // if err != nil {
+// // fmt.Println(err)
+// // }
+
+// // fmt.Printf("%x \n ", byteArray)
+
+// // b, _ := hex.DecodeString("0a0f30372d74656e6465726d696e742d3112230a0131120d4f524445525f4f524445524544120f4f524445525f554e4f5244455245441803222b0a0c69636f6e636c69656e742d30120c636f6e6e656374696f6e2d301a0d0a0b636f6d6d69746d656e7473")
+
+// byteHash := common.Sha3keccak256([]byte("connections/connection-0"))
+
+// common.Sha3keccak256()
+// fmt.Printf("heashed value %x \n", byteHash)
+
+// }
+
+// goloop rpc sendtx call \
+// --uri http://localhost:9082/api/v3 \
+// --nid 3 \
+// --step_limit 1000000000\
+// --to cx41b7ad302add7ab50e3e49e9c0ebd778121f797b \
+// --method sendCallMessage \
+// --param _to=eth \
+// --param _data=0x6e696c696e \
+// --key_store /Users/viveksharmapoudel/keystore/godWallet.json \
+// --key_password gochain
+
+// func TestIConProof(t *testing.T) {
+
+// icp := GetMockIconProvider(2, testCA)
+
+// ctx := context.Background()
+// keyhash, _ := hex.DecodeString("d6cae344c4204e849379faefa0048b0e38ce3ae9b10eded15e53e150f4912cf9331088538c700235f7ef61cb7a4a242399696e6bd2d5f8775f99cfd704345c67")
+
+// p, err := icp.QueryIconProof(ctx, 4690, keyhash)
+// assert.NoError(t, err)
+
+// fmt.Println("the proof is ", p)
+// }
+
+func TestHash(t *testing.T) {
+ // b, _ := hex.DecodeString("000000000000000000000000000000000000000002fb02d168e50d427cf9b439c3b643e3967b0ee9141da9296543e488d78182e42392cf99")
+ // assert.Equal(common.Sha3keccak256(b))
+}
+
+// func TestUpdateClientHeader(t *testing.T) {
+
+// p := GetMockIconProvider(2, "dddd")
+
+// height := int64(401)
+// header, _ := p.GetBtpHeader(height)
+// proofContext, _ := p.GetProofContextByHeight(height - 1)
+
+// cs, _ := p.MsgUpdateClientHeader(NewIconIBCHeader(header, proofContext, height), clienttypes.Height{}, nil)
+
+// signedHeader, ok := cs.(*icon.SignedHeader)
+// assert.True(t, ok)
+
+// btpLocalHeader := types.BTPBlockHeader{
+// MainHeight: signedHeader.Header.MainHeight,
+// Round: int32(signedHeader.Header.Round),
+// NextProofContextHash: signedHeader.Header.NextProofContextHash,
+// NetworkSectionToRoot: signedHeader.Header.NetworkSectionToRoot,
+// NetworkID: signedHeader.Header.NetworkId,
+// UpdateNumber: header.UpdateNumber,
+// PrevNetworkSectionHash: signedHeader.Header.PrevNetworkSectionHash,
+// MessageCount: signedHeader.Header.MessageCount,
+// MessageRoot: signedHeader.Header.MessageRoot,
+// // NextProofContext: signedHeader.Header.NextProofContext,
+// }
+// networkSection := types.NewNetworkSection(&btpLocalHeader)
+// fmt.Printf("newtworkSection :%x \n", networkSection.Hash())
+// decision := types.NewNetworkTypeSectionDecision(getSrcNetworkId(3), 1, height, btpLocalHeader.Round,
+// types.NetworkTypeSection{
+// NextProofContextHash: btpLocalHeader.NextProofContextHash,
+// NetworkSectionsRoot: GetNetworkSectionRoot(&btpLocalHeader),
+// })
+
+// isValid, err := VerifyBtpProof(decision, signedHeader.Signatures, proofContext)
+// assert.NoError(t, err)
+
+// assert.True(t, isValid)
+// }
diff --git a/relayer/chains/icon/query.go b/relayer/chains/icon/query.go
new file mode 100644
index 000000000..da40648ae
--- /dev/null
+++ b/relayer/chains/icon/query.go
@@ -0,0 +1,866 @@
+package icon
+
+import (
+ "context"
+ "encoding/hex"
+ "fmt"
+ "math/big"
+ "strings"
+ "time"
+
+ "cosmossdk.io/math"
+ "github.com/avast/retry-go/v4"
+ sdk "github.com/cosmos/cosmos-sdk/types"
+ "github.com/cosmos/gogoproto/proto"
+ "github.com/cosmos/ibc-go/v7/modules/core/exported"
+ ibcexported "github.com/cosmos/ibc-go/v7/modules/core/exported"
+ "github.com/pkg/errors"
+ "go.uber.org/zap"
+
+ //this import should be letter converted to icon types
+
+ "github.com/cosmos/relayer/v2/relayer/chains/icon/cryptoutils"
+ "github.com/cosmos/relayer/v2/relayer/chains/icon/types"
+ "github.com/cosmos/relayer/v2/relayer/common"
+ "github.com/cosmos/relayer/v2/relayer/provider"
+ "github.com/icon-project/IBC-Integration/libraries/go/common/icon"
+ itm "github.com/icon-project/IBC-Integration/libraries/go/common/tendermint"
+
+ transfertypes "github.com/cosmos/ibc-go/v7/modules/apps/transfer/types"
+ clienttypes "github.com/cosmos/ibc-go/v7/modules/core/02-client/types"
+ conntypes "github.com/cosmos/ibc-go/v7/modules/core/03-connection/types"
+ chantypes "github.com/cosmos/ibc-go/v7/modules/core/04-channel/types"
+ committypes "github.com/cosmos/ibc-go/v7/modules/core/23-commitment/types"
+ //change this to icon types after original repo merge
+)
+
+// ***************** methods marked with legacy should be updated only when relayer is runned through legacy method *****************
+
+var _ provider.QueryProvider = &IconProvider{}
+
+const (
+ epoch = 24 * 3600 * 1000
+)
+
+type CallParamOption func(*types.CallParam)
+
+func callParamsWithHeight(height types.HexInt) CallParamOption {
+ return func(cp *types.CallParam) {
+ cp.Height = height
+ }
+}
+
+func (icp *IconProvider) prepareCallParams(methodName string, param map[string]interface{}, options ...CallParamOption) *types.CallParam {
+
+ callData := &types.CallData{
+ Method: methodName,
+ Params: param,
+ }
+
+ callParam := &types.CallParam{
+ FromAddress: types.Address(fmt.Sprintf("hx%s", strings.Repeat("0", 40))),
+ ToAddress: types.Address(icp.PCfg.IbcHandlerAddress),
+ DataType: "call",
+ Data: callData,
+ }
+
+ for _, option := range options {
+ option(callParam)
+ }
+
+ return callParam
+
+}
+
+func (icp *IconProvider) BlockTime(ctx context.Context, height int64) (time.Time, error) {
+ header, err := icp.client.GetBlockHeaderByHeight(height)
+ if err != nil {
+ return time.Time{}, err
+ }
+ return time.Unix(header.Timestamp, 0), nil
+}
+
+// required for cosmos only
+func (icp *IconProvider) QueryTx(ctx context.Context, hashHex string) (*provider.RelayerTxResponse, error) {
+ panic(fmt.Sprintf("%s%s", icp.ChainName(), NOT_IMPLEMENTED))
+}
+
+// required for cosmos only
+func (icp *IconProvider) QueryTxs(ctx context.Context, page, limit int, events []string) ([]*provider.RelayerTxResponse, error) {
+ panic(fmt.Sprintf("%s%s", icp.ChainName(), NOT_IMPLEMENTED))
+}
+
+func (icp *IconProvider) QueryLatestHeight(ctx context.Context) (int64, error) {
+ var block *types.Block
+ var err error
+ retry.Do(func() error {
+ block, err = icp.client.GetLastBlock()
+
+ return err
+ }, retry.Context(ctx),
+ retry.Attempts(queryRetries),
+ retry.OnRetry(func(n uint, err error) {
+ icp.log.Warn("failed to query latestHeight", zap.String("Chain Id", icp.ChainId()))
+ }))
+
+ if block != nil {
+ return block.Height, nil
+ }
+ return 0, fmt.Errorf("failed to query latest block")
+}
+
+// legacy
+func (icp *IconProvider) QueryIBCHeader(ctx context.Context, h int64) (provider.IBCHeader, error) {
+
+ validators, err := icp.GetProofContextByHeight(h)
+ if err != nil {
+ return nil, err
+ }
+ header, err := icp.GetBtpHeader(h)
+ if err != nil {
+ if btpBlockNotPresent(err) {
+ return NewIconIBCHeader(nil, validators, int64(h)), nil
+ }
+ }
+ return NewIconIBCHeader(header, validators, int64(header.MainHeight)), err
+}
+
+func (icp *IconProvider) QuerySendPacket(ctx context.Context, srcChanID, srcPortID string, sequence uint64) (provider.PacketInfo, error) {
+ panic(fmt.Sprintf("%s%s", icp.ChainName(), NOT_IMPLEMENTED))
+}
+
+func (icp *IconProvider) QueryRecvPacket(ctx context.Context, dstChanID, dstPortID string, sequence uint64) (provider.PacketInfo, error) {
+ panic(fmt.Sprintf("%s%s", icp.ChainName(), NOT_IMPLEMENTED))
+}
+
+func (icp *IconProvider) QueryBalance(ctx context.Context, keyName string) (sdk.Coins, error) {
+ addr, err := icp.ShowAddress(keyName)
+ if err != nil {
+ return nil, err
+ }
+
+ return icp.QueryBalanceWithAddress(ctx, addr)
+}
+
+// implementing is not required
+func (icp *IconProvider) QueryBalanceWithAddress(ctx context.Context, addr string) (sdk.Coins, error) {
+ param := types.AddressParam{
+ Address: types.Address(addr),
+ }
+ balance, err := icp.client.GetBalance(¶m)
+ if err != nil {
+ return nil, err
+ }
+ return sdk.Coins{sdk.Coin{
+ Denom: "ICX",
+ Amount: math.NewInt(balance.Int64()),
+ }}, nil
+}
+
+func (icp *IconProvider) QueryUnbondingPeriod(context.Context) (time.Duration, error) {
+ return epoch, nil
+}
+
+// ****************ClientStates******************* //
+// ics 02 - client
+
+func (icp *IconProvider) QueryClientState(ctx context.Context, height int64, clientid string) (ibcexported.ClientState, error) {
+
+ clientStateRes, err := icp.QueryClientStateResponse(ctx, height, clientid)
+ if err != nil {
+ return nil, err
+ }
+
+ clientStateExported, err := clienttypes.UnpackClientState(clientStateRes.ClientState)
+ if err != nil {
+ return nil, err
+ }
+
+ return clientStateExported, nil
+
+}
+
+func (icp *IconProvider) QueryClientStateWithoutProof(ctx context.Context, height int64, clientid string) (ibcexported.ClientState, error) {
+ callParams := icp.prepareCallParams(MethodGetClientState, map[string]interface{}{
+ "clientId": clientid,
+ }, callParamsWithHeight(types.NewHexInt(height)))
+
+ //similar should be implemented
+ var clientStateB types.HexBytes
+ err := icp.client.Call(callParams, &clientStateB)
+ if err != nil {
+ return nil, err
+ }
+
+ clientStateByte, err := clientStateB.Value()
+ if err != nil {
+ return nil, err
+ }
+
+ // TODO: Use ICON Client State after cosmos chain integrated--
+ any, err := icp.ClientToAny(clientid, clientStateByte)
+ if err != nil {
+ return nil, err
+ }
+
+ clientStateRes := clienttypes.NewQueryClientStateResponse(any, nil, clienttypes.NewHeight(0, uint64(height)))
+ clientStateExported, err := clienttypes.UnpackClientState(clientStateRes.ClientState)
+ if err != nil {
+ return nil, err
+ }
+
+ return clientStateExported, nil
+
+}
+
+func (icp *IconProvider) QueryClientStateResponse(ctx context.Context, height int64, srcClientId string) (*clienttypes.QueryClientStateResponse, error) {
+
+ callParams := icp.prepareCallParams(MethodGetClientState, map[string]interface{}{
+ "clientId": srcClientId,
+ }, callParamsWithHeight(types.NewHexInt(height)))
+
+ //similar should be implemented
+ var clientStateB types.HexBytes
+ err := icp.client.Call(callParams, &clientStateB)
+ if err != nil {
+ return nil, err
+ }
+
+ clientStateByte, err := clientStateB.Value()
+ if err != nil {
+ return nil, err
+ }
+
+ any, err := icp.ClientToAny(srcClientId, clientStateByte)
+ if err != nil {
+ return nil, err
+ }
+
+ commitmentHash := getCommitmentHash(common.GetClientStateCommitmentKey(srcClientId), clientStateByte)
+ proof, err := icp.QueryIconProof(ctx, height, commitmentHash)
+ if err != nil {
+ return nil, err
+ }
+
+ return clienttypes.NewQueryClientStateResponse(any, proof, clienttypes.NewHeight(0, uint64(height))), nil
+}
+
+func (icp *IconProvider) QueryClientConsensusState(ctx context.Context, chainHeight int64, clientid string, clientHeight ibcexported.Height) (*clienttypes.QueryConsensusStateResponse, error) {
+
+ h, ok := clientHeight.(clienttypes.Height)
+ if !ok {
+ return nil, fmt.Errorf("clientHeight type mismatched ")
+ }
+
+ heightBytes, err := icp.codec.Marshaler.Marshal(&h)
+ if err != nil {
+ return nil, err
+ }
+
+ callParams := icp.prepareCallParams(MethodGetConsensusState, map[string]interface{}{
+ "clientId": clientid,
+ "height": types.NewHexBytes(heightBytes),
+ })
+
+ var cnsStateHexByte types.HexBytes
+ err = icp.client.Call(callParams, &cnsStateHexByte)
+ if err != nil {
+ return nil, err
+ }
+ cnsStateByte, err := cnsStateHexByte.Value()
+ if err != nil {
+ return nil, err
+ }
+
+ any, err := icp.ConsensusToAny(clientid, cnsStateByte)
+ if err != nil {
+ return nil, err
+ }
+
+ key := common.GetConsensusStateCommitmentKey(clientid, big.NewInt(0), big.NewInt(int64(h.RevisionHeight)))
+ commitmentHash := getCommitmentHash(key, cnsStateByte)
+
+ proof, err := icp.QueryIconProof(ctx, chainHeight, commitmentHash)
+ if err != nil {
+ return nil, err
+ }
+
+ return &clienttypes.QueryConsensusStateResponse{
+ ConsensusState: any,
+ Proof: proof,
+ ProofHeight: clienttypes.NewHeight(0, uint64(chainHeight)),
+ }, nil
+}
+
+func (icp *IconProvider) QueryUpgradedClient(ctx context.Context, height int64) (*clienttypes.QueryClientStateResponse, error) {
+ panic(fmt.Sprintf("%s%s", icp.ChainName(), NOT_IMPLEMENTED))
+}
+
+func (icp *IconProvider) QueryUpgradedConsState(ctx context.Context, height int64) (*clienttypes.QueryConsensusStateResponse, error) {
+ panic(fmt.Sprintf("%s%s", icp.ChainName(), NOT_IMPLEMENTED))
+}
+
+func (icp *IconProvider) QueryConsensusState(ctx context.Context, height int64) (ibcexported.ConsensusState, int64, error) {
+ panic(fmt.Sprintf("%s%s", icp.ChainName(), NOT_IMPLEMENTED))
+}
+
+// query all the clients of the chain
+func (icp *IconProvider) QueryClients(ctx context.Context) (clienttypes.IdentifiedClientStates, error) {
+ seq, err := icp.getNextSequence(ctx, MethodGetNextClientSequence)
+
+ if err != nil {
+ return nil, err
+ }
+
+ if seq == 0 {
+ return nil, nil
+ }
+
+ identifiedClientStates := make(clienttypes.IdentifiedClientStates, 0)
+ for i := 0; i <= int(seq)-1; i++ {
+ clientIdentifier := common.GetIdentifier(common.TendermintLightClient, i)
+ callParams := icp.prepareCallParams(MethodGetClientState, map[string]interface{}{
+ "clientId": clientIdentifier,
+ })
+
+ //similar should be implemented
+ var clientStateB types.HexBytes
+ err := icp.client.Call(callParams, &clientStateB)
+ if err != nil {
+ return nil, err
+ }
+ clientStateBytes, _ := clientStateB.Value()
+
+ // TODO: Use ICON Client State after cosmos chain integrated--
+ var clientState itm.ClientState
+ if err = icp.codec.Marshaler.Unmarshal(clientStateBytes, &clientState); err != nil {
+ return nil, err
+ }
+
+ identifiedClientStates = append(identifiedClientStates, clienttypes.NewIdentifiedClientState(clientIdentifier, &clientState))
+
+ }
+ return identifiedClientStates, nil
+}
+
+// query connection to the ibc host based on the connection-id
+func (icp *IconProvider) QueryConnection(ctx context.Context, height int64, connectionid string) (*conntypes.QueryConnectionResponse, error) {
+
+ callParam := icp.prepareCallParams(MethodGetConnection, map[string]interface{}{
+ "connectionId": connectionid,
+ }, callParamsWithHeight(types.NewHexInt(height)))
+
+ var conn_string_ types.HexBytes
+ err := icp.client.Call(callParam, &conn_string_)
+ if err != nil {
+ return emptyConnRes, err
+ }
+
+ connectionBytes, err := conn_string_.Value()
+ if err != nil {
+ return emptyConnRes, err
+ }
+
+ var conn conntypes.ConnectionEnd
+ _, err = HexBytesToProtoUnmarshal(conn_string_, &conn)
+ if err != nil {
+ return emptyConnRes, err
+ }
+
+ key := common.GetConnectionCommitmentKey(connectionid)
+ commitmentHash := getCommitmentHash(key, connectionBytes)
+
+ proof, err := icp.QueryIconProof(ctx, height, commitmentHash)
+ if err != nil {
+ return emptyConnRes, err
+ }
+
+ return conntypes.NewQueryConnectionResponse(conn, proof, clienttypes.NewHeight(0, uint64(height))), nil
+
+}
+
+var emptyConnRes = conntypes.NewQueryConnectionResponse(
+ conntypes.NewConnectionEnd(
+ conntypes.UNINITIALIZED,
+ "client",
+ conntypes.NewCounterparty(
+ "client",
+ "connection",
+ committypes.MerklePrefix(committypes.NewMerklePrefix(make([]byte, 0))),
+ ),
+ []*conntypes.Version{},
+ 0,
+ ),
+ []byte{},
+ clienttypes.NewHeight(0, 0),
+)
+
+// ics 03 - connection
+func (icp *IconProvider) QueryConnections(ctx context.Context) (conns []*conntypes.IdentifiedConnection, err error) {
+
+ nextSeq, err := icp.getNextSequence(ctx, MethodGetNextConnectionSequence)
+ if err != nil {
+ return nil, err
+ }
+ if nextSeq == 0 {
+ return nil, nil
+ }
+
+ for i := 0; i <= int(nextSeq)-1; i++ {
+ connectionId := common.GetIdentifier(common.ConnectionKey, i)
+ var conn_string_ types.HexBytes
+ err := icp.client.Call(icp.prepareCallParams(MethodGetConnection, map[string]interface{}{
+ "connectionId": connectionId,
+ }), &conn_string_)
+ if err != nil {
+ icp.log.Error("unable to fetch connection for ", zap.String("connection id", connectionId))
+ continue
+ }
+
+ var conn conntypes.ConnectionEnd
+ _, err = HexBytesToProtoUnmarshal(conn_string_, &conn)
+ if err != nil {
+ icp.log.Info("unable to unmarshal connection for ", zap.String("connection id ", connectionId))
+ continue
+ }
+ // Only return open conenctions
+ if conn.State == conntypes.OPEN {
+ identifiedConn := conntypes.IdentifiedConnection{
+ Id: connectionId,
+ ClientId: conn.ClientId,
+ Versions: conn.Versions,
+ State: conn.State,
+ Counterparty: conn.Counterparty,
+ DelayPeriod: conn.DelayPeriod,
+ }
+ conns = append(conns, &identifiedConn)
+ }
+ }
+
+ return conns, nil
+}
+
+func (icp *IconProvider) getNextSequence(ctx context.Context, methodName string) (uint64, error) {
+
+ var seq types.HexInt
+ switch methodName {
+ case MethodGetNextClientSequence:
+ callParam := icp.prepareCallParams(MethodGetNextClientSequence, map[string]interface{}{})
+ if err := icp.client.Call(callParam, &seq); err != nil {
+ return 0, err
+ }
+ case MethodGetNextChannelSequence:
+ callParam := icp.prepareCallParams(MethodGetNextChannelSequence, map[string]interface{}{})
+ if err := icp.client.Call(callParam, &seq); err != nil {
+ return 0, err
+ }
+ case MethodGetNextConnectionSequence:
+ callParam := icp.prepareCallParams(MethodGetNextConnectionSequence, map[string]interface{}{})
+ if err := icp.client.Call(callParam, &seq); err != nil {
+ return 0, err
+ }
+ default:
+ return 0, errors.New("Invalid method name")
+ }
+ val, _ := seq.Value()
+ return uint64(val), nil
+}
+
+func (icp *IconProvider) getAllPorts(ctx context.Context) ([]string, error) {
+ var portIds []string
+ callParam := icp.prepareCallParams(MethodGetAllPorts, map[string]interface{}{})
+ if err := icp.client.Call(callParam, &portIds); err != nil {
+ return nil, err
+ }
+ return portIds, nil
+}
+
+func (icp *IconProvider) QueryConnectionsUsingClient(ctx context.Context, height int64, clientid string) (*conntypes.QueryConnectionsResponse, error) {
+ panic(fmt.Sprintf("%s%s", icp.ChainName(), NOT_IMPLEMENTED))
+}
+func (icp *IconProvider) GenerateConnHandshakeProof(ctx context.Context, height int64, clientId, connId string) (ibcexported.ClientState,
+ []byte, []byte, []byte,
+ ibcexported.Height, error) {
+
+ // clientProof
+ clientResponse, err := icp.QueryClientStateResponse(ctx, height, clientId)
+ if err != nil {
+ return nil, nil, nil, nil, clienttypes.Height{}, err
+ }
+
+ // clientState
+ anyClientState := clientResponse.ClientState
+ clientState_, err := clienttypes.UnpackClientState(anyClientState)
+ if err != nil {
+ return nil, nil, nil, nil, clienttypes.Height{}, err
+ }
+
+ // consensusRes
+ consensusRes, err := icp.QueryClientConsensusState(ctx, height, clientId, clientState_.GetLatestHeight())
+ if err != nil {
+ return nil, nil, nil, nil, clienttypes.Height{}, err
+ }
+
+ // connectionProof
+ connResponse, err := icp.QueryConnection(ctx, height, connId)
+ if err != nil {
+ return nil, nil, nil, nil, clienttypes.Height{}, err
+ }
+
+ return clientState_, clientResponse.Proof, consensusRes.Proof, connResponse.Proof, clienttypes.NewHeight(0, uint64(height)), nil
+}
+
+// ics 04 - channel
+func (icp *IconProvider) QueryChannel(ctx context.Context, height int64, channelid, portid string) (chanRes *chantypes.QueryChannelResponse, err error) {
+
+ callParam := icp.prepareCallParams(MethodGetChannel, map[string]interface{}{
+ "channelId": channelid,
+ "portId": portid,
+ }, callParamsWithHeight(types.NewHexInt(height)))
+
+ var _channel types.HexBytes
+ err = icp.client.Call(callParam, &_channel)
+ if err != nil {
+ return emptyChannelRes, err
+ }
+
+ channelBytes, err := _channel.Value()
+ if err != nil {
+ return emptyChannelRes, err
+ }
+
+ var channel icon.Channel
+ _, err = HexBytesToProtoUnmarshal(_channel, &channel)
+ if err != nil {
+ return emptyChannelRes, err
+ }
+
+ channelCommitment := common.GetChannelCommitmentKey(portid, channelid)
+ commitmentHash := getCommitmentHash(channelCommitment, channelBytes)
+ proof, err := icp.QueryIconProof(ctx, height, commitmentHash)
+ if err != nil {
+ return emptyChannelRes, err
+ }
+
+ cosmosChan := chantypes.NewChannel(
+ chantypes.State(channel.State),
+ chantypes.Order(channel.Ordering),
+ chantypes.NewCounterparty(
+ channel.Counterparty.PortId,
+ channel.Counterparty.ChannelId),
+ channel.ConnectionHops,
+ channel.Version,
+ )
+
+ return chantypes.NewQueryChannelResponse(cosmosChan, proof, clienttypes.NewHeight(0, uint64(height))), nil
+}
+
+var emptyChannelRes = chantypes.NewQueryChannelResponse(
+ chantypes.NewChannel(
+ chantypes.UNINITIALIZED,
+ chantypes.UNORDERED,
+ chantypes.NewCounterparty(
+ "port",
+ "channel",
+ ),
+ []string{},
+ "version",
+ ),
+ []byte{},
+ clienttypes.NewHeight(0, 0),
+)
+
+func (icp *IconProvider) QueryChannelClient(ctx context.Context, height int64, channelid, portid string) (*clienttypes.IdentifiedClientState, error) {
+ panic(fmt.Sprintf("%s%s", icp.ChainName(), NOT_IMPLEMENTED))
+}
+
+// is not needed currently for the operation
+// get all the channel and start the init-process
+func (icp *IconProvider) QueryConnectionChannels(ctx context.Context, height int64, connectionid string) ([]*chantypes.IdentifiedChannel, error) {
+ allChannel, err := icp.QueryChannels(ctx)
+ if err != nil {
+ return nil, fmt.Errorf("error querying Channels %v", err)
+ }
+ var identifiedChannels []*chantypes.IdentifiedChannel
+ for _, c := range allChannel {
+ if c.ConnectionHops[0] == connectionid {
+ identifiedChannels = append(identifiedChannels, c)
+ }
+ }
+ return identifiedChannels, nil
+
+}
+
+func (icp *IconProvider) QueryChannels(ctx context.Context) ([]*chantypes.IdentifiedChannel, error) {
+ nextSeq, err := icp.getNextSequence(ctx, MethodGetNextChannelSequence)
+ if err != nil {
+ return nil, err
+ }
+ var channels []*chantypes.IdentifiedChannel
+
+ allPorts, err := icp.getAllPorts(ctx)
+ if err != nil {
+ return nil, err
+ }
+
+ if allPorts == nil || len(allPorts) <= 0 {
+ return channels, nil
+ }
+
+ for i := 0; i <= int(nextSeq)-1; i++ {
+ for _, portId := range allPorts {
+ channelId := common.GetIdentifier(common.ChannelKey, i)
+ var _channel types.HexBytes
+ err := icp.client.Call(icp.prepareCallParams(MethodGetChannel, map[string]interface{}{
+ "channelId": channelId,
+ "portId": portId,
+ }), &_channel)
+ if err != nil {
+ icp.log.Error("unable to fetch channel for ", zap.String("channel-id ", channelId), zap.Error(err))
+ continue
+ }
+
+ if _channel == "" {
+ icp.log.Debug("Channel not present for ", zap.String("channel-id ", channelId), zap.String("port-id ", portId))
+ continue
+ }
+
+ var channel chantypes.Channel
+ _, err = HexBytesToProtoUnmarshal(_channel, &channel)
+ if err != nil {
+ icp.log.Info("Unable to unmarshal channel for ",
+ zap.String("channel-id ", channelId), zap.Error(err))
+ continue
+ }
+
+ // check if the channel is open
+ if channel.State == chantypes.OPEN {
+ identifiedChannel := chantypes.IdentifiedChannel{
+ State: channel.State,
+ Ordering: channel.Ordering,
+ Counterparty: channel.Counterparty,
+ ConnectionHops: channel.ConnectionHops,
+ Version: channel.Version,
+ PortId: portId,
+ ChannelId: channelId,
+ }
+ channels = append(channels, &identifiedChannel)
+ }
+ }
+ }
+
+ return channels, nil
+}
+
+// required to flush packets
+func (icp *IconProvider) QueryPacketCommitments(ctx context.Context, height uint64, channelid, portid string) (commitments *chantypes.QueryPacketCommitmentsResponse, err error) {
+ panic(fmt.Sprintf("%s%s", icp.ChainName(), NOT_IMPLEMENTED))
+}
+
+func (icp *IconProvider) QueryPacketAcknowledgements(ctx context.Context, height uint64, channelid, portid string) (acknowledgements []*chantypes.PacketState, err error) {
+ panic(fmt.Sprintf("%s%s", icp.ChainName(), NOT_IMPLEMENTED))
+}
+
+func (icp *IconProvider) QueryUnreceivedPackets(ctx context.Context, height uint64, channelid, portid string, seqs []uint64) ([]uint64, error) {
+ panic(fmt.Sprintf("%s%s", icp.ChainName(), NOT_IMPLEMENTED))
+}
+
+func (icp *IconProvider) QueryUnreceivedAcknowledgements(ctx context.Context, height uint64, channelid, portid string, seqs []uint64) ([]uint64, error) {
+ panic(fmt.Sprintf("%s%s", icp.ChainName(), NOT_IMPLEMENTED))
+}
+
+func (icp *IconProvider) QueryNextSeqAck(ctx context.Context, height int64, channelid, portid string) (recvRes *chantypes.QueryNextSequenceReceiveResponse, err error) {
+ panic(fmt.Sprintf("%s%s", icp.ChainName(), NOT_IMPLEMENTED))
+}
+
+func (icp *IconProvider) QueryNextSeqRecv(ctx context.Context, height int64, channelid, portid string) (recvRes *chantypes.QueryNextSequenceReceiveResponse, err error) {
+ callParam := icp.prepareCallParams(MethodGetNextSequenceReceive, map[string]interface{}{
+ "portId": portid,
+ "channelId": channelid,
+ }, callParamsWithHeight(types.NewHexInt(height)))
+ var nextSeqRecv types.HexInt
+ if err := icp.client.Call(callParam, &nextSeqRecv); err != nil {
+ return nil, err
+ }
+ key := common.GetNextSequenceRecvCommitmentKey(portid, channelid)
+ keyHash := common.Sha3keccak256(key, []byte(nextSeqRecv))
+
+ proof, err := icp.QueryIconProof(ctx, height, keyHash)
+ if err != nil {
+ return nil, err
+ }
+
+ nextSeq, err := nextSeqRecv.Value()
+ if err != nil {
+ return nil, err
+ }
+ return &chantypes.QueryNextSequenceReceiveResponse{
+ NextSequenceReceive: uint64(nextSeq),
+ Proof: proof,
+ ProofHeight: clienttypes.NewHeight(0, uint64(height)),
+ }, nil
+}
+
+func (icp *IconProvider) QueryPacketCommitment(ctx context.Context, height int64, channelid, portid string, seq uint64) (comRes *chantypes.QueryPacketCommitmentResponse, err error) {
+ callParam := icp.prepareCallParams(MethodGetPacketCommitment, map[string]interface{}{
+ "portId": portid,
+ "channelId": channelid,
+ "sequence": types.NewHexInt(int64(seq)),
+ }, callParamsWithHeight(types.NewHexInt(height)))
+ var packetCommitmentHexBytes types.HexBytes
+ if err := icp.client.Call(callParam, &packetCommitmentHexBytes); err != nil {
+ return nil, err
+ }
+ packetCommitmentBytes, err := packetCommitmentHexBytes.Value()
+ if err != nil {
+ return nil, err
+ }
+ if len(packetCommitmentBytes) == 0 {
+ return nil, fmt.Errorf("Invalid commitment bytes")
+ }
+
+ key := common.GetPacketCommitmentKey(portid, channelid, big.NewInt(int64(seq)))
+ keyHash := common.Sha3keccak256(key, packetCommitmentBytes)
+ proof, err := icp.QueryIconProof(ctx, height, keyHash)
+ if err != nil {
+ return nil, err
+ }
+
+ return &chantypes.QueryPacketCommitmentResponse{
+ Commitment: packetCommitmentBytes,
+ Proof: proof,
+ ProofHeight: clienttypes.NewHeight(0, uint64(height)),
+ }, nil
+}
+
+func (icp *IconProvider) QueryPacketAcknowledgement(ctx context.Context, height int64, channelid, portid string, seq uint64) (ackRes *chantypes.QueryPacketAcknowledgementResponse, err error) {
+ callParam := icp.prepareCallParams(MethodGetPacketAcknowledgementCommitment, map[string]interface{}{
+ "portId": portid,
+ "channelId": channelid,
+ "sequence": types.NewHexInt(int64(seq)),
+ }, callParamsWithHeight(types.NewHexInt(height)))
+
+ var packetAckHexBytes types.HexBytes
+ if err := icp.client.Call(callParam, &packetAckHexBytes); err != nil {
+ return nil, err
+ }
+ packetAckBytes, err := packetAckHexBytes.Value()
+ if err != nil {
+ return nil, err
+ }
+ if len(packetAckBytes) == 0 {
+ return nil, fmt.Errorf("Invalid packet bytes")
+ }
+
+ key := common.GetPacketAcknowledgementCommitmentKey(portid, channelid, big.NewInt(int64(seq)))
+ keyhash := common.Sha3keccak256(key, packetAckBytes)
+
+ proof, err := icp.QueryIconProof(ctx, height, keyhash)
+ if err != nil {
+ return nil, err
+ }
+
+ return &chantypes.QueryPacketAcknowledgementResponse{
+ Acknowledgement: packetAckBytes,
+ Proof: proof,
+ ProofHeight: clienttypes.NewHeight(0, uint64(height)),
+ }, nil
+}
+
+func (icp *IconProvider) QueryPacketReceipt(ctx context.Context, height int64, channelid, portid string, seq uint64) (recRes *chantypes.QueryPacketReceiptResponse, err error) {
+ callParam := icp.prepareCallParams(MethodGetPacketReceipt, map[string]interface{}{
+ "portId": portid,
+ "channelId": channelid,
+ "sequence": types.NewHexInt(int64(seq)),
+ })
+ var packetReceiptHexByte types.HexInt
+ if err := icp.client.Call(callParam, &packetReceiptHexByte); err != nil {
+ packetReceiptHexByte = types.NewHexInt(0)
+ }
+ packetReceipt, err := packetReceiptHexByte.Value()
+ if err != nil {
+ return nil, err
+ }
+
+ keyhash := common.Sha3keccak256(common.GetPacketReceiptCommitmentPath(portid, channelid, big.NewInt(height)))
+
+ proof, err := icp.QueryIconProof(ctx, height, keyhash)
+ if err != nil {
+ return nil, err
+ }
+
+ return &chantypes.QueryPacketReceiptResponse{
+ Received: packetReceipt == 1,
+ Proof: proof,
+ ProofHeight: clienttypes.NewHeight(0, uint64(height)),
+ }, nil
+}
+
+// ics 20 - transfer
+// not required for icon
+func (icp *IconProvider) QueryDenomTrace(ctx context.Context, denom string) (*transfertypes.DenomTrace, error) {
+ panic(fmt.Sprintf("%s%s", icp.ChainName(), NOT_IMPLEMENTED))
+}
+
+// not required for icon
+func (icp *IconProvider) QueryDenomTraces(ctx context.Context, offset, limit uint64, height int64) ([]transfertypes.DenomTrace, error) {
+ panic(fmt.Sprintf("%s%s", icp.ChainName(), NOT_IMPLEMENTED))
+}
+
+func (icp *IconProvider) QueryIconProof(ctx context.Context, height int64, keyHash []byte) ([]byte, error) {
+ merkleProofs := icon.MerkleProofs{}
+
+ messages, err := icp.GetBtpMessage(height)
+
+ if err != nil {
+ return nil, err
+ }
+
+ if len(messages) == 0 {
+ icp.log.Info("BTP Message not present",
+ zap.Int64("Height", height),
+ zap.Int64("BtpNetwork", icp.PCfg.BTPNetworkID))
+ }
+
+ if len(messages) > 1 {
+ merkleHashTree := cryptoutils.NewMerkleHashTree(messages)
+ if err != nil {
+ return nil, err
+ }
+ hashIndex := merkleHashTree.Hashes.FindIndex(keyHash)
+ if hashIndex == -1 {
+ return nil, errors.New(fmt.Sprintf("Btp message at height %d for hash: %x not found", height, string(keyHash)))
+ }
+
+ proof := merkleHashTree.MerkleProof(hashIndex)
+
+ merkleProofs = icon.MerkleProofs{
+ Proofs: proof,
+ }
+ return icp.codec.Marshaler.Marshal(&merkleProofs)
+ }
+ return nil, nil
+}
+
+func (ip *IconProvider) QueryClientPrevConsensusStateHeight(ctx context.Context, chainHeight int64, clientId string, clientHeight int64) (exported.Height, error) {
+ panic("QueryClientPrevConsensusStateHeight not implemented")
+}
+
+func (icp *IconProvider) HexStringToProtoUnmarshal(encoded string, v proto.Message) ([]byte, error) {
+ if encoded == "" {
+ return nil, fmt.Errorf("Encoded string is empty ")
+ }
+
+ input_ := strings.TrimPrefix(encoded, "0x")
+ inputBytes, err := hex.DecodeString(input_)
+ if err != nil {
+ return nil, err
+ }
+
+ err = icp.codec.Marshaler.UnmarshalInterface(inputBytes, v)
+ if err != nil {
+ return nil, err
+ }
+ return inputBytes, nil
+
+}
diff --git a/relayer/chains/icon/query_test.go b/relayer/chains/icon/query_test.go
new file mode 100644
index 000000000..67d2e76f1
--- /dev/null
+++ b/relayer/chains/icon/query_test.go
@@ -0,0 +1,25 @@
+package icon
+
+import (
+ "encoding/hex"
+ "fmt"
+ "strings"
+ "testing"
+
+ clienttypes "github.com/cosmos/ibc-go/v7/modules/core/02-client/types"
+ "github.com/gogo/protobuf/proto"
+ itm "github.com/icon-project/IBC-Integration/libraries/go/common/tendermint"
+ "github.com/stretchr/testify/assert"
+)
+
+func TestAnyTypeConversion(t *testing.T) {
+ clientStateByte := "0x0a0469636f6e1204080210031a0308e80722050880b899292a070880c0cbacf622384a40014801"
+ clB, _ := hex.DecodeString(strings.TrimPrefix(clientStateByte, "0x"))
+ var clientState itm.ClientState
+ proto.Unmarshal(clB, &clientState)
+
+ any, err := clienttypes.PackClientState(&clientState)
+ assert.NoError(t, err)
+ assert.Equal(t, fmt.Sprintf("0x%x", any.Value), clientStateByte)
+
+}
diff --git a/relayer/chains/icon/serialize.go b/relayer/chains/icon/serialize.go
new file mode 100644
index 000000000..485d3e3bc
--- /dev/null
+++ b/relayer/chains/icon/serialize.go
@@ -0,0 +1,143 @@
+package icon
+
+import (
+ "bytes"
+ "encoding/json"
+ "fmt"
+ "sort"
+ "strconv"
+)
+
+type SerializeError struct {
+ position, msg string
+}
+
+func (s *SerializeError) Error() string {
+ return s.position + ":" + s.msg
+}
+
+func serializeString(s string) []byte {
+ ret := []byte(s)
+ buf := new(bytes.Buffer)
+ for _, b := range ret {
+ switch b {
+ case '\\':
+ fallthrough
+ case '{':
+ fallthrough
+ case '}':
+ fallthrough
+ case '[':
+ fallthrough
+ case ']':
+ fallthrough
+ case '.':
+ buf.WriteByte('\\')
+ buf.WriteByte(b)
+ default:
+ buf.WriteByte(b)
+ }
+ }
+ return buf.Bytes()
+}
+
+func serializeList(v_list []interface{}) ([]byte, *SerializeError) {
+ buf := new(bytes.Buffer)
+ for idx, v := range v_list {
+ frag, err := serializeValue(v)
+ if err != nil {
+ err.position = "[" + fmt.Sprint(idx) + "]." + err.position
+ return nil, err
+ }
+ if buf.Len() > 0 {
+ buf.WriteByte('.')
+ }
+ buf.Write(frag)
+ }
+ return buf.Bytes(), nil
+}
+
+func serializeValue(v interface{}) ([]byte, *SerializeError) {
+ if v == nil {
+ return []byte("\\0"), nil
+ }
+ v_dict, ok := v.(map[string]interface{})
+ if ok {
+ frag, err := serializeDict(v_dict, nil, nil)
+ if err != nil {
+ return nil, err
+ }
+ buf := new(bytes.Buffer)
+ buf.WriteByte('{')
+ buf.Write(frag)
+ buf.WriteByte('}')
+ return buf.Bytes(), nil
+ }
+ v_list, ok := v.([]interface{})
+ if ok {
+ frag, err := serializeList(v_list)
+ if err != nil {
+ return nil, err
+ }
+ buf := new(bytes.Buffer)
+ buf.WriteByte('[')
+ buf.Write(frag)
+ buf.WriteByte(']')
+ return buf.Bytes(), nil
+ }
+ v_str, ok := v.(string)
+ if ok {
+ return serializeString(v_str), nil
+ }
+ v_float64, ok := v.(float64)
+ if ok {
+ return []byte(strconv.FormatInt(int64(v_float64), 10)), nil
+ }
+ return nil, &SerializeError{"", fmt.Sprintf("unknown type [%T]", v)}
+}
+
+func serializeDict(d map[string]interface{}, in map[string]bool, ex map[string]bool) ([]byte, *SerializeError) {
+ buf := new(bytes.Buffer)
+ keys := make([]string, 0, len(d))
+ for k := range d {
+ keys = append(keys, k)
+ }
+ sort.Strings(keys)
+ for _, k := range keys {
+ if (in != nil && !in[k]) || (ex != nil && ex[k]) {
+ continue
+ }
+ v := d[k]
+ frag, err := serializeValue(v)
+ if err != nil {
+ return nil, &SerializeError{"." + k + err.position, err.msg}
+ }
+ if buf.Len() > 0 {
+ buf.WriteByte('.')
+ }
+ buf.Write(serializeString(k))
+ buf.WriteByte('.')
+ buf.Write(frag)
+ }
+ return buf.Bytes(), nil
+}
+
+func SerializeMap(d map[string]interface{}, i map[string]bool, e map[string]bool) ([]byte, error) {
+ value, err := serializeDict(d, i, e)
+ if err != nil {
+ return nil, err
+ }
+ return value, nil
+}
+
+func SerializeJSON(s []byte, in map[string]bool, exclude map[string]bool) ([]byte, error) {
+ var params map[string]interface{}
+ if err := json.Unmarshal(s, ¶ms); err != nil {
+ return nil, err
+ }
+ data, err := serializeDict(params, in, exclude)
+ if err != nil {
+ return nil, err
+ }
+ return data, nil
+}
diff --git a/relayer/chains/icon/tx.go b/relayer/chains/icon/tx.go
new file mode 100644
index 000000000..fa3b47f20
--- /dev/null
+++ b/relayer/chains/icon/tx.go
@@ -0,0 +1,873 @@
+package icon
+
+import (
+ "context"
+ "encoding/hex"
+ "fmt"
+ "strings"
+ "sync"
+ "time"
+
+ "github.com/avast/retry-go/v4"
+ "github.com/cosmos/gogoproto/proto"
+ clienttypes "github.com/cosmos/ibc-go/v7/modules/core/02-client/types"
+ conntypes "github.com/cosmos/ibc-go/v7/modules/core/03-connection/types"
+ chantypes "github.com/cosmos/ibc-go/v7/modules/core/04-channel/types"
+ ibcexported "github.com/cosmos/ibc-go/v7/modules/core/exported"
+
+ // tmclient "github.com/cosmos/ibc-go/v7/modules/light-clients/07-tendermint"
+ itm "github.com/icon-project/IBC-Integration/libraries/go/common/tendermint"
+
+ "github.com/cosmos/relayer/v2/relayer/chains/icon/types"
+ "github.com/cosmos/relayer/v2/relayer/provider"
+ "github.com/icon-project/IBC-Integration/libraries/go/common/icon"
+ "go.uber.org/zap"
+)
+
+var (
+ rtyAttNum = uint(5)
+ rtyAtt = retry.Attempts(rtyAttNum)
+ rtyDel = retry.Delay(time.Millisecond * 400)
+ rtyErr = retry.LastErrorOnly(true)
+
+ defaultBroadcastWaitTimeout = 10 * time.Minute
+)
+
+func (icp *IconProvider) MsgCreateClient(clientState ibcexported.ClientState, consensusState ibcexported.ConsensusState) (provider.RelayerMessage, error) {
+
+ clientStateBytes, err := proto.Marshal(clientState)
+ if err != nil {
+ return nil, err
+ }
+
+ consensusStateBytes, err := proto.Marshal(consensusState)
+ if err != nil {
+ return nil, err
+ }
+
+ clS := &types.GenericClientParams[types.MsgCreateClient]{
+ Msg: types.MsgCreateClient{
+ ClientState: types.NewHexBytes(clientStateBytes),
+ ConsensusState: types.NewHexBytes(consensusStateBytes),
+ ClientType: clientState.ClientType(),
+ BtpNetworkId: types.NewHexInt(icp.PCfg.BTPNetworkID),
+ },
+ }
+
+ return icp.NewIconMessage(clS, MethodCreateClient), nil
+}
+
+// Upgrade Client Not Implemented implemented
+func (icp *IconProvider) MsgUpgradeClient(srcClientId string, consRes *clienttypes.QueryConsensusStateResponse, clientRes *clienttypes.QueryClientStateResponse) (provider.RelayerMessage, error) {
+
+ clU := &types.MsgUpdateClient{
+ ClientId: srcClientId,
+ ClientMessage: types.HexBytes(""),
+ }
+
+ return icp.NewIconMessage(clU, MethodUpdateClient), nil
+}
+
+func (icp *IconProvider) MsgRecvPacket(msgTransfer provider.PacketInfo, proof provider.PacketProof) (provider.RelayerMessage, error) {
+ pkt := &icon.Packet{
+ Sequence: msgTransfer.Sequence,
+ SourcePort: msgTransfer.SourcePort,
+ SourceChannel: msgTransfer.SourceChannel,
+ DestinationPort: msgTransfer.DestPort,
+ DestinationChannel: msgTransfer.DestChannel,
+ TimeoutHeight: &icon.Height{
+ RevisionNumber: msgTransfer.TimeoutHeight.RevisionNumber,
+ RevisionHeight: msgTransfer.TimeoutHeight.RevisionHeight,
+ },
+ TimeoutTimestamp: msgTransfer.TimeoutTimestamp,
+ Data: msgTransfer.Data,
+ }
+ pktEncode, err := proto.Marshal(pkt)
+ if err != nil {
+ return nil, err
+ }
+
+ ht := &icon.Height{
+ RevisionNumber: proof.ProofHeight.RevisionNumber,
+ RevisionHeight: proof.ProofHeight.RevisionHeight,
+ }
+ htEncode, err := proto.Marshal(ht)
+ if err != nil {
+ return nil, err
+ }
+ recvPacket := types.MsgPacketRecv{
+ Packet: types.NewHexBytes(pktEncode),
+ Proof: types.NewHexBytes(proof.Proof),
+ ProofHeight: types.NewHexBytes(htEncode),
+ }
+
+ recvPacketMsg := &types.GenericPacketParams[types.MsgPacketRecv]{
+ Msg: recvPacket,
+ }
+
+ return icp.NewIconMessage(recvPacketMsg, MethodRecvPacket), nil
+}
+
+func (icp *IconProvider) MsgAcknowledgement(msgRecvPacket provider.PacketInfo, proofAcked provider.PacketProof) (provider.RelayerMessage, error) {
+
+ pktEncode, err := getIconPacketEncodedBytes(msgRecvPacket)
+ if err != nil {
+ return nil, err
+ }
+ ht := &icon.Height{
+ RevisionNumber: proofAcked.ProofHeight.RevisionNumber,
+ RevisionHeight: proofAcked.ProofHeight.RevisionHeight,
+ }
+ htEncode, err := proto.Marshal(ht)
+ if err != nil {
+ return nil, err
+ }
+ msg := types.MsgPacketAcknowledgement{
+ Packet: types.NewHexBytes(pktEncode),
+ Acknowledgement: types.NewHexBytes(msgRecvPacket.Ack),
+ Proof: types.NewHexBytes(proofAcked.Proof),
+ ProofHeight: types.NewHexBytes(htEncode),
+ }
+
+ packetAckMsg := &types.GenericPacketParams[types.MsgPacketAcknowledgement]{
+ Msg: msg,
+ }
+ return icp.NewIconMessage(packetAckMsg, MethodAckPacket), nil
+}
+
+func (icp *IconProvider) MsgTimeout(msgTransfer provider.PacketInfo, proofUnreceived provider.PacketProof) (provider.RelayerMessage, error) {
+ // return nil, fmt.Errorf("Not implemented on icon")
+ pktEncode, err := getIconPacketEncodedBytes(msgTransfer)
+ if err != nil {
+ return nil, err
+ }
+
+ htEncode, err := proto.Marshal(&icon.Height{
+ RevisionNumber: proofUnreceived.ProofHeight.RevisionNumber,
+ RevisionHeight: proofUnreceived.ProofHeight.RevisionHeight,
+ })
+ if err != nil {
+ return nil, err
+ }
+
+ msg := types.MsgTimeoutPacket{
+ Packet: types.NewHexBytes(pktEncode),
+ Proof: types.NewHexBytes(proofUnreceived.Proof),
+ ProofHeight: types.NewHexBytes(htEncode),
+ NextSequenceRecv: types.NewHexInt(int64(msgTransfer.Sequence)),
+ }
+
+ packetTimeoutMsg := types.GenericPacketParams[types.MsgTimeoutPacket]{
+ Msg: msg,
+ }
+ return icp.NewIconMessage(packetTimeoutMsg, MethodTimeoutPacket), nil
+}
+
+func (ip *IconProvider) MsgTimeoutRequest(msgTransfer provider.PacketInfo, proof provider.PacketProof) (provider.RelayerMessage, error) {
+
+ pktEncode, err := getIconPacketEncodedBytes(msgTransfer)
+ if err != nil {
+ return nil, err
+ }
+
+ proofHeight, err := proto.Marshal(&proof.ProofHeight)
+ if err != nil {
+ return nil, err
+ }
+
+ timeoutMsg := types.MsgRequestTimeout{
+ Packet: types.NewHexBytes(pktEncode),
+ Proof: types.NewHexBytes(proof.Proof),
+ ProofHeight: types.NewHexBytes(proofHeight),
+ }
+
+ msg := types.GenericPacketParams[types.MsgRequestTimeout]{
+ Msg: timeoutMsg,
+ }
+ return ip.NewIconMessage(msg, MethodRequestTimeout), nil
+
+}
+
+func (icp *IconProvider) MsgTimeoutOnClose(msgTransfer provider.PacketInfo, proofUnreceived provider.PacketProof) (provider.RelayerMessage, error) {
+ return nil, fmt.Errorf("Not implemented on icon")
+}
+
+func (icp *IconProvider) MsgConnectionOpenInit(info provider.ConnectionInfo, proof provider.ConnectionProof) (provider.RelayerMessage, error) {
+ cc := &icon.Counterparty{
+ ClientId: info.CounterpartyClientID,
+ ConnectionId: info.CounterpartyConnID,
+ Prefix: (*icon.MerklePrefix)(&info.CounterpartyCommitmentPrefix),
+ }
+ ccEncode, err := icp.codec.Marshaler.Marshal(cc)
+ if err != nil {
+ return nil, err
+ }
+
+ msg := types.MsgConnectionOpenInit{
+ ClientId: info.ClientID,
+ Counterparty: types.NewHexBytes(ccEncode),
+ DelayPeriod: defaultDelayPeriod,
+ }
+
+ connectionOpenMsg := &types.GenericConnectionParam[types.MsgConnectionOpenInit]{
+ Msg: msg,
+ }
+ return icp.NewIconMessage(connectionOpenMsg, MethodConnectionOpenInit), nil
+}
+
+func (icp *IconProvider) MsgConnectionOpenTry(msgOpenInit provider.ConnectionInfo, proof provider.ConnectionProof) (provider.RelayerMessage, error) {
+ cc := &icon.Counterparty{
+ ClientId: msgOpenInit.ClientID,
+ ConnectionId: msgOpenInit.ConnID,
+ Prefix: (*icon.MerklePrefix)(&msgOpenInit.CommitmentPrefix),
+ }
+
+ ccEncode, err := proto.Marshal(cc)
+ if err != nil {
+ return nil, err
+ }
+ clientStateEncode, err := proto.Marshal(proof.ClientState)
+ if err != nil {
+ return nil, err
+ }
+
+ ht := &icon.Height{
+ RevisionNumber: proof.ProofHeight.RevisionNumber,
+ RevisionHeight: proof.ProofHeight.RevisionHeight,
+ }
+ htEncode, err := proto.Marshal(ht)
+ if err != nil {
+ return nil, err
+ }
+
+ consHt := &icon.Height{
+ RevisionNumber: 0,
+ RevisionHeight: proof.ClientState.GetLatestHeight().GetRevisionHeight(),
+ }
+ consHtEncode, err := proto.Marshal(consHt)
+ if err != nil {
+ return nil, err
+ }
+
+ versionEnc, err := proto.Marshal(DefaultIBCVersion)
+ if err != nil {
+ return nil, err
+ }
+
+ msg := types.MsgConnectionOpenTry{
+ ClientId: msgOpenInit.CounterpartyClientID,
+ PreviousConnectionId: msgOpenInit.CounterpartyConnID,
+ ClientStateBytes: types.NewHexBytes(clientStateEncode),
+ Counterparty: types.NewHexBytes(ccEncode),
+ DelayPeriod: defaultDelayPeriod,
+ CounterpartyVersions: []types.HexBytes{types.NewHexBytes(versionEnc)},
+ ProofInit: types.NewHexBytes(proof.ConnectionStateProof),
+ ProofHeight: types.NewHexBytes(htEncode),
+ ProofClient: types.NewHexBytes(proof.ClientStateProof),
+ ProofConsensus: types.NewHexBytes(proof.ConsensusStateProof),
+ ConsensusHeight: types.NewHexBytes(consHtEncode),
+ }
+
+ connectionOpenTryMsg := &types.GenericConnectionParam[types.MsgConnectionOpenTry]{
+ Msg: msg,
+ }
+ return icp.NewIconMessage(connectionOpenTryMsg, MethodConnectionOpenTry), nil
+}
+
+func (icp *IconProvider) MsgConnectionOpenAck(msgOpenTry provider.ConnectionInfo, proof provider.ConnectionProof) (provider.RelayerMessage, error) {
+
+ // proof from chainB should return clientState of chainB tracking chainA
+ iconClientState, err := icp.MustReturnIconClientState(proof.ClientState)
+ if err != nil {
+ return nil, err
+ }
+
+ clientStateEncode, err := icp.codec.Marshaler.Marshal(iconClientState)
+ if err != nil {
+ return nil, err
+ }
+
+ ht := &icon.Height{
+ RevisionNumber: proof.ProofHeight.RevisionNumber,
+ RevisionHeight: proof.ProofHeight.RevisionHeight,
+ }
+ htEncode, err := proto.Marshal(ht)
+ if err != nil {
+ return nil, err
+ }
+
+ consHt := &icon.Height{
+ RevisionNumber: proof.ClientState.GetLatestHeight().GetRevisionNumber(),
+ RevisionHeight: proof.ClientState.GetLatestHeight().GetRevisionHeight(),
+ }
+ consHtEncode, err := proto.Marshal(consHt)
+ if err != nil {
+ return nil, err
+ }
+
+ versionEnc, err := proto.Marshal(DefaultIBCVersion)
+ if err != nil {
+ return nil, err
+ }
+
+ msg := types.MsgConnectionOpenAck{
+ ConnectionId: msgOpenTry.CounterpartyConnID,
+ ClientStateBytes: types.NewHexBytes(clientStateEncode),
+ Version: types.NewHexBytes(versionEnc),
+ CounterpartyConnectionID: msgOpenTry.ConnID,
+ ProofTry: types.NewHexBytes(proof.ConnectionStateProof),
+ ProofClient: types.NewHexBytes(proof.ClientStateProof),
+ ProofConsensus: types.NewHexBytes(proof.ConsensusStateProof),
+ ProofHeight: types.NewHexBytes(htEncode),
+ ConsensusHeight: types.NewHexBytes(consHtEncode),
+ }
+
+ connectionOpenAckMsg := &types.GenericConnectionParam[types.MsgConnectionOpenAck]{
+ Msg: msg,
+ }
+ return icp.NewIconMessage(connectionOpenAckMsg, MethodConnectionOpenAck), nil
+}
+
+func (icp *IconProvider) MsgConnectionOpenConfirm(msgOpenAck provider.ConnectionInfo, proof provider.ConnectionProof) (provider.RelayerMessage, error) {
+ ht := &icon.Height{
+ RevisionNumber: proof.ProofHeight.RevisionNumber,
+ RevisionHeight: proof.ProofHeight.RevisionHeight,
+ }
+ htEncode, err := proto.Marshal(ht)
+ if err != nil {
+ return nil, err
+ }
+ msg := types.MsgConnectionOpenConfirm{
+ ConnectionId: msgOpenAck.CounterpartyConnID,
+ ProofAck: types.NewHexBytes(proof.ConnectionStateProof),
+ ProofHeight: types.NewHexBytes(htEncode),
+ }
+ connectionOpenConfirmMsg := &types.GenericConnectionParam[types.MsgConnectionOpenConfirm]{
+ Msg: msg,
+ }
+ return icp.NewIconMessage(connectionOpenConfirmMsg, MethodConnectionOpenConfirm), nil
+}
+
+func (icp *IconProvider) MsgChannelOpenInit(info provider.ChannelInfo, proof provider.ChannelProof) (provider.RelayerMessage, error) {
+ channel := &icon.Channel{
+ State: icon.Channel_STATE_INIT,
+ Ordering: icon.Channel_Order(info.Order),
+ Counterparty: &icon.Channel_Counterparty{
+ PortId: info.CounterpartyPortID,
+ ChannelId: "",
+ },
+ ConnectionHops: []string{info.ConnID},
+ Version: info.Version,
+ }
+ channelEncode, err := proto.Marshal(channel)
+ if err != nil {
+ return nil, err
+ }
+ msg := types.MsgChannelOpenInit{
+ PortId: info.PortID,
+ Channel: types.NewHexBytes(channelEncode),
+ }
+
+ channelOpenMsg := &types.GenericChannelParam[types.MsgChannelOpenInit]{
+ Msg: msg,
+ }
+ return icp.NewIconMessage(channelOpenMsg, MethodChannelOpenInit), nil
+}
+
+func (icp *IconProvider) MsgChannelOpenTry(msgOpenInit provider.ChannelInfo, proof provider.ChannelProof) (provider.RelayerMessage, error) {
+ channel := &icon.Channel{
+ State: icon.Channel_STATE_TRYOPEN,
+ Ordering: icon.Channel_Order(proof.Ordering),
+ Counterparty: &icon.Channel_Counterparty{
+ PortId: msgOpenInit.PortID,
+ ChannelId: msgOpenInit.ChannelID,
+ },
+ ConnectionHops: []string{msgOpenInit.CounterpartyConnID},
+ Version: proof.Version,
+ }
+
+ channeEncode, err := proto.Marshal(channel)
+ if err != nil {
+ return nil, err
+ }
+ htEncode, err := proto.Marshal(&proof.ProofHeight)
+ if err != nil {
+ return nil, err
+ }
+ msg := types.MsgChannelOpenTry{
+ PortId: msgOpenInit.CounterpartyPortID,
+ PreviousChannelId: msgOpenInit.CounterpartyChannelID,
+ Channel: types.NewHexBytes(channeEncode),
+ CounterpartyVersion: proof.Version,
+ ProofInit: types.NewHexBytes(proof.Proof),
+ ProofHeight: types.NewHexBytes(htEncode),
+ }
+
+ channelOpenTryMsg := &types.GenericChannelParam[types.MsgChannelOpenTry]{
+ Msg: msg,
+ }
+ return icp.NewIconMessage(channelOpenTryMsg, MethodChannelOpenTry), nil
+}
+
+func (icp *IconProvider) MsgChannelOpenAck(msgOpenTry provider.ChannelInfo, proof provider.ChannelProof) (provider.RelayerMessage, error) {
+ ht := &icon.Height{
+ RevisionNumber: proof.ProofHeight.RevisionNumber,
+ RevisionHeight: proof.ProofHeight.RevisionHeight,
+ }
+ htEncode, err := proto.Marshal(ht)
+ if err != nil {
+ return nil, err
+ }
+ msg := types.MsgChannelOpenAck{
+ PortId: msgOpenTry.CounterpartyPortID,
+ ChannelId: msgOpenTry.CounterpartyChannelID,
+ CounterpartyVersion: proof.Version,
+ CounterpartyChannelId: msgOpenTry.ChannelID,
+ ProofTry: types.NewHexBytes(proof.Proof),
+ ProofHeight: types.NewHexBytes(htEncode),
+ }
+ channelOpenAckMsg := &types.GenericChannelParam[types.MsgChannelOpenAck]{
+ Msg: msg,
+ }
+ return icp.NewIconMessage(channelOpenAckMsg, MethodChannelOpenAck), nil
+}
+
+func (icp *IconProvider) MsgChannelOpenConfirm(msgOpenAck provider.ChannelInfo, proof provider.ChannelProof) (provider.RelayerMessage, error) {
+ ht := &icon.Height{
+ RevisionNumber: proof.ProofHeight.RevisionNumber,
+ RevisionHeight: proof.ProofHeight.RevisionHeight,
+ }
+ htEncode, err := proto.Marshal(ht)
+ if err != nil {
+ return nil, err
+ }
+ msg := types.MsgChannelOpenConfirm{
+ PortId: msgOpenAck.CounterpartyPortID,
+ ChannelId: msgOpenAck.CounterpartyChannelID,
+ ProofAck: types.NewHexBytes(proof.Proof),
+ ProofHeight: types.NewHexBytes(htEncode),
+ }
+ channelOpenConfirmMsg := &types.GenericChannelParam[types.MsgChannelOpenConfirm]{
+ Msg: msg,
+ }
+ return icp.NewIconMessage(channelOpenConfirmMsg, MethodChannelOpenConfirm), nil
+}
+
+func (icp *IconProvider) MsgChannelCloseInit(info provider.ChannelInfo, proof provider.ChannelProof) (provider.RelayerMessage, error) {
+ msg := types.MsgChannelCloseInit{
+ PortId: info.PortID,
+ ChannelId: info.ChannelID,
+ }
+
+ channelCloseInitMsg := &types.GenericChannelParam[types.MsgChannelCloseInit]{
+ Msg: msg,
+ }
+ return icp.NewIconMessage(channelCloseInitMsg, MethodChannelCloseInit), nil
+}
+
+func (icp *IconProvider) MsgChannelCloseConfirm(msgCloseInit provider.ChannelInfo, proof provider.ChannelProof) (provider.RelayerMessage, error) {
+ ht := &icon.Height{
+ RevisionNumber: proof.ProofHeight.RevisionNumber,
+ RevisionHeight: proof.ProofHeight.RevisionHeight,
+ }
+ htEncode, err := proto.Marshal(ht)
+ if err != nil {
+ return nil, err
+ }
+
+ msg := types.MsgChannelCloseConfirm{
+ PortId: msgCloseInit.CounterpartyPortID,
+ ChannelId: msgCloseInit.CounterpartyChannelID,
+ ProofInit: types.NewHexBytes(proof.Proof),
+ ProofHeight: types.NewHexBytes(htEncode),
+ }
+
+ channelCloseConfirmMsg := &types.GenericChannelParam[types.MsgChannelCloseConfirm]{
+ Msg: msg,
+ }
+ return icp.NewIconMessage(channelCloseConfirmMsg, MethodChannelCloseConfirm), nil
+}
+
+func (icp *IconProvider) MsgUpdateClientHeader(latestHeader provider.IBCHeader, trustedHeight clienttypes.Height, trustedHeader provider.IBCHeader) (ibcexported.ClientMessage, error) {
+
+ latestIconHeader, ok := latestHeader.(IconIBCHeader)
+ if !ok {
+ return nil, fmt.Errorf("Unsupported IBC Header type. Expected: IconIBCHeader,actual: %T", latestHeader)
+ }
+
+ btp_proof, err := icp.GetBTPProof(int64(latestIconHeader.Header.MainHeight))
+ if err != nil {
+ return nil, err
+ }
+
+ var currentValidatorList types.ValidatorList
+ // subtract 1 because it is a current validator not last validator
+ info, err := icp.client.GetNetworkTypeInfo(int64(latestIconHeader.Header.MainHeight-1), icp.PCfg.BTPNetworkTypeID)
+ if err != nil {
+ return nil, err
+ }
+
+ _, err = Base64ToData(string(info.NextProofContext), ¤tValidatorList)
+ if err != nil {
+ return nil, err
+ }
+
+ var nextValidators types.ValidatorList
+ // subtract 1 because it is a current validator not last validator
+ next_info, err := icp.client.GetNetworkTypeInfo(int64(latestIconHeader.Header.MainHeight), icp.PCfg.BTPNetworkTypeID)
+ if err != nil {
+ return nil, err
+ }
+
+ _, err = Base64ToData(string(next_info.NextProofContext), &nextValidators)
+ if err != nil {
+ return nil, err
+ }
+
+ signedHeader := &icon.SignedHeader{
+ Header: &icon.BTPHeader{
+ MainHeight: uint64(latestIconHeader.Header.MainHeight),
+ Round: uint32(latestIconHeader.Header.Round),
+ NextProofContextHash: latestIconHeader.Header.NextProofContextHash,
+ NetworkSectionToRoot: latestIconHeader.Header.NetworkSectionToRoot,
+ NetworkId: latestIconHeader.Header.NetworkID,
+ UpdateNumber: latestIconHeader.Header.UpdateNumber,
+ PrevNetworkSectionHash: latestIconHeader.Header.PrevNetworkSectionHash,
+ MessageCount: latestIconHeader.Header.MessageCount,
+ MessageRoot: latestIconHeader.Header.MessageRoot,
+ NextValidators: nextValidators.Validators,
+ },
+ Signatures: btp_proof,
+ TrustedHeight: trustedHeight.RevisionHeight,
+ CurrentValidators: currentValidatorList.Validators,
+ }
+
+ return signedHeader, nil
+
+}
+
+func (icp *IconProvider) MsgUpdateClient(clientID string, counterpartyHeader ibcexported.ClientMessage) (provider.RelayerMessage, error) {
+
+ cs := counterpartyHeader.(*itm.TmHeader)
+ clientMsg, err := proto.Marshal(cs)
+ if err != nil {
+ return nil, err
+ }
+
+ msg := types.MsgUpdateClient{
+ ClientId: clientID,
+ ClientMessage: types.NewHexBytes(clientMsg),
+ }
+ updateClientMsg := &types.GenericClientParams[types.MsgUpdateClient]{
+ Msg: msg,
+ }
+ return icp.NewIconMessage(updateClientMsg, MethodUpdateClient), nil
+}
+
+func (icp *IconProvider) SendMessage(ctx context.Context, msg provider.RelayerMessage, memo string) (*provider.RelayerTxResponse, bool, error) {
+
+ var (
+ rlyResp *provider.RelayerTxResponse
+ callbackErr error
+ wg sync.WaitGroup
+ )
+
+ callback := func(rtr *provider.RelayerTxResponse, err error) {
+ rlyResp = rtr
+ callbackErr = err
+ wg.Done()
+ }
+
+ wg.Add(1)
+ if err := retry.Do(func() error {
+ return icp.SendMessagesToMempool(ctx, []provider.RelayerMessage{msg}, memo, ctx, []func(*provider.RelayerTxResponse, error){callback})
+ }, retry.Context(ctx), rtyAtt, rtyDel, rtyErr, retry.OnRetry(func(n uint, err error) {
+ icp.log.Info(
+ "Error building or broadcasting transaction",
+ zap.String("chain_id", icp.PCfg.ChainID),
+ zap.Uint("attempt", n+1),
+ zap.Uint("max_attempts", rtyAttNum),
+ zap.Error(err),
+ )
+ })); err != nil {
+ return nil, false, err
+ }
+
+ wg.Wait()
+
+ if callbackErr != nil {
+ return rlyResp, false, callbackErr
+ }
+
+ if rlyResp.Code != 1 {
+ return rlyResp, false, fmt.Errorf("transaction failed with code: %d", rlyResp.Code)
+ }
+
+ return rlyResp, true, callbackErr
+}
+
+func (icp *IconProvider) parseConfirmedEventLogStr(event types.EventLogStr) provider.RelayerEvent {
+
+ eventName := event.Indexed[0]
+ switch eventName {
+
+ case EventTypeCreateClient:
+ return provider.RelayerEvent{
+ EventType: IconCosmosEventMap[eventName],
+ Attributes: map[string]string{
+ clienttypes.AttributeKeyClientID: event.Indexed[1],
+ },
+ }
+
+ case EventTypeConnectionOpenConfirm:
+ protoConn, err := hex.DecodeString(strings.TrimPrefix(event.Data[0], "0x"))
+ if err != nil {
+ icp.log.Error("Error decoding data for ConnectionOpenConfirm", zap.String("connectionData", event.Data[0]))
+ break
+ }
+ var connEnd icon.ConnectionEnd
+ err = proto.Unmarshal(protoConn, &connEnd)
+ if err != nil {
+ icp.log.Error("Error marshaling connectionEnd", zap.String("connectionData", string(protoConn)))
+ break
+ }
+ return provider.RelayerEvent{
+ EventType: IconCosmosEventMap[eventName],
+ Attributes: map[string]string{
+ conntypes.AttributeKeyConnectionID: event.Indexed[1],
+ conntypes.AttributeKeyClientID: connEnd.ClientId,
+ conntypes.AttributeKeyCounterpartyClientID: connEnd.Counterparty.ClientId,
+ conntypes.AttributeKeyCounterpartyConnectionID: connEnd.Counterparty.ConnectionId,
+ },
+ }
+
+ case EventTypeChannelOpenConfirm, EventTypeChannelCloseConfirm:
+ protoChannel, err := hex.DecodeString(strings.TrimPrefix(event.Data[0], "0x"))
+ if err != nil {
+ icp.log.Error("Error decoding data for ChanOpenConfirm", zap.String("channelData", event.Data[0]))
+ break
+ }
+ var channel icon.Channel
+
+ if err := proto.Unmarshal(protoChannel, &channel); err != nil {
+ icp.log.Error("Error when unmarshalling chanOpenConfirm", zap.String("channelData", string(protoChannel)))
+ }
+ return provider.RelayerEvent{
+ EventType: IconCosmosEventMap[eventName],
+ Attributes: map[string]string{
+ chantypes.AttributeKeyPortID: string(event.Indexed[1]),
+ chantypes.AttributeKeyChannelID: string(event.Indexed[2]),
+ chantypes.AttributeCounterpartyPortID: channel.Counterparty.PortId,
+ chantypes.AttributeCounterpartyChannelID: channel.Counterparty.ChannelId,
+ chantypes.AttributeKeyConnectionID: channel.ConnectionHops[0],
+ },
+ }
+
+ }
+
+ return provider.RelayerEvent{}
+}
+
+func (icp *IconProvider) SendMessages(ctx context.Context, msgs []provider.RelayerMessage, memo string) (*provider.RelayerTxResponse, bool, error) {
+ // Handles 1st msg only
+ for _, msg := range msgs {
+ return icp.SendMessage(ctx, msg, memo)
+ }
+ return nil, false, fmt.Errorf("Use SendMessage and one txn at a time")
+}
+
+func (icp *IconProvider) SendMessagesToMempool(
+ ctx context.Context,
+ msgs []provider.RelayerMessage,
+ memo string,
+ asyncCtx context.Context,
+ asyncCallback []func(*provider.RelayerTxResponse, error),
+) error {
+ icp.txMu.Lock()
+ defer icp.txMu.Unlock()
+ if len(msgs) == 0 {
+ icp.log.Info("Length of Messages is empty ")
+ return nil
+ }
+
+ for _, msg := range msgs {
+ if msg != nil {
+ err := icp.SendIconTransaction(ctx, msg, asyncCtx, asyncCallback)
+ if err != nil {
+ icp.log.Warn("Send Icon Transaction Error", zap.String("method", msg.Type()), zap.Error(err))
+ continue
+ }
+ }
+ }
+
+ return nil
+}
+
+func (icp *IconProvider) SendIconTransaction(
+ ctx context.Context,
+ msg provider.RelayerMessage,
+ asyncCtx context.Context,
+ asyncCallback []func(*provider.RelayerTxResponse, error)) error {
+ m := msg.(*IconMessage)
+ wallet, err := icp.Wallet()
+ if err != nil {
+ return err
+ }
+
+ txParamEst := &types.TransactionParamForEstimate{
+ Version: types.NewHexInt(types.JsonrpcApiVersion),
+ FromAddress: types.Address(wallet.Address().String()),
+ ToAddress: types.Address(icp.PCfg.IbcHandlerAddress),
+ NetworkID: types.NewHexInt(icp.PCfg.ICONNetworkID),
+ DataType: "call",
+ Data: types.CallData{
+ Method: m.Method,
+ Params: m.Params,
+ },
+ }
+
+ step, err := icp.client.EstimateStep(txParamEst)
+ if err != nil {
+ return fmt.Errorf("failed estimating step: %w", err)
+ }
+ stepVal, err := step.Int()
+ if err != nil {
+ return err
+ }
+ stepLimit := types.NewHexInt(int64(stepVal + 200_000))
+
+ txParam := &types.TransactionParam{
+ Version: types.NewHexInt(types.JsonrpcApiVersion),
+ FromAddress: types.Address(wallet.Address().String()),
+ ToAddress: types.Address(icp.PCfg.IbcHandlerAddress),
+ NetworkID: types.NewHexInt(icp.PCfg.ICONNetworkID),
+ StepLimit: stepLimit,
+ DataType: "call",
+ Data: types.CallData{
+ Method: m.Method,
+ Params: m.Params,
+ },
+ }
+
+ if err := icp.client.SignTransaction(wallet, txParam); err != nil {
+ return err
+ }
+ _, err = icp.client.SendTransaction(txParam)
+ if err != nil {
+ return err
+ }
+
+ txhash, err := txParam.TxHash.Value()
+ if err != nil {
+ return err
+ }
+ icp.log.Info("Submitted Transaction", zap.String("chain_id", icp.ChainId()), zap.String("method", m.Method), zap.String("tx_hash", string(txParam.TxHash)))
+
+ // wait for the update client but dont cancel sending message.
+ // If update fails, the subsequent txn will fail, result of update not being fetched concurrently
+ switch m.Method {
+ case MethodUpdateClient:
+ icp.WaitForTxResult(asyncCtx, txhash, m.Method, defaultBroadcastWaitTimeout, asyncCallback)
+ default:
+ go icp.WaitForTxResult(asyncCtx, txhash, m.Method, defaultBroadcastWaitTimeout, asyncCallback)
+ }
+
+ return nil
+}
+
+// TODO: review try to remove wait for Tx from packet-transfer and only use this for client and connection creation
+func (icp *IconProvider) WaitForTxResult(
+ asyncCtx context.Context,
+ txHash []byte,
+ method string,
+ timeout time.Duration,
+ callbacks []func(*provider.RelayerTxResponse, error),
+) error {
+ txhash := types.NewHexBytes(txHash)
+ _, txRes, err := icp.client.WaitForResults(asyncCtx, &types.TransactionHashParam{Hash: txhash})
+ if err != nil {
+ icp.log.Error("Failed to get txn result", zap.String("txHash", string(txhash)), zap.String("method", method), zap.Error(err))
+ if len(callbacks) > 0 {
+ for _, cb := range callbacks {
+ // Call each callback in order since waitForTx is already invoked asyncronously
+ cb(nil, err)
+ }
+ }
+ return err
+ }
+
+ height, err := txRes.BlockHeight.Value()
+ if err != nil {
+ return err
+ }
+
+ var eventLogs []provider.RelayerEvent
+ events := txRes.EventLogs
+ for _, event := range events {
+ if IconCosmosEventMap[event.Indexed[0]] != "" {
+ if event.Addr == types.Address(icp.PCfg.IbcHandlerAddress) {
+ evt := icp.parseConfirmedEventLogStr(event)
+ eventLogs = append(eventLogs, evt)
+ }
+ }
+ }
+
+ status, err := txRes.Status.Int()
+ if status != 1 {
+ err = fmt.Errorf("Transaction Failed to Execute")
+ if len(callbacks) > 0 {
+ for _, cb := range callbacks {
+ // Call each callback in order since waitForTx is already invoked asyncronously
+ cb(nil, err)
+ }
+ }
+ icp.LogFailedTx(method, txRes, err)
+ return err
+
+ }
+
+ rlyResp := &provider.RelayerTxResponse{
+ Height: height,
+ TxHash: string(txRes.TxHash),
+ Code: uint32(status),
+ Data: string(txRes.SCOREAddress),
+ Events: eventLogs,
+ }
+ if len(callbacks) > 0 {
+ for _, cb := range callbacks {
+ // Call each callback in order since waitForTx is already invoked asyncronously
+ cb(rlyResp, err)
+ }
+ }
+
+ // log successful txn
+ icp.LogSuccessTx(method, txRes)
+ return nil
+}
+
+func (icp *IconProvider) LogSuccessTx(method string, result *types.TransactionResult) {
+ stepUsed, _ := result.StepUsed.Value()
+ height, _ := result.BlockHeight.Value()
+
+ icp.log.Info("Successful Transaction",
+ zap.String("chain_id", icp.ChainId()),
+ zap.String("method", method),
+ zap.String("tx_hash", string(result.TxHash)),
+ zap.Int64("height", height),
+ zap.Int64("step_used", stepUsed),
+ )
+}
+
+func (icp *IconProvider) LogFailedTx(method string, result *types.TransactionResult, err error) {
+ stepUsed, _ := result.StepUsed.Value()
+ height, _ := result.BlockHeight.Value()
+
+ icp.log.Info("Failed Transaction",
+ zap.String("chain_id", icp.ChainId()),
+ zap.String("method", method),
+ zap.String("tx_hash", string(result.TxHash)),
+ zap.Int64("height", height),
+ zap.Int64("step_used", stepUsed),
+ zap.Error(err),
+ )
+}
diff --git a/relayer/chains/icon/types/types.go b/relayer/chains/icon/types/types.go
new file mode 100644
index 000000000..7026f4a54
--- /dev/null
+++ b/relayer/chains/icon/types/types.go
@@ -0,0 +1,668 @@
+/*
+ * Copyright 2021 ICON Foundation
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package types
+
+import (
+ "encoding/hex"
+ "encoding/json"
+ "fmt"
+ "math/big"
+ "strconv"
+ "strings"
+
+ "github.com/gorilla/websocket"
+ "github.com/icon-project/IBC-Integration/libraries/go/common/icon"
+ "github.com/icon-project/goloop/common"
+ "github.com/icon-project/goloop/common/codec"
+
+ relayer_common "github.com/cosmos/relayer/v2/relayer/common"
+ "github.com/icon-project/goloop/server/jsonrpc"
+)
+
+const (
+ JsonrpcApiVersion = 3
+ JsonrpcErrorCodeSystem jsonrpc.ErrorCode = -31000
+ JsonrpcErrorCodeTxPoolOverflow jsonrpc.ErrorCode = -31001
+ JsonrpcErrorCodePending jsonrpc.ErrorCode = -31002
+ JsonrpcErrorCodeExecuting jsonrpc.ErrorCode = -31003
+ JsonrpcErrorCodeNotFound jsonrpc.ErrorCode = -31004
+ JsonrpcErrorLackOfResource jsonrpc.ErrorCode = -31005
+ JsonrpcErrorCodeTimeout jsonrpc.ErrorCode = -31006
+ JsonrpcErrorCodeSystemTimeout jsonrpc.ErrorCode = -31007
+ JsonrpcErrorCodeScore jsonrpc.ErrorCode = -30000
+)
+
+const (
+ DuplicateTransactionError = iota + 2000
+ TransactionPoolOverflowError
+ ExpiredTransactionError
+ FutureTransactionError
+ TransitionInterruptedError
+ InvalidTransactionError
+ InvalidQueryError
+ InvalidResultError
+ NoActiveContractError
+ NotContractAddressError
+ InvalidPatchDataError
+ CommittedTransactionError
+)
+
+const (
+ ResultStatusSuccess = "0x1"
+ ResultStatusFailureCodeRevert = 32
+ ResultStatusFailureCodeEnd = 99
+)
+
+type BlockHeader struct {
+ Version int
+ Height int64
+ Timestamp int64
+ Proposer []byte
+ PrevID []byte
+ VotesHash []byte
+ NextValidatorsHash []byte
+ PatchTransactionsHash []byte
+ NormalTransactionsHash []byte
+ LogsBloom []byte
+ Result []byte
+}
+
+type EventLog struct {
+ Addr Address
+ Indexed [][]byte
+ Data [][]byte
+}
+
+type EventLogStr struct {
+ Addr Address `json:"scoreAddress"`
+ Indexed []string `json:"indexed"`
+ Data []string `json:"data"`
+}
+
+type TransactionResult struct {
+ To Address `json:"to"`
+ CumulativeStepUsed HexInt `json:"cumulativeStepUsed"`
+ StepUsed HexInt `json:"stepUsed"`
+ StepPrice HexInt `json:"stepPrice"`
+ EventLogs []EventLogStr `json:"eventLogs"`
+ LogsBloom HexBytes `json:"logsBloom"`
+ Status HexInt `json:"status"`
+ Failure *struct {
+ CodeValue HexInt `json:"code"`
+ MessageValue string `json:"message"`
+ } `json:"failure,omitempty"`
+ SCOREAddress Address `json:"scoreAddress,omitempty"`
+ BlockHash HexBytes `json:"blockHash" validate:"required,t_hash"`
+ BlockHeight HexInt `json:"blockHeight" validate:"required,t_int"`
+ TxIndex HexInt `json:"txIndex" validate:"required,t_int"`
+ TxHash HexBytes `json:"txHash" validate:"required,t_int"`
+}
+
+type TransactionParamForEstimate struct {
+ Version HexInt `json:"version" validate:"required,t_int"`
+ FromAddress Address `json:"from" validate:"required,t_addr_eoa"`
+ ToAddress Address `json:"to" validate:"required,t_addr"`
+ Value HexInt `json:"value,omitempty" validate:"optional,t_int"`
+ Timestamp HexInt `json:"timestamp" validate:"required,t_int"`
+ NetworkID HexInt `json:"nid" validate:"required,t_int"`
+ Nonce HexInt `json:"nonce,omitempty" validate:"optional,t_int"`
+ DataType string `json:"dataType,omitempty" validate:"optional,call|deploy|message|deposit"`
+ Data CallData `json:"data,omitempty"`
+}
+type TransactionParam struct {
+ Version HexInt `json:"version" validate:"required,t_int"`
+ FromAddress Address `json:"from" validate:"required,t_addr_eoa"`
+ ToAddress Address `json:"to" validate:"required,t_addr"`
+ Value HexInt `json:"value,omitempty" validate:"optional,t_int"`
+ StepLimit HexInt `json:"stepLimit" validate:"required,t_int"`
+ Timestamp HexInt `json:"timestamp" validate:"required,t_int"`
+ NetworkID HexInt `json:"nid" validate:"required,t_int"`
+ Nonce HexInt `json:"nonce,omitempty" validate:"optional,t_int"`
+ Signature string `json:"signature" validate:"required,t_sig"`
+ DataType string `json:"dataType,omitempty" validate:"optional,call|deploy|message"`
+ Data CallData `json:"data,omitempty"`
+ TxHash HexBytes `json:"-"`
+}
+
+type BlockHeaderResult struct {
+ StateHash []byte
+ PatchReceiptHash []byte
+ ReceiptHash common.HexBytes
+ ExtensionData []byte
+}
+type TxResult struct {
+ Status int64
+ To []byte
+ CumulativeStepUsed []byte
+ StepUsed []byte
+ StepPrice []byte
+ LogsBloom []byte
+ EventLogs []EventLog
+ ScoreAddress []byte
+ EventLogsHash common.HexBytes
+ TxIndex HexInt
+ BlockHeight HexInt
+}
+
+type CallData struct {
+ Method string `json:"method"`
+ Params interface{} `json:"params,omitempty"`
+}
+
+type GenericClientParams[T MsgCreateClient | MsgUpdateClient] struct {
+ Msg T `json:"msg"`
+}
+
+type MsgCreateClient struct {
+ ClientState HexBytes `json:"clientState"`
+ ConsensusState HexBytes `json:"consensusState"`
+ ClientType string `json:"clientType"`
+ BtpNetworkId HexInt `json:"btpNetworkId"`
+}
+
+type MsgUpdateClient struct {
+ ClientId string `json:"clientId"`
+ ClientMessage HexBytes `json:"clientMessage"`
+}
+
+type GenericChannelParam[T MsgChannelOpenInit | MsgChannelOpenTry | MsgChannelOpenAck | MsgChannelOpenConfirm | MsgChannelCloseInit | MsgChannelCloseConfirm] struct {
+ Msg T `json:"msg"`
+}
+
+type MsgChannelCloseConfirm struct {
+ PortId string `json:"portId"`
+ ChannelId string `json:"channelId"`
+ ProofInit HexBytes `json:"proofInit"`
+ ProofHeight HexBytes `json:"proofHeight"`
+}
+
+type MsgChannelCloseInit struct {
+ PortId string `json:"portId"`
+ ChannelId string `json:"channelId"`
+}
+
+type MsgChannelOpenAck struct {
+ PortId string `json:"portId"`
+ ChannelId string `json:"channelId"`
+ CounterpartyVersion string `json:"counterpartyVersion"`
+ CounterpartyChannelId string `json:"counterpartyChannelId"`
+ ProofTry HexBytes `json:"proofTry"`
+ ProofHeight HexBytes `json:"proofHeight"`
+}
+
+type MsgChannelOpenConfirm struct {
+ PortId string `json:"portId"`
+ ChannelId string `json:"channelId"`
+ ProofAck HexBytes `json:"proofAck"`
+ ProofHeight HexBytes `json:"proofHeight"`
+}
+
+type MsgChannelOpenInit struct {
+ PortId string `json:"portId"`
+ Channel HexBytes `json:"channel"` // HexBytes
+}
+
+type MsgChannelOpenTry struct {
+ PortId string `json:"portId"`
+ PreviousChannelId string `json:"previousChannelId"`
+ Channel HexBytes `json:"channel"`
+ CounterpartyVersion string `json:"counterpartyVersion"`
+ ProofInit HexBytes `json:"proofInit"`
+ ProofHeight HexBytes `json:"proofHeight"`
+}
+
+type GenericConnectionParam[T MsgConnectionOpenInit | MsgConnectionOpenTry | MsgConnectionOpenAck | MsgConnectionOpenConfirm] struct {
+ Msg T `json:"msg"`
+}
+
+type MsgConnectionOpenAck struct {
+ ConnectionId string `json:"connectionId"`
+ ClientStateBytes HexBytes `json:"clientStateBytes"`
+ Version HexBytes `json:"version"`
+ CounterpartyConnectionID string `json:"counterpartyConnectionID"`
+ ProofTry HexBytes `json:"proofTry"`
+ ProofClient HexBytes `json:"proofClient"`
+ ProofConsensus HexBytes `json:"proofConsensus"`
+ ProofHeight HexBytes `json:"proofHeight"`
+ ConsensusHeight HexBytes `json:"consensusHeight"`
+}
+
+type MsgConnectionOpenConfirm struct {
+ ConnectionId string `json:"connectionId"`
+ ProofAck HexBytes `json:"proofAck"`
+ ProofHeight HexBytes `json:"proofHeight"`
+}
+
+type MsgConnectionOpenInit struct {
+ ClientId string `json:"clientId"`
+ Counterparty HexBytes `json:"counterparty"`
+ DelayPeriod HexInt `json:"delayPeriod"`
+}
+
+type MsgConnectionOpenTry struct {
+ PreviousConnectionId string `json:"previousConnectionId"`
+ Counterparty HexBytes `json:"counterparty"`
+ DelayPeriod HexInt `json:"delayPeriod"`
+ ClientId string `json:"clientId"`
+ ClientStateBytes HexBytes `json:"clientStateBytes"`
+ CounterpartyVersions []HexBytes `json:"counterpartyVersions"`
+ ProofInit HexBytes `json:"proofInit"`
+ ProofClient HexBytes `json:"proofClient"`
+ ProofConsensus HexBytes `json:"proofConsensus"`
+ ProofHeight HexBytes `json:"proofHeight"`
+ ConsensusHeight HexBytes `json:"consensusHeight"`
+}
+
+type GenericPacketParams[T MsgPacketRecv | MsgPacketAcknowledgement | MsgTimeoutPacket | MsgRequestTimeout] struct {
+ Msg T `json:"msg"`
+}
+
+type MsgPacketAcknowledgement struct {
+ Packet HexBytes `json:"packet"`
+ Acknowledgement HexBytes `json:"acknowledgement"`
+ Proof HexBytes `json:"proof"`
+ ProofHeight HexBytes `json:"proofHeight"`
+}
+
+type MsgPacketRecv struct {
+ Packet HexBytes `json:"packet"`
+ Proof HexBytes `json:"proof"`
+ ProofHeight HexBytes `json:"proofHeight"`
+}
+
+type MsgTimeoutPacket struct {
+ Packet HexBytes `json:"packet"`
+ Proof HexBytes `json:"proof"`
+ ProofHeight HexBytes `json:"proofHeight"`
+ NextSequenceRecv HexInt `json:"nextSequenceRecv"`
+}
+
+type MsgRequestTimeout struct {
+ Packet HexBytes `json:"packet"`
+ Proof HexBytes `json:"proof"`
+ ProofHeight HexBytes `json:"proofHeight"`
+}
+
+type CallParam struct {
+ FromAddress Address `json:"from" validate:"optional,t_addr_eoa"`
+ ToAddress Address `json:"to" validate:"required,t_addr_score"`
+ DataType string `json:"dataType" validate:"required,call"`
+ Data *CallData `json:"data"`
+ Height HexInt `json:"height,omitempty"`
+}
+
+// Added to implement RelayerMessage interface
+func (c *CallParam) Type() string {
+ return c.DataType
+}
+
+func (c *CallParam) MsgBytes() ([]byte, error) {
+ return nil, nil
+}
+
+type AddressParam struct {
+ Address Address `json:"address" validate:"required,t_addr"`
+ Height HexInt `json:"height,omitempty" validate:"optional,t_int"`
+}
+
+type TransactionHashParam struct {
+ Hash HexBytes `json:"txHash" validate:"required,t_hash"`
+}
+
+type BlockHeightParam struct {
+ Height HexInt `json:"height" validate:"required,t_int"`
+}
+type DataHashParam struct {
+ Hash HexBytes `json:"hash" validate:"required,t_hash"`
+}
+type ProofResultParam struct {
+ BlockHash HexBytes `json:"hash" validate:"required,t_hash"`
+ Index HexInt `json:"index" validate:"required,t_int"`
+}
+type ProofEventsParam struct {
+ BlockHash HexBytes `json:"hash" validate:"required,t_hash"`
+ Index HexInt `json:"index" validate:"required,t_int"`
+ Events []HexInt `json:"events"`
+}
+
+type BlockRequest struct {
+ Height HexInt `json:"height"`
+ EventFilters []*EventFilter `json:"eventFilters,omitempty"`
+}
+
+type EventFilter struct {
+ Addr Address `json:"addr,omitempty"`
+ Signature string `json:"event"`
+ Indexed []*string `json:"indexed,omitempty"`
+ Data []*string `json:"data,omitempty"`
+}
+
+type BlockNotification struct {
+ Hash HexBytes `json:"hash"`
+ Height HexInt `json:"height"`
+ Indexes [][]HexInt `json:"indexes,omitempty"`
+ Events [][][]HexInt `json:"events,omitempty"`
+}
+
+type EventRequest struct {
+ EventFilter
+ Height HexInt `json:"height"`
+}
+
+type EventNotification struct {
+ Hash HexBytes `json:"hash"`
+ Height HexInt `json:"height"`
+ Index HexInt `json:"index"`
+ Events []HexInt `json:"events,omitempty"`
+}
+
+type WSEvent string
+
+const (
+ WSEventInit WSEvent = "WSEventInit"
+)
+
+type WSResponse struct {
+ Code int `json:"code"`
+ Message string `json:"message,omitempty"`
+}
+
+// T_BIN_DATA, T_HASH
+type HexBytes string
+
+func (hs HexBytes) Value() ([]byte, error) {
+ if hs == "" {
+ return nil, nil
+ }
+ return hex.DecodeString(string(hs[2:]))
+}
+func NewHexBytes(b []byte) HexBytes {
+ return HexBytes("0x" + hex.EncodeToString(b))
+}
+
+// T_INT
+type HexInt string
+
+func (i HexInt) Value() (int64, error) {
+ s := string(i)
+ if strings.HasPrefix(s, "0x") {
+ s = s[2:]
+ }
+ return strconv.ParseInt(s, 16, 64)
+}
+
+func (i HexInt) Int() (int, error) {
+ s := string(i)
+ if strings.HasPrefix(s, "0x") {
+ s = s[2:]
+ }
+ v, err := strconv.ParseInt(s, 16, 32)
+ return int(v), err
+}
+
+func (i HexInt) BigInt() (*big.Int, error) {
+ bi := new(big.Int)
+
+ if err := ParseBigInt(bi, string(i)); err != nil {
+ return nil, err
+ } else {
+ return bi, nil
+ }
+}
+
+func decodeHexNumber(s string) (bool, []byte, error) {
+ negative := false
+ if len(s) > 0 && s[0] == '-' {
+ negative = true
+ s = s[1:]
+ }
+ if len(s) > 2 && s[0:2] == "0x" {
+ s = s[2:]
+ }
+ if (len(s) % 2) == 1 {
+ s = "0" + s
+ }
+ bs, err := hex.DecodeString(s)
+ return negative, bs, err
+}
+
+func ParseBigInt(i *big.Int, s string) error {
+ neg, bs, err := decodeHexNumber(s)
+ if err != nil {
+ return err
+ }
+ i.SetBytes(bs)
+ if neg {
+ i.Neg(i)
+ }
+ return nil
+}
+
+func NewHexInt(v int64) HexInt {
+ return HexInt("0x" + strconv.FormatInt(v, 16))
+}
+
+// T_ADDR_EOA, T_ADDR_SCORE
+type Address string
+
+func (a Address) Value() ([]byte, error) {
+ var b [21]byte
+ switch a[:2] {
+ case "cx":
+ b[0] = 1
+ case "hx":
+ default:
+ return nil, fmt.Errorf("invalid prefix %s", a[:2])
+ }
+ n, err := hex.Decode(b[1:], []byte(a[2:]))
+ if err != nil {
+ return nil, err
+ }
+ if n != 20 {
+ return nil, fmt.Errorf("invalid length %d", n)
+ }
+ return b[:], nil
+}
+
+func NewAddress(b []byte) Address {
+ if len(b) != 21 {
+ return ""
+ }
+ switch b[0] {
+ case 1:
+ return Address("cx" + hex.EncodeToString(b[1:]))
+ case 0:
+ return Address("hx" + hex.EncodeToString(b[1:]))
+ default:
+ return ""
+ }
+}
+
+type Block struct {
+ //BlockHash HexBytes `json:"block_hash" validate:"required,t_hash"`
+ //Version HexInt `json:"version" validate:"required,t_int"`
+ Height int64 `json:"height" validate:"required,t_int"`
+ Timestamp int64 `json:"time_stamp" validate:"required,t_int"`
+ //Proposer HexBytes `json:"peer_id" validate:"optional,t_addr_eoa"`
+ //PrevID HexBytes `json:"prev_block_hash" validate:"required,t_hash"`
+ //NormalTransactionsHash HexBytes `json:"merkle_tree_root_hash" validate:"required,t_hash"`
+ NormalTransactions []struct {
+ TxHash HexBytes `json:"txHash"`
+ //Version HexInt `json:"version"`
+ From Address `json:"from"`
+ To Address `json:"to"`
+ //Value HexInt `json:"value,omitempty" `
+ //StepLimit HexInt `json:"stepLimit"`
+ //TimeStamp HexInt `json:"timestamp"`
+ //NID HexInt `json:"nid,omitempty"`
+ //Nonce HexInt `json:"nonce,omitempty"`
+ //Signature HexBytes `json:"signature"`
+ DataType string `json:"dataType,omitempty"`
+ Data json.RawMessage `json:"data,omitempty"`
+ } `json:"confirmed_transaction_list"`
+ //Signature HexBytes `json:"signature" validate:"optional,t_hash"`
+}
+
+type WsReadCallback func(*websocket.Conn, interface{}) error
+
+// BTP Related
+type BTPBlockParam struct {
+ Height HexInt `json:"height" validate:"required,t_int"`
+ NetworkId HexInt `json:"networkID" validate:"required,t_int"`
+}
+
+type BTPNetworkInfoParam struct {
+ Height HexInt `json:"height" validate:"optional,t_int"`
+ Id HexInt `json:"id" validate:"required,t_int"`
+}
+
+type BTPNotification struct {
+ Header string `json:"header"`
+ Proof string `json:"proof,omitempty"`
+}
+
+type BTPRequest struct {
+ Height HexInt `json:"height"`
+ NetworkID HexInt `json:"networkID"`
+ ProofFlag HexInt `json:"proofFlag"`
+}
+
+type BTPNetworkInfo struct {
+ StartHeight HexInt `json:"startHeight"`
+ NetworkTypeID HexInt `json:"networkTypeID"`
+ NetworkName string `json:"networkName"`
+ Open HexInt `json:"open"`
+ Owner Address `json:"owner"`
+ NextMessageSN HexInt `json:"nextMessageSN"`
+ NextProofContextChanged HexInt `json:"nextProofContextChanged"`
+ PrevNSHash HexBytes `json:"prevNSHash"`
+ LastNSHash HexBytes `json:"lastNSHash"`
+ NetworkID HexInt `json:"networkID"`
+ NetworkTypeName string `json:"networkTypeName"`
+}
+
+type BTPBlockHeader struct {
+ MainHeight uint64
+ Round int32
+ NextProofContextHash []byte
+ NetworkSectionToRoot []*icon.MerkleNode
+ NetworkID uint64
+ UpdateNumber uint64
+ PrevNetworkSectionHash []byte
+ MessageCount uint64
+ MessageRoot []byte
+ NextProofContext []byte
+}
+
+type Dir int
+
+const (
+ DirLeft = Dir(iota)
+ DirRight
+)
+
+type BTPQueryParam struct {
+ Height HexInt `json:"height,omitempty" validate:"optional,t_int"`
+ Id HexInt `json:"id" validate:"required,t_int"`
+}
+
+type BTPNetworkTypeInfo struct {
+ NetworkTypeName string `json:"networkTypeName"`
+ NextProofContext HexBytes `json:"nextProofContext"`
+ OpenNetworkIDs []HexInt `json:"openNetworkIDs"`
+ NetworkTypeID HexInt `json:"networkTypeID"`
+}
+
+type ValidatorList struct {
+ Validators [][]byte `json:"validators"`
+}
+
+type ValidatorSignatures struct {
+ Signatures [][]byte `json:"signatures"`
+}
+
+type NetworkSection struct {
+ Nid int64
+ UpdateNumber uint64
+ Prev []byte
+ MessageCount int64
+ MessageRoot []byte
+}
+
+func NewNetworkSection(
+ header *BTPBlockHeader,
+) *NetworkSection {
+
+ return &NetworkSection{
+ Nid: int64(header.NetworkID),
+ UpdateNumber: uint64(header.UpdateNumber), //
+ Prev: header.PrevNetworkSectionHash,
+ MessageCount: int64(header.MessageCount),
+ MessageRoot: header.MessageRoot,
+ }
+}
+
+func (h *NetworkSection) Hash() []byte {
+ return relayer_common.Sha3keccak256(h.Encode())
+}
+func (h *NetworkSection) Encode() []byte {
+ return codec.RLP.MustMarshalToBytes(h)
+}
+
+type NetworkTypeSection struct {
+ NextProofContextHash []byte
+ NetworkSectionsRoot []byte
+}
+
+type NetworkTypeSectionDecision struct {
+ SrcNetworkID string
+ NetworkTypeId int64
+ Height int64
+ Round int32
+ NetworkTypeSectionHash []byte
+}
+
+func NewNetworkTypeSectionDecision(SrcNetworkID string,
+ NetworkTypeId int64,
+ Height int64,
+ Round int32,
+ networkTypeSection NetworkTypeSection,
+) *NetworkTypeSectionDecision {
+ return &NetworkTypeSectionDecision{
+ SrcNetworkID,
+ NetworkTypeId,
+ Height,
+ Round,
+ (networkTypeSection.Hash()),
+ }
+}
+
+func (h *NetworkTypeSectionDecision) Encode() []byte {
+ return codec.RLP.MustMarshalToBytes(h)
+}
+
+func (h *NetworkTypeSectionDecision) Hash() []byte {
+ return relayer_common.Sha3keccak256(h.Encode())
+}
+
+func (h *NetworkTypeSection) Encode() []byte {
+ return codec.RLP.MustMarshalToBytes(h)
+}
+
+func (h *NetworkTypeSection) Hash() []byte {
+ return relayer_common.Sha3keccak256(h.Encode())
+}
diff --git a/relayer/chains/icon/utils.go b/relayer/chains/icon/utils.go
new file mode 100644
index 000000000..167172356
--- /dev/null
+++ b/relayer/chains/icon/utils.go
@@ -0,0 +1,228 @@
+package icon
+
+import (
+ "bytes"
+ "encoding/base64"
+ "encoding/hex"
+ "fmt"
+ "net/url"
+ "strings"
+
+ "github.com/cosmos/relayer/v2/relayer/chains/icon/cryptoutils"
+ "github.com/cosmos/relayer/v2/relayer/chains/icon/types"
+ "github.com/cosmos/relayer/v2/relayer/common"
+ "github.com/cosmos/relayer/v2/relayer/provider"
+
+ "github.com/cosmos/gogoproto/proto"
+
+ "github.com/icon-project/IBC-Integration/libraries/go/common/icon"
+ icn "github.com/icon-project/IBC-Integration/libraries/go/common/icon"
+ "github.com/icon-project/goloop/common/codec"
+ "github.com/icon-project/goloop/common/crypto"
+ "github.com/icon-project/goloop/common/db"
+ "github.com/icon-project/goloop/common/trie/ompt"
+)
+
+var (
+ ethAddressLen = 20
+)
+
+func MptProve(key types.HexInt, proofs [][]byte, hash []byte) ([]byte, error) {
+ db := db.NewMapDB()
+ defer db.Close()
+ index, err := key.Value()
+ if err != nil {
+ return nil, err
+ }
+ indexKey, err := codec.RLP.MarshalToBytes(index)
+ if err != nil {
+ return nil, err
+ }
+ mpt := ompt.NewMPTForBytes(db, hash)
+ trie, err1 := mpt.Prove(indexKey, proofs)
+ if err1 != nil {
+ return nil, err1
+
+ }
+ return trie, nil
+}
+
+func Base64ToData(encoded string, v interface{}) ([]byte, error) {
+ if encoded == "" {
+ return nil, fmt.Errorf("Encoded string is empty ")
+ }
+
+ decoded, err := base64.StdEncoding.DecodeString(encoded)
+ if err != nil {
+ return nil, err
+ }
+
+ return codec.RLP.UnmarshalFromBytes(decoded, v)
+}
+
+func HexBytesToProtoUnmarshal(encoded types.HexBytes, v proto.Message) ([]byte, error) {
+ inputBytes, err := encoded.Value()
+ if err != nil {
+ return nil, fmt.Errorf("Error unmarshalling HexByte")
+ }
+
+ if bytes.Equal(inputBytes, make([]byte, 0)) {
+ return nil, fmt.Errorf("Encoded hexbyte is empty ")
+ }
+
+ if err := proto.Unmarshal(inputBytes, v); err != nil {
+ return nil, err
+
+ }
+ return inputBytes, nil
+
+}
+
+func isHexString(s string) bool {
+ s = strings.ToLower(s)
+ if !strings.HasPrefix(s, "0x") {
+ return false
+ }
+
+ s = s[2:]
+
+ for _, c := range s {
+ if !(c >= '0' && c <= '9' || c >= 'a' && c <= 'f') {
+ return false
+ }
+ }
+ return true
+}
+
+func btpBlockNotPresent(err error) bool {
+ return strings.Contains(err.Error(), "NotFound: E1005:fail to get a BTP block header")
+}
+
+func getCommitmentHash(key, msg []byte) []byte {
+ msgHash := common.Sha3keccak256(msg)
+ return common.Sha3keccak256(key, msgHash)
+}
+
+func VerifyProof(commitmentkey []byte, msgval []byte, root []byte, proof []byte) (bool, error) {
+ leaf := getCommitmentHash(commitmentkey, msgval)
+ var decodedProof icn.MerkleProofs
+ if err := proto.Unmarshal(proof, &decodedProof); err != nil {
+ return false, err
+ }
+
+ return cryptoutils.VerifyMerkleProof(root, leaf, decodedProof.Proofs), nil
+}
+
+func getSrcNetworkId(id int64) string {
+ return fmt.Sprintf("%s.icon", types.NewHexInt(id))
+}
+
+func getIconPacketEncodedBytes(pkt provider.PacketInfo) ([]byte, error) {
+ iconPkt := icon.Packet{
+ Sequence: pkt.Sequence,
+ SourcePort: pkt.SourcePort,
+ SourceChannel: pkt.SourceChannel,
+ DestinationPort: pkt.DestPort,
+ DestinationChannel: pkt.DestChannel,
+ TimeoutHeight: &icon.Height{
+ RevisionNumber: pkt.TimeoutHeight.RevisionNumber,
+ RevisionHeight: pkt.TimeoutHeight.RevisionHeight,
+ },
+ TimeoutTimestamp: pkt.TimeoutTimestamp,
+ Data: pkt.Data,
+ }
+
+ return proto.Marshal(&iconPkt)
+
+}
+
+func GetNetworkSectionRoot(header *types.BTPBlockHeader) []byte {
+ networkSection := types.NewNetworkSection(header)
+ return cryptoutils.CalculateRootFromProof(networkSection.Hash(), header.NetworkSectionToRoot)
+}
+
+func VerifyBtpProof(decision *types.NetworkTypeSectionDecision, proof [][]byte, listValidators [][]byte) (bool, error) {
+
+ requiredVotes := (2 * len(listValidators)) / 3
+ if requiredVotes < 1 {
+ requiredVotes = 1
+ }
+
+ numVotes := 0
+ validators := make(map[types.HexBytes]struct{})
+ for _, val := range listValidators {
+ validators[types.NewHexBytes(val)] = struct{}{}
+ }
+
+ for _, raw_sig := range proof {
+ sig, err := crypto.ParseSignature(raw_sig)
+ if err != nil {
+ return false, err
+ }
+ pubkey, err := sig.RecoverPublicKey(decision.Hash())
+ if err != nil {
+ continue
+ }
+
+ address, err := newEthAddressFromPubKey(pubkey.SerializeCompressed())
+ if err != nil {
+ continue
+ }
+ if address == nil {
+ continue
+ }
+ if _, ok := validators[types.NewHexBytes(address)]; !ok {
+ continue
+ }
+ delete(validators, types.NewHexBytes(address))
+ if numVotes++; numVotes >= requiredVotes {
+ return true, nil
+ }
+ }
+
+ return false, nil
+
+}
+
+func newEthAddressFromPubKey(pubKey []byte) ([]byte, error) {
+ if len(pubKey) == crypto.PublicKeyLenCompressed {
+ pk, err := crypto.ParsePublicKey(pubKey)
+ if err != nil {
+ return nil, err
+ }
+ pubKey = pk.SerializeUncompressed()
+ }
+ digest := common.Sha3keccak256(pubKey[1:])
+ return digest[len(digest)-ethAddressLen:], nil
+}
+
+func guessDebugEndpoint(endpoint string) string {
+ uo, err := url.Parse(endpoint)
+ if err != nil {
+ return ""
+ }
+ ps := strings.Split(uo.Path, "/")
+ for i, v := range ps {
+ if v == "api" {
+ if len(ps) > i+1 && ps[i+1] == "v3" {
+ ps[i+1] = "v3d"
+ uo.Path = strings.Join(ps, "/")
+ return uo.String()
+ }
+ break
+ }
+ }
+ return ""
+}
+
+func isValidIconContractAddress(addr string) bool {
+ if !strings.HasPrefix(addr, "cx") {
+ return false
+ }
+ if len(addr) != 42 {
+ return false
+ }
+ _, err := hex.DecodeString(addr[2:])
+ return err == nil
+
+}
diff --git a/relayer/chains/mock/message_handlers.go b/relayer/chains/mock/message_handlers.go
index 01d2ff24b..263f50d71 100644
--- a/relayer/chains/mock/message_handlers.go
+++ b/relayer/chains/mock/message_handlers.go
@@ -11,6 +11,7 @@ import (
type msgHandlerParams struct {
mcp *MockChainProcessor
+ height int64
packetInfo *chantypes.Packet
ibcMessagesCache processor.IBCMessagesCache
}
@@ -31,9 +32,14 @@ func handleMsgTransfer(p msgHandlerParams) {
CounterpartyPortID: p.packetInfo.DestinationPort,
}
p.ibcMessagesCache.PacketFlow.Retain(channelKey, chantypes.EventTypeSendPacket, provider.PacketInfo{
+ Height: uint64(p.height),
Sequence: p.packetInfo.Sequence,
Data: p.packetInfo.Data,
TimeoutHeight: p.packetInfo.TimeoutHeight,
+ SourcePort: p.packetInfo.SourcePort,
+ SourceChannel: p.packetInfo.SourceChannel,
+ DestPort: p.packetInfo.DestinationPort,
+ DestChannel: p.packetInfo.DestinationChannel,
})
p.mcp.log.Debug("observed MsgTransfer",
zap.String("chain_id", p.mcp.chainID),
@@ -53,8 +59,13 @@ func handleMsgRecvPacket(p msgHandlerParams) {
CounterpartyPortID: p.packetInfo.SourcePort,
}
p.ibcMessagesCache.PacketFlow.Retain(channelKey, chantypes.EventTypeRecvPacket, provider.PacketInfo{
- Sequence: p.packetInfo.Sequence,
- Data: p.packetInfo.Data,
+ Height: uint64(p.height),
+ Sequence: p.packetInfo.Sequence,
+ Data: p.packetInfo.Data,
+ SourcePort: p.packetInfo.SourcePort,
+ SourceChannel: p.packetInfo.SourceChannel,
+ DestPort: p.packetInfo.DestinationPort,
+ DestChannel: p.packetInfo.DestinationChannel,
})
p.mcp.log.Debug("observed MsgRecvPacket",
zap.String("chain_id", p.mcp.chainID),
@@ -74,8 +85,13 @@ func handleMsgAcknowledgement(p msgHandlerParams) {
CounterpartyPortID: p.packetInfo.DestinationPort,
}
p.ibcMessagesCache.PacketFlow.Retain(channelKey, chantypes.EventTypeAcknowledgePacket, provider.PacketInfo{
- Sequence: p.packetInfo.Sequence,
- Data: p.packetInfo.Data,
+ Height: uint64(p.height),
+ Sequence: p.packetInfo.Sequence,
+ Data: p.packetInfo.Data,
+ SourcePort: p.packetInfo.SourcePort,
+ SourceChannel: p.packetInfo.SourceChannel,
+ DestPort: p.packetInfo.DestinationPort,
+ DestChannel: p.packetInfo.DestinationChannel,
})
p.mcp.log.Debug("observed MsgAcknowledgement",
zap.String("chain_id", p.mcp.chainID),
diff --git a/relayer/chains/mock/mock_chain_processor.go b/relayer/chains/mock/mock_chain_processor.go
index 329c4215b..c6001a257 100644
--- a/relayer/chains/mock/mock_chain_processor.go
+++ b/relayer/chains/mock/mock_chain_processor.go
@@ -4,6 +4,7 @@ import (
"context"
"time"
+ "github.com/cosmos/cosmos-sdk/crypto/hd"
"github.com/cosmos/relayer/v2/relayer/chains/cosmos"
"github.com/cosmos/relayer/v2/relayer/processor"
"github.com/cosmos/relayer/v2/relayer/provider"
@@ -49,7 +50,7 @@ func NewMockChainProcessor(ctx context.Context, log *zap.Logger, chainID string,
}
chainProvider, _ := chainProviderCfg.NewProvider(zap.NewNop(), "/tmp", true, "mock-chain-name-"+chainID)
_ = chainProvider.Init(ctx)
- _, _ = chainProvider.AddKey(chainProvider.Key(), 118)
+ _, _ = chainProvider.AddKey(chainProvider.Key(), 118, string(hd.Secp256k1Type), "")
return &MockChainProcessor{
log: log,
chainID: chainID,
@@ -58,6 +59,14 @@ func NewMockChainProcessor(ctx context.Context, log *zap.Logger, chainID string,
}
}
+func (mcp *MockChainProcessor) SnapshotHeight(height int64) {
+ panic("")
+}
+
+func (mcp *MockChainProcessor) StartFromHeight(ctx context.Context) int64 {
+ return 0
+}
+
func (mcp *MockChainProcessor) SetPathProcessors(pathProcessors processor.PathProcessors) {
mcp.pathProcessors = pathProcessors
}
@@ -156,6 +165,7 @@ func (mcp *MockChainProcessor) queryCycle(ctx context.Context, persistence *quer
for _, m := range messages {
if handler, ok := messageHandlers[m.EventType]; ok {
handler(msgHandlerParams{
+ height: i,
mcp: mcp,
packetInfo: m.PacketInfo,
ibcMessagesCache: ibcMessagesCache,
@@ -168,13 +178,17 @@ func (mcp *MockChainProcessor) queryCycle(ctx context.Context, persistence *quer
// mocking all channels open
for channelKey := range ibcMessagesCache.PacketFlow {
- channelStateCache[channelKey] = true
+ channelStateCache.SetOpen(channelKey, true, chantypes.NONE)
}
// now pass foundMessages to the path processors
for _, pp := range mcp.pathProcessors {
mcp.log.Info("sending messages to path processor", zap.String("chain_id", mcp.chainID))
pp.HandleNewData(mcp.chainID, processor.ChainProcessorCacheData{
+ LatestBlock: provider.LatestBlock{
+ Height: uint64(i),
+ Time: time.Now(),
+ },
IBCMessagesCache: ibcMessagesCache,
InSync: mcp.inSync,
ChannelStateCache: channelStateCache,
diff --git a/relayer/chains/mock/mock_chain_processor_test.go b/relayer/chains/mock/mock_chain_processor_test.go
index 505fa87db..718826917 100644
--- a/relayer/chains/mock/mock_chain_processor_test.go
+++ b/relayer/chains/mock/mock_chain_processor_test.go
@@ -9,6 +9,7 @@ import (
clienttypes "github.com/cosmos/ibc-go/v7/modules/core/02-client/types"
chantypes "github.com/cosmos/ibc-go/v7/modules/core/04-channel/types"
+ "github.com/cosmos/relayer/v2/relayer"
"github.com/cosmos/relayer/v2/relayer/chains/mock"
"github.com/cosmos/relayer/v2/relayer/processor"
"github.com/prometheus/client_golang/prometheus/testutil"
@@ -61,7 +62,8 @@ func TestMockChainAndPathProcessors(t *testing.T) {
clientUpdateThresholdTime := 6 * time.Hour
flushInterval := 6 * time.Hour
- pathProcessor := processor.NewPathProcessor(log, pathEnd1, pathEnd2, metrics, "", clientUpdateThresholdTime, flushInterval)
+ pathProcessor := processor.NewPathProcessor(log, pathEnd1, pathEnd2, metrics, "",
+ clientUpdateThresholdTime, flushInterval, relayer.DefaultMaxMsgLength)
eventProcessor := processor.NewEventProcessor().
WithChainProcessors(
diff --git a/relayer/chains/penumbra/codec.go b/relayer/chains/penumbra/codec.go
new file mode 100644
index 000000000..ac075741c
--- /dev/null
+++ b/relayer/chains/penumbra/codec.go
@@ -0,0 +1,100 @@
+package penumbra
+
+import (
+ "github.com/cosmos/cosmos-sdk/client"
+ "github.com/cosmos/cosmos-sdk/codec"
+ "github.com/cosmos/cosmos-sdk/codec/types"
+ "github.com/cosmos/cosmos-sdk/std"
+ "github.com/cosmos/cosmos-sdk/types/module"
+ "github.com/cosmos/cosmos-sdk/x/auth"
+ "github.com/cosmos/cosmos-sdk/x/auth/tx"
+ authz "github.com/cosmos/cosmos-sdk/x/authz/module"
+ "github.com/cosmos/cosmos-sdk/x/bank"
+ "github.com/cosmos/cosmos-sdk/x/crisis"
+ "github.com/cosmos/cosmos-sdk/x/distribution"
+ feegrant "github.com/cosmos/cosmos-sdk/x/feegrant/module"
+ "github.com/cosmos/cosmos-sdk/x/gov"
+ govclient "github.com/cosmos/cosmos-sdk/x/gov/client"
+ "github.com/cosmos/cosmos-sdk/x/mint"
+ "github.com/cosmos/cosmos-sdk/x/params"
+ paramsclient "github.com/cosmos/cosmos-sdk/x/params/client"
+ "github.com/cosmos/cosmos-sdk/x/slashing"
+ "github.com/cosmos/cosmos-sdk/x/staking"
+ "github.com/cosmos/cosmos-sdk/x/upgrade"
+ upgradeclient "github.com/cosmos/cosmos-sdk/x/upgrade/client"
+ "github.com/cosmos/ibc-go/modules/capability"
+ "github.com/cosmos/ibc-go/v7/modules/apps/transfer"
+ ibc "github.com/cosmos/ibc-go/v7/modules/core"
+
+ cosmosmodule "github.com/cosmos/relayer/v2/relayer/chains/cosmos/module"
+ "github.com/cosmos/relayer/v2/relayer/chains/cosmos/stride"
+ ethermintcodecs "github.com/cosmos/relayer/v2/relayer/codecs/ethermint"
+ injectivecodecs "github.com/cosmos/relayer/v2/relayer/codecs/injective"
+)
+
+var moduleBasics = []module.AppModuleBasic{
+ auth.AppModuleBasic{},
+ authz.AppModuleBasic{},
+ bank.AppModuleBasic{},
+ capability.AppModuleBasic{},
+ gov.NewAppModuleBasic(
+ []govclient.ProposalHandler{
+ paramsclient.ProposalHandler,
+ upgradeclient.LegacyProposalHandler,
+ upgradeclient.LegacyCancelProposalHandler,
+ },
+ ),
+ crisis.AppModuleBasic{},
+ distribution.AppModuleBasic{},
+ feegrant.AppModuleBasic{},
+ mint.AppModuleBasic{},
+ params.AppModuleBasic{},
+ slashing.AppModuleBasic{},
+ staking.AppModuleBasic{},
+ upgrade.AppModuleBasic{},
+ transfer.AppModuleBasic{},
+ ibc.AppModuleBasic{},
+ cosmosmodule.AppModuleBasic{},
+ stride.AppModuleBasic{},
+}
+
+type Codec struct {
+ InterfaceRegistry types.InterfaceRegistry
+ Marshaler codec.Codec
+ TxConfig client.TxConfig
+ Amino *codec.LegacyAmino
+}
+
+func makeCodec(moduleBasics []module.AppModuleBasic, extraCodecs []string) Codec {
+ modBasic := module.NewBasicManager(moduleBasics...)
+ encodingConfig := makeCodecConfig()
+ std.RegisterLegacyAminoCodec(encodingConfig.Amino)
+ std.RegisterInterfaces(encodingConfig.InterfaceRegistry)
+ modBasic.RegisterLegacyAminoCodec(encodingConfig.Amino)
+ modBasic.RegisterInterfaces(encodingConfig.InterfaceRegistry)
+ for _, c := range extraCodecs {
+ switch c {
+ case "ethermint":
+ ethermintcodecs.RegisterInterfaces(encodingConfig.InterfaceRegistry)
+ encodingConfig.Amino.RegisterConcrete(ðermintcodecs.PubKey{}, ethermintcodecs.PubKeyName, nil)
+ encodingConfig.Amino.RegisterConcrete(ðermintcodecs.PrivKey{}, ethermintcodecs.PrivKeyName, nil)
+ case "injective":
+ injectivecodecs.RegisterInterfaces(encodingConfig.InterfaceRegistry)
+ encodingConfig.Amino.RegisterConcrete(&injectivecodecs.PubKey{}, injectivecodecs.PubKeyName, nil)
+ encodingConfig.Amino.RegisterConcrete(&injectivecodecs.PrivKey{}, injectivecodecs.PrivKeyName, nil)
+ }
+ }
+
+ return encodingConfig
+}
+
+func makeCodecConfig() Codec {
+ interfaceRegistry := types.NewInterfaceRegistry()
+ marshaler := codec.NewProtoCodec(interfaceRegistry)
+ return Codec{
+ InterfaceRegistry: interfaceRegistry,
+ Marshaler: marshaler,
+ TxConfig: tx.NewTxConfig(marshaler, tx.DefaultSignModes),
+ Amino: codec.NewLegacyAmino(),
+ }
+}
diff --git a/relayer/chains/penumbra/core/chain/v1alpha1/chain.pb.go b/relayer/chains/penumbra/core/chain/v1alpha1/chain.pb.go
new file mode 100644
index 000000000..16e8fe13e
--- /dev/null
+++ b/relayer/chains/penumbra/core/chain/v1alpha1/chain.pb.go
@@ -0,0 +1,4551 @@
+// Code generated by protoc-gen-gogo. DO NOT EDIT.
+// source: penumbra/core/chain/v1alpha1/chain.proto
+
+package chainv1alpha1
+
+import (
+ fmt "fmt"
+ proto "github.com/cosmos/gogoproto/proto"
+ v1alpha1 "github.com/cosmos/relayer/v2/relayer/chains/penumbra/core/crypto/v1alpha1"
+ v1alpha11 "github.com/cosmos/relayer/v2/relayer/chains/penumbra/core/dex/v1alpha1"
+ v1alpha12 "github.com/cosmos/relayer/v2/relayer/chains/penumbra/core/stake/v1alpha1"
+ io "io"
+ math "math"
+ math_bits "math/bits"
+)
+
+// Reference imports to suppress errors if they are not otherwise used.
+var _ = proto.Marshal
+var _ = fmt.Errorf
+var _ = math.Inf
+
+// This is a compile-time assertion to ensure that this generated file
+// is compatible with the proto package it is being compiled against.
+// A compilation error at this line likely means your copy of the
+// proto package needs to be updated.
+const _ = proto.GoGoProtoPackageIsVersion3 // please upgrade the proto package
+
+// Global chain configuration data, such as chain ID, epoch duration, etc.
+type ChainParameters struct {
+ // The identifier of the chain.
+ ChainId string `protobuf:"bytes,1,opt,name=chain_id,json=chainId,proto3" json:"chain_id,omitempty"`
+ // The duration of each epoch, in number of blocks.
+ EpochDuration uint64 `protobuf:"varint,2,opt,name=epoch_duration,json=epochDuration,proto3" json:"epoch_duration,omitempty"`
+ // The number of epochs an unbonding note for before being released.
+ UnbondingEpochs uint64 `protobuf:"varint,3,opt,name=unbonding_epochs,json=unbondingEpochs,proto3" json:"unbonding_epochs,omitempty"`
+ // The maximum number of validators in the consensus set.
+ ActiveValidatorLimit uint64 `protobuf:"varint,4,opt,name=active_validator_limit,json=activeValidatorLimit,proto3" json:"active_validator_limit,omitempty"`
+ // The base reward rate, expressed in basis points of basis points
+ BaseRewardRate uint64 `protobuf:"varint,9,opt,name=base_reward_rate,json=baseRewardRate,proto3" json:"base_reward_rate,omitempty"`
+ // The penalty for slashing due to misbehavior.
+ SlashingPenaltyMisbehavior uint64 `protobuf:"varint,5,opt,name=slashing_penalty_misbehavior,json=slashingPenaltyMisbehavior,proto3" json:"slashing_penalty_misbehavior,omitempty"`
+ // The penalty for slashing due to downtime.
+ SlashingPenaltyDowntime uint64 `protobuf:"varint,10,opt,name=slashing_penalty_downtime,json=slashingPenaltyDowntime,proto3" json:"slashing_penalty_downtime,omitempty"`
+ // The number of blocks in the window to check for downtime.
+ SignedBlocksWindowLen uint64 `protobuf:"varint,11,opt,name=signed_blocks_window_len,json=signedBlocksWindowLen,proto3" json:"signed_blocks_window_len,omitempty"`
+ // The maximum number of blocks in the window each validator can miss signing without slashing.
+ MissedBlocksMaximum uint64 `protobuf:"varint,12,opt,name=missed_blocks_maximum,json=missedBlocksMaximum,proto3" json:"missed_blocks_maximum,omitempty"`
+ // Whether IBC (forming connections, processing IBC packets) is enabled.
+ IbcEnabled bool `protobuf:"varint,6,opt,name=ibc_enabled,json=ibcEnabled,proto3" json:"ibc_enabled,omitempty"`
+ // Whether inbound ICS-20 transfers are enabled
+ InboundIcs20TransfersEnabled bool `protobuf:"varint,7,opt,name=inbound_ics20_transfers_enabled,json=inboundIcs20TransfersEnabled,proto3" json:"inbound_ics20_transfers_enabled,omitempty"`
+ // Whether outbound ICS-20 transfers are enabled
+ OutboundIcs20TransfersEnabled bool `protobuf:"varint,8,opt,name=outbound_ics20_transfers_enabled,json=outboundIcs20TransfersEnabled,proto3" json:"outbound_ics20_transfers_enabled,omitempty"`
+ // The number of blocks during which a proposal is voted on.
+ ProposalVotingBlocks uint64 `protobuf:"varint,20,opt,name=proposal_voting_blocks,json=proposalVotingBlocks,proto3" json:"proposal_voting_blocks,omitempty"`
+ // The deposit required to create a proposal.
+ ProposalDepositAmount *v1alpha1.Amount `protobuf:"bytes,21,opt,name=proposal_deposit_amount,json=proposalDepositAmount,proto3" json:"proposal_deposit_amount,omitempty"`
+ // The quorum required for a proposal to be considered valid, as a fraction of the total stake
+ // weight of the network.
+ ProposalValidQuorum string `protobuf:"bytes,22,opt,name=proposal_valid_quorum,json=proposalValidQuorum,proto3" json:"proposal_valid_quorum,omitempty"`
+ // The threshold for a proposal to pass voting, as a ratio of "yes" votes over "no" votes.
+ ProposalPassThreshold string `protobuf:"bytes,23,opt,name=proposal_pass_threshold,json=proposalPassThreshold,proto3" json:"proposal_pass_threshold,omitempty"`
+ // The threshold for a proposal to be slashed, regardless of whether the "yes" and "no" votes
+ // would have passed it, as a ratio of "no" votes over all total votes.
+ ProposalSlashThreshold string `protobuf:"bytes,24,opt,name=proposal_slash_threshold,json=proposalSlashThreshold,proto3" json:"proposal_slash_threshold,omitempty"`
+ // Whether DAO spend proposals are enabled.
+ DaoSpendProposalsEnabled bool `protobuf:"varint,25,opt,name=dao_spend_proposals_enabled,json=daoSpendProposalsEnabled,proto3" json:"dao_spend_proposals_enabled,omitempty"`
+}
+
+func (m *ChainParameters) Reset() { *m = ChainParameters{} }
+func (m *ChainParameters) String() string { return proto.CompactTextString(m) }
+func (*ChainParameters) ProtoMessage() {}
+func (*ChainParameters) Descriptor() ([]byte, []int) {
+ return fileDescriptor_b0cedb8b84ba3224, []int{0}
+}
+func (m *ChainParameters) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *ChainParameters) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_ChainParameters.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *ChainParameters) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_ChainParameters.Merge(m, src)
+}
+func (m *ChainParameters) XXX_Size() int {
+ return m.Size()
+}
+func (m *ChainParameters) XXX_DiscardUnknown() {
+ xxx_messageInfo_ChainParameters.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_ChainParameters proto.InternalMessageInfo
+
+func (m *ChainParameters) GetChainId() string {
+ if m != nil {
+ return m.ChainId
+ }
+ return ""
+}
+
+func (m *ChainParameters) GetEpochDuration() uint64 {
+ if m != nil {
+ return m.EpochDuration
+ }
+ return 0
+}
+
+func (m *ChainParameters) GetUnbondingEpochs() uint64 {
+ if m != nil {
+ return m.UnbondingEpochs
+ }
+ return 0
+}
+
+func (m *ChainParameters) GetActiveValidatorLimit() uint64 {
+ if m != nil {
+ return m.ActiveValidatorLimit
+ }
+ return 0
+}
+
+func (m *ChainParameters) GetBaseRewardRate() uint64 {
+ if m != nil {
+ return m.BaseRewardRate
+ }
+ return 0
+}
+
+func (m *ChainParameters) GetSlashingPenaltyMisbehavior() uint64 {
+ if m != nil {
+ return m.SlashingPenaltyMisbehavior
+ }
+ return 0
+}
+
+func (m *ChainParameters) GetSlashingPenaltyDowntime() uint64 {
+ if m != nil {
+ return m.SlashingPenaltyDowntime
+ }
+ return 0
+}
+
+func (m *ChainParameters) GetSignedBlocksWindowLen() uint64 {
+ if m != nil {
+ return m.SignedBlocksWindowLen
+ }
+ return 0
+}
+
+func (m *ChainParameters) GetMissedBlocksMaximum() uint64 {
+ if m != nil {
+ return m.MissedBlocksMaximum
+ }
+ return 0
+}
+
+func (m *ChainParameters) GetIbcEnabled() bool {
+ if m != nil {
+ return m.IbcEnabled
+ }
+ return false
+}
+
+func (m *ChainParameters) GetInboundIcs20TransfersEnabled() bool {
+ if m != nil {
+ return m.InboundIcs20TransfersEnabled
+ }
+ return false
+}
+
+func (m *ChainParameters) GetOutboundIcs20TransfersEnabled() bool {
+ if m != nil {
+ return m.OutboundIcs20TransfersEnabled
+ }
+ return false
+}
+
+func (m *ChainParameters) GetProposalVotingBlocks() uint64 {
+ if m != nil {
+ return m.ProposalVotingBlocks
+ }
+ return 0
+}
+
+func (m *ChainParameters) GetProposalDepositAmount() *v1alpha1.Amount {
+ if m != nil {
+ return m.ProposalDepositAmount
+ }
+ return nil
+}
+
+func (m *ChainParameters) GetProposalValidQuorum() string {
+ if m != nil {
+ return m.ProposalValidQuorum
+ }
+ return ""
+}
+
+func (m *ChainParameters) GetProposalPassThreshold() string {
+ if m != nil {
+ return m.ProposalPassThreshold
+ }
+ return ""
+}
+
+func (m *ChainParameters) GetProposalSlashThreshold() string {
+ if m != nil {
+ return m.ProposalSlashThreshold
+ }
+ return ""
+}
+
+func (m *ChainParameters) GetDaoSpendProposalsEnabled() bool {
+ if m != nil {
+ return m.DaoSpendProposalsEnabled
+ }
+ return false
+}
+
+// The ratio between two numbers, used in governance to describe vote thresholds and quorums.
+type Ratio struct {
+ // The numerator.
+ Numerator uint64 `protobuf:"varint,1,opt,name=numerator,proto3" json:"numerator,omitempty"`
+ // The denominator.
+ Denominator uint64 `protobuf:"varint,2,opt,name=denominator,proto3" json:"denominator,omitempty"`
+}
+
+func (m *Ratio) Reset() { *m = Ratio{} }
+func (m *Ratio) String() string { return proto.CompactTextString(m) }
+func (*Ratio) ProtoMessage() {}
+func (*Ratio) Descriptor() ([]byte, []int) {
+ return fileDescriptor_b0cedb8b84ba3224, []int{1}
+}
+func (m *Ratio) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *Ratio) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_Ratio.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *Ratio) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_Ratio.Merge(m, src)
+}
+func (m *Ratio) XXX_Size() int {
+ return m.Size()
+}
+func (m *Ratio) XXX_DiscardUnknown() {
+ xxx_messageInfo_Ratio.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_Ratio proto.InternalMessageInfo
+
+func (m *Ratio) GetNumerator() uint64 {
+ if m != nil {
+ return m.Numerator
+ }
+ return 0
+}
+
+func (m *Ratio) GetDenominator() uint64 {
+ if m != nil {
+ return m.Denominator
+ }
+ return 0
+}
+
+// Parameters for Fuzzy Message Detection
+type FmdParameters struct {
+ PrecisionBits uint32 `protobuf:"varint,1,opt,name=precision_bits,json=precisionBits,proto3" json:"precision_bits,omitempty"`
+ AsOfBlockHeight uint64 `protobuf:"varint,2,opt,name=as_of_block_height,json=asOfBlockHeight,proto3" json:"as_of_block_height,omitempty"`
+}
+
+func (m *FmdParameters) Reset() { *m = FmdParameters{} }
+func (m *FmdParameters) String() string { return proto.CompactTextString(m) }
+func (*FmdParameters) ProtoMessage() {}
+func (*FmdParameters) Descriptor() ([]byte, []int) {
+ return fileDescriptor_b0cedb8b84ba3224, []int{2}
+}
+func (m *FmdParameters) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *FmdParameters) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_FmdParameters.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *FmdParameters) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_FmdParameters.Merge(m, src)
+}
+func (m *FmdParameters) XXX_Size() int {
+ return m.Size()
+}
+func (m *FmdParameters) XXX_DiscardUnknown() {
+ xxx_messageInfo_FmdParameters.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_FmdParameters proto.InternalMessageInfo
+
+func (m *FmdParameters) GetPrecisionBits() uint32 {
+ if m != nil {
+ return m.PrecisionBits
+ }
+ return 0
+}
+
+func (m *FmdParameters) GetAsOfBlockHeight() uint64 {
+ if m != nil {
+ return m.AsOfBlockHeight
+ }
+ return 0
+}
+
+// Contains the minimum data needed to update client state.
+type CompactBlock struct {
+ Height uint64 `protobuf:"varint,1,opt,name=height,proto3" json:"height,omitempty"`
+ // State payloads describing new state fragments.
+ StatePayloads []*StatePayload `protobuf:"bytes,2,rep,name=state_payloads,json=statePayloads,proto3" json:"state_payloads,omitempty"`
+ // Nullifiers identifying spent notes.
+ Nullifiers []*v1alpha1.Nullifier `protobuf:"bytes,3,rep,name=nullifiers,proto3" json:"nullifiers,omitempty"`
+ // The block root of this block.
+ BlockRoot *v1alpha1.MerkleRoot `protobuf:"bytes,4,opt,name=block_root,json=blockRoot,proto3" json:"block_root,omitempty"`
+ // The epoch root of this epoch (only present when the block is the last in an epoch).
+ EpochRoot *v1alpha1.MerkleRoot `protobuf:"bytes,17,opt,name=epoch_root,json=epochRoot,proto3" json:"epoch_root,omitempty"`
+ // If a proposal started voting in this block, this is set to `true`.
+ ProposalStarted bool `protobuf:"varint,20,opt,name=proposal_started,json=proposalStarted,proto3" json:"proposal_started,omitempty"`
+ // Latest Fuzzy Message Detection parameters.
+ FmdParameters *FmdParameters `protobuf:"bytes,100,opt,name=fmd_parameters,json=fmdParameters,proto3" json:"fmd_parameters,omitempty"`
+ // Price data for swaps executed in this block.
+ SwapOutputs []*v1alpha11.BatchSwapOutputData `protobuf:"bytes,5,rep,name=swap_outputs,json=swapOutputs,proto3" json:"swap_outputs,omitempty"`
+ // Updated chain parameters, if they have changed.
+ ChainParameters *ChainParameters `protobuf:"bytes,6,opt,name=chain_parameters,json=chainParameters,proto3" json:"chain_parameters,omitempty"`
+}
+
+func (m *CompactBlock) Reset() { *m = CompactBlock{} }
+func (m *CompactBlock) String() string { return proto.CompactTextString(m) }
+func (*CompactBlock) ProtoMessage() {}
+func (*CompactBlock) Descriptor() ([]byte, []int) {
+ return fileDescriptor_b0cedb8b84ba3224, []int{3}
+}
+func (m *CompactBlock) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *CompactBlock) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_CompactBlock.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *CompactBlock) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_CompactBlock.Merge(m, src)
+}
+func (m *CompactBlock) XXX_Size() int {
+ return m.Size()
+}
+func (m *CompactBlock) XXX_DiscardUnknown() {
+ xxx_messageInfo_CompactBlock.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_CompactBlock proto.InternalMessageInfo
+
+func (m *CompactBlock) GetHeight() uint64 {
+ if m != nil {
+ return m.Height
+ }
+ return 0
+}
+
+func (m *CompactBlock) GetStatePayloads() []*StatePayload {
+ if m != nil {
+ return m.StatePayloads
+ }
+ return nil
+}
+
+func (m *CompactBlock) GetNullifiers() []*v1alpha1.Nullifier {
+ if m != nil {
+ return m.Nullifiers
+ }
+ return nil
+}
+
+func (m *CompactBlock) GetBlockRoot() *v1alpha1.MerkleRoot {
+ if m != nil {
+ return m.BlockRoot
+ }
+ return nil
+}
+
+func (m *CompactBlock) GetEpochRoot() *v1alpha1.MerkleRoot {
+ if m != nil {
+ return m.EpochRoot
+ }
+ return nil
+}
+
+func (m *CompactBlock) GetProposalStarted() bool {
+ if m != nil {
+ return m.ProposalStarted
+ }
+ return false
+}
+
+func (m *CompactBlock) GetFmdParameters() *FmdParameters {
+ if m != nil {
+ return m.FmdParameters
+ }
+ return nil
+}
+
+func (m *CompactBlock) GetSwapOutputs() []*v1alpha11.BatchSwapOutputData {
+ if m != nil {
+ return m.SwapOutputs
+ }
+ return nil
+}
+
+func (m *CompactBlock) GetChainParameters() *ChainParameters {
+ if m != nil {
+ return m.ChainParameters
+ }
+ return nil
+}
+
+type StatePayload struct {
+ // Types that are valid to be assigned to StatePayload:
+ // *StatePayload_RolledUp_
+ // *StatePayload_Note_
+ // *StatePayload_Swap_
+ StatePayload isStatePayload_StatePayload `protobuf_oneof:"state_payload"`
+}
+
+func (m *StatePayload) Reset() { *m = StatePayload{} }
+func (m *StatePayload) String() string { return proto.CompactTextString(m) }
+func (*StatePayload) ProtoMessage() {}
+func (*StatePayload) Descriptor() ([]byte, []int) {
+ return fileDescriptor_b0cedb8b84ba3224, []int{4}
+}
+func (m *StatePayload) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *StatePayload) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_StatePayload.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *StatePayload) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_StatePayload.Merge(m, src)
+}
+func (m *StatePayload) XXX_Size() int {
+ return m.Size()
+}
+func (m *StatePayload) XXX_DiscardUnknown() {
+ xxx_messageInfo_StatePayload.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_StatePayload proto.InternalMessageInfo
+
+type isStatePayload_StatePayload interface {
+ isStatePayload_StatePayload()
+ MarshalTo([]byte) (int, error)
+ Size() int
+}
+
+type StatePayload_RolledUp_ struct {
+ RolledUp *StatePayload_RolledUp `protobuf:"bytes,1,opt,name=rolled_up,json=rolledUp,proto3,oneof" json:"rolled_up,omitempty"`
+}
+type StatePayload_Note_ struct {
+ Note *StatePayload_Note `protobuf:"bytes,2,opt,name=note,proto3,oneof" json:"note,omitempty"`
+}
+type StatePayload_Swap_ struct {
+ Swap *StatePayload_Swap `protobuf:"bytes,3,opt,name=swap,proto3,oneof" json:"swap,omitempty"`
+}
+
+func (*StatePayload_RolledUp_) isStatePayload_StatePayload() {}
+func (*StatePayload_Note_) isStatePayload_StatePayload() {}
+func (*StatePayload_Swap_) isStatePayload_StatePayload() {}
+
+func (m *StatePayload) GetStatePayload() isStatePayload_StatePayload {
+ if m != nil {
+ return m.StatePayload
+ }
+ return nil
+}
+
+func (m *StatePayload) GetRolledUp() *StatePayload_RolledUp {
+ if x, ok := m.GetStatePayload().(*StatePayload_RolledUp_); ok {
+ return x.RolledUp
+ }
+ return nil
+}
+
+func (m *StatePayload) GetNote() *StatePayload_Note {
+ if x, ok := m.GetStatePayload().(*StatePayload_Note_); ok {
+ return x.Note
+ }
+ return nil
+}
+
+func (m *StatePayload) GetSwap() *StatePayload_Swap {
+ if x, ok := m.GetStatePayload().(*StatePayload_Swap_); ok {
+ return x.Swap
+ }
+ return nil
+}
+
+// XXX_OneofWrappers is for the internal use of the proto package.
+func (*StatePayload) XXX_OneofWrappers() []interface{} {
+ return []interface{}{
+ (*StatePayload_RolledUp_)(nil),
+ (*StatePayload_Note_)(nil),
+ (*StatePayload_Swap_)(nil),
+ }
+}
+
+type StatePayload_RolledUp struct {
+ Commitment *v1alpha1.StateCommitment `protobuf:"bytes,1,opt,name=commitment,proto3" json:"commitment,omitempty"`
+}
+
+func (m *StatePayload_RolledUp) Reset() { *m = StatePayload_RolledUp{} }
+func (m *StatePayload_RolledUp) String() string { return proto.CompactTextString(m) }
+func (*StatePayload_RolledUp) ProtoMessage() {}
+func (*StatePayload_RolledUp) Descriptor() ([]byte, []int) {
+ return fileDescriptor_b0cedb8b84ba3224, []int{4, 0}
+}
+func (m *StatePayload_RolledUp) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *StatePayload_RolledUp) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_StatePayload_RolledUp.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *StatePayload_RolledUp) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_StatePayload_RolledUp.Merge(m, src)
+}
+func (m *StatePayload_RolledUp) XXX_Size() int {
+ return m.Size()
+}
+func (m *StatePayload_RolledUp) XXX_DiscardUnknown() {
+ xxx_messageInfo_StatePayload_RolledUp.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_StatePayload_RolledUp proto.InternalMessageInfo
+
+func (m *StatePayload_RolledUp) GetCommitment() *v1alpha1.StateCommitment {
+ if m != nil {
+ return m.Commitment
+ }
+ return nil
+}
+
+type StatePayload_Note struct {
+ Source *NoteSource `protobuf:"bytes,1,opt,name=source,proto3" json:"source,omitempty"`
+ Note *v1alpha1.NotePayload `protobuf:"bytes,2,opt,name=note,proto3" json:"note,omitempty"`
+}
+
+func (m *StatePayload_Note) Reset() { *m = StatePayload_Note{} }
+func (m *StatePayload_Note) String() string { return proto.CompactTextString(m) }
+func (*StatePayload_Note) ProtoMessage() {}
+func (*StatePayload_Note) Descriptor() ([]byte, []int) {
+ return fileDescriptor_b0cedb8b84ba3224, []int{4, 1}
+}
+func (m *StatePayload_Note) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *StatePayload_Note) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_StatePayload_Note.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *StatePayload_Note) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_StatePayload_Note.Merge(m, src)
+}
+func (m *StatePayload_Note) XXX_Size() int {
+ return m.Size()
+}
+func (m *StatePayload_Note) XXX_DiscardUnknown() {
+ xxx_messageInfo_StatePayload_Note.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_StatePayload_Note proto.InternalMessageInfo
+
+func (m *StatePayload_Note) GetSource() *NoteSource {
+ if m != nil {
+ return m.Source
+ }
+ return nil
+}
+
+func (m *StatePayload_Note) GetNote() *v1alpha1.NotePayload {
+ if m != nil {
+ return m.Note
+ }
+ return nil
+}
+
+type StatePayload_Swap struct {
+ Source *NoteSource `protobuf:"bytes,1,opt,name=source,proto3" json:"source,omitempty"`
+ Swap *v1alpha11.SwapPayload `protobuf:"bytes,2,opt,name=swap,proto3" json:"swap,omitempty"`
+}
+
+func (m *StatePayload_Swap) Reset() { *m = StatePayload_Swap{} }
+func (m *StatePayload_Swap) String() string { return proto.CompactTextString(m) }
+func (*StatePayload_Swap) ProtoMessage() {}
+func (*StatePayload_Swap) Descriptor() ([]byte, []int) {
+ return fileDescriptor_b0cedb8b84ba3224, []int{4, 2}
+}
+func (m *StatePayload_Swap) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *StatePayload_Swap) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_StatePayload_Swap.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *StatePayload_Swap) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_StatePayload_Swap.Merge(m, src)
+}
+func (m *StatePayload_Swap) XXX_Size() int {
+ return m.Size()
+}
+func (m *StatePayload_Swap) XXX_DiscardUnknown() {
+ xxx_messageInfo_StatePayload_Swap.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_StatePayload_Swap proto.InternalMessageInfo
+
+func (m *StatePayload_Swap) GetSource() *NoteSource {
+ if m != nil {
+ return m.Source
+ }
+ return nil
+}
+
+func (m *StatePayload_Swap) GetSwap() *v1alpha11.SwapPayload {
+ if m != nil {
+ return m.Swap
+ }
+ return nil
+}
+
+type KnownAssets struct {
+ Assets []*v1alpha1.DenomMetadata `protobuf:"bytes,1,rep,name=assets,proto3" json:"assets,omitempty"`
+}
+
+func (m *KnownAssets) Reset() { *m = KnownAssets{} }
+func (m *KnownAssets) String() string { return proto.CompactTextString(m) }
+func (*KnownAssets) ProtoMessage() {}
+func (*KnownAssets) Descriptor() ([]byte, []int) {
+ return fileDescriptor_b0cedb8b84ba3224, []int{5}
+}
+func (m *KnownAssets) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *KnownAssets) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_KnownAssets.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *KnownAssets) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_KnownAssets.Merge(m, src)
+}
+func (m *KnownAssets) XXX_Size() int {
+ return m.Size()
+}
+func (m *KnownAssets) XXX_DiscardUnknown() {
+ xxx_messageInfo_KnownAssets.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_KnownAssets proto.InternalMessageInfo
+
+func (m *KnownAssets) GetAssets() []*v1alpha1.DenomMetadata {
+ if m != nil {
+ return m.Assets
+ }
+ return nil
+}
+
+// A spicy transaction ID
+type NoteSource struct {
+ Inner []byte `protobuf:"bytes,1,opt,name=inner,proto3" json:"inner,omitempty"`
+}
+
+func (m *NoteSource) Reset() { *m = NoteSource{} }
+func (m *NoteSource) String() string { return proto.CompactTextString(m) }
+func (*NoteSource) ProtoMessage() {}
+func (*NoteSource) Descriptor() ([]byte, []int) {
+ return fileDescriptor_b0cedb8b84ba3224, []int{6}
+}
+func (m *NoteSource) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *NoteSource) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_NoteSource.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *NoteSource) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_NoteSource.Merge(m, src)
+}
+func (m *NoteSource) XXX_Size() int {
+ return m.Size()
+}
+func (m *NoteSource) XXX_DiscardUnknown() {
+ xxx_messageInfo_NoteSource.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_NoteSource proto.InternalMessageInfo
+
+func (m *NoteSource) GetInner() []byte {
+ if m != nil {
+ return m.Inner
+ }
+ return nil
+}
+
+// A NoteSource paired with the height at which the note was spent
+type SpendInfo struct {
+ NoteSource *NoteSource `protobuf:"bytes,1,opt,name=note_source,json=noteSource,proto3" json:"note_source,omitempty"`
+ SpendHeight uint64 `protobuf:"varint,2,opt,name=spend_height,json=spendHeight,proto3" json:"spend_height,omitempty"`
+}
+
+func (m *SpendInfo) Reset() { *m = SpendInfo{} }
+func (m *SpendInfo) String() string { return proto.CompactTextString(m) }
+func (*SpendInfo) ProtoMessage() {}
+func (*SpendInfo) Descriptor() ([]byte, []int) {
+ return fileDescriptor_b0cedb8b84ba3224, []int{7}
+}
+func (m *SpendInfo) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *SpendInfo) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_SpendInfo.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *SpendInfo) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_SpendInfo.Merge(m, src)
+}
+func (m *SpendInfo) XXX_Size() int {
+ return m.Size()
+}
+func (m *SpendInfo) XXX_DiscardUnknown() {
+ xxx_messageInfo_SpendInfo.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_SpendInfo proto.InternalMessageInfo
+
+func (m *SpendInfo) GetNoteSource() *NoteSource {
+ if m != nil {
+ return m.NoteSource
+ }
+ return nil
+}
+
+func (m *SpendInfo) GetSpendHeight() uint64 {
+ if m != nil {
+ return m.SpendHeight
+ }
+ return 0
+}
+
+type GenesisAppState struct {
+ ChainParams *ChainParameters `protobuf:"bytes,1,opt,name=chain_params,json=chainParams,proto3" json:"chain_params,omitempty"`
+ Validators []*v1alpha12.Validator `protobuf:"bytes,2,rep,name=validators,proto3" json:"validators,omitempty"`
+ Allocations []*GenesisAppState_Allocation `protobuf:"bytes,3,rep,name=allocations,proto3" json:"allocations,omitempty"`
+}
+
+func (m *GenesisAppState) Reset() { *m = GenesisAppState{} }
+func (m *GenesisAppState) String() string { return proto.CompactTextString(m) }
+func (*GenesisAppState) ProtoMessage() {}
+func (*GenesisAppState) Descriptor() ([]byte, []int) {
+ return fileDescriptor_b0cedb8b84ba3224, []int{8}
+}
+func (m *GenesisAppState) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *GenesisAppState) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_GenesisAppState.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *GenesisAppState) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_GenesisAppState.Merge(m, src)
+}
+func (m *GenesisAppState) XXX_Size() int {
+ return m.Size()
+}
+func (m *GenesisAppState) XXX_DiscardUnknown() {
+ xxx_messageInfo_GenesisAppState.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_GenesisAppState proto.InternalMessageInfo
+
+func (m *GenesisAppState) GetChainParams() *ChainParameters {
+ if m != nil {
+ return m.ChainParams
+ }
+ return nil
+}
+
+func (m *GenesisAppState) GetValidators() []*v1alpha12.Validator {
+ if m != nil {
+ return m.Validators
+ }
+ return nil
+}
+
+func (m *GenesisAppState) GetAllocations() []*GenesisAppState_Allocation {
+ if m != nil {
+ return m.Allocations
+ }
+ return nil
+}
+
+type GenesisAppState_Allocation struct {
+ Amount *v1alpha1.Amount `protobuf:"bytes,1,opt,name=amount,proto3" json:"amount,omitempty"`
+ Denom string `protobuf:"bytes,2,opt,name=denom,proto3" json:"denom,omitempty"`
+ Address *v1alpha1.Address `protobuf:"bytes,3,opt,name=address,proto3" json:"address,omitempty"`
+}
+
+func (m *GenesisAppState_Allocation) Reset() { *m = GenesisAppState_Allocation{} }
+func (m *GenesisAppState_Allocation) String() string { return proto.CompactTextString(m) }
+func (*GenesisAppState_Allocation) ProtoMessage() {}
+func (*GenesisAppState_Allocation) Descriptor() ([]byte, []int) {
+ return fileDescriptor_b0cedb8b84ba3224, []int{8, 0}
+}
+func (m *GenesisAppState_Allocation) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *GenesisAppState_Allocation) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_GenesisAppState_Allocation.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *GenesisAppState_Allocation) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_GenesisAppState_Allocation.Merge(m, src)
+}
+func (m *GenesisAppState_Allocation) XXX_Size() int {
+ return m.Size()
+}
+func (m *GenesisAppState_Allocation) XXX_DiscardUnknown() {
+ xxx_messageInfo_GenesisAppState_Allocation.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_GenesisAppState_Allocation proto.InternalMessageInfo
+
+func (m *GenesisAppState_Allocation) GetAmount() *v1alpha1.Amount {
+ if m != nil {
+ return m.Amount
+ }
+ return nil
+}
+
+func (m *GenesisAppState_Allocation) GetDenom() string {
+ if m != nil {
+ return m.Denom
+ }
+ return ""
+}
+
+func (m *GenesisAppState_Allocation) GetAddress() *v1alpha1.Address {
+ if m != nil {
+ return m.Address
+ }
+ return nil
+}
+
+type Epoch struct {
+ Index uint64 `protobuf:"varint,1,opt,name=index,proto3" json:"index,omitempty"`
+ StartHeight uint64 `protobuf:"varint,2,opt,name=start_height,json=startHeight,proto3" json:"start_height,omitempty"`
+}
+
+func (m *Epoch) Reset() { *m = Epoch{} }
+func (m *Epoch) String() string { return proto.CompactTextString(m) }
+func (*Epoch) ProtoMessage() {}
+func (*Epoch) Descriptor() ([]byte, []int) {
+ return fileDescriptor_b0cedb8b84ba3224, []int{9}
+}
+func (m *Epoch) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *Epoch) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_Epoch.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *Epoch) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_Epoch.Merge(m, src)
+}
+func (m *Epoch) XXX_Size() int {
+ return m.Size()
+}
+func (m *Epoch) XXX_DiscardUnknown() {
+ xxx_messageInfo_Epoch.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_Epoch proto.InternalMessageInfo
+
+func (m *Epoch) GetIndex() uint64 {
+ if m != nil {
+ return m.Index
+ }
+ return 0
+}
+
+func (m *Epoch) GetStartHeight() uint64 {
+ if m != nil {
+ return m.StartHeight
+ }
+ return 0
+}
+
+func init() {
+ proto.RegisterType((*ChainParameters)(nil), "penumbra.core.chain.v1alpha1.ChainParameters")
+ proto.RegisterType((*Ratio)(nil), "penumbra.core.chain.v1alpha1.Ratio")
+ proto.RegisterType((*FmdParameters)(nil), "penumbra.core.chain.v1alpha1.FmdParameters")
+ proto.RegisterType((*CompactBlock)(nil), "penumbra.core.chain.v1alpha1.CompactBlock")
+ proto.RegisterType((*StatePayload)(nil), "penumbra.core.chain.v1alpha1.StatePayload")
+ proto.RegisterType((*StatePayload_RolledUp)(nil), "penumbra.core.chain.v1alpha1.StatePayload.RolledUp")
+ proto.RegisterType((*StatePayload_Note)(nil), "penumbra.core.chain.v1alpha1.StatePayload.Note")
+ proto.RegisterType((*StatePayload_Swap)(nil), "penumbra.core.chain.v1alpha1.StatePayload.Swap")
+ proto.RegisterType((*KnownAssets)(nil), "penumbra.core.chain.v1alpha1.KnownAssets")
+ proto.RegisterType((*NoteSource)(nil), "penumbra.core.chain.v1alpha1.NoteSource")
+ proto.RegisterType((*SpendInfo)(nil), "penumbra.core.chain.v1alpha1.SpendInfo")
+ proto.RegisterType((*GenesisAppState)(nil), "penumbra.core.chain.v1alpha1.GenesisAppState")
+ proto.RegisterType((*GenesisAppState_Allocation)(nil), "penumbra.core.chain.v1alpha1.GenesisAppState.Allocation")
+ proto.RegisterType((*Epoch)(nil), "penumbra.core.chain.v1alpha1.Epoch")
+}
+
+func init() {
+ proto.RegisterFile("penumbra/core/chain/v1alpha1/chain.proto", fileDescriptor_b0cedb8b84ba3224)
+}
+
+var fileDescriptor_b0cedb8b84ba3224 = []byte{
+ // 1498 bytes of a gzipped FileDescriptorProto
+ 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xac, 0x57, 0x4b, 0x6f, 0x1c, 0xc7,
+ 0x11, 0xe6, 0xf2, 0xcd, 0x5a, 0xbe, 0xd2, 0x12, 0xa9, 0x11, 0xc3, 0x50, 0x9b, 0x45, 0x94, 0xac,
+ 0xa4, 0x64, 0x37, 0xa2, 0x84, 0x44, 0xa0, 0xa0, 0x80, 0xcf, 0x90, 0x44, 0x44, 0x69, 0x35, 0x54,
+ 0x98, 0x40, 0x60, 0x30, 0xe8, 0x9d, 0x69, 0x72, 0x1b, 0x9a, 0xe9, 0x9e, 0x4c, 0xf7, 0xf0, 0x71,
+ 0x4f, 0x00, 0x1f, 0xfd, 0x1b, 0xec, 0x9b, 0x0f, 0x06, 0xfc, 0x2f, 0x0c, 0x9f, 0x74, 0xf4, 0xd1,
+ 0xa0, 0x6e, 0x3e, 0xf9, 0xe0, 0x1f, 0x60, 0x74, 0xf5, 0xcc, 0xec, 0x72, 0x65, 0x2c, 0x4d, 0xc3,
+ 0xb7, 0xe9, 0xaa, 0xef, 0xfb, 0xba, 0xba, 0xba, 0xaa, 0xbb, 0x07, 0x6a, 0x31, 0x13, 0x69, 0xd4,
+ 0x4a, 0x68, 0xc3, 0x97, 0x09, 0x6b, 0xf8, 0x6d, 0xca, 0x45, 0xe3, 0xe4, 0x21, 0x0d, 0xe3, 0x36,
+ 0x7d, 0x68, 0x87, 0xf5, 0x38, 0x91, 0x5a, 0x92, 0xc5, 0x1c, 0x59, 0x37, 0xc8, 0xba, 0x75, 0xe5,
+ 0xc8, 0x85, 0xfb, 0x3d, 0x3a, 0xc9, 0x79, 0xac, 0x65, 0x97, 0x10, 0x8e, 0xad, 0xd2, 0x42, 0xcf,
+ 0x9c, 0x4a, 0xd3, 0xb7, 0xac, 0x03, 0xc5, 0x61, 0x86, 0xfc, 0xdd, 0x65, 0x64, 0xc0, 0xce, 0x3a,
+ 0xb8, 0x80, 0x9d, 0x59, 0x54, 0xf5, 0xfb, 0x31, 0x98, 0xd9, 0x30, 0xe1, 0x34, 0x69, 0x42, 0x23,
+ 0xa6, 0x59, 0xa2, 0xc8, 0x6d, 0x18, 0xc7, 0x08, 0x3d, 0x1e, 0x38, 0xa5, 0x4a, 0xa9, 0x36, 0xe1,
+ 0x8e, 0xe1, 0x78, 0x37, 0x20, 0x77, 0x61, 0x9a, 0xc5, 0xd2, 0x6f, 0x7b, 0x41, 0x9a, 0x50, 0xcd,
+ 0xa5, 0x70, 0x06, 0x2b, 0xa5, 0xda, 0xb0, 0x3b, 0x85, 0xd6, 0xcd, 0xcc, 0x48, 0xee, 0xc1, 0x6c,
+ 0x2a, 0x5a, 0x52, 0x04, 0x5c, 0x1c, 0x7b, 0xe8, 0x52, 0xce, 0x10, 0x02, 0x67, 0x0a, 0xfb, 0x16,
+ 0x9a, 0xc9, 0x63, 0x98, 0xa7, 0xbe, 0xe6, 0x27, 0xcc, 0x3b, 0xa1, 0x21, 0x0f, 0xa8, 0x96, 0x89,
+ 0x17, 0xf2, 0x88, 0x6b, 0x67, 0x18, 0x09, 0x37, 0xad, 0xf7, 0x20, 0x77, 0x3e, 0x37, 0x3e, 0x52,
+ 0x83, 0xd9, 0x16, 0x55, 0xcc, 0x4b, 0xd8, 0x29, 0x4d, 0x02, 0x2f, 0xa1, 0x9a, 0x39, 0x13, 0x88,
+ 0x9f, 0x36, 0x76, 0x17, 0xcd, 0x2e, 0xd5, 0x8c, 0xac, 0xc2, 0xa2, 0x0a, 0xa9, 0x6a, 0x9b, 0x48,
+ 0x62, 0x26, 0x68, 0xa8, 0xcf, 0xbd, 0x88, 0xab, 0x16, 0x6b, 0xd3, 0x13, 0x2e, 0x13, 0x67, 0x04,
+ 0x59, 0x0b, 0x39, 0xa6, 0x69, 0x21, 0x7b, 0x1d, 0x04, 0x59, 0x81, 0xdb, 0x1f, 0x28, 0x04, 0xf2,
+ 0x54, 0x68, 0x1e, 0x31, 0x07, 0x90, 0x7e, 0xab, 0x87, 0xbe, 0x99, 0xb9, 0xc9, 0x5f, 0xc1, 0x51,
+ 0xfc, 0x58, 0xb0, 0xc0, 0x6b, 0x85, 0xd2, 0x7f, 0xab, 0xbc, 0x53, 0x2e, 0x02, 0x79, 0xea, 0x85,
+ 0x4c, 0x38, 0x65, 0xa4, 0xce, 0x59, 0xff, 0x3a, 0xba, 0xff, 0x85, 0xde, 0xe7, 0x4c, 0x90, 0x65,
+ 0x98, 0x8b, 0xb8, 0x52, 0x1d, 0x62, 0x44, 0xcf, 0x78, 0x94, 0x46, 0xce, 0x24, 0xb2, 0x6e, 0x58,
+ 0xa7, 0x65, 0xed, 0x59, 0x17, 0xb9, 0x03, 0x65, 0xde, 0xf2, 0x3d, 0x26, 0x68, 0x2b, 0x64, 0x81,
+ 0x33, 0x5a, 0x29, 0xd5, 0xc6, 0x5d, 0xe0, 0x2d, 0x7f, 0xcb, 0x5a, 0xc8, 0x16, 0xdc, 0xe1, 0xa2,
+ 0x25, 0x53, 0x11, 0x78, 0xdc, 0x57, 0xcb, 0x7f, 0xf6, 0x74, 0x42, 0x85, 0x3a, 0x62, 0x89, 0x2a,
+ 0x48, 0x63, 0x48, 0x5a, 0xcc, 0x60, 0xbb, 0x06, 0xf5, 0x3a, 0x07, 0xe5, 0x32, 0xdb, 0x50, 0x91,
+ 0xa9, 0xee, 0xaf, 0x33, 0x8e, 0x3a, 0xbf, 0xc9, 0x71, 0x3f, 0x2e, 0xf4, 0x18, 0xe6, 0xe3, 0x44,
+ 0xc6, 0x52, 0xd1, 0xd0, 0x3b, 0x91, 0xda, 0x24, 0xd8, 0xae, 0xd6, 0xb9, 0x69, 0xf7, 0x3e, 0xf7,
+ 0x1e, 0xa0, 0xd3, 0xae, 0x96, 0xfc, 0x07, 0x6e, 0x15, 0xac, 0x80, 0xc5, 0x52, 0x71, 0xed, 0xd1,
+ 0x48, 0xa6, 0x42, 0x3b, 0x73, 0x95, 0x52, 0xad, 0xbc, 0x7c, 0xb7, 0xde, 0xd3, 0x6e, 0xb6, 0x81,
+ 0xf2, 0xea, 0xaf, 0xaf, 0x21, 0xd8, 0x9d, 0xcb, 0x55, 0x36, 0xad, 0x88, 0x35, 0x9b, 0xcc, 0x77,
+ 0x82, 0x32, 0x55, 0xe7, 0xfd, 0x37, 0x95, 0x49, 0x1a, 0x39, 0xf3, 0xd8, 0x0a, 0x37, 0x8a, 0x98,
+ 0x8c, 0xef, 0x15, 0xba, 0xc8, 0x5f, 0xba, 0x42, 0x8a, 0xa9, 0x52, 0x9e, 0x6e, 0x27, 0x4c, 0xb5,
+ 0x65, 0x18, 0x38, 0xb7, 0x90, 0x55, 0x48, 0x36, 0xa9, 0x52, 0xaf, 0x73, 0x27, 0x79, 0x02, 0x4e,
+ 0xc1, 0xc3, 0x12, 0xea, 0x22, 0x3a, 0x48, 0x2c, 0x12, 0xb4, 0x6f, 0xdc, 0x1d, 0xe6, 0x33, 0xf8,
+ 0x75, 0x40, 0xa5, 0xa7, 0x62, 0x26, 0x02, 0x2f, 0xc7, 0x74, 0xd2, 0x7f, 0x1b, 0xd3, 0xef, 0x04,
+ 0x54, 0xee, 0x1b, 0x44, 0x33, 0x07, 0x64, 0x99, 0xaf, 0x6e, 0xc3, 0x88, 0x6b, 0x5a, 0x95, 0x2c,
+ 0xc2, 0x84, 0x48, 0x23, 0x96, 0x98, 0xd6, 0xc2, 0x66, 0x1f, 0x76, 0x3b, 0x06, 0x52, 0x81, 0x72,
+ 0xc0, 0x84, 0x8c, 0xb8, 0x40, 0xbf, 0xed, 0xf5, 0x6e, 0x53, 0xd5, 0x87, 0xa9, 0xbf, 0x47, 0x41,
+ 0xd7, 0xe1, 0x71, 0x17, 0xa6, 0xe3, 0x84, 0xf9, 0x5c, 0x71, 0x29, 0xbc, 0x16, 0xd7, 0x0a, 0x55,
+ 0xa7, 0xdc, 0xa9, 0xc2, 0xba, 0xce, 0xb5, 0x22, 0x0f, 0x80, 0x50, 0xe5, 0xc9, 0x23, 0xbb, 0xe1,
+ 0x5e, 0x9b, 0xf1, 0xe3, 0xb6, 0xce, 0x26, 0x98, 0xa1, 0xea, 0xe5, 0x11, 0x6e, 0xf6, 0x0e, 0x9a,
+ 0xab, 0xff, 0x1b, 0x81, 0xc9, 0x0d, 0x19, 0xc5, 0xd4, 0xd7, 0x68, 0x26, 0xf3, 0x30, 0x9a, 0x31,
+ 0x6c, 0xc8, 0xd9, 0x88, 0xbc, 0x82, 0x69, 0xa5, 0xa9, 0x66, 0x5e, 0x4c, 0xcf, 0x43, 0x49, 0x03,
+ 0xe5, 0x0c, 0x56, 0x86, 0x6a, 0xe5, 0xe5, 0xfb, 0xf5, 0x7e, 0x07, 0x70, 0x7d, 0xdf, 0x70, 0x9a,
+ 0x96, 0xe2, 0x4e, 0xa9, 0xae, 0x91, 0x22, 0x3b, 0x00, 0x22, 0x0d, 0x43, 0x7e, 0xc4, 0x59, 0x62,
+ 0x0e, 0x31, 0x23, 0x57, 0xbb, 0xa2, 0xc0, 0x5e, 0xe4, 0x04, 0xb7, 0x8b, 0x6b, 0x94, 0xec, 0x62,
+ 0x13, 0x29, 0xed, 0xe9, 0x56, 0x5e, 0xbe, 0x77, 0x85, 0xd2, 0x1e, 0x4b, 0xde, 0x86, 0xcc, 0x95,
+ 0x52, 0xbb, 0x13, 0x48, 0x36, 0x9f, 0x46, 0xc9, 0x9e, 0xc2, 0xa8, 0xf4, 0xab, 0x6b, 0x2b, 0x21,
+ 0x19, 0x95, 0xee, 0xc1, 0x6c, 0xa7, 0x00, 0x35, 0x4d, 0x34, 0x0b, 0xb0, 0xf7, 0xc6, 0xdd, 0x99,
+ 0xa2, 0xf0, 0xac, 0x99, 0xb8, 0x30, 0x7d, 0x14, 0x05, 0x5e, 0x5c, 0x6c, 0xb5, 0x13, 0xe0, 0xc4,
+ 0x0f, 0xfa, 0xe7, 0xf6, 0x52, 0x75, 0xb8, 0x53, 0x47, 0x97, 0x8a, 0xc5, 0x85, 0x49, 0x75, 0x4a,
+ 0x63, 0x4f, 0xa6, 0x3a, 0x4e, 0xb5, 0x72, 0x46, 0x30, 0xbd, 0x8d, 0x1e, 0x45, 0x73, 0x5b, 0x15,
+ 0x7a, 0xeb, 0x54, 0xfb, 0xed, 0xfd, 0x53, 0x1a, 0xbf, 0x44, 0xce, 0x26, 0xd5, 0xd4, 0x2d, 0xab,
+ 0x62, 0xac, 0xc8, 0xbf, 0x61, 0xd6, 0xde, 0x5e, 0x5d, 0x91, 0x8e, 0x62, 0xa4, 0x7f, 0xea, 0x1f,
+ 0x69, 0xcf, 0x35, 0xe8, 0xce, 0xf8, 0x97, 0x0d, 0xd5, 0xef, 0x86, 0x61, 0xb2, 0xbb, 0x54, 0x88,
+ 0x0b, 0x13, 0x89, 0x0c, 0x43, 0x16, 0x78, 0x69, 0x8c, 0x95, 0x58, 0x5e, 0x7e, 0xf4, 0xd3, 0x2b,
+ 0xad, 0xee, 0x22, 0xf7, 0x9f, 0xf1, 0xce, 0x80, 0x3b, 0x9e, 0x64, 0xdf, 0x64, 0x0b, 0x86, 0x85,
+ 0xd4, 0x0c, 0x5b, 0xe1, 0xc3, 0x54, 0xf4, 0x93, 0x7b, 0x21, 0x35, 0xdb, 0x19, 0x70, 0x91, 0x6e,
+ 0x64, 0x4c, 0x52, 0xf0, 0xd6, 0xbd, 0x9e, 0x8c, 0xc9, 0xad, 0x91, 0x31, 0xf4, 0x85, 0x37, 0x30,
+ 0x9e, 0x47, 0x49, 0x5e, 0x00, 0xf8, 0x32, 0x8a, 0xb8, 0x8e, 0x98, 0xd0, 0xd9, 0x72, 0xeb, 0x57,
+ 0x54, 0x1d, 0x2a, 0x6f, 0x14, 0x2c, 0xb7, 0x4b, 0x61, 0xe1, 0xa3, 0x12, 0x0c, 0x9b, 0x98, 0xc9,
+ 0x2a, 0x8c, 0x2a, 0x99, 0x26, 0x3e, 0xcb, 0x44, 0x6b, 0xfd, 0xa3, 0x35, 0x9c, 0x7d, 0xc4, 0xbb,
+ 0x19, 0x8f, 0xfc, 0xed, 0x52, 0xd2, 0xee, 0x5f, 0xd5, 0x9e, 0xb2, 0xd3, 0xed, 0xc8, 0x5b, 0xf8,
+ 0x7f, 0x09, 0x86, 0xcd, 0xba, 0x7f, 0x81, 0x50, 0x9e, 0x66, 0x89, 0xb7, 0xa1, 0xfc, 0xa1, 0x5f,
+ 0x29, 0x9b, 0x19, 0x8b, 0x38, 0x0c, 0x69, 0x7d, 0x06, 0xa6, 0x2e, 0x9d, 0x5f, 0xd5, 0x7d, 0x28,
+ 0xff, 0x43, 0xc8, 0x53, 0xb1, 0xa6, 0x14, 0xd3, 0x8a, 0x6c, 0xc2, 0x28, 0xc5, 0x2f, 0xa7, 0x84,
+ 0x9d, 0xf2, 0xc7, 0x2b, 0x56, 0xba, 0x69, 0x4e, 0xea, 0x3d, 0xa6, 0x69, 0x60, 0xda, 0x24, 0xe3,
+ 0x56, 0xab, 0x00, 0x9d, 0xc0, 0xc9, 0x4d, 0x18, 0xe1, 0x42, 0x30, 0x7b, 0xfa, 0x4f, 0xba, 0x76,
+ 0x50, 0x3d, 0x87, 0x09, 0xbc, 0x39, 0x76, 0xc5, 0x91, 0x24, 0xbb, 0x50, 0x36, 0x69, 0xf2, 0x7e,
+ 0x66, 0x6a, 0x40, 0x74, 0x66, 0xfb, 0x2d, 0x4c, 0xda, 0x3b, 0xeb, 0xd2, 0x89, 0x5f, 0x46, 0x5b,
+ 0x76, 0xda, 0x7f, 0x3e, 0x04, 0x33, 0xdb, 0x4c, 0x30, 0xc5, 0xd5, 0x5a, 0x1c, 0x63, 0x05, 0x91,
+ 0x26, 0x4c, 0x76, 0x35, 0xb5, 0xca, 0x42, 0xb8, 0x66, 0x43, 0x97, 0x3b, 0x0d, 0xad, 0xc8, 0x36,
+ 0x40, 0xf1, 0xe0, 0xcc, 0xaf, 0x89, 0xde, 0xdd, 0xb2, 0xcf, 0xe9, 0x42, 0xaf, 0x78, 0x83, 0xba,
+ 0x5d, 0x54, 0xf2, 0x06, 0xca, 0x34, 0x0c, 0xa5, 0x8f, 0x2f, 0xdf, 0xfc, 0x86, 0x78, 0xd2, 0x3f,
+ 0xb2, 0x9e, 0xe5, 0xd5, 0xd7, 0x0a, 0x01, 0xb7, 0x5b, 0x6c, 0xe1, 0xd3, 0x12, 0x40, 0xc7, 0x47,
+ 0x9e, 0xc1, 0x68, 0xf6, 0xd0, 0x29, 0x5d, 0xe7, 0xa1, 0x93, 0x91, 0xcc, 0x4e, 0xe3, 0xd5, 0x8d,
+ 0x49, 0x9f, 0x70, 0xed, 0x80, 0xac, 0xc2, 0x18, 0x0d, 0x82, 0x84, 0x29, 0x95, 0x1d, 0x16, 0xbf,
+ 0xbf, 0x4a, 0xd5, 0xa2, 0xdd, 0x9c, 0x56, 0x5d, 0x85, 0x11, 0x7c, 0xcc, 0xdb, 0x52, 0x0a, 0xd8,
+ 0x59, 0x76, 0x2b, 0xdb, 0x01, 0x6e, 0xb9, 0xb9, 0x43, 0x7a, 0xb7, 0xdc, 0xd8, 0xec, 0x96, 0xaf,
+ 0x7f, 0x31, 0xf8, 0xe5, 0xc5, 0x52, 0xe9, 0xdd, 0xc5, 0x52, 0xe9, 0x9b, 0x8b, 0xa5, 0xd2, 0xc7,
+ 0xef, 0x97, 0x06, 0xde, 0xbd, 0x5f, 0x1a, 0xf8, 0xfa, 0xfd, 0xd2, 0x00, 0x54, 0x7c, 0x19, 0xf5,
+ 0x4d, 0xe6, 0x3a, 0xd8, 0x7d, 0x36, 0xbf, 0x33, 0xcd, 0xd2, 0x9b, 0x83, 0x63, 0xae, 0xdb, 0x69,
+ 0xab, 0xee, 0xcb, 0xa8, 0xe1, 0x4b, 0x15, 0x49, 0xd5, 0x48, 0x58, 0x48, 0xcf, 0x59, 0xd2, 0x38,
+ 0x59, 0x2e, 0x3e, 0x51, 0x42, 0x35, 0xfa, 0xfd, 0xc0, 0x3d, 0xc5, 0x61, 0x3e, 0xfa, 0x64, 0x70,
+ 0xa8, 0xb9, 0xb1, 0xf1, 0xd9, 0xe0, 0x62, 0x33, 0x0f, 0x65, 0xc3, 0x84, 0x82, 0x53, 0xd7, 0x0f,
+ 0x32, 0xd0, 0x57, 0x1d, 0xf7, 0xa1, 0x71, 0x1f, 0xa2, 0xfb, 0x30, 0x77, 0x5f, 0x0c, 0xd6, 0xfa,
+ 0xb9, 0x0f, 0xb7, 0x9b, 0xeb, 0x79, 0xaf, 0x7e, 0x3b, 0x78, 0x27, 0x87, 0xae, 0xac, 0x18, 0xec,
+ 0xca, 0x0a, 0x82, 0x57, 0x56, 0x72, 0x74, 0x6b, 0x14, 0x7f, 0xe0, 0x1e, 0xfd, 0x10, 0x00, 0x00,
+ 0xff, 0xff, 0xd1, 0xb8, 0x41, 0x47, 0x86, 0x0e, 0x00, 0x00,
+}
+
+func (m *ChainParameters) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *ChainParameters) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ChainParameters) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.DaoSpendProposalsEnabled {
+ i--
+ if m.DaoSpendProposalsEnabled {
+ dAtA[i] = 1
+ } else {
+ dAtA[i] = 0
+ }
+ i--
+ dAtA[i] = 0x1
+ i--
+ dAtA[i] = 0xc8
+ }
+ if len(m.ProposalSlashThreshold) > 0 {
+ i -= len(m.ProposalSlashThreshold)
+ copy(dAtA[i:], m.ProposalSlashThreshold)
+ i = encodeVarintChain(dAtA, i, uint64(len(m.ProposalSlashThreshold)))
+ i--
+ dAtA[i] = 0x1
+ i--
+ dAtA[i] = 0xc2
+ }
+ if len(m.ProposalPassThreshold) > 0 {
+ i -= len(m.ProposalPassThreshold)
+ copy(dAtA[i:], m.ProposalPassThreshold)
+ i = encodeVarintChain(dAtA, i, uint64(len(m.ProposalPassThreshold)))
+ i--
+ dAtA[i] = 0x1
+ i--
+ dAtA[i] = 0xba
+ }
+ if len(m.ProposalValidQuorum) > 0 {
+ i -= len(m.ProposalValidQuorum)
+ copy(dAtA[i:], m.ProposalValidQuorum)
+ i = encodeVarintChain(dAtA, i, uint64(len(m.ProposalValidQuorum)))
+ i--
+ dAtA[i] = 0x1
+ i--
+ dAtA[i] = 0xb2
+ }
+ if m.ProposalDepositAmount != nil {
+ {
+ size, err := m.ProposalDepositAmount.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintChain(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1
+ i--
+ dAtA[i] = 0xaa
+ }
+ if m.ProposalVotingBlocks != 0 {
+ i = encodeVarintChain(dAtA, i, uint64(m.ProposalVotingBlocks))
+ i--
+ dAtA[i] = 0x1
+ i--
+ dAtA[i] = 0xa0
+ }
+ if m.MissedBlocksMaximum != 0 {
+ i = encodeVarintChain(dAtA, i, uint64(m.MissedBlocksMaximum))
+ i--
+ dAtA[i] = 0x60
+ }
+ if m.SignedBlocksWindowLen != 0 {
+ i = encodeVarintChain(dAtA, i, uint64(m.SignedBlocksWindowLen))
+ i--
+ dAtA[i] = 0x58
+ }
+ if m.SlashingPenaltyDowntime != 0 {
+ i = encodeVarintChain(dAtA, i, uint64(m.SlashingPenaltyDowntime))
+ i--
+ dAtA[i] = 0x50
+ }
+ if m.BaseRewardRate != 0 {
+ i = encodeVarintChain(dAtA, i, uint64(m.BaseRewardRate))
+ i--
+ dAtA[i] = 0x48
+ }
+ if m.OutboundIcs20TransfersEnabled {
+ i--
+ if m.OutboundIcs20TransfersEnabled {
+ dAtA[i] = 1
+ } else {
+ dAtA[i] = 0
+ }
+ i--
+ dAtA[i] = 0x40
+ }
+ if m.InboundIcs20TransfersEnabled {
+ i--
+ if m.InboundIcs20TransfersEnabled {
+ dAtA[i] = 1
+ } else {
+ dAtA[i] = 0
+ }
+ i--
+ dAtA[i] = 0x38
+ }
+ if m.IbcEnabled {
+ i--
+ if m.IbcEnabled {
+ dAtA[i] = 1
+ } else {
+ dAtA[i] = 0
+ }
+ i--
+ dAtA[i] = 0x30
+ }
+ if m.SlashingPenaltyMisbehavior != 0 {
+ i = encodeVarintChain(dAtA, i, uint64(m.SlashingPenaltyMisbehavior))
+ i--
+ dAtA[i] = 0x28
+ }
+ if m.ActiveValidatorLimit != 0 {
+ i = encodeVarintChain(dAtA, i, uint64(m.ActiveValidatorLimit))
+ i--
+ dAtA[i] = 0x20
+ }
+ if m.UnbondingEpochs != 0 {
+ i = encodeVarintChain(dAtA, i, uint64(m.UnbondingEpochs))
+ i--
+ dAtA[i] = 0x18
+ }
+ if m.EpochDuration != 0 {
+ i = encodeVarintChain(dAtA, i, uint64(m.EpochDuration))
+ i--
+ dAtA[i] = 0x10
+ }
+ if len(m.ChainId) > 0 {
+ i -= len(m.ChainId)
+ copy(dAtA[i:], m.ChainId)
+ i = encodeVarintChain(dAtA, i, uint64(len(m.ChainId)))
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *Ratio) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *Ratio) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *Ratio) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Denominator != 0 {
+ i = encodeVarintChain(dAtA, i, uint64(m.Denominator))
+ i--
+ dAtA[i] = 0x10
+ }
+ if m.Numerator != 0 {
+ i = encodeVarintChain(dAtA, i, uint64(m.Numerator))
+ i--
+ dAtA[i] = 0x8
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *FmdParameters) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *FmdParameters) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *FmdParameters) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.AsOfBlockHeight != 0 {
+ i = encodeVarintChain(dAtA, i, uint64(m.AsOfBlockHeight))
+ i--
+ dAtA[i] = 0x10
+ }
+ if m.PrecisionBits != 0 {
+ i = encodeVarintChain(dAtA, i, uint64(m.PrecisionBits))
+ i--
+ dAtA[i] = 0x8
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *CompactBlock) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *CompactBlock) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *CompactBlock) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.FmdParameters != nil {
+ {
+ size, err := m.FmdParameters.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintChain(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x6
+ i--
+ dAtA[i] = 0xa2
+ }
+ if m.ProposalStarted {
+ i--
+ if m.ProposalStarted {
+ dAtA[i] = 1
+ } else {
+ dAtA[i] = 0
+ }
+ i--
+ dAtA[i] = 0x1
+ i--
+ dAtA[i] = 0xa0
+ }
+ if m.EpochRoot != nil {
+ {
+ size, err := m.EpochRoot.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintChain(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1
+ i--
+ dAtA[i] = 0x8a
+ }
+ if m.ChainParameters != nil {
+ {
+ size, err := m.ChainParameters.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintChain(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x32
+ }
+ if len(m.SwapOutputs) > 0 {
+ for iNdEx := len(m.SwapOutputs) - 1; iNdEx >= 0; iNdEx-- {
+ {
+ size, err := m.SwapOutputs[iNdEx].MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintChain(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x2a
+ }
+ }
+ if m.BlockRoot != nil {
+ {
+ size, err := m.BlockRoot.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintChain(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x22
+ }
+ if len(m.Nullifiers) > 0 {
+ for iNdEx := len(m.Nullifiers) - 1; iNdEx >= 0; iNdEx-- {
+ {
+ size, err := m.Nullifiers[iNdEx].MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintChain(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1a
+ }
+ }
+ if len(m.StatePayloads) > 0 {
+ for iNdEx := len(m.StatePayloads) - 1; iNdEx >= 0; iNdEx-- {
+ {
+ size, err := m.StatePayloads[iNdEx].MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintChain(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ }
+ if m.Height != 0 {
+ i = encodeVarintChain(dAtA, i, uint64(m.Height))
+ i--
+ dAtA[i] = 0x8
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *StatePayload) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *StatePayload) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *StatePayload) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.StatePayload != nil {
+ {
+ size := m.StatePayload.Size()
+ i -= size
+ if _, err := m.StatePayload.MarshalTo(dAtA[i:]); err != nil {
+ return 0, err
+ }
+ }
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *StatePayload_RolledUp_) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *StatePayload_RolledUp_) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.RolledUp != nil {
+ {
+ size, err := m.RolledUp.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintChain(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+func (m *StatePayload_Note_) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *StatePayload_Note_) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.Note != nil {
+ {
+ size, err := m.Note.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintChain(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ return len(dAtA) - i, nil
+}
+func (m *StatePayload_Swap_) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *StatePayload_Swap_) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.Swap != nil {
+ {
+ size, err := m.Swap.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintChain(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1a
+ }
+ return len(dAtA) - i, nil
+}
+func (m *StatePayload_RolledUp) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *StatePayload_RolledUp) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *StatePayload_RolledUp) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Commitment != nil {
+ {
+ size, err := m.Commitment.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintChain(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *StatePayload_Note) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *StatePayload_Note) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *StatePayload_Note) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Note != nil {
+ {
+ size, err := m.Note.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintChain(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.Source != nil {
+ {
+ size, err := m.Source.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintChain(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *StatePayload_Swap) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *StatePayload_Swap) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *StatePayload_Swap) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Swap != nil {
+ {
+ size, err := m.Swap.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintChain(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.Source != nil {
+ {
+ size, err := m.Source.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintChain(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *KnownAssets) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *KnownAssets) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *KnownAssets) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.Assets) > 0 {
+ for iNdEx := len(m.Assets) - 1; iNdEx >= 0; iNdEx-- {
+ {
+ size, err := m.Assets[iNdEx].MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintChain(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *NoteSource) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *NoteSource) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *NoteSource) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.Inner) > 0 {
+ i -= len(m.Inner)
+ copy(dAtA[i:], m.Inner)
+ i = encodeVarintChain(dAtA, i, uint64(len(m.Inner)))
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *SpendInfo) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *SpendInfo) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *SpendInfo) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.SpendHeight != 0 {
+ i = encodeVarintChain(dAtA, i, uint64(m.SpendHeight))
+ i--
+ dAtA[i] = 0x10
+ }
+ if m.NoteSource != nil {
+ {
+ size, err := m.NoteSource.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintChain(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *GenesisAppState) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *GenesisAppState) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *GenesisAppState) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.Allocations) > 0 {
+ for iNdEx := len(m.Allocations) - 1; iNdEx >= 0; iNdEx-- {
+ {
+ size, err := m.Allocations[iNdEx].MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintChain(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1a
+ }
+ }
+ if len(m.Validators) > 0 {
+ for iNdEx := len(m.Validators) - 1; iNdEx >= 0; iNdEx-- {
+ {
+ size, err := m.Validators[iNdEx].MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintChain(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ }
+ if m.ChainParams != nil {
+ {
+ size, err := m.ChainParams.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintChain(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *GenesisAppState_Allocation) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *GenesisAppState_Allocation) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *GenesisAppState_Allocation) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Address != nil {
+ {
+ size, err := m.Address.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintChain(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1a
+ }
+ if len(m.Denom) > 0 {
+ i -= len(m.Denom)
+ copy(dAtA[i:], m.Denom)
+ i = encodeVarintChain(dAtA, i, uint64(len(m.Denom)))
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.Amount != nil {
+ {
+ size, err := m.Amount.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintChain(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *Epoch) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *Epoch) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *Epoch) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.StartHeight != 0 {
+ i = encodeVarintChain(dAtA, i, uint64(m.StartHeight))
+ i--
+ dAtA[i] = 0x10
+ }
+ if m.Index != 0 {
+ i = encodeVarintChain(dAtA, i, uint64(m.Index))
+ i--
+ dAtA[i] = 0x8
+ }
+ return len(dAtA) - i, nil
+}
+
+func encodeVarintChain(dAtA []byte, offset int, v uint64) int {
+ offset -= sovChain(v)
+ base := offset
+ for v >= 1<<7 {
+ dAtA[offset] = uint8(v&0x7f | 0x80)
+ v >>= 7
+ offset++
+ }
+ dAtA[offset] = uint8(v)
+ return base
+}
+func (m *ChainParameters) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ l = len(m.ChainId)
+ if l > 0 {
+ n += 1 + l + sovChain(uint64(l))
+ }
+ if m.EpochDuration != 0 {
+ n += 1 + sovChain(uint64(m.EpochDuration))
+ }
+ if m.UnbondingEpochs != 0 {
+ n += 1 + sovChain(uint64(m.UnbondingEpochs))
+ }
+ if m.ActiveValidatorLimit != 0 {
+ n += 1 + sovChain(uint64(m.ActiveValidatorLimit))
+ }
+ if m.SlashingPenaltyMisbehavior != 0 {
+ n += 1 + sovChain(uint64(m.SlashingPenaltyMisbehavior))
+ }
+ if m.IbcEnabled {
+ n += 2
+ }
+ if m.InboundIcs20TransfersEnabled {
+ n += 2
+ }
+ if m.OutboundIcs20TransfersEnabled {
+ n += 2
+ }
+ if m.BaseRewardRate != 0 {
+ n += 1 + sovChain(uint64(m.BaseRewardRate))
+ }
+ if m.SlashingPenaltyDowntime != 0 {
+ n += 1 + sovChain(uint64(m.SlashingPenaltyDowntime))
+ }
+ if m.SignedBlocksWindowLen != 0 {
+ n += 1 + sovChain(uint64(m.SignedBlocksWindowLen))
+ }
+ if m.MissedBlocksMaximum != 0 {
+ n += 1 + sovChain(uint64(m.MissedBlocksMaximum))
+ }
+ if m.ProposalVotingBlocks != 0 {
+ n += 2 + sovChain(uint64(m.ProposalVotingBlocks))
+ }
+ if m.ProposalDepositAmount != nil {
+ l = m.ProposalDepositAmount.Size()
+ n += 2 + l + sovChain(uint64(l))
+ }
+ l = len(m.ProposalValidQuorum)
+ if l > 0 {
+ n += 2 + l + sovChain(uint64(l))
+ }
+ l = len(m.ProposalPassThreshold)
+ if l > 0 {
+ n += 2 + l + sovChain(uint64(l))
+ }
+ l = len(m.ProposalSlashThreshold)
+ if l > 0 {
+ n += 2 + l + sovChain(uint64(l))
+ }
+ if m.DaoSpendProposalsEnabled {
+ n += 3
+ }
+ return n
+}
+
+func (m *Ratio) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Numerator != 0 {
+ n += 1 + sovChain(uint64(m.Numerator))
+ }
+ if m.Denominator != 0 {
+ n += 1 + sovChain(uint64(m.Denominator))
+ }
+ return n
+}
+
+func (m *FmdParameters) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.PrecisionBits != 0 {
+ n += 1 + sovChain(uint64(m.PrecisionBits))
+ }
+ if m.AsOfBlockHeight != 0 {
+ n += 1 + sovChain(uint64(m.AsOfBlockHeight))
+ }
+ return n
+}
+
+func (m *CompactBlock) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Height != 0 {
+ n += 1 + sovChain(uint64(m.Height))
+ }
+ if len(m.StatePayloads) > 0 {
+ for _, e := range m.StatePayloads {
+ l = e.Size()
+ n += 1 + l + sovChain(uint64(l))
+ }
+ }
+ if len(m.Nullifiers) > 0 {
+ for _, e := range m.Nullifiers {
+ l = e.Size()
+ n += 1 + l + sovChain(uint64(l))
+ }
+ }
+ if m.BlockRoot != nil {
+ l = m.BlockRoot.Size()
+ n += 1 + l + sovChain(uint64(l))
+ }
+ if len(m.SwapOutputs) > 0 {
+ for _, e := range m.SwapOutputs {
+ l = e.Size()
+ n += 1 + l + sovChain(uint64(l))
+ }
+ }
+ if m.ChainParameters != nil {
+ l = m.ChainParameters.Size()
+ n += 1 + l + sovChain(uint64(l))
+ }
+ if m.EpochRoot != nil {
+ l = m.EpochRoot.Size()
+ n += 2 + l + sovChain(uint64(l))
+ }
+ if m.ProposalStarted {
+ n += 3
+ }
+ if m.FmdParameters != nil {
+ l = m.FmdParameters.Size()
+ n += 2 + l + sovChain(uint64(l))
+ }
+ return n
+}
+
+func (m *StatePayload) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.StatePayload != nil {
+ n += m.StatePayload.Size()
+ }
+ return n
+}
+
+func (m *StatePayload_RolledUp_) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.RolledUp != nil {
+ l = m.RolledUp.Size()
+ n += 1 + l + sovChain(uint64(l))
+ }
+ return n
+}
+func (m *StatePayload_Note_) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Note != nil {
+ l = m.Note.Size()
+ n += 1 + l + sovChain(uint64(l))
+ }
+ return n
+}
+func (m *StatePayload_Swap_) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Swap != nil {
+ l = m.Swap.Size()
+ n += 1 + l + sovChain(uint64(l))
+ }
+ return n
+}
+func (m *StatePayload_RolledUp) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Commitment != nil {
+ l = m.Commitment.Size()
+ n += 1 + l + sovChain(uint64(l))
+ }
+ return n
+}
+
+func (m *StatePayload_Note) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Source != nil {
+ l = m.Source.Size()
+ n += 1 + l + sovChain(uint64(l))
+ }
+ if m.Note != nil {
+ l = m.Note.Size()
+ n += 1 + l + sovChain(uint64(l))
+ }
+ return n
+}
+
+func (m *StatePayload_Swap) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Source != nil {
+ l = m.Source.Size()
+ n += 1 + l + sovChain(uint64(l))
+ }
+ if m.Swap != nil {
+ l = m.Swap.Size()
+ n += 1 + l + sovChain(uint64(l))
+ }
+ return n
+}
+
+func (m *KnownAssets) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if len(m.Assets) > 0 {
+ for _, e := range m.Assets {
+ l = e.Size()
+ n += 1 + l + sovChain(uint64(l))
+ }
+ }
+ return n
+}
+
+func (m *NoteSource) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ l = len(m.Inner)
+ if l > 0 {
+ n += 1 + l + sovChain(uint64(l))
+ }
+ return n
+}
+
+func (m *SpendInfo) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.NoteSource != nil {
+ l = m.NoteSource.Size()
+ n += 1 + l + sovChain(uint64(l))
+ }
+ if m.SpendHeight != 0 {
+ n += 1 + sovChain(uint64(m.SpendHeight))
+ }
+ return n
+}
+
+func (m *GenesisAppState) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.ChainParams != nil {
+ l = m.ChainParams.Size()
+ n += 1 + l + sovChain(uint64(l))
+ }
+ if len(m.Validators) > 0 {
+ for _, e := range m.Validators {
+ l = e.Size()
+ n += 1 + l + sovChain(uint64(l))
+ }
+ }
+ if len(m.Allocations) > 0 {
+ for _, e := range m.Allocations {
+ l = e.Size()
+ n += 1 + l + sovChain(uint64(l))
+ }
+ }
+ return n
+}
+
+func (m *GenesisAppState_Allocation) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Amount != nil {
+ l = m.Amount.Size()
+ n += 1 + l + sovChain(uint64(l))
+ }
+ l = len(m.Denom)
+ if l > 0 {
+ n += 1 + l + sovChain(uint64(l))
+ }
+ if m.Address != nil {
+ l = m.Address.Size()
+ n += 1 + l + sovChain(uint64(l))
+ }
+ return n
+}
+
+func (m *Epoch) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Index != 0 {
+ n += 1 + sovChain(uint64(m.Index))
+ }
+ if m.StartHeight != 0 {
+ n += 1 + sovChain(uint64(m.StartHeight))
+ }
+ return n
+}
+
+func sovChain(x uint64) (n int) {
+ return (math_bits.Len64(x|1) + 6) / 7
+}
+func sozChain(x uint64) (n int) {
+ return sovChain(uint64((x << 1) ^ uint64((int64(x) >> 63))))
+}
+func (m *ChainParameters) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: ChainParameters: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: ChainParameters: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ChainId", wireType)
+ }
+ var stringLen uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ stringLen |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ intStringLen := int(stringLen)
+ if intStringLen < 0 {
+ return ErrInvalidLengthChain
+ }
+ postIndex := iNdEx + intStringLen
+ if postIndex < 0 {
+ return ErrInvalidLengthChain
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.ChainId = string(dAtA[iNdEx:postIndex])
+ iNdEx = postIndex
+ case 2:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field EpochDuration", wireType)
+ }
+ m.EpochDuration = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.EpochDuration |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 3:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field UnbondingEpochs", wireType)
+ }
+ m.UnbondingEpochs = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.UnbondingEpochs |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 4:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ActiveValidatorLimit", wireType)
+ }
+ m.ActiveValidatorLimit = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.ActiveValidatorLimit |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 5:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field SlashingPenaltyMisbehavior", wireType)
+ }
+ m.SlashingPenaltyMisbehavior = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.SlashingPenaltyMisbehavior |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 6:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field IbcEnabled", wireType)
+ }
+ var v int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ v |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ m.IbcEnabled = bool(v != 0)
+ case 7:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field InboundIcs20TransfersEnabled", wireType)
+ }
+ var v int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ v |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ m.InboundIcs20TransfersEnabled = bool(v != 0)
+ case 8:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field OutboundIcs20TransfersEnabled", wireType)
+ }
+ var v int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ v |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ m.OutboundIcs20TransfersEnabled = bool(v != 0)
+ case 9:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field BaseRewardRate", wireType)
+ }
+ m.BaseRewardRate = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.BaseRewardRate |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 10:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field SlashingPenaltyDowntime", wireType)
+ }
+ m.SlashingPenaltyDowntime = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.SlashingPenaltyDowntime |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 11:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field SignedBlocksWindowLen", wireType)
+ }
+ m.SignedBlocksWindowLen = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.SignedBlocksWindowLen |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 12:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field MissedBlocksMaximum", wireType)
+ }
+ m.MissedBlocksMaximum = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.MissedBlocksMaximum |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 20:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ProposalVotingBlocks", wireType)
+ }
+ m.ProposalVotingBlocks = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.ProposalVotingBlocks |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 21:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ProposalDepositAmount", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthChain
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthChain
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.ProposalDepositAmount == nil {
+ m.ProposalDepositAmount = &v1alpha1.Amount{}
+ }
+ if err := m.ProposalDepositAmount.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 22:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ProposalValidQuorum", wireType)
+ }
+ var stringLen uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ stringLen |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ intStringLen := int(stringLen)
+ if intStringLen < 0 {
+ return ErrInvalidLengthChain
+ }
+ postIndex := iNdEx + intStringLen
+ if postIndex < 0 {
+ return ErrInvalidLengthChain
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.ProposalValidQuorum = string(dAtA[iNdEx:postIndex])
+ iNdEx = postIndex
+ case 23:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ProposalPassThreshold", wireType)
+ }
+ var stringLen uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ stringLen |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ intStringLen := int(stringLen)
+ if intStringLen < 0 {
+ return ErrInvalidLengthChain
+ }
+ postIndex := iNdEx + intStringLen
+ if postIndex < 0 {
+ return ErrInvalidLengthChain
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.ProposalPassThreshold = string(dAtA[iNdEx:postIndex])
+ iNdEx = postIndex
+ case 24:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ProposalSlashThreshold", wireType)
+ }
+ var stringLen uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ stringLen |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ intStringLen := int(stringLen)
+ if intStringLen < 0 {
+ return ErrInvalidLengthChain
+ }
+ postIndex := iNdEx + intStringLen
+ if postIndex < 0 {
+ return ErrInvalidLengthChain
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.ProposalSlashThreshold = string(dAtA[iNdEx:postIndex])
+ iNdEx = postIndex
+ case 25:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field DaoSpendProposalsEnabled", wireType)
+ }
+ var v int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ v |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ m.DaoSpendProposalsEnabled = bool(v != 0)
+ default:
+ iNdEx = preIndex
+ skippy, err := skipChain(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthChain
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *Ratio) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Ratio: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Ratio: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Numerator", wireType)
+ }
+ m.Numerator = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.Numerator |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 2:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Denominator", wireType)
+ }
+ m.Denominator = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.Denominator |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ default:
+ iNdEx = preIndex
+ skippy, err := skipChain(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthChain
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *FmdParameters) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: FmdParameters: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: FmdParameters: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field PrecisionBits", wireType)
+ }
+ m.PrecisionBits = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.PrecisionBits |= uint32(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 2:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field AsOfBlockHeight", wireType)
+ }
+ m.AsOfBlockHeight = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.AsOfBlockHeight |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ default:
+ iNdEx = preIndex
+ skippy, err := skipChain(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthChain
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *CompactBlock) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: CompactBlock: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: CompactBlock: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Height", wireType)
+ }
+ m.Height = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.Height |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field StatePayloads", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthChain
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthChain
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.StatePayloads = append(m.StatePayloads, &StatePayload{})
+ if err := m.StatePayloads[len(m.StatePayloads)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Nullifiers", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthChain
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthChain
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Nullifiers = append(m.Nullifiers, &v1alpha1.Nullifier{})
+ if err := m.Nullifiers[len(m.Nullifiers)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 4:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field BlockRoot", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthChain
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthChain
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.BlockRoot == nil {
+ m.BlockRoot = &v1alpha1.MerkleRoot{}
+ }
+ if err := m.BlockRoot.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 5:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field SwapOutputs", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthChain
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthChain
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.SwapOutputs = append(m.SwapOutputs, &v1alpha11.BatchSwapOutputData{})
+ if err := m.SwapOutputs[len(m.SwapOutputs)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 6:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ChainParameters", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthChain
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthChain
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.ChainParameters == nil {
+ m.ChainParameters = &ChainParameters{}
+ }
+ if err := m.ChainParameters.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 17:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field EpochRoot", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthChain
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthChain
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.EpochRoot == nil {
+ m.EpochRoot = &v1alpha1.MerkleRoot{}
+ }
+ if err := m.EpochRoot.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 20:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ProposalStarted", wireType)
+ }
+ var v int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ v |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ m.ProposalStarted = bool(v != 0)
+ case 100:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field FmdParameters", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthChain
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthChain
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.FmdParameters == nil {
+ m.FmdParameters = &FmdParameters{}
+ }
+ if err := m.FmdParameters.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipChain(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthChain
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *StatePayload) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: StatePayload: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: StatePayload: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field RolledUp", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthChain
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthChain
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &StatePayload_RolledUp{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.StatePayload = &StatePayload_RolledUp_{v}
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Note", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthChain
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthChain
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &StatePayload_Note{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.StatePayload = &StatePayload_Note_{v}
+ iNdEx = postIndex
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Swap", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthChain
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthChain
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &StatePayload_Swap{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.StatePayload = &StatePayload_Swap_{v}
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipChain(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthChain
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *StatePayload_RolledUp) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: RolledUp: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: RolledUp: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Commitment", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthChain
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthChain
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Commitment == nil {
+ m.Commitment = &v1alpha1.StateCommitment{}
+ }
+ if err := m.Commitment.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipChain(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthChain
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *StatePayload_Note) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Note: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Note: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Source", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthChain
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthChain
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Source == nil {
+ m.Source = &NoteSource{}
+ }
+ if err := m.Source.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Note", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthChain
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthChain
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Note == nil {
+ m.Note = &v1alpha1.NotePayload{}
+ }
+ if err := m.Note.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipChain(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthChain
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *StatePayload_Swap) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Swap: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Swap: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Source", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthChain
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthChain
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Source == nil {
+ m.Source = &NoteSource{}
+ }
+ if err := m.Source.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Swap", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthChain
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthChain
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Swap == nil {
+ m.Swap = &v1alpha11.SwapPayload{}
+ }
+ if err := m.Swap.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipChain(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthChain
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *KnownAssets) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: KnownAssets: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: KnownAssets: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Assets", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthChain
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthChain
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Assets = append(m.Assets, &v1alpha1.DenomMetadata{})
+ if err := m.Assets[len(m.Assets)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipChain(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthChain
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *NoteSource) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: NoteSource: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: NoteSource: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Inner", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthChain
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthChain
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Inner = append(m.Inner[:0], dAtA[iNdEx:postIndex]...)
+ if m.Inner == nil {
+ m.Inner = []byte{}
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipChain(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthChain
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *SpendInfo) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: SpendInfo: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: SpendInfo: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field NoteSource", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthChain
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthChain
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.NoteSource == nil {
+ m.NoteSource = &NoteSource{}
+ }
+ if err := m.NoteSource.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field SpendHeight", wireType)
+ }
+ m.SpendHeight = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.SpendHeight |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ default:
+ iNdEx = preIndex
+ skippy, err := skipChain(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthChain
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *GenesisAppState) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: GenesisAppState: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: GenesisAppState: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ChainParams", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthChain
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthChain
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.ChainParams == nil {
+ m.ChainParams = &ChainParameters{}
+ }
+ if err := m.ChainParams.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Validators", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthChain
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthChain
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Validators = append(m.Validators, &v1alpha12.Validator{})
+ if err := m.Validators[len(m.Validators)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Allocations", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthChain
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthChain
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Allocations = append(m.Allocations, &GenesisAppState_Allocation{})
+ if err := m.Allocations[len(m.Allocations)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipChain(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthChain
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *GenesisAppState_Allocation) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Allocation: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Allocation: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Amount", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthChain
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthChain
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Amount == nil {
+ m.Amount = &v1alpha1.Amount{}
+ }
+ if err := m.Amount.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Denom", wireType)
+ }
+ var stringLen uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ stringLen |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ intStringLen := int(stringLen)
+ if intStringLen < 0 {
+ return ErrInvalidLengthChain
+ }
+ postIndex := iNdEx + intStringLen
+ if postIndex < 0 {
+ return ErrInvalidLengthChain
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Denom = string(dAtA[iNdEx:postIndex])
+ iNdEx = postIndex
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Address", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthChain
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthChain
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Address == nil {
+ m.Address = &v1alpha1.Address{}
+ }
+ if err := m.Address.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipChain(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthChain
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *Epoch) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Epoch: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Epoch: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Index", wireType)
+ }
+ m.Index = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.Index |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 2:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field StartHeight", wireType)
+ }
+ m.StartHeight = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.StartHeight |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ default:
+ iNdEx = preIndex
+ skippy, err := skipChain(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthChain
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func skipChain(dAtA []byte) (n int, err error) {
+ l := len(dAtA)
+ iNdEx := 0
+ depth := 0
+ for iNdEx < l {
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return 0, ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return 0, io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= (uint64(b) & 0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ wireType := int(wire & 0x7)
+ switch wireType {
+ case 0:
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return 0, ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return 0, io.ErrUnexpectedEOF
+ }
+ iNdEx++
+ if dAtA[iNdEx-1] < 0x80 {
+ break
+ }
+ }
+ case 1:
+ iNdEx += 8
+ case 2:
+ var length int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return 0, ErrIntOverflowChain
+ }
+ if iNdEx >= l {
+ return 0, io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ length |= (int(b) & 0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if length < 0 {
+ return 0, ErrInvalidLengthChain
+ }
+ iNdEx += length
+ case 3:
+ depth++
+ case 4:
+ if depth == 0 {
+ return 0, ErrUnexpectedEndOfGroupChain
+ }
+ depth--
+ case 5:
+ iNdEx += 4
+ default:
+ return 0, fmt.Errorf("proto: illegal wireType %d", wireType)
+ }
+ if iNdEx < 0 {
+ return 0, ErrInvalidLengthChain
+ }
+ if depth == 0 {
+ return iNdEx, nil
+ }
+ }
+ return 0, io.ErrUnexpectedEOF
+}
+
+var (
+ ErrInvalidLengthChain = fmt.Errorf("proto: negative length found during unmarshaling")
+ ErrIntOverflowChain = fmt.Errorf("proto: integer overflow")
+ ErrUnexpectedEndOfGroupChain = fmt.Errorf("proto: unexpected end of group")
+)
diff --git a/relayer/chains/penumbra/core/crypto/v1alpha1/crypto.pb.go b/relayer/chains/penumbra/core/crypto/v1alpha1/crypto.pb.go
new file mode 100644
index 000000000..088785c8e
--- /dev/null
+++ b/relayer/chains/penumbra/core/crypto/v1alpha1/crypto.pb.go
@@ -0,0 +1,9861 @@
+// Code generated by protoc-gen-gogo. DO NOT EDIT.
+// source: penumbra/core/crypto/v1alpha1/crypto.proto
+
+package cryptov1alpha1
+
+import (
+ fmt "fmt"
+ proto "github.com/cosmos/gogoproto/proto"
+ io "io"
+ math "math"
+ math_bits "math/bits"
+)
+
+// Reference imports to suppress errors if they are not otherwise used.
+var _ = proto.Marshal
+var _ = fmt.Errorf
+var _ = math.Inf
+
+// This is a compile-time assertion to ensure that this generated file
+// is compatible with the proto package it is being compiled against.
+// A compilation error at this line likely means your copy of the
+// proto package needs to be updated.
+const _ = proto.GoGoProtoPackageIsVersion3 // please upgrade the proto package
+
+// Specifies fees paid by a transaction.
+type Fee struct {
+ // The amount of the token used to pay fees.
+ Amount *Amount `protobuf:"bytes,1,opt,name=amount,proto3" json:"amount,omitempty"`
+ // If present, the asset ID of the token used to pay fees.
+ // If absent, specifies the staking token implicitly.
+ AssetId *AssetId `protobuf:"bytes,2,opt,name=asset_id,json=assetId,proto3" json:"asset_id,omitempty"`
+}
+
+func (m *Fee) Reset() { *m = Fee{} }
+func (m *Fee) String() string { return proto.CompactTextString(m) }
+func (*Fee) ProtoMessage() {}
+func (*Fee) Descriptor() ([]byte, []int) {
+ return fileDescriptor_5c23a0b4440af102, []int{0}
+}
+func (m *Fee) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *Fee) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_Fee.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *Fee) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_Fee.Merge(m, src)
+}
+func (m *Fee) XXX_Size() int {
+ return m.Size()
+}
+func (m *Fee) XXX_DiscardUnknown() {
+ xxx_messageInfo_Fee.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_Fee proto.InternalMessageInfo
+
+func (m *Fee) GetAmount() *Amount {
+ if m != nil {
+ return m.Amount
+ }
+ return nil
+}
+
+func (m *Fee) GetAssetId() *AssetId {
+ if m != nil {
+ return m.AssetId
+ }
+ return nil
+}
+
+// A Penumbra address. An address in Penumbra is a Bech32m-encoded
+// string, with the human-readable prefix (HRP) `penumbrav2t`.
+type Address struct {
+ // The bytes of the address. Must be represented as a series of
+ // `uint8` (i.e. values 0 through 255), with a length of 80 elements.
+ Inner []byte `protobuf:"bytes,1,opt,name=inner,proto3" json:"inner,omitempty"`
+ // Alternatively, a Bech32m-encoded string representation of the `inner`
+ // bytes.
+ //
+ // NOTE: implementations are not required to support parsing this field.
+ // Implementations should prefer to encode the bytes in all messages they
+ // produce. Implementations must not accept messages with both `inner` and
+ // `alt_bech32m` set.
+ AltBech32M string `protobuf:"bytes,2,opt,name=alt_bech32m,json=altBech32m,proto3" json:"alt_bech32m,omitempty"`
+}
+
+func (m *Address) Reset() { *m = Address{} }
+func (m *Address) String() string { return proto.CompactTextString(m) }
+func (*Address) ProtoMessage() {}
+func (*Address) Descriptor() ([]byte, []int) {
+ return fileDescriptor_5c23a0b4440af102, []int{1}
+}
+func (m *Address) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *Address) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_Address.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *Address) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_Address.Merge(m, src)
+}
+func (m *Address) XXX_Size() int {
+ return m.Size()
+}
+func (m *Address) XXX_DiscardUnknown() {
+ xxx_messageInfo_Address.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_Address proto.InternalMessageInfo
+
+func (m *Address) GetInner() []byte {
+ if m != nil {
+ return m.Inner
+ }
+ return nil
+}
+
+func (m *Address) GetAltBech32M() string {
+ if m != nil {
+ return m.AltBech32M
+ }
+ return ""
+}
+
+type AddressView struct {
+ // Types that are valid to be assigned to AddressView:
+ //
+ // *AddressView_Visible_
+ // *AddressView_Opaque_
+ AddressView isAddressView_AddressView `protobuf_oneof:"address_view"`
+}
+
+func (m *AddressView) Reset() { *m = AddressView{} }
+func (m *AddressView) String() string { return proto.CompactTextString(m) }
+func (*AddressView) ProtoMessage() {}
+func (*AddressView) Descriptor() ([]byte, []int) {
+ return fileDescriptor_5c23a0b4440af102, []int{2}
+}
+func (m *AddressView) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *AddressView) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_AddressView.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *AddressView) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_AddressView.Merge(m, src)
+}
+func (m *AddressView) XXX_Size() int {
+ return m.Size()
+}
+func (m *AddressView) XXX_DiscardUnknown() {
+ xxx_messageInfo_AddressView.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_AddressView proto.InternalMessageInfo
+
+type isAddressView_AddressView interface {
+ isAddressView_AddressView()
+ MarshalTo([]byte) (int, error)
+ Size() int
+}
+
+type AddressView_Visible_ struct {
+ Visible *AddressView_Visible `protobuf:"bytes,1,opt,name=visible,proto3,oneof" json:"visible,omitempty"`
+}
+type AddressView_Opaque_ struct {
+ Opaque *AddressView_Opaque `protobuf:"bytes,2,opt,name=opaque,proto3,oneof" json:"opaque,omitempty"`
+}
+
+func (*AddressView_Visible_) isAddressView_AddressView() {}
+func (*AddressView_Opaque_) isAddressView_AddressView() {}
+
+func (m *AddressView) GetAddressView() isAddressView_AddressView {
+ if m != nil {
+ return m.AddressView
+ }
+ return nil
+}
+
+func (m *AddressView) GetVisible() *AddressView_Visible {
+ if x, ok := m.GetAddressView().(*AddressView_Visible_); ok {
+ return x.Visible
+ }
+ return nil
+}
+
+func (m *AddressView) GetOpaque() *AddressView_Opaque {
+ if x, ok := m.GetAddressView().(*AddressView_Opaque_); ok {
+ return x.Opaque
+ }
+ return nil
+}
+
+// XXX_OneofWrappers is for the internal use of the proto package.
+func (*AddressView) XXX_OneofWrappers() []interface{} {
+ return []interface{}{
+ (*AddressView_Visible_)(nil),
+ (*AddressView_Opaque_)(nil),
+ }
+}
+
+type AddressView_Visible struct {
+ Address *Address `protobuf:"bytes,1,opt,name=address,proto3" json:"address,omitempty"`
+ Index *AddressIndex `protobuf:"bytes,2,opt,name=index,proto3" json:"index,omitempty"`
+ AccountGroupId *AccountGroupId `protobuf:"bytes,3,opt,name=account_group_id,json=accountGroupId,proto3" json:"account_group_id,omitempty"`
+}
+
+func (m *AddressView_Visible) Reset() { *m = AddressView_Visible{} }
+func (m *AddressView_Visible) String() string { return proto.CompactTextString(m) }
+func (*AddressView_Visible) ProtoMessage() {}
+func (*AddressView_Visible) Descriptor() ([]byte, []int) {
+ return fileDescriptor_5c23a0b4440af102, []int{2, 0}
+}
+func (m *AddressView_Visible) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *AddressView_Visible) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_AddressView_Visible.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *AddressView_Visible) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_AddressView_Visible.Merge(m, src)
+}
+func (m *AddressView_Visible) XXX_Size() int {
+ return m.Size()
+}
+func (m *AddressView_Visible) XXX_DiscardUnknown() {
+ xxx_messageInfo_AddressView_Visible.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_AddressView_Visible proto.InternalMessageInfo
+
+func (m *AddressView_Visible) GetAddress() *Address {
+ if m != nil {
+ return m.Address
+ }
+ return nil
+}
+
+func (m *AddressView_Visible) GetIndex() *AddressIndex {
+ if m != nil {
+ return m.Index
+ }
+ return nil
+}
+
+func (m *AddressView_Visible) GetAccountGroupId() *AccountGroupId {
+ if m != nil {
+ return m.AccountGroupId
+ }
+ return nil
+}
+
+type AddressView_Opaque struct {
+ Address *Address `protobuf:"bytes,1,opt,name=address,proto3" json:"address,omitempty"`
+}
+
+func (m *AddressView_Opaque) Reset() { *m = AddressView_Opaque{} }
+func (m *AddressView_Opaque) String() string { return proto.CompactTextString(m) }
+func (*AddressView_Opaque) ProtoMessage() {}
+func (*AddressView_Opaque) Descriptor() ([]byte, []int) {
+ return fileDescriptor_5c23a0b4440af102, []int{2, 1}
+}
+func (m *AddressView_Opaque) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *AddressView_Opaque) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_AddressView_Opaque.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *AddressView_Opaque) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_AddressView_Opaque.Merge(m, src)
+}
+func (m *AddressView_Opaque) XXX_Size() int {
+ return m.Size()
+}
+func (m *AddressView_Opaque) XXX_DiscardUnknown() {
+ xxx_messageInfo_AddressView_Opaque.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_AddressView_Opaque proto.InternalMessageInfo
+
+func (m *AddressView_Opaque) GetAddress() *Address {
+ if m != nil {
+ return m.Address
+ }
+ return nil
+}
+
+type SpendKey struct {
+ Inner []byte `protobuf:"bytes,1,opt,name=inner,proto3" json:"inner,omitempty"`
+}
+
+func (m *SpendKey) Reset() { *m = SpendKey{} }
+func (m *SpendKey) String() string { return proto.CompactTextString(m) }
+func (*SpendKey) ProtoMessage() {}
+func (*SpendKey) Descriptor() ([]byte, []int) {
+ return fileDescriptor_5c23a0b4440af102, []int{3}
+}
+func (m *SpendKey) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *SpendKey) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_SpendKey.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *SpendKey) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_SpendKey.Merge(m, src)
+}
+func (m *SpendKey) XXX_Size() int {
+ return m.Size()
+}
+func (m *SpendKey) XXX_DiscardUnknown() {
+ xxx_messageInfo_SpendKey.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_SpendKey proto.InternalMessageInfo
+
+func (m *SpendKey) GetInner() []byte {
+ if m != nil {
+ return m.Inner
+ }
+ return nil
+}
+
+type SpendVerificationKey struct {
+ Inner []byte `protobuf:"bytes,1,opt,name=inner,proto3" json:"inner,omitempty"`
+}
+
+func (m *SpendVerificationKey) Reset() { *m = SpendVerificationKey{} }
+func (m *SpendVerificationKey) String() string { return proto.CompactTextString(m) }
+func (*SpendVerificationKey) ProtoMessage() {}
+func (*SpendVerificationKey) Descriptor() ([]byte, []int) {
+ return fileDescriptor_5c23a0b4440af102, []int{4}
+}
+func (m *SpendVerificationKey) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *SpendVerificationKey) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_SpendVerificationKey.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *SpendVerificationKey) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_SpendVerificationKey.Merge(m, src)
+}
+func (m *SpendVerificationKey) XXX_Size() int {
+ return m.Size()
+}
+func (m *SpendVerificationKey) XXX_DiscardUnknown() {
+ xxx_messageInfo_SpendVerificationKey.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_SpendVerificationKey proto.InternalMessageInfo
+
+func (m *SpendVerificationKey) GetInner() []byte {
+ if m != nil {
+ return m.Inner
+ }
+ return nil
+}
+
+type FullViewingKey struct {
+ Inner []byte `protobuf:"bytes,1,opt,name=inner,proto3" json:"inner,omitempty"`
+}
+
+func (m *FullViewingKey) Reset() { *m = FullViewingKey{} }
+func (m *FullViewingKey) String() string { return proto.CompactTextString(m) }
+func (*FullViewingKey) ProtoMessage() {}
+func (*FullViewingKey) Descriptor() ([]byte, []int) {
+ return fileDescriptor_5c23a0b4440af102, []int{5}
+}
+func (m *FullViewingKey) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *FullViewingKey) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_FullViewingKey.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *FullViewingKey) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_FullViewingKey.Merge(m, src)
+}
+func (m *FullViewingKey) XXX_Size() int {
+ return m.Size()
+}
+func (m *FullViewingKey) XXX_DiscardUnknown() {
+ xxx_messageInfo_FullViewingKey.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_FullViewingKey proto.InternalMessageInfo
+
+func (m *FullViewingKey) GetInner() []byte {
+ if m != nil {
+ return m.Inner
+ }
+ return nil
+}
+
+type AccountGroupId struct {
+ Inner []byte `protobuf:"bytes,1,opt,name=inner,proto3" json:"inner,omitempty"`
+}
+
+func (m *AccountGroupId) Reset() { *m = AccountGroupId{} }
+func (m *AccountGroupId) String() string { return proto.CompactTextString(m) }
+func (*AccountGroupId) ProtoMessage() {}
+func (*AccountGroupId) Descriptor() ([]byte, []int) {
+ return fileDescriptor_5c23a0b4440af102, []int{6}
+}
+func (m *AccountGroupId) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *AccountGroupId) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_AccountGroupId.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *AccountGroupId) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_AccountGroupId.Merge(m, src)
+}
+func (m *AccountGroupId) XXX_Size() int {
+ return m.Size()
+}
+func (m *AccountGroupId) XXX_DiscardUnknown() {
+ xxx_messageInfo_AccountGroupId.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_AccountGroupId proto.InternalMessageInfo
+
+func (m *AccountGroupId) GetInner() []byte {
+ if m != nil {
+ return m.Inner
+ }
+ return nil
+}
+
+type Diversifier struct {
+ Inner []byte `protobuf:"bytes,1,opt,name=inner,proto3" json:"inner,omitempty"`
+}
+
+func (m *Diversifier) Reset() { *m = Diversifier{} }
+func (m *Diversifier) String() string { return proto.CompactTextString(m) }
+func (*Diversifier) ProtoMessage() {}
+func (*Diversifier) Descriptor() ([]byte, []int) {
+ return fileDescriptor_5c23a0b4440af102, []int{7}
+}
+func (m *Diversifier) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *Diversifier) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_Diversifier.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *Diversifier) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_Diversifier.Merge(m, src)
+}
+func (m *Diversifier) XXX_Size() int {
+ return m.Size()
+}
+func (m *Diversifier) XXX_DiscardUnknown() {
+ xxx_messageInfo_Diversifier.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_Diversifier proto.InternalMessageInfo
+
+func (m *Diversifier) GetInner() []byte {
+ if m != nil {
+ return m.Inner
+ }
+ return nil
+}
+
+type AddressIndex struct {
+ Account uint32 `protobuf:"varint,2,opt,name=account,proto3" json:"account,omitempty"`
+ Randomizer []byte `protobuf:"bytes,3,opt,name=randomizer,proto3" json:"randomizer,omitempty"`
+}
+
+func (m *AddressIndex) Reset() { *m = AddressIndex{} }
+func (m *AddressIndex) String() string { return proto.CompactTextString(m) }
+func (*AddressIndex) ProtoMessage() {}
+func (*AddressIndex) Descriptor() ([]byte, []int) {
+ return fileDescriptor_5c23a0b4440af102, []int{8}
+}
+func (m *AddressIndex) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *AddressIndex) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_AddressIndex.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *AddressIndex) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_AddressIndex.Merge(m, src)
+}
+func (m *AddressIndex) XXX_Size() int {
+ return m.Size()
+}
+func (m *AddressIndex) XXX_DiscardUnknown() {
+ xxx_messageInfo_AddressIndex.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_AddressIndex proto.InternalMessageInfo
+
+func (m *AddressIndex) GetAccount() uint32 {
+ if m != nil {
+ return m.Account
+ }
+ return 0
+}
+
+func (m *AddressIndex) GetRandomizer() []byte {
+ if m != nil {
+ return m.Randomizer
+ }
+ return nil
+}
+
+type StateCommitment struct {
+ Inner []byte `protobuf:"bytes,1,opt,name=inner,proto3" json:"inner,omitempty"`
+}
+
+func (m *StateCommitment) Reset() { *m = StateCommitment{} }
+func (m *StateCommitment) String() string { return proto.CompactTextString(m) }
+func (*StateCommitment) ProtoMessage() {}
+func (*StateCommitment) Descriptor() ([]byte, []int) {
+ return fileDescriptor_5c23a0b4440af102, []int{9}
+}
+func (m *StateCommitment) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *StateCommitment) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_StateCommitment.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *StateCommitment) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_StateCommitment.Merge(m, src)
+}
+func (m *StateCommitment) XXX_Size() int {
+ return m.Size()
+}
+func (m *StateCommitment) XXX_DiscardUnknown() {
+ xxx_messageInfo_StateCommitment.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_StateCommitment proto.InternalMessageInfo
+
+func (m *StateCommitment) GetInner() []byte {
+ if m != nil {
+ return m.Inner
+ }
+ return nil
+}
+
+type BalanceCommitment struct {
+ Inner []byte `protobuf:"bytes,1,opt,name=inner,proto3" json:"inner,omitempty"`
+}
+
+func (m *BalanceCommitment) Reset() { *m = BalanceCommitment{} }
+func (m *BalanceCommitment) String() string { return proto.CompactTextString(m) }
+func (*BalanceCommitment) ProtoMessage() {}
+func (*BalanceCommitment) Descriptor() ([]byte, []int) {
+ return fileDescriptor_5c23a0b4440af102, []int{10}
+}
+func (m *BalanceCommitment) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *BalanceCommitment) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_BalanceCommitment.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *BalanceCommitment) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_BalanceCommitment.Merge(m, src)
+}
+func (m *BalanceCommitment) XXX_Size() int {
+ return m.Size()
+}
+func (m *BalanceCommitment) XXX_DiscardUnknown() {
+ xxx_messageInfo_BalanceCommitment.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_BalanceCommitment proto.InternalMessageInfo
+
+func (m *BalanceCommitment) GetInner() []byte {
+ if m != nil {
+ return m.Inner
+ }
+ return nil
+}
+
+// A Penumbra asset ID.
+type AssetId struct {
+ // The bytes of the asset ID.
+ Inner []byte `protobuf:"bytes,1,opt,name=inner,proto3" json:"inner,omitempty"`
+ // Alternatively, a Bech32m-encoded string representation of the `inner`
+ // bytes.
+ //
+ // NOTE: implementations are not required to support parsing this field.
+ // Implementations should prefer to encode the `inner` bytes in all messages they
+ // produce. Implementations must not accept messages with both `inner` and
+ // `alt_bech32m` set. This field exists for convenience of RPC users.
+ AltBech32M string `protobuf:"bytes,2,opt,name=alt_bech32m,json=altBech32m,proto3" json:"alt_bech32m,omitempty"`
+ // Alternatively, a base denomination string which should be hashed to obtain the asset ID.
+ //
+ // NOTE: implementations are not required to support parsing this field.
+ // Implementations should prefer to encode the bytes in all messages they
+ // produce. Implementations must not accept messages with both `inner` and
+ // `alt_base_denom` set. This field exists for convenience of RPC users.
+ AltBaseDenom string `protobuf:"bytes,3,opt,name=alt_base_denom,json=altBaseDenom,proto3" json:"alt_base_denom,omitempty"`
+}
+
+func (m *AssetId) Reset() { *m = AssetId{} }
+func (m *AssetId) String() string { return proto.CompactTextString(m) }
+func (*AssetId) ProtoMessage() {}
+func (*AssetId) Descriptor() ([]byte, []int) {
+ return fileDescriptor_5c23a0b4440af102, []int{11}
+}
+func (m *AssetId) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *AssetId) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_AssetId.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *AssetId) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_AssetId.Merge(m, src)
+}
+func (m *AssetId) XXX_Size() int {
+ return m.Size()
+}
+func (m *AssetId) XXX_DiscardUnknown() {
+ xxx_messageInfo_AssetId.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_AssetId proto.InternalMessageInfo
+
+func (m *AssetId) GetInner() []byte {
+ if m != nil {
+ return m.Inner
+ }
+ return nil
+}
+
+func (m *AssetId) GetAltBech32M() string {
+ if m != nil {
+ return m.AltBech32M
+ }
+ return ""
+}
+
+func (m *AssetId) GetAltBaseDenom() string {
+ if m != nil {
+ return m.AltBaseDenom
+ }
+ return ""
+}
+
+// The quantity of a particular Asset. Represented as a 128-bit unsigned integer,
+// split over two fields, `lo` and `hi`, representing the low- and high-order bytes
+// of the 128-bit value, respectively. Clients must assemble these bits in their
+// implementation into a `uint128` or comparable data structure, in order to model
+// the Amount accurately.
+type Amount struct {
+ Lo uint64 `protobuf:"varint,1,opt,name=lo,proto3" json:"lo,omitempty"`
+ Hi uint64 `protobuf:"varint,2,opt,name=hi,proto3" json:"hi,omitempty"`
+}
+
+func (m *Amount) Reset() { *m = Amount{} }
+func (m *Amount) String() string { return proto.CompactTextString(m) }
+func (*Amount) ProtoMessage() {}
+func (*Amount) Descriptor() ([]byte, []int) {
+ return fileDescriptor_5c23a0b4440af102, []int{12}
+}
+func (m *Amount) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *Amount) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_Amount.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *Amount) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_Amount.Merge(m, src)
+}
+func (m *Amount) XXX_Size() int {
+ return m.Size()
+}
+func (m *Amount) XXX_DiscardUnknown() {
+ xxx_messageInfo_Amount.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_Amount proto.InternalMessageInfo
+
+func (m *Amount) GetLo() uint64 {
+ if m != nil {
+ return m.Lo
+ }
+ return 0
+}
+
+func (m *Amount) GetHi() uint64 {
+ if m != nil {
+ return m.Hi
+ }
+ return 0
+}
+
+type Denom struct {
+ Denom string `protobuf:"bytes,1,opt,name=denom,proto3" json:"denom,omitempty"`
+}
+
+func (m *Denom) Reset() { *m = Denom{} }
+func (m *Denom) String() string { return proto.CompactTextString(m) }
+func (*Denom) ProtoMessage() {}
+func (*Denom) Descriptor() ([]byte, []int) {
+ return fileDescriptor_5c23a0b4440af102, []int{13}
+}
+func (m *Denom) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *Denom) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_Denom.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *Denom) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_Denom.Merge(m, src)
+}
+func (m *Denom) XXX_Size() int {
+ return m.Size()
+}
+func (m *Denom) XXX_DiscardUnknown() {
+ xxx_messageInfo_Denom.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_Denom proto.InternalMessageInfo
+
+func (m *Denom) GetDenom() string {
+ if m != nil {
+ return m.Denom
+ }
+ return ""
+}
+
+// DenomMetadata represents a struct that describes a basic token.
+type DenomMetadata struct {
+ Description string `protobuf:"bytes,1,opt,name=description,proto3" json:"description,omitempty"`
+ // denom_units represents the list of DenomUnit's for a given coin
+ DenomUnits []*DenomUnit `protobuf:"bytes,2,rep,name=denom_units,json=denomUnits,proto3" json:"denom_units,omitempty"`
+ // base represents the base denom (should be the DenomUnit with exponent = 0).
+ Base string `protobuf:"bytes,3,opt,name=base,proto3" json:"base,omitempty"`
+ // display indicates the suggested denom that should be
+ // displayed in clients.
+ Display string `protobuf:"bytes,4,opt,name=display,proto3" json:"display,omitempty"`
+ // name defines the name of the token (eg: Cosmos Atom)
+ Name string `protobuf:"bytes,5,opt,name=name,proto3" json:"name,omitempty"`
+ // symbol is the token symbol usually shown on exchanges (eg: ATOM). This can
+ // be the same as the display.
+ Symbol string `protobuf:"bytes,6,opt,name=symbol,proto3" json:"symbol,omitempty"`
+ // URI to a document (on or off-chain) that contains additional information. Optional.
+ Uri string `protobuf:"bytes,7,opt,name=uri,proto3" json:"uri,omitempty"`
+ // URIHash is a sha256 hash of a document pointed by URI. It's used to verify that
+ // the document didn't change. Optional.
+ UriHash string `protobuf:"bytes,8,opt,name=uri_hash,json=uriHash,proto3" json:"uri_hash,omitempty"`
+ // the asset ID on Penumbra for this denomination.
+ PenumbraAssetId *AssetId `protobuf:"bytes,1984,opt,name=penumbra_asset_id,json=penumbraAssetId,proto3" json:"penumbra_asset_id,omitempty"`
+}
+
+func (m *DenomMetadata) Reset() { *m = DenomMetadata{} }
+func (m *DenomMetadata) String() string { return proto.CompactTextString(m) }
+func (*DenomMetadata) ProtoMessage() {}
+func (*DenomMetadata) Descriptor() ([]byte, []int) {
+ return fileDescriptor_5c23a0b4440af102, []int{14}
+}
+func (m *DenomMetadata) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *DenomMetadata) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_DenomMetadata.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *DenomMetadata) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_DenomMetadata.Merge(m, src)
+}
+func (m *DenomMetadata) XXX_Size() int {
+ return m.Size()
+}
+func (m *DenomMetadata) XXX_DiscardUnknown() {
+ xxx_messageInfo_DenomMetadata.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_DenomMetadata proto.InternalMessageInfo
+
+func (m *DenomMetadata) GetDescription() string {
+ if m != nil {
+ return m.Description
+ }
+ return ""
+}
+
+func (m *DenomMetadata) GetDenomUnits() []*DenomUnit {
+ if m != nil {
+ return m.DenomUnits
+ }
+ return nil
+}
+
+func (m *DenomMetadata) GetBase() string {
+ if m != nil {
+ return m.Base
+ }
+ return ""
+}
+
+func (m *DenomMetadata) GetDisplay() string {
+ if m != nil {
+ return m.Display
+ }
+ return ""
+}
+
+func (m *DenomMetadata) GetName() string {
+ if m != nil {
+ return m.Name
+ }
+ return ""
+}
+
+func (m *DenomMetadata) GetSymbol() string {
+ if m != nil {
+ return m.Symbol
+ }
+ return ""
+}
+
+func (m *DenomMetadata) GetUri() string {
+ if m != nil {
+ return m.Uri
+ }
+ return ""
+}
+
+func (m *DenomMetadata) GetUriHash() string {
+ if m != nil {
+ return m.UriHash
+ }
+ return ""
+}
+
+func (m *DenomMetadata) GetPenumbraAssetId() *AssetId {
+ if m != nil {
+ return m.PenumbraAssetId
+ }
+ return nil
+}
+
+// DenomUnit represents a struct that describes a given denomination unit of the basic token.
+type DenomUnit struct {
+ // denom represents the string name of the given denom unit (e.g uatom).
+ Denom string `protobuf:"bytes,1,opt,name=denom,proto3" json:"denom,omitempty"`
+ // exponent represents power of 10 exponent that one must
+ // raise the base_denom to in order to equal the given DenomUnit's denom
+ // 1 denom = 10^exponent base_denom
+ // (e.g. with a base_denom of uatom, one can create a DenomUnit of 'atom' with
+ // exponent = 6, thus: 1 atom = 10^6 uatom).
+ Exponent uint32 `protobuf:"varint,2,opt,name=exponent,proto3" json:"exponent,omitempty"`
+ // aliases is a list of string aliases for the given denom
+ Aliases []string `protobuf:"bytes,3,rep,name=aliases,proto3" json:"aliases,omitempty"`
+}
+
+func (m *DenomUnit) Reset() { *m = DenomUnit{} }
+func (m *DenomUnit) String() string { return proto.CompactTextString(m) }
+func (*DenomUnit) ProtoMessage() {}
+func (*DenomUnit) Descriptor() ([]byte, []int) {
+ return fileDescriptor_5c23a0b4440af102, []int{15}
+}
+func (m *DenomUnit) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *DenomUnit) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_DenomUnit.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *DenomUnit) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_DenomUnit.Merge(m, src)
+}
+func (m *DenomUnit) XXX_Size() int {
+ return m.Size()
+}
+func (m *DenomUnit) XXX_DiscardUnknown() {
+ xxx_messageInfo_DenomUnit.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_DenomUnit proto.InternalMessageInfo
+
+func (m *DenomUnit) GetDenom() string {
+ if m != nil {
+ return m.Denom
+ }
+ return ""
+}
+
+func (m *DenomUnit) GetExponent() uint32 {
+ if m != nil {
+ return m.Exponent
+ }
+ return 0
+}
+
+func (m *DenomUnit) GetAliases() []string {
+ if m != nil {
+ return m.Aliases
+ }
+ return nil
+}
+
+type Value struct {
+ Amount *Amount `protobuf:"bytes,1,opt,name=amount,proto3" json:"amount,omitempty"`
+ AssetId *AssetId `protobuf:"bytes,2,opt,name=asset_id,json=assetId,proto3" json:"asset_id,omitempty"`
+}
+
+func (m *Value) Reset() { *m = Value{} }
+func (m *Value) String() string { return proto.CompactTextString(m) }
+func (*Value) ProtoMessage() {}
+func (*Value) Descriptor() ([]byte, []int) {
+ return fileDescriptor_5c23a0b4440af102, []int{16}
+}
+func (m *Value) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *Value) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_Value.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *Value) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_Value.Merge(m, src)
+}
+func (m *Value) XXX_Size() int {
+ return m.Size()
+}
+func (m *Value) XXX_DiscardUnknown() {
+ xxx_messageInfo_Value.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_Value proto.InternalMessageInfo
+
+func (m *Value) GetAmount() *Amount {
+ if m != nil {
+ return m.Amount
+ }
+ return nil
+}
+
+func (m *Value) GetAssetId() *AssetId {
+ if m != nil {
+ return m.AssetId
+ }
+ return nil
+}
+
+// Represents a value of a known or unknown denomination.
+//
+// Note: unlike some other View types, we don't just store the underlying
+// `Value` message together with an additional `Denom`. Instead, we record
+// either an `Amount` and `Denom` (only) or an `Amount` and `AssetId`. This is
+// because we don't want to allow a situation where the supplied `Denom` doesn't
+// match the `AssetId`, and a consumer of the API that doesn't check is tricked.
+// This way, the `Denom` will always match, because the consumer is forced to
+// recompute it themselves if they want it.
+type ValueView struct {
+ // Types that are valid to be assigned to ValueView:
+ //
+ // *ValueView_KnownDenom_
+ // *ValueView_UnknownDenom_
+ ValueView isValueView_ValueView `protobuf_oneof:"value_view"`
+}
+
+func (m *ValueView) Reset() { *m = ValueView{} }
+func (m *ValueView) String() string { return proto.CompactTextString(m) }
+func (*ValueView) ProtoMessage() {}
+func (*ValueView) Descriptor() ([]byte, []int) {
+ return fileDescriptor_5c23a0b4440af102, []int{17}
+}
+func (m *ValueView) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *ValueView) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_ValueView.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *ValueView) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_ValueView.Merge(m, src)
+}
+func (m *ValueView) XXX_Size() int {
+ return m.Size()
+}
+func (m *ValueView) XXX_DiscardUnknown() {
+ xxx_messageInfo_ValueView.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_ValueView proto.InternalMessageInfo
+
+type isValueView_ValueView interface {
+ isValueView_ValueView()
+ MarshalTo([]byte) (int, error)
+ Size() int
+}
+
+type ValueView_KnownDenom_ struct {
+ KnownDenom *ValueView_KnownDenom `protobuf:"bytes,1,opt,name=known_denom,json=knownDenom,proto3,oneof" json:"known_denom,omitempty"`
+}
+type ValueView_UnknownDenom_ struct {
+ UnknownDenom *ValueView_UnknownDenom `protobuf:"bytes,2,opt,name=unknown_denom,json=unknownDenom,proto3,oneof" json:"unknown_denom,omitempty"`
+}
+
+func (*ValueView_KnownDenom_) isValueView_ValueView() {}
+func (*ValueView_UnknownDenom_) isValueView_ValueView() {}
+
+func (m *ValueView) GetValueView() isValueView_ValueView {
+ if m != nil {
+ return m.ValueView
+ }
+ return nil
+}
+
+func (m *ValueView) GetKnownDenom() *ValueView_KnownDenom {
+ if x, ok := m.GetValueView().(*ValueView_KnownDenom_); ok {
+ return x.KnownDenom
+ }
+ return nil
+}
+
+func (m *ValueView) GetUnknownDenom() *ValueView_UnknownDenom {
+ if x, ok := m.GetValueView().(*ValueView_UnknownDenom_); ok {
+ return x.UnknownDenom
+ }
+ return nil
+}
+
+// XXX_OneofWrappers is for the internal use of the proto package.
+func (*ValueView) XXX_OneofWrappers() []interface{} {
+ return []interface{}{
+ (*ValueView_KnownDenom_)(nil),
+ (*ValueView_UnknownDenom_)(nil),
+ }
+}
+
+// A value whose asset ID has a known denomination.
+type ValueView_KnownDenom struct {
+ Amount *Amount `protobuf:"bytes,1,opt,name=amount,proto3" json:"amount,omitempty"`
+ Denom *DenomMetadata `protobuf:"bytes,2,opt,name=denom,proto3" json:"denom,omitempty"`
+}
+
+func (m *ValueView_KnownDenom) Reset() { *m = ValueView_KnownDenom{} }
+func (m *ValueView_KnownDenom) String() string { return proto.CompactTextString(m) }
+func (*ValueView_KnownDenom) ProtoMessage() {}
+func (*ValueView_KnownDenom) Descriptor() ([]byte, []int) {
+ return fileDescriptor_5c23a0b4440af102, []int{17, 0}
+}
+func (m *ValueView_KnownDenom) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *ValueView_KnownDenom) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_ValueView_KnownDenom.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *ValueView_KnownDenom) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_ValueView_KnownDenom.Merge(m, src)
+}
+func (m *ValueView_KnownDenom) XXX_Size() int {
+ return m.Size()
+}
+func (m *ValueView_KnownDenom) XXX_DiscardUnknown() {
+ xxx_messageInfo_ValueView_KnownDenom.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_ValueView_KnownDenom proto.InternalMessageInfo
+
+func (m *ValueView_KnownDenom) GetAmount() *Amount {
+ if m != nil {
+ return m.Amount
+ }
+ return nil
+}
+
+func (m *ValueView_KnownDenom) GetDenom() *DenomMetadata {
+ if m != nil {
+ return m.Denom
+ }
+ return nil
+}
+
+type ValueView_UnknownDenom struct {
+ Amount *Amount `protobuf:"bytes,1,opt,name=amount,proto3" json:"amount,omitempty"`
+ AssetId *AssetId `protobuf:"bytes,2,opt,name=asset_id,json=assetId,proto3" json:"asset_id,omitempty"`
+}
+
+func (m *ValueView_UnknownDenom) Reset() { *m = ValueView_UnknownDenom{} }
+func (m *ValueView_UnknownDenom) String() string { return proto.CompactTextString(m) }
+func (*ValueView_UnknownDenom) ProtoMessage() {}
+func (*ValueView_UnknownDenom) Descriptor() ([]byte, []int) {
+ return fileDescriptor_5c23a0b4440af102, []int{17, 1}
+}
+func (m *ValueView_UnknownDenom) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *ValueView_UnknownDenom) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_ValueView_UnknownDenom.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *ValueView_UnknownDenom) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_ValueView_UnknownDenom.Merge(m, src)
+}
+func (m *ValueView_UnknownDenom) XXX_Size() int {
+ return m.Size()
+}
+func (m *ValueView_UnknownDenom) XXX_DiscardUnknown() {
+ xxx_messageInfo_ValueView_UnknownDenom.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_ValueView_UnknownDenom proto.InternalMessageInfo
+
+func (m *ValueView_UnknownDenom) GetAmount() *Amount {
+ if m != nil {
+ return m.Amount
+ }
+ return nil
+}
+
+func (m *ValueView_UnknownDenom) GetAssetId() *AssetId {
+ if m != nil {
+ return m.AssetId
+ }
+ return nil
+}
+
+type MerkleRoot struct {
+ Inner []byte `protobuf:"bytes,1,opt,name=inner,proto3" json:"inner,omitempty"`
+}
+
+func (m *MerkleRoot) Reset() { *m = MerkleRoot{} }
+func (m *MerkleRoot) String() string { return proto.CompactTextString(m) }
+func (*MerkleRoot) ProtoMessage() {}
+func (*MerkleRoot) Descriptor() ([]byte, []int) {
+ return fileDescriptor_5c23a0b4440af102, []int{18}
+}
+func (m *MerkleRoot) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *MerkleRoot) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_MerkleRoot.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *MerkleRoot) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_MerkleRoot.Merge(m, src)
+}
+func (m *MerkleRoot) XXX_Size() int {
+ return m.Size()
+}
+func (m *MerkleRoot) XXX_DiscardUnknown() {
+ xxx_messageInfo_MerkleRoot.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_MerkleRoot proto.InternalMessageInfo
+
+func (m *MerkleRoot) GetInner() []byte {
+ if m != nil {
+ return m.Inner
+ }
+ return nil
+}
+
+// A validator's identity key (decaf377-rdsa spendauth verification key).
+type IdentityKey struct {
+ Ik []byte `protobuf:"bytes,1,opt,name=ik,proto3" json:"ik,omitempty"`
+}
+
+func (m *IdentityKey) Reset() { *m = IdentityKey{} }
+func (m *IdentityKey) String() string { return proto.CompactTextString(m) }
+func (*IdentityKey) ProtoMessage() {}
+func (*IdentityKey) Descriptor() ([]byte, []int) {
+ return fileDescriptor_5c23a0b4440af102, []int{19}
+}
+func (m *IdentityKey) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *IdentityKey) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_IdentityKey.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *IdentityKey) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_IdentityKey.Merge(m, src)
+}
+func (m *IdentityKey) XXX_Size() int {
+ return m.Size()
+}
+func (m *IdentityKey) XXX_DiscardUnknown() {
+ xxx_messageInfo_IdentityKey.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_IdentityKey proto.InternalMessageInfo
+
+func (m *IdentityKey) GetIk() []byte {
+ if m != nil {
+ return m.Ik
+ }
+ return nil
+}
+
+// A validator's governance key (decaf377-rdsa spendauth verification key).
+type GovernanceKey struct {
+ Gk []byte `protobuf:"bytes,1,opt,name=gk,proto3" json:"gk,omitempty"`
+}
+
+func (m *GovernanceKey) Reset() { *m = GovernanceKey{} }
+func (m *GovernanceKey) String() string { return proto.CompactTextString(m) }
+func (*GovernanceKey) ProtoMessage() {}
+func (*GovernanceKey) Descriptor() ([]byte, []int) {
+ return fileDescriptor_5c23a0b4440af102, []int{20}
+}
+func (m *GovernanceKey) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *GovernanceKey) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_GovernanceKey.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *GovernanceKey) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_GovernanceKey.Merge(m, src)
+}
+func (m *GovernanceKey) XXX_Size() int {
+ return m.Size()
+}
+func (m *GovernanceKey) XXX_DiscardUnknown() {
+ xxx_messageInfo_GovernanceKey.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_GovernanceKey proto.InternalMessageInfo
+
+func (m *GovernanceKey) GetGk() []byte {
+ if m != nil {
+ return m.Gk
+ }
+ return nil
+}
+
+type ConsensusKey struct {
+ Inner []byte `protobuf:"bytes,1,opt,name=inner,proto3" json:"inner,omitempty"`
+}
+
+func (m *ConsensusKey) Reset() { *m = ConsensusKey{} }
+func (m *ConsensusKey) String() string { return proto.CompactTextString(m) }
+func (*ConsensusKey) ProtoMessage() {}
+func (*ConsensusKey) Descriptor() ([]byte, []int) {
+ return fileDescriptor_5c23a0b4440af102, []int{21}
+}
+func (m *ConsensusKey) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *ConsensusKey) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_ConsensusKey.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *ConsensusKey) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_ConsensusKey.Merge(m, src)
+}
+func (m *ConsensusKey) XXX_Size() int {
+ return m.Size()
+}
+func (m *ConsensusKey) XXX_DiscardUnknown() {
+ xxx_messageInfo_ConsensusKey.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_ConsensusKey proto.InternalMessageInfo
+
+func (m *ConsensusKey) GetInner() []byte {
+ if m != nil {
+ return m.Inner
+ }
+ return nil
+}
+
+type Note struct {
+ Value *Value `protobuf:"bytes,1,opt,name=value,proto3" json:"value,omitempty"`
+ Rseed []byte `protobuf:"bytes,2,opt,name=rseed,proto3" json:"rseed,omitempty"`
+ Address *Address `protobuf:"bytes,3,opt,name=address,proto3" json:"address,omitempty"`
+}
+
+func (m *Note) Reset() { *m = Note{} }
+func (m *Note) String() string { return proto.CompactTextString(m) }
+func (*Note) ProtoMessage() {}
+func (*Note) Descriptor() ([]byte, []int) {
+ return fileDescriptor_5c23a0b4440af102, []int{22}
+}
+func (m *Note) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *Note) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_Note.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *Note) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_Note.Merge(m, src)
+}
+func (m *Note) XXX_Size() int {
+ return m.Size()
+}
+func (m *Note) XXX_DiscardUnknown() {
+ xxx_messageInfo_Note.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_Note proto.InternalMessageInfo
+
+func (m *Note) GetValue() *Value {
+ if m != nil {
+ return m.Value
+ }
+ return nil
+}
+
+func (m *Note) GetRseed() []byte {
+ if m != nil {
+ return m.Rseed
+ }
+ return nil
+}
+
+func (m *Note) GetAddress() *Address {
+ if m != nil {
+ return m.Address
+ }
+ return nil
+}
+
+type NoteView struct {
+ Value *ValueView `protobuf:"bytes,1,opt,name=value,proto3" json:"value,omitempty"`
+ Rseed []byte `protobuf:"bytes,2,opt,name=rseed,proto3" json:"rseed,omitempty"`
+ Address *AddressView `protobuf:"bytes,3,opt,name=address,proto3" json:"address,omitempty"`
+}
+
+func (m *NoteView) Reset() { *m = NoteView{} }
+func (m *NoteView) String() string { return proto.CompactTextString(m) }
+func (*NoteView) ProtoMessage() {}
+func (*NoteView) Descriptor() ([]byte, []int) {
+ return fileDescriptor_5c23a0b4440af102, []int{23}
+}
+func (m *NoteView) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *NoteView) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_NoteView.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *NoteView) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_NoteView.Merge(m, src)
+}
+func (m *NoteView) XXX_Size() int {
+ return m.Size()
+}
+func (m *NoteView) XXX_DiscardUnknown() {
+ xxx_messageInfo_NoteView.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_NoteView proto.InternalMessageInfo
+
+func (m *NoteView) GetValue() *ValueView {
+ if m != nil {
+ return m.Value
+ }
+ return nil
+}
+
+func (m *NoteView) GetRseed() []byte {
+ if m != nil {
+ return m.Rseed
+ }
+ return nil
+}
+
+func (m *NoteView) GetAddress() *AddressView {
+ if m != nil {
+ return m.Address
+ }
+ return nil
+}
+
+// An encrypted note.
+// 132 = 1(type) + 11(d) + 8(amount) + 32(asset_id) + 32(rcm) + 32(pk_d) + 16(MAC) bytes.
+type NoteCiphertext struct {
+ Inner []byte `protobuf:"bytes,1,opt,name=inner,proto3" json:"inner,omitempty"`
+}
+
+func (m *NoteCiphertext) Reset() { *m = NoteCiphertext{} }
+func (m *NoteCiphertext) String() string { return proto.CompactTextString(m) }
+func (*NoteCiphertext) ProtoMessage() {}
+func (*NoteCiphertext) Descriptor() ([]byte, []int) {
+ return fileDescriptor_5c23a0b4440af102, []int{24}
+}
+func (m *NoteCiphertext) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *NoteCiphertext) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_NoteCiphertext.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *NoteCiphertext) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_NoteCiphertext.Merge(m, src)
+}
+func (m *NoteCiphertext) XXX_Size() int {
+ return m.Size()
+}
+func (m *NoteCiphertext) XXX_DiscardUnknown() {
+ xxx_messageInfo_NoteCiphertext.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_NoteCiphertext proto.InternalMessageInfo
+
+func (m *NoteCiphertext) GetInner() []byte {
+ if m != nil {
+ return m.Inner
+ }
+ return nil
+}
+
+type Nullifier struct {
+ Inner []byte `protobuf:"bytes,1,opt,name=inner,proto3" json:"inner,omitempty"`
+}
+
+func (m *Nullifier) Reset() { *m = Nullifier{} }
+func (m *Nullifier) String() string { return proto.CompactTextString(m) }
+func (*Nullifier) ProtoMessage() {}
+func (*Nullifier) Descriptor() ([]byte, []int) {
+ return fileDescriptor_5c23a0b4440af102, []int{25}
+}
+func (m *Nullifier) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *Nullifier) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_Nullifier.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *Nullifier) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_Nullifier.Merge(m, src)
+}
+func (m *Nullifier) XXX_Size() int {
+ return m.Size()
+}
+func (m *Nullifier) XXX_DiscardUnknown() {
+ xxx_messageInfo_Nullifier.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_Nullifier proto.InternalMessageInfo
+
+func (m *Nullifier) GetInner() []byte {
+ if m != nil {
+ return m.Inner
+ }
+ return nil
+}
+
+type SpendAuthSignature struct {
+ Inner []byte `protobuf:"bytes,1,opt,name=inner,proto3" json:"inner,omitempty"`
+}
+
+func (m *SpendAuthSignature) Reset() { *m = SpendAuthSignature{} }
+func (m *SpendAuthSignature) String() string { return proto.CompactTextString(m) }
+func (*SpendAuthSignature) ProtoMessage() {}
+func (*SpendAuthSignature) Descriptor() ([]byte, []int) {
+ return fileDescriptor_5c23a0b4440af102, []int{26}
+}
+func (m *SpendAuthSignature) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *SpendAuthSignature) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_SpendAuthSignature.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *SpendAuthSignature) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_SpendAuthSignature.Merge(m, src)
+}
+func (m *SpendAuthSignature) XXX_Size() int {
+ return m.Size()
+}
+func (m *SpendAuthSignature) XXX_DiscardUnknown() {
+ xxx_messageInfo_SpendAuthSignature.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_SpendAuthSignature proto.InternalMessageInfo
+
+func (m *SpendAuthSignature) GetInner() []byte {
+ if m != nil {
+ return m.Inner
+ }
+ return nil
+}
+
+type BindingSignature struct {
+ Inner []byte `protobuf:"bytes,1,opt,name=inner,proto3" json:"inner,omitempty"`
+}
+
+func (m *BindingSignature) Reset() { *m = BindingSignature{} }
+func (m *BindingSignature) String() string { return proto.CompactTextString(m) }
+func (*BindingSignature) ProtoMessage() {}
+func (*BindingSignature) Descriptor() ([]byte, []int) {
+ return fileDescriptor_5c23a0b4440af102, []int{27}
+}
+func (m *BindingSignature) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *BindingSignature) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_BindingSignature.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *BindingSignature) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_BindingSignature.Merge(m, src)
+}
+func (m *BindingSignature) XXX_Size() int {
+ return m.Size()
+}
+func (m *BindingSignature) XXX_DiscardUnknown() {
+ xxx_messageInfo_BindingSignature.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_BindingSignature proto.InternalMessageInfo
+
+func (m *BindingSignature) GetInner() []byte {
+ if m != nil {
+ return m.Inner
+ }
+ return nil
+}
+
+// The body of an output description, including only the minimal
+// data required to scan and process the output.
+type NotePayload struct {
+ // The note commitment for the output note. 32 bytes.
+ NoteCommitment *StateCommitment `protobuf:"bytes,1,opt,name=note_commitment,json=noteCommitment,proto3" json:"note_commitment,omitempty"`
+ // The encoding of an ephemeral public key. 32 bytes.
+ EphemeralKey []byte `protobuf:"bytes,2,opt,name=ephemeral_key,json=ephemeralKey,proto3" json:"ephemeral_key,omitempty"`
+ // An encryption of the newly created note.
+ // 132 = 1(type) + 11(d) + 8(amount) + 32(asset_id) + 32(rcm) + 32(pk_d) + 16(MAC) bytes.
+ EncryptedNote *NoteCiphertext `protobuf:"bytes,3,opt,name=encrypted_note,json=encryptedNote,proto3" json:"encrypted_note,omitempty"`
+}
+
+func (m *NotePayload) Reset() { *m = NotePayload{} }
+func (m *NotePayload) String() string { return proto.CompactTextString(m) }
+func (*NotePayload) ProtoMessage() {}
+func (*NotePayload) Descriptor() ([]byte, []int) {
+ return fileDescriptor_5c23a0b4440af102, []int{28}
+}
+func (m *NotePayload) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *NotePayload) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_NotePayload.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *NotePayload) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_NotePayload.Merge(m, src)
+}
+func (m *NotePayload) XXX_Size() int {
+ return m.Size()
+}
+func (m *NotePayload) XXX_DiscardUnknown() {
+ xxx_messageInfo_NotePayload.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_NotePayload proto.InternalMessageInfo
+
+func (m *NotePayload) GetNoteCommitment() *StateCommitment {
+ if m != nil {
+ return m.NoteCommitment
+ }
+ return nil
+}
+
+func (m *NotePayload) GetEphemeralKey() []byte {
+ if m != nil {
+ return m.EphemeralKey
+ }
+ return nil
+}
+
+func (m *NotePayload) GetEncryptedNote() *NoteCiphertext {
+ if m != nil {
+ return m.EncryptedNote
+ }
+ return nil
+}
+
+// An authentication path from a state commitment to the root of the state commitment tree.
+type StateCommitmentProof struct {
+ NoteCommitment *StateCommitment `protobuf:"bytes,1,opt,name=note_commitment,json=noteCommitment,proto3" json:"note_commitment,omitempty"`
+ Position uint64 `protobuf:"varint,2,opt,name=position,proto3" json:"position,omitempty"`
+ AuthPath []*MerklePathChunk `protobuf:"bytes,3,rep,name=auth_path,json=authPath,proto3" json:"auth_path,omitempty"`
+}
+
+func (m *StateCommitmentProof) Reset() { *m = StateCommitmentProof{} }
+func (m *StateCommitmentProof) String() string { return proto.CompactTextString(m) }
+func (*StateCommitmentProof) ProtoMessage() {}
+func (*StateCommitmentProof) Descriptor() ([]byte, []int) {
+ return fileDescriptor_5c23a0b4440af102, []int{29}
+}
+func (m *StateCommitmentProof) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *StateCommitmentProof) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_StateCommitmentProof.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *StateCommitmentProof) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_StateCommitmentProof.Merge(m, src)
+}
+func (m *StateCommitmentProof) XXX_Size() int {
+ return m.Size()
+}
+func (m *StateCommitmentProof) XXX_DiscardUnknown() {
+ xxx_messageInfo_StateCommitmentProof.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_StateCommitmentProof proto.InternalMessageInfo
+
+func (m *StateCommitmentProof) GetNoteCommitment() *StateCommitment {
+ if m != nil {
+ return m.NoteCommitment
+ }
+ return nil
+}
+
+func (m *StateCommitmentProof) GetPosition() uint64 {
+ if m != nil {
+ return m.Position
+ }
+ return 0
+}
+
+func (m *StateCommitmentProof) GetAuthPath() []*MerklePathChunk {
+ if m != nil {
+ return m.AuthPath
+ }
+ return nil
+}
+
+// A set of 3 sibling hashes in the auth path for some note commitment.
+type MerklePathChunk struct {
+ Sibling_1 []byte `protobuf:"bytes,1,opt,name=sibling_1,json=sibling1,proto3" json:"sibling_1,omitempty"`
+ Sibling_2 []byte `protobuf:"bytes,2,opt,name=sibling_2,json=sibling2,proto3" json:"sibling_2,omitempty"`
+ Sibling_3 []byte `protobuf:"bytes,3,opt,name=sibling_3,json=sibling3,proto3" json:"sibling_3,omitempty"`
+}
+
+func (m *MerklePathChunk) Reset() { *m = MerklePathChunk{} }
+func (m *MerklePathChunk) String() string { return proto.CompactTextString(m) }
+func (*MerklePathChunk) ProtoMessage() {}
+func (*MerklePathChunk) Descriptor() ([]byte, []int) {
+ return fileDescriptor_5c23a0b4440af102, []int{30}
+}
+func (m *MerklePathChunk) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *MerklePathChunk) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_MerklePathChunk.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *MerklePathChunk) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_MerklePathChunk.Merge(m, src)
+}
+func (m *MerklePathChunk) XXX_Size() int {
+ return m.Size()
+}
+func (m *MerklePathChunk) XXX_DiscardUnknown() {
+ xxx_messageInfo_MerklePathChunk.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_MerklePathChunk proto.InternalMessageInfo
+
+func (m *MerklePathChunk) GetSibling_1() []byte {
+ if m != nil {
+ return m.Sibling_1
+ }
+ return nil
+}
+
+func (m *MerklePathChunk) GetSibling_2() []byte {
+ if m != nil {
+ return m.Sibling_2
+ }
+ return nil
+}
+
+func (m *MerklePathChunk) GetSibling_3() []byte {
+ if m != nil {
+ return m.Sibling_3
+ }
+ return nil
+}
+
+// A clue for use with Fuzzy Message Detection.
+type Clue struct {
+ Inner []byte `protobuf:"bytes,1,opt,name=inner,proto3" json:"inner,omitempty"`
+}
+
+func (m *Clue) Reset() { *m = Clue{} }
+func (m *Clue) String() string { return proto.CompactTextString(m) }
+func (*Clue) ProtoMessage() {}
+func (*Clue) Descriptor() ([]byte, []int) {
+ return fileDescriptor_5c23a0b4440af102, []int{31}
+}
+func (m *Clue) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *Clue) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_Clue.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *Clue) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_Clue.Merge(m, src)
+}
+func (m *Clue) XXX_Size() int {
+ return m.Size()
+}
+func (m *Clue) XXX_DiscardUnknown() {
+ xxx_messageInfo_Clue.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_Clue proto.InternalMessageInfo
+
+func (m *Clue) GetInner() []byte {
+ if m != nil {
+ return m.Inner
+ }
+ return nil
+}
+
+// An authorization hash for a Penumbra transaction.
+type EffectHash struct {
+ Inner []byte `protobuf:"bytes,1,opt,name=inner,proto3" json:"inner,omitempty"`
+}
+
+func (m *EffectHash) Reset() { *m = EffectHash{} }
+func (m *EffectHash) String() string { return proto.CompactTextString(m) }
+func (*EffectHash) ProtoMessage() {}
+func (*EffectHash) Descriptor() ([]byte, []int) {
+ return fileDescriptor_5c23a0b4440af102, []int{32}
+}
+func (m *EffectHash) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *EffectHash) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_EffectHash.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *EffectHash) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_EffectHash.Merge(m, src)
+}
+func (m *EffectHash) XXX_Size() int {
+ return m.Size()
+}
+func (m *EffectHash) XXX_DiscardUnknown() {
+ xxx_messageInfo_EffectHash.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_EffectHash proto.InternalMessageInfo
+
+func (m *EffectHash) GetInner() []byte {
+ if m != nil {
+ return m.Inner
+ }
+ return nil
+}
+
+// A Penumbra ZK output proof.
+type ZKOutputProof struct {
+ Inner []byte `protobuf:"bytes,1,opt,name=inner,proto3" json:"inner,omitempty"`
+}
+
+func (m *ZKOutputProof) Reset() { *m = ZKOutputProof{} }
+func (m *ZKOutputProof) String() string { return proto.CompactTextString(m) }
+func (*ZKOutputProof) ProtoMessage() {}
+func (*ZKOutputProof) Descriptor() ([]byte, []int) {
+ return fileDescriptor_5c23a0b4440af102, []int{33}
+}
+func (m *ZKOutputProof) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *ZKOutputProof) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_ZKOutputProof.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *ZKOutputProof) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_ZKOutputProof.Merge(m, src)
+}
+func (m *ZKOutputProof) XXX_Size() int {
+ return m.Size()
+}
+func (m *ZKOutputProof) XXX_DiscardUnknown() {
+ xxx_messageInfo_ZKOutputProof.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_ZKOutputProof proto.InternalMessageInfo
+
+func (m *ZKOutputProof) GetInner() []byte {
+ if m != nil {
+ return m.Inner
+ }
+ return nil
+}
+
+// A Penumbra ZK spend proof.
+type ZKSpendProof struct {
+ Inner []byte `protobuf:"bytes,1,opt,name=inner,proto3" json:"inner,omitempty"`
+}
+
+func (m *ZKSpendProof) Reset() { *m = ZKSpendProof{} }
+func (m *ZKSpendProof) String() string { return proto.CompactTextString(m) }
+func (*ZKSpendProof) ProtoMessage() {}
+func (*ZKSpendProof) Descriptor() ([]byte, []int) {
+ return fileDescriptor_5c23a0b4440af102, []int{34}
+}
+func (m *ZKSpendProof) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *ZKSpendProof) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_ZKSpendProof.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *ZKSpendProof) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_ZKSpendProof.Merge(m, src)
+}
+func (m *ZKSpendProof) XXX_Size() int {
+ return m.Size()
+}
+func (m *ZKSpendProof) XXX_DiscardUnknown() {
+ xxx_messageInfo_ZKSpendProof.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_ZKSpendProof proto.InternalMessageInfo
+
+func (m *ZKSpendProof) GetInner() []byte {
+ if m != nil {
+ return m.Inner
+ }
+ return nil
+}
+
+// A Penumbra ZK swap proof.
+type ZKSwapProof struct {
+ Inner []byte `protobuf:"bytes,1,opt,name=inner,proto3" json:"inner,omitempty"`
+}
+
+func (m *ZKSwapProof) Reset() { *m = ZKSwapProof{} }
+func (m *ZKSwapProof) String() string { return proto.CompactTextString(m) }
+func (*ZKSwapProof) ProtoMessage() {}
+func (*ZKSwapProof) Descriptor() ([]byte, []int) {
+ return fileDescriptor_5c23a0b4440af102, []int{35}
+}
+func (m *ZKSwapProof) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *ZKSwapProof) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_ZKSwapProof.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *ZKSwapProof) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_ZKSwapProof.Merge(m, src)
+}
+func (m *ZKSwapProof) XXX_Size() int {
+ return m.Size()
+}
+func (m *ZKSwapProof) XXX_DiscardUnknown() {
+ xxx_messageInfo_ZKSwapProof.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_ZKSwapProof proto.InternalMessageInfo
+
+func (m *ZKSwapProof) GetInner() []byte {
+ if m != nil {
+ return m.Inner
+ }
+ return nil
+}
+
+// A Penumbra ZK swap claim proof.
+type ZKSwapClaimProof struct {
+ Inner []byte `protobuf:"bytes,1,opt,name=inner,proto3" json:"inner,omitempty"`
+}
+
+func (m *ZKSwapClaimProof) Reset() { *m = ZKSwapClaimProof{} }
+func (m *ZKSwapClaimProof) String() string { return proto.CompactTextString(m) }
+func (*ZKSwapClaimProof) ProtoMessage() {}
+func (*ZKSwapClaimProof) Descriptor() ([]byte, []int) {
+ return fileDescriptor_5c23a0b4440af102, []int{36}
+}
+func (m *ZKSwapClaimProof) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *ZKSwapClaimProof) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_ZKSwapClaimProof.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *ZKSwapClaimProof) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_ZKSwapClaimProof.Merge(m, src)
+}
+func (m *ZKSwapClaimProof) XXX_Size() int {
+ return m.Size()
+}
+func (m *ZKSwapClaimProof) XXX_DiscardUnknown() {
+ xxx_messageInfo_ZKSwapClaimProof.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_ZKSwapClaimProof proto.InternalMessageInfo
+
+func (m *ZKSwapClaimProof) GetInner() []byte {
+ if m != nil {
+ return m.Inner
+ }
+ return nil
+}
+
+// A Penumbra ZK undelegate claim proof.
+type ZKUndelegateClaimProof struct {
+ Inner []byte `protobuf:"bytes,1,opt,name=inner,proto3" json:"inner,omitempty"`
+}
+
+func (m *ZKUndelegateClaimProof) Reset() { *m = ZKUndelegateClaimProof{} }
+func (m *ZKUndelegateClaimProof) String() string { return proto.CompactTextString(m) }
+func (*ZKUndelegateClaimProof) ProtoMessage() {}
+func (*ZKUndelegateClaimProof) Descriptor() ([]byte, []int) {
+ return fileDescriptor_5c23a0b4440af102, []int{37}
+}
+func (m *ZKUndelegateClaimProof) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *ZKUndelegateClaimProof) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_ZKUndelegateClaimProof.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *ZKUndelegateClaimProof) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_ZKUndelegateClaimProof.Merge(m, src)
+}
+func (m *ZKUndelegateClaimProof) XXX_Size() int {
+ return m.Size()
+}
+func (m *ZKUndelegateClaimProof) XXX_DiscardUnknown() {
+ xxx_messageInfo_ZKUndelegateClaimProof.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_ZKUndelegateClaimProof proto.InternalMessageInfo
+
+func (m *ZKUndelegateClaimProof) GetInner() []byte {
+ if m != nil {
+ return m.Inner
+ }
+ return nil
+}
+
+// A Penumbra ZK delegator vote proof.
+type ZKDelegatorVoteProof struct {
+ Inner []byte `protobuf:"bytes,1,opt,name=inner,proto3" json:"inner,omitempty"`
+}
+
+func (m *ZKDelegatorVoteProof) Reset() { *m = ZKDelegatorVoteProof{} }
+func (m *ZKDelegatorVoteProof) String() string { return proto.CompactTextString(m) }
+func (*ZKDelegatorVoteProof) ProtoMessage() {}
+func (*ZKDelegatorVoteProof) Descriptor() ([]byte, []int) {
+ return fileDescriptor_5c23a0b4440af102, []int{38}
+}
+func (m *ZKDelegatorVoteProof) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *ZKDelegatorVoteProof) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_ZKDelegatorVoteProof.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *ZKDelegatorVoteProof) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_ZKDelegatorVoteProof.Merge(m, src)
+}
+func (m *ZKDelegatorVoteProof) XXX_Size() int {
+ return m.Size()
+}
+func (m *ZKDelegatorVoteProof) XXX_DiscardUnknown() {
+ xxx_messageInfo_ZKDelegatorVoteProof.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_ZKDelegatorVoteProof proto.InternalMessageInfo
+
+func (m *ZKDelegatorVoteProof) GetInner() []byte {
+ if m != nil {
+ return m.Inner
+ }
+ return nil
+}
+
+// A Penumbra ZK nullifier derivation proof.
+type ZKNullifierDerivationProof struct {
+ Inner []byte `protobuf:"bytes,1,opt,name=inner,proto3" json:"inner,omitempty"`
+}
+
+func (m *ZKNullifierDerivationProof) Reset() { *m = ZKNullifierDerivationProof{} }
+func (m *ZKNullifierDerivationProof) String() string { return proto.CompactTextString(m) }
+func (*ZKNullifierDerivationProof) ProtoMessage() {}
+func (*ZKNullifierDerivationProof) Descriptor() ([]byte, []int) {
+ return fileDescriptor_5c23a0b4440af102, []int{39}
+}
+func (m *ZKNullifierDerivationProof) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *ZKNullifierDerivationProof) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_ZKNullifierDerivationProof.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *ZKNullifierDerivationProof) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_ZKNullifierDerivationProof.Merge(m, src)
+}
+func (m *ZKNullifierDerivationProof) XXX_Size() int {
+ return m.Size()
+}
+func (m *ZKNullifierDerivationProof) XXX_DiscardUnknown() {
+ xxx_messageInfo_ZKNullifierDerivationProof.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_ZKNullifierDerivationProof proto.InternalMessageInfo
+
+func (m *ZKNullifierDerivationProof) GetInner() []byte {
+ if m != nil {
+ return m.Inner
+ }
+ return nil
+}
+
+func init() {
+ proto.RegisterType((*Fee)(nil), "penumbra.core.crypto.v1alpha1.Fee")
+ proto.RegisterType((*Address)(nil), "penumbra.core.crypto.v1alpha1.Address")
+ proto.RegisterType((*AddressView)(nil), "penumbra.core.crypto.v1alpha1.AddressView")
+ proto.RegisterType((*AddressView_Visible)(nil), "penumbra.core.crypto.v1alpha1.AddressView.Visible")
+ proto.RegisterType((*AddressView_Opaque)(nil), "penumbra.core.crypto.v1alpha1.AddressView.Opaque")
+ proto.RegisterType((*SpendKey)(nil), "penumbra.core.crypto.v1alpha1.SpendKey")
+ proto.RegisterType((*SpendVerificationKey)(nil), "penumbra.core.crypto.v1alpha1.SpendVerificationKey")
+ proto.RegisterType((*FullViewingKey)(nil), "penumbra.core.crypto.v1alpha1.FullViewingKey")
+ proto.RegisterType((*AccountGroupId)(nil), "penumbra.core.crypto.v1alpha1.AccountGroupId")
+ proto.RegisterType((*Diversifier)(nil), "penumbra.core.crypto.v1alpha1.Diversifier")
+ proto.RegisterType((*AddressIndex)(nil), "penumbra.core.crypto.v1alpha1.AddressIndex")
+ proto.RegisterType((*StateCommitment)(nil), "penumbra.core.crypto.v1alpha1.StateCommitment")
+ proto.RegisterType((*BalanceCommitment)(nil), "penumbra.core.crypto.v1alpha1.BalanceCommitment")
+ proto.RegisterType((*AssetId)(nil), "penumbra.core.crypto.v1alpha1.AssetId")
+ proto.RegisterType((*Amount)(nil), "penumbra.core.crypto.v1alpha1.Amount")
+ proto.RegisterType((*Denom)(nil), "penumbra.core.crypto.v1alpha1.Denom")
+ proto.RegisterType((*DenomMetadata)(nil), "penumbra.core.crypto.v1alpha1.DenomMetadata")
+ proto.RegisterType((*DenomUnit)(nil), "penumbra.core.crypto.v1alpha1.DenomUnit")
+ proto.RegisterType((*Value)(nil), "penumbra.core.crypto.v1alpha1.Value")
+ proto.RegisterType((*ValueView)(nil), "penumbra.core.crypto.v1alpha1.ValueView")
+ proto.RegisterType((*ValueView_KnownDenom)(nil), "penumbra.core.crypto.v1alpha1.ValueView.KnownDenom")
+ proto.RegisterType((*ValueView_UnknownDenom)(nil), "penumbra.core.crypto.v1alpha1.ValueView.UnknownDenom")
+ proto.RegisterType((*MerkleRoot)(nil), "penumbra.core.crypto.v1alpha1.MerkleRoot")
+ proto.RegisterType((*IdentityKey)(nil), "penumbra.core.crypto.v1alpha1.IdentityKey")
+ proto.RegisterType((*GovernanceKey)(nil), "penumbra.core.crypto.v1alpha1.GovernanceKey")
+ proto.RegisterType((*ConsensusKey)(nil), "penumbra.core.crypto.v1alpha1.ConsensusKey")
+ proto.RegisterType((*Note)(nil), "penumbra.core.crypto.v1alpha1.Note")
+ proto.RegisterType((*NoteView)(nil), "penumbra.core.crypto.v1alpha1.NoteView")
+ proto.RegisterType((*NoteCiphertext)(nil), "penumbra.core.crypto.v1alpha1.NoteCiphertext")
+ proto.RegisterType((*Nullifier)(nil), "penumbra.core.crypto.v1alpha1.Nullifier")
+ proto.RegisterType((*SpendAuthSignature)(nil), "penumbra.core.crypto.v1alpha1.SpendAuthSignature")
+ proto.RegisterType((*BindingSignature)(nil), "penumbra.core.crypto.v1alpha1.BindingSignature")
+ proto.RegisterType((*NotePayload)(nil), "penumbra.core.crypto.v1alpha1.NotePayload")
+ proto.RegisterType((*StateCommitmentProof)(nil), "penumbra.core.crypto.v1alpha1.StateCommitmentProof")
+ proto.RegisterType((*MerklePathChunk)(nil), "penumbra.core.crypto.v1alpha1.MerklePathChunk")
+ proto.RegisterType((*Clue)(nil), "penumbra.core.crypto.v1alpha1.Clue")
+ proto.RegisterType((*EffectHash)(nil), "penumbra.core.crypto.v1alpha1.EffectHash")
+ proto.RegisterType((*ZKOutputProof)(nil), "penumbra.core.crypto.v1alpha1.ZKOutputProof")
+ proto.RegisterType((*ZKSpendProof)(nil), "penumbra.core.crypto.v1alpha1.ZKSpendProof")
+ proto.RegisterType((*ZKSwapProof)(nil), "penumbra.core.crypto.v1alpha1.ZKSwapProof")
+ proto.RegisterType((*ZKSwapClaimProof)(nil), "penumbra.core.crypto.v1alpha1.ZKSwapClaimProof")
+ proto.RegisterType((*ZKUndelegateClaimProof)(nil), "penumbra.core.crypto.v1alpha1.ZKUndelegateClaimProof")
+ proto.RegisterType((*ZKDelegatorVoteProof)(nil), "penumbra.core.crypto.v1alpha1.ZKDelegatorVoteProof")
+ proto.RegisterType((*ZKNullifierDerivationProof)(nil), "penumbra.core.crypto.v1alpha1.ZKNullifierDerivationProof")
+}
+
+func init() {
+ proto.RegisterFile("penumbra/core/crypto/v1alpha1/crypto.proto", fileDescriptor_5c23a0b4440af102)
+}
+
+var fileDescriptor_5c23a0b4440af102 = []byte{
+ // 1437 bytes of a gzipped FileDescriptorProto
+ 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xcc, 0x58, 0xcd, 0x6e, 0x1b, 0xb7,
+ 0x16, 0xf6, 0x48, 0xb6, 0x25, 0x1f, 0xc9, 0xb2, 0x43, 0x18, 0x81, 0xae, 0xef, 0xb5, 0xe3, 0x4c,
+ 0x1c, 0x5f, 0x27, 0x37, 0x57, 0x86, 0x65, 0x74, 0xe3, 0xa2, 0x45, 0x2c, 0xb9, 0x89, 0x5d, 0x21,
+ 0x89, 0x30, 0x6e, 0x9c, 0x42, 0x30, 0x20, 0xd0, 0x33, 0xb4, 0x86, 0xd0, 0x0c, 0x39, 0x9d, 0x1f,
+ 0x39, 0xea, 0x0b, 0x14, 0x5d, 0x35, 0xeb, 0x2e, 0xbb, 0xe8, 0xa2, 0x6f, 0xd0, 0x5d, 0x97, 0x45,
+ 0x57, 0x59, 0x66, 0xd9, 0x3a, 0x8b, 0x02, 0x5d, 0x75, 0xd1, 0x07, 0x28, 0xc8, 0xe1, 0xc8, 0xb2,
+ 0x61, 0xfd, 0x24, 0x41, 0xd1, 0xee, 0x78, 0x78, 0xbe, 0xf3, 0xf1, 0xe3, 0x39, 0xe4, 0x1c, 0x4a,
+ 0x70, 0xd7, 0x23, 0x2c, 0x72, 0x8f, 0x7d, 0xbc, 0x61, 0x72, 0x9f, 0x6c, 0x98, 0x7e, 0xd7, 0x0b,
+ 0xf9, 0x46, 0x67, 0x13, 0x3b, 0x9e, 0x8d, 0x37, 0x95, 0x5d, 0xf2, 0x7c, 0x1e, 0x72, 0xb4, 0x94,
+ 0x60, 0x4b, 0x02, 0x5b, 0x52, 0xbe, 0x04, 0xab, 0x7f, 0xa1, 0x41, 0xfa, 0x01, 0x21, 0xe8, 0x03,
+ 0x98, 0xc6, 0x2e, 0x8f, 0x58, 0x58, 0xd4, 0x56, 0xb4, 0xf5, 0x5c, 0xf9, 0x76, 0x69, 0x68, 0x5c,
+ 0x69, 0x47, 0x82, 0x0d, 0x15, 0x84, 0x76, 0x20, 0x8b, 0x83, 0x80, 0x84, 0x4d, 0x6a, 0x15, 0x53,
+ 0x92, 0x60, 0x6d, 0x14, 0x81, 0x80, 0xef, 0x5b, 0x46, 0x06, 0xc7, 0x03, 0xfd, 0x3e, 0x64, 0x76,
+ 0x2c, 0xcb, 0x27, 0x41, 0x80, 0x16, 0x60, 0x8a, 0x32, 0x46, 0x7c, 0xa9, 0x25, 0x6f, 0xc4, 0x06,
+ 0xba, 0x01, 0x39, 0xec, 0x84, 0xcd, 0x63, 0x62, 0xda, 0x5b, 0x65, 0x57, 0x2e, 0x33, 0x63, 0x00,
+ 0x76, 0xc2, 0x4a, 0x3c, 0xa3, 0xff, 0x9e, 0x86, 0x9c, 0xa2, 0x38, 0xa4, 0xe4, 0x14, 0x3d, 0x86,
+ 0x4c, 0x87, 0x06, 0xf4, 0xd8, 0x21, 0x6a, 0x53, 0xe5, 0x51, 0x9a, 0xce, 0x83, 0x4b, 0x87, 0x71,
+ 0xe4, 0xde, 0x84, 0x91, 0x90, 0xa0, 0x1a, 0x4c, 0x73, 0x0f, 0x7f, 0x16, 0x11, 0xb5, 0xc5, 0xcd,
+ 0x37, 0xa0, 0x7b, 0x22, 0x03, 0xf7, 0x26, 0x0c, 0x45, 0xb1, 0xf8, 0xab, 0x06, 0x19, 0xb5, 0x06,
+ 0xba, 0x0f, 0x19, 0x1c, 0x63, 0x95, 0xd0, 0xb5, 0xf1, 0x98, 0x8d, 0x24, 0x0c, 0xed, 0x88, 0x8c,
+ 0x59, 0xe4, 0xb9, 0x52, 0xf6, 0xbf, 0xf1, 0xe2, 0xf7, 0x45, 0x88, 0x11, 0x47, 0xa2, 0x67, 0x30,
+ 0x8f, 0x4d, 0x53, 0x54, 0xb3, 0xd9, 0xf2, 0x79, 0xe4, 0x89, 0x52, 0xa6, 0x25, 0xdb, 0xff, 0x47,
+ 0xb1, 0xc5, 0x61, 0x0f, 0x45, 0xd4, 0xbe, 0x65, 0x14, 0xf0, 0x05, 0x7b, 0xf1, 0x63, 0x98, 0x8e,
+ 0x77, 0xff, 0xee, 0xfb, 0xac, 0x14, 0x20, 0xaf, 0x86, 0xcd, 0x0e, 0x25, 0xa7, 0xfa, 0x0a, 0x64,
+ 0x0f, 0x3c, 0xc2, 0xac, 0x1a, 0xe9, 0x5e, 0x7d, 0x6a, 0xf4, 0x7b, 0xb0, 0x20, 0x11, 0x87, 0xc4,
+ 0xa7, 0x27, 0xd4, 0xc4, 0x21, 0xe5, 0x6c, 0x30, 0x7a, 0x0d, 0x0a, 0x0f, 0x22, 0xc7, 0x11, 0x25,
+ 0xa3, 0xac, 0x35, 0x14, 0x77, 0x71, 0xd7, 0x03, 0x70, 0xb7, 0x20, 0xb7, 0x4b, 0x3b, 0xc4, 0x0f,
+ 0xe8, 0x09, 0x25, 0xfe, 0x00, 0xd0, 0x1e, 0xe4, 0xfb, 0x0b, 0x82, 0x8a, 0x90, 0x51, 0x29, 0x94,
+ 0xe5, 0x9c, 0x35, 0x12, 0x13, 0x2d, 0x03, 0xf8, 0x98, 0x59, 0xdc, 0xa5, 0x9f, 0x13, 0x5f, 0x56,
+ 0x27, 0x6f, 0xf4, 0xcd, 0xe8, 0xff, 0x85, 0xb9, 0x83, 0x10, 0x87, 0xa4, 0xca, 0x5d, 0x97, 0x86,
+ 0x2e, 0x61, 0xe1, 0x80, 0x25, 0xef, 0xc0, 0xb5, 0x0a, 0x76, 0x30, 0x33, 0x47, 0x43, 0x4f, 0x20,
+ 0xa3, 0xee, 0xea, 0x5b, 0xde, 0x4b, 0xb4, 0x0a, 0x05, 0x09, 0xc0, 0x01, 0x69, 0x5a, 0x84, 0x71,
+ 0x57, 0x2a, 0x9f, 0x31, 0xf2, 0x02, 0x83, 0x03, 0xb2, 0x2b, 0xe6, 0xf4, 0x75, 0x98, 0x8e, 0x3f,
+ 0x2a, 0xa8, 0x00, 0x29, 0x87, 0xcb, 0x35, 0x26, 0x8d, 0x94, 0xc3, 0x85, 0x6d, 0x53, 0xc9, 0x3b,
+ 0x69, 0xa4, 0x6c, 0xaa, 0x2f, 0xc1, 0x94, 0x0c, 0x11, 0x7a, 0x62, 0x3e, 0x4d, 0xf2, 0xc5, 0x86,
+ 0xfe, 0x2a, 0x05, 0xb3, 0xd2, 0xff, 0x88, 0x84, 0xd8, 0xc2, 0x21, 0x46, 0x2b, 0x90, 0xb3, 0x48,
+ 0x60, 0xfa, 0xd4, 0x13, 0xd5, 0x57, 0xe8, 0xfe, 0x29, 0xb4, 0x2f, 0x10, 0x8c, 0xbb, 0xcd, 0x88,
+ 0xd1, 0x30, 0x28, 0xa6, 0x56, 0xd2, 0xeb, 0xb9, 0xf2, 0xfa, 0x88, 0xd3, 0x29, 0x17, 0x79, 0xca,
+ 0x68, 0x68, 0x80, 0x95, 0x0c, 0x03, 0x84, 0x60, 0x52, 0xec, 0x54, 0xed, 0x51, 0x8e, 0x45, 0x45,
+ 0x2d, 0x1a, 0x78, 0x0e, 0xee, 0x16, 0x27, 0xe5, 0x74, 0x62, 0x0a, 0x34, 0xc3, 0x2e, 0x29, 0x4e,
+ 0xc5, 0x68, 0x31, 0x46, 0xd7, 0x61, 0x3a, 0xe8, 0xba, 0xc7, 0xdc, 0x29, 0x4e, 0xcb, 0x59, 0x65,
+ 0xa1, 0x79, 0x48, 0x47, 0x3e, 0x2d, 0x66, 0xe4, 0xa4, 0x18, 0xa2, 0x7f, 0x41, 0x36, 0xf2, 0x69,
+ 0xd3, 0xc6, 0x81, 0x5d, 0xcc, 0xc6, 0xc4, 0x91, 0x4f, 0xf7, 0x70, 0x60, 0xa3, 0x03, 0xb8, 0x96,
+ 0xa8, 0x6f, 0xf6, 0x3e, 0xcd, 0x3f, 0xcc, 0xbd, 0xd1, 0xb7, 0x79, 0x2e, 0x81, 0xa9, 0x09, 0xfd,
+ 0x19, 0xcc, 0xf4, 0x36, 0x7d, 0x75, 0xf6, 0xd1, 0x22, 0x64, 0xc9, 0x73, 0x8f, 0x33, 0xd2, 0x3b,
+ 0xbd, 0x3d, 0x5b, 0x1e, 0x6c, 0x87, 0xe2, 0x80, 0x04, 0xc5, 0xf4, 0x4a, 0x5a, 0xa8, 0x55, 0xa6,
+ 0xfe, 0xa5, 0x06, 0x53, 0x87, 0xd8, 0x89, 0xfe, 0x09, 0x8d, 0xe8, 0x8f, 0x34, 0xcc, 0x48, 0x2d,
+ 0xb2, 0x89, 0x1c, 0x42, 0xae, 0xcd, 0xf8, 0x29, 0x6b, 0x9e, 0xef, 0x35, 0x57, 0xde, 0x1a, 0xc1,
+ 0xd9, 0x0b, 0x2f, 0xd5, 0x44, 0xac, 0xcc, 0xd9, 0xde, 0x84, 0x01, 0xed, 0x9e, 0x85, 0x8e, 0x60,
+ 0x36, 0x62, 0xfd, 0xcc, 0xb1, 0xda, 0xf7, 0xc6, 0x66, 0x7e, 0xca, 0xda, 0xfd, 0xdc, 0xf9, 0xa8,
+ 0xcf, 0x5e, 0xfc, 0x4a, 0x03, 0x38, 0x5f, 0xfa, 0x5d, 0x93, 0x5a, 0x49, 0x2a, 0x1d, 0x6b, 0xbc,
+ 0x37, 0xce, 0xbd, 0x48, 0x2e, 0x9f, 0x3a, 0x17, 0x8b, 0x2f, 0x34, 0xc8, 0xf7, 0x4b, 0xfe, 0xfb,
+ 0x0b, 0x5d, 0xc9, 0x03, 0x74, 0x44, 0x3a, 0xe3, 0x56, 0xa2, 0x03, 0x3c, 0x22, 0x7e, 0xdb, 0x21,
+ 0x06, 0xe7, 0x83, 0xbe, 0x85, 0x4b, 0x90, 0xdb, 0xb7, 0x08, 0x0b, 0x69, 0xd8, 0x15, 0xbd, 0xa1,
+ 0x00, 0x29, 0xda, 0x56, 0x88, 0x14, 0x6d, 0xeb, 0x37, 0x60, 0xf6, 0x21, 0xef, 0x10, 0x9f, 0x89,
+ 0x0f, 0xab, 0x02, 0xb4, 0x7a, 0x80, 0x56, 0x5b, 0x5f, 0x85, 0x7c, 0x95, 0xb3, 0x80, 0xb0, 0x20,
+ 0x0a, 0x06, 0x37, 0x97, 0xaf, 0x35, 0x98, 0x7c, 0xcc, 0x43, 0x82, 0xb6, 0x61, 0x4a, 0x0a, 0x54,
+ 0x19, 0x5a, 0x1d, 0xe7, 0x6c, 0x18, 0x71, 0x88, 0xa0, 0xf6, 0x03, 0x42, 0xe2, 0xe4, 0xe4, 0x8d,
+ 0xd8, 0xe8, 0xef, 0xc0, 0xe9, 0xb7, 0xea, 0xc0, 0xfa, 0xb7, 0x1a, 0x64, 0x85, 0x38, 0x79, 0x39,
+ 0x3e, 0xbc, 0x28, 0x70, 0x7d, 0xdc, 0xc3, 0x3b, 0x5c, 0xe4, 0xee, 0x65, 0x91, 0x77, 0xc7, 0x7f,
+ 0x68, 0x9d, 0x0b, 0x5d, 0x83, 0x82, 0xd0, 0x59, 0xa5, 0x9e, 0x4d, 0xfc, 0x90, 0x3c, 0x1f, 0x54,
+ 0xd3, 0x9b, 0x30, 0xf3, 0x38, 0x72, 0x9c, 0x61, 0x0d, 0xfa, 0x2e, 0x20, 0xf9, 0x86, 0xd8, 0x89,
+ 0x42, 0xfb, 0x80, 0xb6, 0x18, 0x0e, 0x23, 0x9f, 0x0c, 0xc0, 0xae, 0xc3, 0x7c, 0x85, 0x32, 0x8b,
+ 0xb2, 0xd6, 0x28, 0xe4, 0x2f, 0x1a, 0xe4, 0x84, 0xc2, 0x3a, 0xee, 0x3a, 0x1c, 0x5b, 0xe8, 0x19,
+ 0xcc, 0x31, 0x1e, 0x92, 0xa6, 0xd9, 0xeb, 0xc8, 0x2a, 0xad, 0xa5, 0x11, 0xdb, 0xbf, 0xd4, 0xf2,
+ 0x8d, 0x82, 0xa0, 0xe9, 0xeb, 0xeb, 0xb7, 0x60, 0x96, 0x78, 0x36, 0x71, 0x89, 0x8f, 0x9d, 0x66,
+ 0x9b, 0x74, 0x55, 0xb6, 0xf3, 0xbd, 0x49, 0x71, 0x14, 0x3f, 0x81, 0x02, 0x61, 0x92, 0x99, 0x58,
+ 0x4d, 0x41, 0x30, 0xe6, 0xe3, 0xef, 0x62, 0x8e, 0x8d, 0xd9, 0x1e, 0x89, 0x70, 0xe8, 0xaf, 0x34,
+ 0x58, 0xb8, 0x24, 0xaf, 0xee, 0x73, 0x7e, 0xf2, 0xd7, 0x6d, 0x76, 0x11, 0xb2, 0x1e, 0x0f, 0xa8,
+ 0x6c, 0xf4, 0xf1, 0x93, 0xa1, 0x67, 0xa3, 0x1a, 0xcc, 0xe0, 0x28, 0xb4, 0x9b, 0x1e, 0x0e, 0x6d,
+ 0xd9, 0x81, 0x46, 0x2f, 0x17, 0x7f, 0x12, 0xea, 0x38, 0xb4, 0xab, 0x76, 0xc4, 0xda, 0x46, 0x56,
+ 0x10, 0x08, 0x53, 0xb7, 0x61, 0xee, 0x92, 0x13, 0xfd, 0x1b, 0x66, 0xc4, 0x83, 0x9e, 0xb2, 0x56,
+ 0x73, 0x53, 0xd5, 0x3a, 0xab, 0x26, 0x36, 0xfb, 0x9d, 0x65, 0x55, 0x81, 0xc4, 0x59, 0xee, 0x77,
+ 0x6e, 0xa9, 0x77, 0x5d, 0xe2, 0xdc, 0xd2, 0xff, 0x03, 0x93, 0x55, 0x75, 0x5b, 0xae, 0x38, 0x46,
+ 0x3a, 0xc0, 0x47, 0x27, 0x27, 0xc4, 0x0c, 0x65, 0xdb, 0xbf, 0x1a, 0x73, 0x1b, 0x66, 0x1b, 0xb5,
+ 0x27, 0x51, 0xe8, 0x45, 0x2a, 0xfd, 0x57, 0xc3, 0x56, 0x21, 0xdf, 0xa8, 0xc9, 0x93, 0x3e, 0x0c,
+ 0x75, 0x0b, 0x72, 0x8d, 0xda, 0xc1, 0x29, 0xf6, 0x86, 0x81, 0xd6, 0x61, 0x3e, 0x06, 0x55, 0x1d,
+ 0x4c, 0xdd, 0x61, 0xc8, 0x12, 0x5c, 0x6f, 0xd4, 0x9e, 0x32, 0x8b, 0x38, 0xa4, 0x25, 0x4a, 0x3b,
+ 0x0a, 0x7f, 0x0f, 0x16, 0x1a, 0xb5, 0xdd, 0x18, 0xcd, 0xfd, 0x43, 0x71, 0x81, 0x86, 0xa0, 0xcb,
+ 0xb0, 0xd8, 0xa8, 0xf5, 0xee, 0xf7, 0x2e, 0xf1, 0x69, 0x47, 0xfe, 0x04, 0x18, 0x12, 0x53, 0xf9,
+ 0x3e, 0xf5, 0xe3, 0xd9, 0xb2, 0xf6, 0xf2, 0x6c, 0x59, 0xfb, 0xf9, 0x6c, 0x59, 0x7b, 0xf1, 0x7a,
+ 0x79, 0xe2, 0xe5, 0xeb, 0xe5, 0x89, 0x57, 0xaf, 0x97, 0x27, 0xe0, 0xa6, 0xc9, 0xdd, 0xe1, 0x27,
+ 0xa6, 0x92, 0xab, 0xca, 0x89, 0xba, 0xf8, 0xf5, 0x5d, 0xd7, 0x1a, 0x9f, 0xb6, 0x68, 0x68, 0x47,
+ 0xc7, 0x25, 0x93, 0xbb, 0x1b, 0x26, 0x0f, 0x5c, 0x1e, 0x6c, 0xf8, 0xc4, 0xc1, 0x5d, 0xe2, 0x6f,
+ 0x74, 0xca, 0xbd, 0xa1, 0x69, 0x63, 0xca, 0x82, 0x8d, 0xa1, 0xbf, 0xeb, 0xdf, 0x8f, 0xed, 0xc4,
+ 0xfc, 0x26, 0x95, 0xae, 0x57, 0xab, 0xdf, 0xa5, 0x96, 0xea, 0x89, 0x9c, 0xaa, 0x90, 0x13, 0xaf,
+ 0x5e, 0x3a, 0x54, 0xa8, 0x9f, 0xce, 0xfd, 0x47, 0xc2, 0x7f, 0x14, 0xfb, 0x8f, 0x12, 0xff, 0x59,
+ 0xea, 0xce, 0x50, 0xff, 0xd1, 0xc3, 0x7a, 0x25, 0x69, 0xe5, 0xbf, 0xa5, 0x56, 0x12, 0xec, 0xf6,
+ 0xb6, 0x00, 0x6f, 0x6f, 0xc7, 0xe8, 0xed, 0xed, 0x04, 0x7e, 0x3c, 0x2d, 0xff, 0x75, 0xd8, 0xfa,
+ 0x33, 0x00, 0x00, 0xff, 0xff, 0x88, 0xb9, 0x8c, 0xd5, 0xa3, 0x10, 0x00, 0x00,
+}
+
+func (m *Fee) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *Fee) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *Fee) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.AssetId != nil {
+ {
+ size, err := m.AssetId.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintCrypto(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.Amount != nil {
+ {
+ size, err := m.Amount.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintCrypto(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *Address) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *Address) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *Address) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.AltBech32M) > 0 {
+ i -= len(m.AltBech32M)
+ copy(dAtA[i:], m.AltBech32M)
+ i = encodeVarintCrypto(dAtA, i, uint64(len(m.AltBech32M)))
+ i--
+ dAtA[i] = 0x12
+ }
+ if len(m.Inner) > 0 {
+ i -= len(m.Inner)
+ copy(dAtA[i:], m.Inner)
+ i = encodeVarintCrypto(dAtA, i, uint64(len(m.Inner)))
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *AddressView) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *AddressView) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *AddressView) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.AddressView != nil {
+ {
+ size := m.AddressView.Size()
+ i -= size
+ if _, err := m.AddressView.MarshalTo(dAtA[i:]); err != nil {
+ return 0, err
+ }
+ }
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *AddressView_Visible_) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *AddressView_Visible_) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.Visible != nil {
+ {
+ size, err := m.Visible.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintCrypto(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+func (m *AddressView_Opaque_) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *AddressView_Opaque_) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.Opaque != nil {
+ {
+ size, err := m.Opaque.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintCrypto(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ return len(dAtA) - i, nil
+}
+func (m *AddressView_Visible) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *AddressView_Visible) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *AddressView_Visible) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.AccountGroupId != nil {
+ {
+ size, err := m.AccountGroupId.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintCrypto(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1a
+ }
+ if m.Index != nil {
+ {
+ size, err := m.Index.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintCrypto(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.Address != nil {
+ {
+ size, err := m.Address.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintCrypto(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *AddressView_Opaque) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *AddressView_Opaque) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *AddressView_Opaque) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Address != nil {
+ {
+ size, err := m.Address.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintCrypto(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *SpendKey) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *SpendKey) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *SpendKey) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.Inner) > 0 {
+ i -= len(m.Inner)
+ copy(dAtA[i:], m.Inner)
+ i = encodeVarintCrypto(dAtA, i, uint64(len(m.Inner)))
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *SpendVerificationKey) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *SpendVerificationKey) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *SpendVerificationKey) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.Inner) > 0 {
+ i -= len(m.Inner)
+ copy(dAtA[i:], m.Inner)
+ i = encodeVarintCrypto(dAtA, i, uint64(len(m.Inner)))
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *FullViewingKey) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *FullViewingKey) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *FullViewingKey) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.Inner) > 0 {
+ i -= len(m.Inner)
+ copy(dAtA[i:], m.Inner)
+ i = encodeVarintCrypto(dAtA, i, uint64(len(m.Inner)))
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *AccountGroupId) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *AccountGroupId) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *AccountGroupId) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.Inner) > 0 {
+ i -= len(m.Inner)
+ copy(dAtA[i:], m.Inner)
+ i = encodeVarintCrypto(dAtA, i, uint64(len(m.Inner)))
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *Diversifier) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *Diversifier) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *Diversifier) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.Inner) > 0 {
+ i -= len(m.Inner)
+ copy(dAtA[i:], m.Inner)
+ i = encodeVarintCrypto(dAtA, i, uint64(len(m.Inner)))
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *AddressIndex) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *AddressIndex) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *AddressIndex) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.Randomizer) > 0 {
+ i -= len(m.Randomizer)
+ copy(dAtA[i:], m.Randomizer)
+ i = encodeVarintCrypto(dAtA, i, uint64(len(m.Randomizer)))
+ i--
+ dAtA[i] = 0x1a
+ }
+ if m.Account != 0 {
+ i = encodeVarintCrypto(dAtA, i, uint64(m.Account))
+ i--
+ dAtA[i] = 0x10
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *StateCommitment) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *StateCommitment) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *StateCommitment) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.Inner) > 0 {
+ i -= len(m.Inner)
+ copy(dAtA[i:], m.Inner)
+ i = encodeVarintCrypto(dAtA, i, uint64(len(m.Inner)))
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *BalanceCommitment) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *BalanceCommitment) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *BalanceCommitment) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.Inner) > 0 {
+ i -= len(m.Inner)
+ copy(dAtA[i:], m.Inner)
+ i = encodeVarintCrypto(dAtA, i, uint64(len(m.Inner)))
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *AssetId) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *AssetId) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *AssetId) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.AltBaseDenom) > 0 {
+ i -= len(m.AltBaseDenom)
+ copy(dAtA[i:], m.AltBaseDenom)
+ i = encodeVarintCrypto(dAtA, i, uint64(len(m.AltBaseDenom)))
+ i--
+ dAtA[i] = 0x1a
+ }
+ if len(m.AltBech32M) > 0 {
+ i -= len(m.AltBech32M)
+ copy(dAtA[i:], m.AltBech32M)
+ i = encodeVarintCrypto(dAtA, i, uint64(len(m.AltBech32M)))
+ i--
+ dAtA[i] = 0x12
+ }
+ if len(m.Inner) > 0 {
+ i -= len(m.Inner)
+ copy(dAtA[i:], m.Inner)
+ i = encodeVarintCrypto(dAtA, i, uint64(len(m.Inner)))
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *Amount) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *Amount) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *Amount) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Hi != 0 {
+ i = encodeVarintCrypto(dAtA, i, uint64(m.Hi))
+ i--
+ dAtA[i] = 0x10
+ }
+ if m.Lo != 0 {
+ i = encodeVarintCrypto(dAtA, i, uint64(m.Lo))
+ i--
+ dAtA[i] = 0x8
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *Denom) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *Denom) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *Denom) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.Denom) > 0 {
+ i -= len(m.Denom)
+ copy(dAtA[i:], m.Denom)
+ i = encodeVarintCrypto(dAtA, i, uint64(len(m.Denom)))
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *DenomMetadata) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *DenomMetadata) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *DenomMetadata) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.PenumbraAssetId != nil {
+ {
+ size, err := m.PenumbraAssetId.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintCrypto(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x7c
+ i--
+ dAtA[i] = 0x82
+ }
+ if len(m.UriHash) > 0 {
+ i -= len(m.UriHash)
+ copy(dAtA[i:], m.UriHash)
+ i = encodeVarintCrypto(dAtA, i, uint64(len(m.UriHash)))
+ i--
+ dAtA[i] = 0x42
+ }
+ if len(m.Uri) > 0 {
+ i -= len(m.Uri)
+ copy(dAtA[i:], m.Uri)
+ i = encodeVarintCrypto(dAtA, i, uint64(len(m.Uri)))
+ i--
+ dAtA[i] = 0x3a
+ }
+ if len(m.Symbol) > 0 {
+ i -= len(m.Symbol)
+ copy(dAtA[i:], m.Symbol)
+ i = encodeVarintCrypto(dAtA, i, uint64(len(m.Symbol)))
+ i--
+ dAtA[i] = 0x32
+ }
+ if len(m.Name) > 0 {
+ i -= len(m.Name)
+ copy(dAtA[i:], m.Name)
+ i = encodeVarintCrypto(dAtA, i, uint64(len(m.Name)))
+ i--
+ dAtA[i] = 0x2a
+ }
+ if len(m.Display) > 0 {
+ i -= len(m.Display)
+ copy(dAtA[i:], m.Display)
+ i = encodeVarintCrypto(dAtA, i, uint64(len(m.Display)))
+ i--
+ dAtA[i] = 0x22
+ }
+ if len(m.Base) > 0 {
+ i -= len(m.Base)
+ copy(dAtA[i:], m.Base)
+ i = encodeVarintCrypto(dAtA, i, uint64(len(m.Base)))
+ i--
+ dAtA[i] = 0x1a
+ }
+ if len(m.DenomUnits) > 0 {
+ for iNdEx := len(m.DenomUnits) - 1; iNdEx >= 0; iNdEx-- {
+ {
+ size, err := m.DenomUnits[iNdEx].MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintCrypto(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ }
+ if len(m.Description) > 0 {
+ i -= len(m.Description)
+ copy(dAtA[i:], m.Description)
+ i = encodeVarintCrypto(dAtA, i, uint64(len(m.Description)))
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *DenomUnit) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *DenomUnit) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *DenomUnit) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.Aliases) > 0 {
+ for iNdEx := len(m.Aliases) - 1; iNdEx >= 0; iNdEx-- {
+ i -= len(m.Aliases[iNdEx])
+ copy(dAtA[i:], m.Aliases[iNdEx])
+ i = encodeVarintCrypto(dAtA, i, uint64(len(m.Aliases[iNdEx])))
+ i--
+ dAtA[i] = 0x1a
+ }
+ }
+ if m.Exponent != 0 {
+ i = encodeVarintCrypto(dAtA, i, uint64(m.Exponent))
+ i--
+ dAtA[i] = 0x10
+ }
+ if len(m.Denom) > 0 {
+ i -= len(m.Denom)
+ copy(dAtA[i:], m.Denom)
+ i = encodeVarintCrypto(dAtA, i, uint64(len(m.Denom)))
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *Value) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *Value) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *Value) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.AssetId != nil {
+ {
+ size, err := m.AssetId.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintCrypto(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.Amount != nil {
+ {
+ size, err := m.Amount.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintCrypto(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *ValueView) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *ValueView) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ValueView) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.ValueView != nil {
+ {
+ size := m.ValueView.Size()
+ i -= size
+ if _, err := m.ValueView.MarshalTo(dAtA[i:]); err != nil {
+ return 0, err
+ }
+ }
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *ValueView_KnownDenom_) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ValueView_KnownDenom_) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.KnownDenom != nil {
+ {
+ size, err := m.KnownDenom.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintCrypto(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+func (m *ValueView_UnknownDenom_) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ValueView_UnknownDenom_) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.UnknownDenom != nil {
+ {
+ size, err := m.UnknownDenom.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintCrypto(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ return len(dAtA) - i, nil
+}
+func (m *ValueView_KnownDenom) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *ValueView_KnownDenom) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ValueView_KnownDenom) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Denom != nil {
+ {
+ size, err := m.Denom.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintCrypto(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.Amount != nil {
+ {
+ size, err := m.Amount.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintCrypto(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *ValueView_UnknownDenom) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *ValueView_UnknownDenom) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ValueView_UnknownDenom) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.AssetId != nil {
+ {
+ size, err := m.AssetId.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintCrypto(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.Amount != nil {
+ {
+ size, err := m.Amount.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintCrypto(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *MerkleRoot) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *MerkleRoot) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *MerkleRoot) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.Inner) > 0 {
+ i -= len(m.Inner)
+ copy(dAtA[i:], m.Inner)
+ i = encodeVarintCrypto(dAtA, i, uint64(len(m.Inner)))
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *IdentityKey) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *IdentityKey) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *IdentityKey) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.Ik) > 0 {
+ i -= len(m.Ik)
+ copy(dAtA[i:], m.Ik)
+ i = encodeVarintCrypto(dAtA, i, uint64(len(m.Ik)))
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *GovernanceKey) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *GovernanceKey) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *GovernanceKey) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.Gk) > 0 {
+ i -= len(m.Gk)
+ copy(dAtA[i:], m.Gk)
+ i = encodeVarintCrypto(dAtA, i, uint64(len(m.Gk)))
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *ConsensusKey) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *ConsensusKey) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ConsensusKey) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.Inner) > 0 {
+ i -= len(m.Inner)
+ copy(dAtA[i:], m.Inner)
+ i = encodeVarintCrypto(dAtA, i, uint64(len(m.Inner)))
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *Note) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *Note) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *Note) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Address != nil {
+ {
+ size, err := m.Address.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintCrypto(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1a
+ }
+ if len(m.Rseed) > 0 {
+ i -= len(m.Rseed)
+ copy(dAtA[i:], m.Rseed)
+ i = encodeVarintCrypto(dAtA, i, uint64(len(m.Rseed)))
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.Value != nil {
+ {
+ size, err := m.Value.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintCrypto(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *NoteView) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *NoteView) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *NoteView) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Address != nil {
+ {
+ size, err := m.Address.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintCrypto(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1a
+ }
+ if len(m.Rseed) > 0 {
+ i -= len(m.Rseed)
+ copy(dAtA[i:], m.Rseed)
+ i = encodeVarintCrypto(dAtA, i, uint64(len(m.Rseed)))
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.Value != nil {
+ {
+ size, err := m.Value.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintCrypto(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *NoteCiphertext) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *NoteCiphertext) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *NoteCiphertext) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.Inner) > 0 {
+ i -= len(m.Inner)
+ copy(dAtA[i:], m.Inner)
+ i = encodeVarintCrypto(dAtA, i, uint64(len(m.Inner)))
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *Nullifier) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *Nullifier) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *Nullifier) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.Inner) > 0 {
+ i -= len(m.Inner)
+ copy(dAtA[i:], m.Inner)
+ i = encodeVarintCrypto(dAtA, i, uint64(len(m.Inner)))
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *SpendAuthSignature) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *SpendAuthSignature) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *SpendAuthSignature) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.Inner) > 0 {
+ i -= len(m.Inner)
+ copy(dAtA[i:], m.Inner)
+ i = encodeVarintCrypto(dAtA, i, uint64(len(m.Inner)))
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *BindingSignature) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *BindingSignature) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *BindingSignature) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.Inner) > 0 {
+ i -= len(m.Inner)
+ copy(dAtA[i:], m.Inner)
+ i = encodeVarintCrypto(dAtA, i, uint64(len(m.Inner)))
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *NotePayload) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *NotePayload) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *NotePayload) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.EncryptedNote != nil {
+ {
+ size, err := m.EncryptedNote.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintCrypto(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1a
+ }
+ if len(m.EphemeralKey) > 0 {
+ i -= len(m.EphemeralKey)
+ copy(dAtA[i:], m.EphemeralKey)
+ i = encodeVarintCrypto(dAtA, i, uint64(len(m.EphemeralKey)))
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.NoteCommitment != nil {
+ {
+ size, err := m.NoteCommitment.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintCrypto(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *StateCommitmentProof) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *StateCommitmentProof) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *StateCommitmentProof) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.AuthPath) > 0 {
+ for iNdEx := len(m.AuthPath) - 1; iNdEx >= 0; iNdEx-- {
+ {
+ size, err := m.AuthPath[iNdEx].MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintCrypto(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1a
+ }
+ }
+ if m.Position != 0 {
+ i = encodeVarintCrypto(dAtA, i, uint64(m.Position))
+ i--
+ dAtA[i] = 0x10
+ }
+ if m.NoteCommitment != nil {
+ {
+ size, err := m.NoteCommitment.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintCrypto(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *MerklePathChunk) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *MerklePathChunk) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *MerklePathChunk) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.Sibling_3) > 0 {
+ i -= len(m.Sibling_3)
+ copy(dAtA[i:], m.Sibling_3)
+ i = encodeVarintCrypto(dAtA, i, uint64(len(m.Sibling_3)))
+ i--
+ dAtA[i] = 0x1a
+ }
+ if len(m.Sibling_2) > 0 {
+ i -= len(m.Sibling_2)
+ copy(dAtA[i:], m.Sibling_2)
+ i = encodeVarintCrypto(dAtA, i, uint64(len(m.Sibling_2)))
+ i--
+ dAtA[i] = 0x12
+ }
+ if len(m.Sibling_1) > 0 {
+ i -= len(m.Sibling_1)
+ copy(dAtA[i:], m.Sibling_1)
+ i = encodeVarintCrypto(dAtA, i, uint64(len(m.Sibling_1)))
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *Clue) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *Clue) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *Clue) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.Inner) > 0 {
+ i -= len(m.Inner)
+ copy(dAtA[i:], m.Inner)
+ i = encodeVarintCrypto(dAtA, i, uint64(len(m.Inner)))
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *EffectHash) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *EffectHash) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *EffectHash) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.Inner) > 0 {
+ i -= len(m.Inner)
+ copy(dAtA[i:], m.Inner)
+ i = encodeVarintCrypto(dAtA, i, uint64(len(m.Inner)))
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *ZKOutputProof) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *ZKOutputProof) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ZKOutputProof) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.Inner) > 0 {
+ i -= len(m.Inner)
+ copy(dAtA[i:], m.Inner)
+ i = encodeVarintCrypto(dAtA, i, uint64(len(m.Inner)))
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *ZKSpendProof) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *ZKSpendProof) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ZKSpendProof) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.Inner) > 0 {
+ i -= len(m.Inner)
+ copy(dAtA[i:], m.Inner)
+ i = encodeVarintCrypto(dAtA, i, uint64(len(m.Inner)))
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *ZKSwapProof) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *ZKSwapProof) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ZKSwapProof) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.Inner) > 0 {
+ i -= len(m.Inner)
+ copy(dAtA[i:], m.Inner)
+ i = encodeVarintCrypto(dAtA, i, uint64(len(m.Inner)))
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *ZKSwapClaimProof) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *ZKSwapClaimProof) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ZKSwapClaimProof) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.Inner) > 0 {
+ i -= len(m.Inner)
+ copy(dAtA[i:], m.Inner)
+ i = encodeVarintCrypto(dAtA, i, uint64(len(m.Inner)))
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *ZKUndelegateClaimProof) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *ZKUndelegateClaimProof) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ZKUndelegateClaimProof) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.Inner) > 0 {
+ i -= len(m.Inner)
+ copy(dAtA[i:], m.Inner)
+ i = encodeVarintCrypto(dAtA, i, uint64(len(m.Inner)))
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *ZKDelegatorVoteProof) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *ZKDelegatorVoteProof) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ZKDelegatorVoteProof) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.Inner) > 0 {
+ i -= len(m.Inner)
+ copy(dAtA[i:], m.Inner)
+ i = encodeVarintCrypto(dAtA, i, uint64(len(m.Inner)))
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *ZKNullifierDerivationProof) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *ZKNullifierDerivationProof) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ZKNullifierDerivationProof) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.Inner) > 0 {
+ i -= len(m.Inner)
+ copy(dAtA[i:], m.Inner)
+ i = encodeVarintCrypto(dAtA, i, uint64(len(m.Inner)))
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func encodeVarintCrypto(dAtA []byte, offset int, v uint64) int {
+ offset -= sovCrypto(v)
+ base := offset
+ for v >= 1<<7 {
+ dAtA[offset] = uint8(v&0x7f | 0x80)
+ v >>= 7
+ offset++
+ }
+ dAtA[offset] = uint8(v)
+ return base
+}
+func (m *Fee) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Amount != nil {
+ l = m.Amount.Size()
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ if m.AssetId != nil {
+ l = m.AssetId.Size()
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ return n
+}
+
+func (m *Address) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ l = len(m.Inner)
+ if l > 0 {
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ l = len(m.AltBech32M)
+ if l > 0 {
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ return n
+}
+
+func (m *AddressView) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.AddressView != nil {
+ n += m.AddressView.Size()
+ }
+ return n
+}
+
+func (m *AddressView_Visible_) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Visible != nil {
+ l = m.Visible.Size()
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ return n
+}
+func (m *AddressView_Opaque_) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Opaque != nil {
+ l = m.Opaque.Size()
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ return n
+}
+func (m *AddressView_Visible) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Address != nil {
+ l = m.Address.Size()
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ if m.Index != nil {
+ l = m.Index.Size()
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ if m.AccountGroupId != nil {
+ l = m.AccountGroupId.Size()
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ return n
+}
+
+func (m *AddressView_Opaque) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Address != nil {
+ l = m.Address.Size()
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ return n
+}
+
+func (m *SpendKey) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ l = len(m.Inner)
+ if l > 0 {
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ return n
+}
+
+func (m *SpendVerificationKey) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ l = len(m.Inner)
+ if l > 0 {
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ return n
+}
+
+func (m *FullViewingKey) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ l = len(m.Inner)
+ if l > 0 {
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ return n
+}
+
+func (m *AccountGroupId) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ l = len(m.Inner)
+ if l > 0 {
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ return n
+}
+
+func (m *Diversifier) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ l = len(m.Inner)
+ if l > 0 {
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ return n
+}
+
+func (m *AddressIndex) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Account != 0 {
+ n += 1 + sovCrypto(uint64(m.Account))
+ }
+ l = len(m.Randomizer)
+ if l > 0 {
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ return n
+}
+
+func (m *StateCommitment) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ l = len(m.Inner)
+ if l > 0 {
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ return n
+}
+
+func (m *BalanceCommitment) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ l = len(m.Inner)
+ if l > 0 {
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ return n
+}
+
+func (m *AssetId) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ l = len(m.Inner)
+ if l > 0 {
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ l = len(m.AltBech32M)
+ if l > 0 {
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ l = len(m.AltBaseDenom)
+ if l > 0 {
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ return n
+}
+
+func (m *Amount) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Lo != 0 {
+ n += 1 + sovCrypto(uint64(m.Lo))
+ }
+ if m.Hi != 0 {
+ n += 1 + sovCrypto(uint64(m.Hi))
+ }
+ return n
+}
+
+func (m *Denom) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ l = len(m.Denom)
+ if l > 0 {
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ return n
+}
+
+func (m *DenomMetadata) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ l = len(m.Description)
+ if l > 0 {
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ if len(m.DenomUnits) > 0 {
+ for _, e := range m.DenomUnits {
+ l = e.Size()
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ }
+ l = len(m.Base)
+ if l > 0 {
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ l = len(m.Display)
+ if l > 0 {
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ l = len(m.Name)
+ if l > 0 {
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ l = len(m.Symbol)
+ if l > 0 {
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ l = len(m.Uri)
+ if l > 0 {
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ l = len(m.UriHash)
+ if l > 0 {
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ if m.PenumbraAssetId != nil {
+ l = m.PenumbraAssetId.Size()
+ n += 2 + l + sovCrypto(uint64(l))
+ }
+ return n
+}
+
+func (m *DenomUnit) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ l = len(m.Denom)
+ if l > 0 {
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ if m.Exponent != 0 {
+ n += 1 + sovCrypto(uint64(m.Exponent))
+ }
+ if len(m.Aliases) > 0 {
+ for _, s := range m.Aliases {
+ l = len(s)
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ }
+ return n
+}
+
+func (m *Value) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Amount != nil {
+ l = m.Amount.Size()
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ if m.AssetId != nil {
+ l = m.AssetId.Size()
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ return n
+}
+
+func (m *ValueView) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.ValueView != nil {
+ n += m.ValueView.Size()
+ }
+ return n
+}
+
+func (m *ValueView_KnownDenom_) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.KnownDenom != nil {
+ l = m.KnownDenom.Size()
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ return n
+}
+func (m *ValueView_UnknownDenom_) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.UnknownDenom != nil {
+ l = m.UnknownDenom.Size()
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ return n
+}
+func (m *ValueView_KnownDenom) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Amount != nil {
+ l = m.Amount.Size()
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ if m.Denom != nil {
+ l = m.Denom.Size()
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ return n
+}
+
+func (m *ValueView_UnknownDenom) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Amount != nil {
+ l = m.Amount.Size()
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ if m.AssetId != nil {
+ l = m.AssetId.Size()
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ return n
+}
+
+func (m *MerkleRoot) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ l = len(m.Inner)
+ if l > 0 {
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ return n
+}
+
+func (m *IdentityKey) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ l = len(m.Ik)
+ if l > 0 {
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ return n
+}
+
+func (m *GovernanceKey) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ l = len(m.Gk)
+ if l > 0 {
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ return n
+}
+
+func (m *ConsensusKey) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ l = len(m.Inner)
+ if l > 0 {
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ return n
+}
+
+func (m *Note) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Value != nil {
+ l = m.Value.Size()
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ l = len(m.Rseed)
+ if l > 0 {
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ if m.Address != nil {
+ l = m.Address.Size()
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ return n
+}
+
+func (m *NoteView) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Value != nil {
+ l = m.Value.Size()
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ l = len(m.Rseed)
+ if l > 0 {
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ if m.Address != nil {
+ l = m.Address.Size()
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ return n
+}
+
+func (m *NoteCiphertext) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ l = len(m.Inner)
+ if l > 0 {
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ return n
+}
+
+func (m *Nullifier) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ l = len(m.Inner)
+ if l > 0 {
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ return n
+}
+
+func (m *SpendAuthSignature) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ l = len(m.Inner)
+ if l > 0 {
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ return n
+}
+
+func (m *BindingSignature) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ l = len(m.Inner)
+ if l > 0 {
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ return n
+}
+
+func (m *NotePayload) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.NoteCommitment != nil {
+ l = m.NoteCommitment.Size()
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ l = len(m.EphemeralKey)
+ if l > 0 {
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ if m.EncryptedNote != nil {
+ l = m.EncryptedNote.Size()
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ return n
+}
+
+func (m *StateCommitmentProof) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.NoteCommitment != nil {
+ l = m.NoteCommitment.Size()
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ if m.Position != 0 {
+ n += 1 + sovCrypto(uint64(m.Position))
+ }
+ if len(m.AuthPath) > 0 {
+ for _, e := range m.AuthPath {
+ l = e.Size()
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ }
+ return n
+}
+
+func (m *MerklePathChunk) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ l = len(m.Sibling_1)
+ if l > 0 {
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ l = len(m.Sibling_2)
+ if l > 0 {
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ l = len(m.Sibling_3)
+ if l > 0 {
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ return n
+}
+
+func (m *Clue) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ l = len(m.Inner)
+ if l > 0 {
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ return n
+}
+
+func (m *EffectHash) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ l = len(m.Inner)
+ if l > 0 {
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ return n
+}
+
+func (m *ZKOutputProof) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ l = len(m.Inner)
+ if l > 0 {
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ return n
+}
+
+func (m *ZKSpendProof) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ l = len(m.Inner)
+ if l > 0 {
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ return n
+}
+
+func (m *ZKSwapProof) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ l = len(m.Inner)
+ if l > 0 {
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ return n
+}
+
+func (m *ZKSwapClaimProof) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ l = len(m.Inner)
+ if l > 0 {
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ return n
+}
+
+func (m *ZKUndelegateClaimProof) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ l = len(m.Inner)
+ if l > 0 {
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ return n
+}
+
+func (m *ZKDelegatorVoteProof) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ l = len(m.Inner)
+ if l > 0 {
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ return n
+}
+
+func (m *ZKNullifierDerivationProof) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ l = len(m.Inner)
+ if l > 0 {
+ n += 1 + l + sovCrypto(uint64(l))
+ }
+ return n
+}
+
+func sovCrypto(x uint64) (n int) {
+ return (math_bits.Len64(x|1) + 6) / 7
+}
+func sozCrypto(x uint64) (n int) {
+ return sovCrypto(uint64((x << 1) ^ uint64((int64(x) >> 63))))
+}
+func (m *Fee) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Fee: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Fee: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Amount", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Amount == nil {
+ m.Amount = &Amount{}
+ }
+ if err := m.Amount.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field AssetId", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.AssetId == nil {
+ m.AssetId = &AssetId{}
+ }
+ if err := m.AssetId.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipCrypto(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *Address) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Address: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Address: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Inner", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Inner = append(m.Inner[:0], dAtA[iNdEx:postIndex]...)
+ if m.Inner == nil {
+ m.Inner = []byte{}
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field AltBech32M", wireType)
+ }
+ var stringLen uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ stringLen |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ intStringLen := int(stringLen)
+ if intStringLen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + intStringLen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.AltBech32M = string(dAtA[iNdEx:postIndex])
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipCrypto(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *AddressView) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: AddressView: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: AddressView: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Visible", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &AddressView_Visible{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.AddressView = &AddressView_Visible_{v}
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Opaque", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &AddressView_Opaque{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.AddressView = &AddressView_Opaque_{v}
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipCrypto(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *AddressView_Visible) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Visible: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Visible: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Address", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Address == nil {
+ m.Address = &Address{}
+ }
+ if err := m.Address.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Index", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Index == nil {
+ m.Index = &AddressIndex{}
+ }
+ if err := m.Index.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field AccountGroupId", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.AccountGroupId == nil {
+ m.AccountGroupId = &AccountGroupId{}
+ }
+ if err := m.AccountGroupId.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipCrypto(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *AddressView_Opaque) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Opaque: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Opaque: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Address", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Address == nil {
+ m.Address = &Address{}
+ }
+ if err := m.Address.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipCrypto(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *SpendKey) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: SpendKey: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: SpendKey: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Inner", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Inner = append(m.Inner[:0], dAtA[iNdEx:postIndex]...)
+ if m.Inner == nil {
+ m.Inner = []byte{}
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipCrypto(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *SpendVerificationKey) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: SpendVerificationKey: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: SpendVerificationKey: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Inner", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Inner = append(m.Inner[:0], dAtA[iNdEx:postIndex]...)
+ if m.Inner == nil {
+ m.Inner = []byte{}
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipCrypto(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *FullViewingKey) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: FullViewingKey: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: FullViewingKey: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Inner", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Inner = append(m.Inner[:0], dAtA[iNdEx:postIndex]...)
+ if m.Inner == nil {
+ m.Inner = []byte{}
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipCrypto(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *AccountGroupId) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: AccountGroupId: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: AccountGroupId: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Inner", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Inner = append(m.Inner[:0], dAtA[iNdEx:postIndex]...)
+ if m.Inner == nil {
+ m.Inner = []byte{}
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipCrypto(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *Diversifier) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Diversifier: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Diversifier: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Inner", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Inner = append(m.Inner[:0], dAtA[iNdEx:postIndex]...)
+ if m.Inner == nil {
+ m.Inner = []byte{}
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipCrypto(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *AddressIndex) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: AddressIndex: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: AddressIndex: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 2:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Account", wireType)
+ }
+ m.Account = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.Account |= uint32(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Randomizer", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Randomizer = append(m.Randomizer[:0], dAtA[iNdEx:postIndex]...)
+ if m.Randomizer == nil {
+ m.Randomizer = []byte{}
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipCrypto(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *StateCommitment) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: StateCommitment: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: StateCommitment: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Inner", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Inner = append(m.Inner[:0], dAtA[iNdEx:postIndex]...)
+ if m.Inner == nil {
+ m.Inner = []byte{}
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipCrypto(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *BalanceCommitment) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: BalanceCommitment: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: BalanceCommitment: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Inner", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Inner = append(m.Inner[:0], dAtA[iNdEx:postIndex]...)
+ if m.Inner == nil {
+ m.Inner = []byte{}
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipCrypto(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *AssetId) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: AssetId: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: AssetId: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Inner", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Inner = append(m.Inner[:0], dAtA[iNdEx:postIndex]...)
+ if m.Inner == nil {
+ m.Inner = []byte{}
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field AltBech32M", wireType)
+ }
+ var stringLen uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ stringLen |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ intStringLen := int(stringLen)
+ if intStringLen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + intStringLen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.AltBech32M = string(dAtA[iNdEx:postIndex])
+ iNdEx = postIndex
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field AltBaseDenom", wireType)
+ }
+ var stringLen uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ stringLen |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ intStringLen := int(stringLen)
+ if intStringLen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + intStringLen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.AltBaseDenom = string(dAtA[iNdEx:postIndex])
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipCrypto(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *Amount) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Amount: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Amount: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Lo", wireType)
+ }
+ m.Lo = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.Lo |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 2:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Hi", wireType)
+ }
+ m.Hi = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.Hi |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ default:
+ iNdEx = preIndex
+ skippy, err := skipCrypto(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *Denom) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Denom: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Denom: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Denom", wireType)
+ }
+ var stringLen uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ stringLen |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ intStringLen := int(stringLen)
+ if intStringLen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + intStringLen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Denom = string(dAtA[iNdEx:postIndex])
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipCrypto(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *DenomMetadata) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: DenomMetadata: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: DenomMetadata: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Description", wireType)
+ }
+ var stringLen uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ stringLen |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ intStringLen := int(stringLen)
+ if intStringLen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + intStringLen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Description = string(dAtA[iNdEx:postIndex])
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field DenomUnits", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.DenomUnits = append(m.DenomUnits, &DenomUnit{})
+ if err := m.DenomUnits[len(m.DenomUnits)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Base", wireType)
+ }
+ var stringLen uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ stringLen |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ intStringLen := int(stringLen)
+ if intStringLen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + intStringLen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Base = string(dAtA[iNdEx:postIndex])
+ iNdEx = postIndex
+ case 4:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Display", wireType)
+ }
+ var stringLen uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ stringLen |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ intStringLen := int(stringLen)
+ if intStringLen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + intStringLen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Display = string(dAtA[iNdEx:postIndex])
+ iNdEx = postIndex
+ case 5:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Name", wireType)
+ }
+ var stringLen uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ stringLen |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ intStringLen := int(stringLen)
+ if intStringLen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + intStringLen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Name = string(dAtA[iNdEx:postIndex])
+ iNdEx = postIndex
+ case 6:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Symbol", wireType)
+ }
+ var stringLen uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ stringLen |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ intStringLen := int(stringLen)
+ if intStringLen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + intStringLen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Symbol = string(dAtA[iNdEx:postIndex])
+ iNdEx = postIndex
+ case 7:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Uri", wireType)
+ }
+ var stringLen uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ stringLen |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ intStringLen := int(stringLen)
+ if intStringLen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + intStringLen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Uri = string(dAtA[iNdEx:postIndex])
+ iNdEx = postIndex
+ case 8:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field UriHash", wireType)
+ }
+ var stringLen uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ stringLen |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ intStringLen := int(stringLen)
+ if intStringLen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + intStringLen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.UriHash = string(dAtA[iNdEx:postIndex])
+ iNdEx = postIndex
+ case 1984:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field PenumbraAssetId", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.PenumbraAssetId == nil {
+ m.PenumbraAssetId = &AssetId{}
+ }
+ if err := m.PenumbraAssetId.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipCrypto(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *DenomUnit) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: DenomUnit: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: DenomUnit: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Denom", wireType)
+ }
+ var stringLen uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ stringLen |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ intStringLen := int(stringLen)
+ if intStringLen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + intStringLen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Denom = string(dAtA[iNdEx:postIndex])
+ iNdEx = postIndex
+ case 2:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Exponent", wireType)
+ }
+ m.Exponent = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.Exponent |= uint32(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Aliases", wireType)
+ }
+ var stringLen uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ stringLen |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ intStringLen := int(stringLen)
+ if intStringLen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + intStringLen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Aliases = append(m.Aliases, string(dAtA[iNdEx:postIndex]))
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipCrypto(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *Value) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Value: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Value: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Amount", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Amount == nil {
+ m.Amount = &Amount{}
+ }
+ if err := m.Amount.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field AssetId", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.AssetId == nil {
+ m.AssetId = &AssetId{}
+ }
+ if err := m.AssetId.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipCrypto(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *ValueView) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: ValueView: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: ValueView: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field KnownDenom", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &ValueView_KnownDenom{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.ValueView = &ValueView_KnownDenom_{v}
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field UnknownDenom", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &ValueView_UnknownDenom{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.ValueView = &ValueView_UnknownDenom_{v}
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipCrypto(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *ValueView_KnownDenom) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: KnownDenom: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: KnownDenom: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Amount", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Amount == nil {
+ m.Amount = &Amount{}
+ }
+ if err := m.Amount.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Denom", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Denom == nil {
+ m.Denom = &DenomMetadata{}
+ }
+ if err := m.Denom.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipCrypto(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *ValueView_UnknownDenom) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: UnknownDenom: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: UnknownDenom: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Amount", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Amount == nil {
+ m.Amount = &Amount{}
+ }
+ if err := m.Amount.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field AssetId", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.AssetId == nil {
+ m.AssetId = &AssetId{}
+ }
+ if err := m.AssetId.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipCrypto(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *MerkleRoot) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: MerkleRoot: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: MerkleRoot: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Inner", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Inner = append(m.Inner[:0], dAtA[iNdEx:postIndex]...)
+ if m.Inner == nil {
+ m.Inner = []byte{}
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipCrypto(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *IdentityKey) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: IdentityKey: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: IdentityKey: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Ik", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Ik = append(m.Ik[:0], dAtA[iNdEx:postIndex]...)
+ if m.Ik == nil {
+ m.Ik = []byte{}
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipCrypto(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *GovernanceKey) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: GovernanceKey: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: GovernanceKey: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Gk", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Gk = append(m.Gk[:0], dAtA[iNdEx:postIndex]...)
+ if m.Gk == nil {
+ m.Gk = []byte{}
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipCrypto(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *ConsensusKey) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: ConsensusKey: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: ConsensusKey: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Inner", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Inner = append(m.Inner[:0], dAtA[iNdEx:postIndex]...)
+ if m.Inner == nil {
+ m.Inner = []byte{}
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipCrypto(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *Note) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Note: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Note: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Value", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Value == nil {
+ m.Value = &Value{}
+ }
+ if err := m.Value.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Rseed", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Rseed = append(m.Rseed[:0], dAtA[iNdEx:postIndex]...)
+ if m.Rseed == nil {
+ m.Rseed = []byte{}
+ }
+ iNdEx = postIndex
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Address", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Address == nil {
+ m.Address = &Address{}
+ }
+ if err := m.Address.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipCrypto(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *NoteView) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: NoteView: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: NoteView: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Value", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Value == nil {
+ m.Value = &ValueView{}
+ }
+ if err := m.Value.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Rseed", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Rseed = append(m.Rseed[:0], dAtA[iNdEx:postIndex]...)
+ if m.Rseed == nil {
+ m.Rseed = []byte{}
+ }
+ iNdEx = postIndex
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Address", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Address == nil {
+ m.Address = &AddressView{}
+ }
+ if err := m.Address.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipCrypto(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *NoteCiphertext) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: NoteCiphertext: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: NoteCiphertext: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Inner", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Inner = append(m.Inner[:0], dAtA[iNdEx:postIndex]...)
+ if m.Inner == nil {
+ m.Inner = []byte{}
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipCrypto(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *Nullifier) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Nullifier: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Nullifier: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Inner", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Inner = append(m.Inner[:0], dAtA[iNdEx:postIndex]...)
+ if m.Inner == nil {
+ m.Inner = []byte{}
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipCrypto(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *SpendAuthSignature) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: SpendAuthSignature: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: SpendAuthSignature: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Inner", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Inner = append(m.Inner[:0], dAtA[iNdEx:postIndex]...)
+ if m.Inner == nil {
+ m.Inner = []byte{}
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipCrypto(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *BindingSignature) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: BindingSignature: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: BindingSignature: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Inner", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Inner = append(m.Inner[:0], dAtA[iNdEx:postIndex]...)
+ if m.Inner == nil {
+ m.Inner = []byte{}
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipCrypto(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *NotePayload) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: NotePayload: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: NotePayload: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field NoteCommitment", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.NoteCommitment == nil {
+ m.NoteCommitment = &StateCommitment{}
+ }
+ if err := m.NoteCommitment.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field EphemeralKey", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.EphemeralKey = append(m.EphemeralKey[:0], dAtA[iNdEx:postIndex]...)
+ if m.EphemeralKey == nil {
+ m.EphemeralKey = []byte{}
+ }
+ iNdEx = postIndex
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field EncryptedNote", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.EncryptedNote == nil {
+ m.EncryptedNote = &NoteCiphertext{}
+ }
+ if err := m.EncryptedNote.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipCrypto(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *StateCommitmentProof) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: StateCommitmentProof: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: StateCommitmentProof: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field NoteCommitment", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.NoteCommitment == nil {
+ m.NoteCommitment = &StateCommitment{}
+ }
+ if err := m.NoteCommitment.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Position", wireType)
+ }
+ m.Position = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.Position |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field AuthPath", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.AuthPath = append(m.AuthPath, &MerklePathChunk{})
+ if err := m.AuthPath[len(m.AuthPath)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipCrypto(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *MerklePathChunk) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: MerklePathChunk: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: MerklePathChunk: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Sibling_1", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Sibling_1 = append(m.Sibling_1[:0], dAtA[iNdEx:postIndex]...)
+ if m.Sibling_1 == nil {
+ m.Sibling_1 = []byte{}
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Sibling_2", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Sibling_2 = append(m.Sibling_2[:0], dAtA[iNdEx:postIndex]...)
+ if m.Sibling_2 == nil {
+ m.Sibling_2 = []byte{}
+ }
+ iNdEx = postIndex
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Sibling_3", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Sibling_3 = append(m.Sibling_3[:0], dAtA[iNdEx:postIndex]...)
+ if m.Sibling_3 == nil {
+ m.Sibling_3 = []byte{}
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipCrypto(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *Clue) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Clue: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Clue: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Inner", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Inner = append(m.Inner[:0], dAtA[iNdEx:postIndex]...)
+ if m.Inner == nil {
+ m.Inner = []byte{}
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipCrypto(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *EffectHash) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: EffectHash: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: EffectHash: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Inner", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Inner = append(m.Inner[:0], dAtA[iNdEx:postIndex]...)
+ if m.Inner == nil {
+ m.Inner = []byte{}
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipCrypto(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *ZKOutputProof) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: ZKOutputProof: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: ZKOutputProof: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Inner", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Inner = append(m.Inner[:0], dAtA[iNdEx:postIndex]...)
+ if m.Inner == nil {
+ m.Inner = []byte{}
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipCrypto(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *ZKSpendProof) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: ZKSpendProof: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: ZKSpendProof: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Inner", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Inner = append(m.Inner[:0], dAtA[iNdEx:postIndex]...)
+ if m.Inner == nil {
+ m.Inner = []byte{}
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipCrypto(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *ZKSwapProof) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: ZKSwapProof: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: ZKSwapProof: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Inner", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Inner = append(m.Inner[:0], dAtA[iNdEx:postIndex]...)
+ if m.Inner == nil {
+ m.Inner = []byte{}
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipCrypto(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *ZKSwapClaimProof) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: ZKSwapClaimProof: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: ZKSwapClaimProof: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Inner", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Inner = append(m.Inner[:0], dAtA[iNdEx:postIndex]...)
+ if m.Inner == nil {
+ m.Inner = []byte{}
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipCrypto(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *ZKUndelegateClaimProof) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: ZKUndelegateClaimProof: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: ZKUndelegateClaimProof: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Inner", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Inner = append(m.Inner[:0], dAtA[iNdEx:postIndex]...)
+ if m.Inner == nil {
+ m.Inner = []byte{}
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipCrypto(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *ZKDelegatorVoteProof) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: ZKDelegatorVoteProof: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: ZKDelegatorVoteProof: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Inner", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Inner = append(m.Inner[:0], dAtA[iNdEx:postIndex]...)
+ if m.Inner == nil {
+ m.Inner = []byte{}
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipCrypto(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *ZKNullifierDerivationProof) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: ZKNullifierDerivationProof: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: ZKNullifierDerivationProof: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Inner", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Inner = append(m.Inner[:0], dAtA[iNdEx:postIndex]...)
+ if m.Inner == nil {
+ m.Inner = []byte{}
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipCrypto(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthCrypto
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func skipCrypto(dAtA []byte) (n int, err error) {
+ l := len(dAtA)
+ iNdEx := 0
+ depth := 0
+ for iNdEx < l {
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return 0, ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return 0, io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= (uint64(b) & 0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ wireType := int(wire & 0x7)
+ switch wireType {
+ case 0:
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return 0, ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return 0, io.ErrUnexpectedEOF
+ }
+ iNdEx++
+ if dAtA[iNdEx-1] < 0x80 {
+ break
+ }
+ }
+ case 1:
+ iNdEx += 8
+ case 2:
+ var length int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return 0, ErrIntOverflowCrypto
+ }
+ if iNdEx >= l {
+ return 0, io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ length |= (int(b) & 0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if length < 0 {
+ return 0, ErrInvalidLengthCrypto
+ }
+ iNdEx += length
+ case 3:
+ depth++
+ case 4:
+ if depth == 0 {
+ return 0, ErrUnexpectedEndOfGroupCrypto
+ }
+ depth--
+ case 5:
+ iNdEx += 4
+ default:
+ return 0, fmt.Errorf("proto: illegal wireType %d", wireType)
+ }
+ if iNdEx < 0 {
+ return 0, ErrInvalidLengthCrypto
+ }
+ if depth == 0 {
+ return iNdEx, nil
+ }
+ }
+ return 0, io.ErrUnexpectedEOF
+}
+
+var (
+ ErrInvalidLengthCrypto = fmt.Errorf("proto: negative length found during unmarshaling")
+ ErrIntOverflowCrypto = fmt.Errorf("proto: integer overflow")
+ ErrUnexpectedEndOfGroupCrypto = fmt.Errorf("proto: unexpected end of group")
+)
diff --git a/relayer/chains/penumbra/core/dex/v1alpha1/dex.pb.go b/relayer/chains/penumbra/core/dex/v1alpha1/dex.pb.go
new file mode 100644
index 000000000..9456bbbb2
--- /dev/null
+++ b/relayer/chains/penumbra/core/dex/v1alpha1/dex.pb.go
@@ -0,0 +1,9422 @@
+// Code generated by protoc-gen-gogo. DO NOT EDIT.
+// source: penumbra/core/dex/v1alpha1/dex.proto
+
+package dexv1alpha1
+
+import (
+ fmt "fmt"
+ proto "github.com/cosmos/gogoproto/proto"
+ v1alpha1 "github.com/cosmos/relayer/v2/relayer/chains/penumbra/core/crypto/v1alpha1"
+ io "io"
+ math "math"
+ math_bits "math/bits"
+)
+
+// Reference imports to suppress errors if they are not otherwise used.
+var _ = proto.Marshal
+var _ = fmt.Errorf
+var _ = math.Inf
+
+// This is a compile-time assertion to ensure that this generated file
+// is compatible with the proto package it is being compiled against.
+// A compilation error at this line likely means your copy of the
+// proto package needs to be updated.
+const _ = proto.GoGoProtoPackageIsVersion3 // please upgrade the proto package
+
+type PositionState_PositionStateEnum int32
+
+const (
+ PositionState_POSITION_STATE_ENUM_UNSPECIFIED PositionState_PositionStateEnum = 0
+ // The position has been opened, is active, has reserves and accumulated
+ // fees, and can be traded against.
+ PositionState_POSITION_STATE_ENUM_OPENED PositionState_PositionStateEnum = 1
+ // The position has been closed, is inactive and can no longer be traded
+ // against, but still has reserves and accumulated fees.
+ PositionState_POSITION_STATE_ENUM_CLOSED PositionState_PositionStateEnum = 2
+ // The final reserves and accumulated fees have been withdrawn, leaving an
+ // empty, inactive position awaiting (possible) retroactive rewards.
+ PositionState_POSITION_STATE_ENUM_WITHDRAWN PositionState_PositionStateEnum = 3
+ // Any retroactive rewards have been claimed. The position is now an inert,
+ // historical artefact.
+ PositionState_POSITION_STATE_ENUM_CLAIMED PositionState_PositionStateEnum = 4
+)
+
+var PositionState_PositionStateEnum_name = map[int32]string{
+ 0: "POSITION_STATE_ENUM_UNSPECIFIED",
+ 1: "POSITION_STATE_ENUM_OPENED",
+ 2: "POSITION_STATE_ENUM_CLOSED",
+ 3: "POSITION_STATE_ENUM_WITHDRAWN",
+ 4: "POSITION_STATE_ENUM_CLAIMED",
+}
+
+var PositionState_PositionStateEnum_value = map[string]int32{
+ "POSITION_STATE_ENUM_UNSPECIFIED": 0,
+ "POSITION_STATE_ENUM_OPENED": 1,
+ "POSITION_STATE_ENUM_CLOSED": 2,
+ "POSITION_STATE_ENUM_WITHDRAWN": 3,
+ "POSITION_STATE_ENUM_CLAIMED": 4,
+}
+
+func (x PositionState_PositionStateEnum) String() string {
+ return proto.EnumName(PositionState_PositionStateEnum_name, int32(x))
+}
+
+func (PositionState_PositionStateEnum) EnumDescriptor() ([]byte, []int) {
+ return fileDescriptor_d1eba752ca2f0d70, []int{18, 0}
+}
+
+// A transaction action that submits a swap to the dex.
+type Swap struct {
+ // Contains the Swap proof.
+ Proof *v1alpha1.ZKSwapProof `protobuf:"bytes,1,opt,name=proof,proto3" json:"proof,omitempty"`
+ // Encapsulates the authorized fields of the Swap action, used in signing.
+ Body *SwapBody `protobuf:"bytes,4,opt,name=body,proto3" json:"body,omitempty"`
+}
+
+func (m *Swap) Reset() { *m = Swap{} }
+func (m *Swap) String() string { return proto.CompactTextString(m) }
+func (*Swap) ProtoMessage() {}
+func (*Swap) Descriptor() ([]byte, []int) {
+ return fileDescriptor_d1eba752ca2f0d70, []int{0}
+}
+func (m *Swap) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *Swap) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_Swap.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *Swap) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_Swap.Merge(m, src)
+}
+func (m *Swap) XXX_Size() int {
+ return m.Size()
+}
+func (m *Swap) XXX_DiscardUnknown() {
+ xxx_messageInfo_Swap.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_Swap proto.InternalMessageInfo
+
+func (m *Swap) GetProof() *v1alpha1.ZKSwapProof {
+ if m != nil {
+ return m.Proof
+ }
+ return nil
+}
+
+func (m *Swap) GetBody() *SwapBody {
+ if m != nil {
+ return m.Body
+ }
+ return nil
+}
+
+// A transaction action that obtains assets previously confirmed
+// via a Swap transaction. Does not include a spend authorization
+// signature, as it is only capable of consuming the NFT from a
+// Swap transaction.
+type SwapClaim struct {
+ // Contains the SwapClaim proof.
+ Proof []byte `protobuf:"bytes,1,opt,name=proof,proto3" json:"proof,omitempty"`
+ // Encapsulates the authorized fields of the SwapClaim action, used in signing.
+ Body *SwapClaimBody `protobuf:"bytes,2,opt,name=body,proto3" json:"body,omitempty"`
+ // The epoch duration of the chain when the swap claim took place.
+ EpochDuration uint64 `protobuf:"varint,7,opt,name=epoch_duration,json=epochDuration,proto3" json:"epoch_duration,omitempty"`
+}
+
+func (m *SwapClaim) Reset() { *m = SwapClaim{} }
+func (m *SwapClaim) String() string { return proto.CompactTextString(m) }
+func (*SwapClaim) ProtoMessage() {}
+func (*SwapClaim) Descriptor() ([]byte, []int) {
+ return fileDescriptor_d1eba752ca2f0d70, []int{1}
+}
+func (m *SwapClaim) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *SwapClaim) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_SwapClaim.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *SwapClaim) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_SwapClaim.Merge(m, src)
+}
+func (m *SwapClaim) XXX_Size() int {
+ return m.Size()
+}
+func (m *SwapClaim) XXX_DiscardUnknown() {
+ xxx_messageInfo_SwapClaim.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_SwapClaim proto.InternalMessageInfo
+
+func (m *SwapClaim) GetProof() []byte {
+ if m != nil {
+ return m.Proof
+ }
+ return nil
+}
+
+func (m *SwapClaim) GetBody() *SwapClaimBody {
+ if m != nil {
+ return m.Body
+ }
+ return nil
+}
+
+func (m *SwapClaim) GetEpochDuration() uint64 {
+ if m != nil {
+ return m.EpochDuration
+ }
+ return 0
+}
+
+// Encapsulates the authorized fields of the SwapClaim action, used in signing.
+type SwapClaimBody struct {
+ // The nullifier for the Swap commitment to be consumed.
+ Nullifier *v1alpha1.Nullifier `protobuf:"bytes,1,opt,name=nullifier,proto3" json:"nullifier,omitempty"`
+ // The fee allows `SwapClaim` without an additional `Spend`.
+ Fee *v1alpha1.Fee `protobuf:"bytes,2,opt,name=fee,proto3" json:"fee,omitempty"`
+ // Note output for asset 1.
+ Output_1Commitment *v1alpha1.StateCommitment `protobuf:"bytes,3,opt,name=output_1_commitment,json=output1Commitment,proto3" json:"output_1_commitment,omitempty"`
+ // Note output for asset 2.
+ Output_2Commitment *v1alpha1.StateCommitment `protobuf:"bytes,4,opt,name=output_2_commitment,json=output2Commitment,proto3" json:"output_2_commitment,omitempty"`
+ // Input and output amounts, and asset IDs for the assets in the swap.
+ OutputData *BatchSwapOutputData `protobuf:"bytes,6,opt,name=output_data,json=outputData,proto3" json:"output_data,omitempty"`
+}
+
+func (m *SwapClaimBody) Reset() { *m = SwapClaimBody{} }
+func (m *SwapClaimBody) String() string { return proto.CompactTextString(m) }
+func (*SwapClaimBody) ProtoMessage() {}
+func (*SwapClaimBody) Descriptor() ([]byte, []int) {
+ return fileDescriptor_d1eba752ca2f0d70, []int{2}
+}
+func (m *SwapClaimBody) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *SwapClaimBody) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_SwapClaimBody.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *SwapClaimBody) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_SwapClaimBody.Merge(m, src)
+}
+func (m *SwapClaimBody) XXX_Size() int {
+ return m.Size()
+}
+func (m *SwapClaimBody) XXX_DiscardUnknown() {
+ xxx_messageInfo_SwapClaimBody.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_SwapClaimBody proto.InternalMessageInfo
+
+func (m *SwapClaimBody) GetNullifier() *v1alpha1.Nullifier {
+ if m != nil {
+ return m.Nullifier
+ }
+ return nil
+}
+
+func (m *SwapClaimBody) GetFee() *v1alpha1.Fee {
+ if m != nil {
+ return m.Fee
+ }
+ return nil
+}
+
+func (m *SwapClaimBody) GetOutput_1Commitment() *v1alpha1.StateCommitment {
+ if m != nil {
+ return m.Output_1Commitment
+ }
+ return nil
+}
+
+func (m *SwapClaimBody) GetOutput_2Commitment() *v1alpha1.StateCommitment {
+ if m != nil {
+ return m.Output_2Commitment
+ }
+ return nil
+}
+
+func (m *SwapClaimBody) GetOutputData() *BatchSwapOutputData {
+ if m != nil {
+ return m.OutputData
+ }
+ return nil
+}
+
+// The authorized data of a Swap transaction.
+type SwapBody struct {
+ // The trading pair to swap.
+ TradingPair *TradingPair `protobuf:"bytes,1,opt,name=trading_pair,json=tradingPair,proto3" json:"trading_pair,omitempty"`
+ // The amount for asset 1.
+ Delta_1I *v1alpha1.Amount `protobuf:"bytes,2,opt,name=delta_1_i,json=delta1I,proto3" json:"delta_1_i,omitempty"`
+ // The amount for asset 2.
+ Delta_2I *v1alpha1.Amount `protobuf:"bytes,3,opt,name=delta_2_i,json=delta2I,proto3" json:"delta_2_i,omitempty"`
+ // A commitment to a prepaid fee for the future SwapClaim.
+ // This is recorded separately from delta_j_i because it's shielded;
+ // in the future we'll want separate commitments to each delta_j_i
+ // anyways in order to prove consistency with flow encryption.
+ FeeCommitment *v1alpha1.BalanceCommitment `protobuf:"bytes,4,opt,name=fee_commitment,json=feeCommitment,proto3" json:"fee_commitment,omitempty"`
+ // The swap commitment and encryption of the swap data.
+ Payload *SwapPayload `protobuf:"bytes,5,opt,name=payload,proto3" json:"payload,omitempty"`
+}
+
+func (m *SwapBody) Reset() { *m = SwapBody{} }
+func (m *SwapBody) String() string { return proto.CompactTextString(m) }
+func (*SwapBody) ProtoMessage() {}
+func (*SwapBody) Descriptor() ([]byte, []int) {
+ return fileDescriptor_d1eba752ca2f0d70, []int{3}
+}
+func (m *SwapBody) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *SwapBody) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_SwapBody.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *SwapBody) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_SwapBody.Merge(m, src)
+}
+func (m *SwapBody) XXX_Size() int {
+ return m.Size()
+}
+func (m *SwapBody) XXX_DiscardUnknown() {
+ xxx_messageInfo_SwapBody.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_SwapBody proto.InternalMessageInfo
+
+func (m *SwapBody) GetTradingPair() *TradingPair {
+ if m != nil {
+ return m.TradingPair
+ }
+ return nil
+}
+
+func (m *SwapBody) GetDelta_1I() *v1alpha1.Amount {
+ if m != nil {
+ return m.Delta_1I
+ }
+ return nil
+}
+
+func (m *SwapBody) GetDelta_2I() *v1alpha1.Amount {
+ if m != nil {
+ return m.Delta_2I
+ }
+ return nil
+}
+
+func (m *SwapBody) GetFeeCommitment() *v1alpha1.BalanceCommitment {
+ if m != nil {
+ return m.FeeCommitment
+ }
+ return nil
+}
+
+func (m *SwapBody) GetPayload() *SwapPayload {
+ if m != nil {
+ return m.Payload
+ }
+ return nil
+}
+
+type SwapPayload struct {
+ Commitment *v1alpha1.StateCommitment `protobuf:"bytes,1,opt,name=commitment,proto3" json:"commitment,omitempty"`
+ EncryptedSwap []byte `protobuf:"bytes,2,opt,name=encrypted_swap,json=encryptedSwap,proto3" json:"encrypted_swap,omitempty"`
+}
+
+func (m *SwapPayload) Reset() { *m = SwapPayload{} }
+func (m *SwapPayload) String() string { return proto.CompactTextString(m) }
+func (*SwapPayload) ProtoMessage() {}
+func (*SwapPayload) Descriptor() ([]byte, []int) {
+ return fileDescriptor_d1eba752ca2f0d70, []int{4}
+}
+func (m *SwapPayload) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *SwapPayload) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_SwapPayload.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *SwapPayload) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_SwapPayload.Merge(m, src)
+}
+func (m *SwapPayload) XXX_Size() int {
+ return m.Size()
+}
+func (m *SwapPayload) XXX_DiscardUnknown() {
+ xxx_messageInfo_SwapPayload.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_SwapPayload proto.InternalMessageInfo
+
+func (m *SwapPayload) GetCommitment() *v1alpha1.StateCommitment {
+ if m != nil {
+ return m.Commitment
+ }
+ return nil
+}
+
+func (m *SwapPayload) GetEncryptedSwap() []byte {
+ if m != nil {
+ return m.EncryptedSwap
+ }
+ return nil
+}
+
+type SwapPlaintext struct {
+ // The trading pair to swap.
+ TradingPair *TradingPair `protobuf:"bytes,1,opt,name=trading_pair,json=tradingPair,proto3" json:"trading_pair,omitempty"`
+ // Input amount of asset 1
+ Delta_1I *v1alpha1.Amount `protobuf:"bytes,2,opt,name=delta_1_i,json=delta1I,proto3" json:"delta_1_i,omitempty"`
+ // Input amount of asset 2
+ Delta_2I *v1alpha1.Amount `protobuf:"bytes,3,opt,name=delta_2_i,json=delta2I,proto3" json:"delta_2_i,omitempty"`
+ // Pre-paid fee to claim the swap
+ ClaimFee *v1alpha1.Fee `protobuf:"bytes,4,opt,name=claim_fee,json=claimFee,proto3" json:"claim_fee,omitempty"`
+ // Address that will claim the swap outputs via SwapClaim.
+ ClaimAddress *v1alpha1.Address `protobuf:"bytes,5,opt,name=claim_address,json=claimAddress,proto3" json:"claim_address,omitempty"`
+ // Swap rseed (blinding factors are derived from this)
+ Rseed []byte `protobuf:"bytes,6,opt,name=rseed,proto3" json:"rseed,omitempty"`
+}
+
+func (m *SwapPlaintext) Reset() { *m = SwapPlaintext{} }
+func (m *SwapPlaintext) String() string { return proto.CompactTextString(m) }
+func (*SwapPlaintext) ProtoMessage() {}
+func (*SwapPlaintext) Descriptor() ([]byte, []int) {
+ return fileDescriptor_d1eba752ca2f0d70, []int{5}
+}
+func (m *SwapPlaintext) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *SwapPlaintext) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_SwapPlaintext.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *SwapPlaintext) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_SwapPlaintext.Merge(m, src)
+}
+func (m *SwapPlaintext) XXX_Size() int {
+ return m.Size()
+}
+func (m *SwapPlaintext) XXX_DiscardUnknown() {
+ xxx_messageInfo_SwapPlaintext.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_SwapPlaintext proto.InternalMessageInfo
+
+func (m *SwapPlaintext) GetTradingPair() *TradingPair {
+ if m != nil {
+ return m.TradingPair
+ }
+ return nil
+}
+
+func (m *SwapPlaintext) GetDelta_1I() *v1alpha1.Amount {
+ if m != nil {
+ return m.Delta_1I
+ }
+ return nil
+}
+
+func (m *SwapPlaintext) GetDelta_2I() *v1alpha1.Amount {
+ if m != nil {
+ return m.Delta_2I
+ }
+ return nil
+}
+
+func (m *SwapPlaintext) GetClaimFee() *v1alpha1.Fee {
+ if m != nil {
+ return m.ClaimFee
+ }
+ return nil
+}
+
+func (m *SwapPlaintext) GetClaimAddress() *v1alpha1.Address {
+ if m != nil {
+ return m.ClaimAddress
+ }
+ return nil
+}
+
+func (m *SwapPlaintext) GetRseed() []byte {
+ if m != nil {
+ return m.Rseed
+ }
+ return nil
+}
+
+type SwapPlan struct {
+ // The plaintext version of the swap to be performed.
+ SwapPlaintext *SwapPlaintext `protobuf:"bytes,1,opt,name=swap_plaintext,json=swapPlaintext,proto3" json:"swap_plaintext,omitempty"`
+ // The blinding factor for the fee commitment. The fee in the SwapPlan is private to prevent linkability with the SwapClaim.
+ FeeBlinding []byte `protobuf:"bytes,2,opt,name=fee_blinding,json=feeBlinding,proto3" json:"fee_blinding,omitempty"`
+ // The first blinding factor to use for the ZK swap proof.
+ ProofBlindingR []byte `protobuf:"bytes,3,opt,name=proof_blinding_r,json=proofBlindingR,proto3" json:"proof_blinding_r,omitempty"`
+ // The second blinding factor to use for the ZK swap proof.
+ ProofBlindingS []byte `protobuf:"bytes,4,opt,name=proof_blinding_s,json=proofBlindingS,proto3" json:"proof_blinding_s,omitempty"`
+}
+
+func (m *SwapPlan) Reset() { *m = SwapPlan{} }
+func (m *SwapPlan) String() string { return proto.CompactTextString(m) }
+func (*SwapPlan) ProtoMessage() {}
+func (*SwapPlan) Descriptor() ([]byte, []int) {
+ return fileDescriptor_d1eba752ca2f0d70, []int{6}
+}
+func (m *SwapPlan) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *SwapPlan) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_SwapPlan.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *SwapPlan) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_SwapPlan.Merge(m, src)
+}
+func (m *SwapPlan) XXX_Size() int {
+ return m.Size()
+}
+func (m *SwapPlan) XXX_DiscardUnknown() {
+ xxx_messageInfo_SwapPlan.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_SwapPlan proto.InternalMessageInfo
+
+func (m *SwapPlan) GetSwapPlaintext() *SwapPlaintext {
+ if m != nil {
+ return m.SwapPlaintext
+ }
+ return nil
+}
+
+func (m *SwapPlan) GetFeeBlinding() []byte {
+ if m != nil {
+ return m.FeeBlinding
+ }
+ return nil
+}
+
+func (m *SwapPlan) GetProofBlindingR() []byte {
+ if m != nil {
+ return m.ProofBlindingR
+ }
+ return nil
+}
+
+func (m *SwapPlan) GetProofBlindingS() []byte {
+ if m != nil {
+ return m.ProofBlindingS
+ }
+ return nil
+}
+
+type SwapClaimPlan struct {
+ // The plaintext version of the swap to be performed.
+ SwapPlaintext *SwapPlaintext `protobuf:"bytes,1,opt,name=swap_plaintext,json=swapPlaintext,proto3" json:"swap_plaintext,omitempty"`
+ // The position of the swap commitment.
+ Position uint64 `protobuf:"varint,2,opt,name=position,proto3" json:"position,omitempty"`
+ // Input and output amounts for the Swap.
+ OutputData *BatchSwapOutputData `protobuf:"bytes,3,opt,name=output_data,json=outputData,proto3" json:"output_data,omitempty"`
+ // The epoch duration, used in proving.
+ EpochDuration uint64 `protobuf:"varint,4,opt,name=epoch_duration,json=epochDuration,proto3" json:"epoch_duration,omitempty"`
+ // The first blinding factor to use for the ZK swap claim proof.
+ ProofBlindingR []byte `protobuf:"bytes,5,opt,name=proof_blinding_r,json=proofBlindingR,proto3" json:"proof_blinding_r,omitempty"`
+ // The second blinding factor to use for the ZK swap claim proof.
+ ProofBlindingS []byte `protobuf:"bytes,6,opt,name=proof_blinding_s,json=proofBlindingS,proto3" json:"proof_blinding_s,omitempty"`
+}
+
+func (m *SwapClaimPlan) Reset() { *m = SwapClaimPlan{} }
+func (m *SwapClaimPlan) String() string { return proto.CompactTextString(m) }
+func (*SwapClaimPlan) ProtoMessage() {}
+func (*SwapClaimPlan) Descriptor() ([]byte, []int) {
+ return fileDescriptor_d1eba752ca2f0d70, []int{7}
+}
+func (m *SwapClaimPlan) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *SwapClaimPlan) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_SwapClaimPlan.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *SwapClaimPlan) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_SwapClaimPlan.Merge(m, src)
+}
+func (m *SwapClaimPlan) XXX_Size() int {
+ return m.Size()
+}
+func (m *SwapClaimPlan) XXX_DiscardUnknown() {
+ xxx_messageInfo_SwapClaimPlan.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_SwapClaimPlan proto.InternalMessageInfo
+
+func (m *SwapClaimPlan) GetSwapPlaintext() *SwapPlaintext {
+ if m != nil {
+ return m.SwapPlaintext
+ }
+ return nil
+}
+
+func (m *SwapClaimPlan) GetPosition() uint64 {
+ if m != nil {
+ return m.Position
+ }
+ return 0
+}
+
+func (m *SwapClaimPlan) GetOutputData() *BatchSwapOutputData {
+ if m != nil {
+ return m.OutputData
+ }
+ return nil
+}
+
+func (m *SwapClaimPlan) GetEpochDuration() uint64 {
+ if m != nil {
+ return m.EpochDuration
+ }
+ return 0
+}
+
+func (m *SwapClaimPlan) GetProofBlindingR() []byte {
+ if m != nil {
+ return m.ProofBlindingR
+ }
+ return nil
+}
+
+func (m *SwapClaimPlan) GetProofBlindingS() []byte {
+ if m != nil {
+ return m.ProofBlindingS
+ }
+ return nil
+}
+
+type SwapView struct {
+ // Types that are valid to be assigned to SwapView:
+ //
+ // *SwapView_Visible_
+ // *SwapView_Opaque_
+ SwapView isSwapView_SwapView `protobuf_oneof:"swap_view"`
+}
+
+func (m *SwapView) Reset() { *m = SwapView{} }
+func (m *SwapView) String() string { return proto.CompactTextString(m) }
+func (*SwapView) ProtoMessage() {}
+func (*SwapView) Descriptor() ([]byte, []int) {
+ return fileDescriptor_d1eba752ca2f0d70, []int{8}
+}
+func (m *SwapView) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *SwapView) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_SwapView.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *SwapView) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_SwapView.Merge(m, src)
+}
+func (m *SwapView) XXX_Size() int {
+ return m.Size()
+}
+func (m *SwapView) XXX_DiscardUnknown() {
+ xxx_messageInfo_SwapView.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_SwapView proto.InternalMessageInfo
+
+type isSwapView_SwapView interface {
+ isSwapView_SwapView()
+ MarshalTo([]byte) (int, error)
+ Size() int
+}
+
+type SwapView_Visible_ struct {
+ Visible *SwapView_Visible `protobuf:"bytes,1,opt,name=visible,proto3,oneof" json:"visible,omitempty"`
+}
+type SwapView_Opaque_ struct {
+ Opaque *SwapView_Opaque `protobuf:"bytes,2,opt,name=opaque,proto3,oneof" json:"opaque,omitempty"`
+}
+
+func (*SwapView_Visible_) isSwapView_SwapView() {}
+func (*SwapView_Opaque_) isSwapView_SwapView() {}
+
+func (m *SwapView) GetSwapView() isSwapView_SwapView {
+ if m != nil {
+ return m.SwapView
+ }
+ return nil
+}
+
+func (m *SwapView) GetVisible() *SwapView_Visible {
+ if x, ok := m.GetSwapView().(*SwapView_Visible_); ok {
+ return x.Visible
+ }
+ return nil
+}
+
+func (m *SwapView) GetOpaque() *SwapView_Opaque {
+ if x, ok := m.GetSwapView().(*SwapView_Opaque_); ok {
+ return x.Opaque
+ }
+ return nil
+}
+
+// XXX_OneofWrappers is for the internal use of the proto package.
+func (*SwapView) XXX_OneofWrappers() []interface{} {
+ return []interface{}{
+ (*SwapView_Visible_)(nil),
+ (*SwapView_Opaque_)(nil),
+ }
+}
+
+type SwapView_Visible struct {
+ Swap *Swap `protobuf:"bytes,1,opt,name=swap,proto3" json:"swap,omitempty"`
+ SwapPlaintext *SwapPlaintext `protobuf:"bytes,3,opt,name=swap_plaintext,json=swapPlaintext,proto3" json:"swap_plaintext,omitempty"`
+}
+
+func (m *SwapView_Visible) Reset() { *m = SwapView_Visible{} }
+func (m *SwapView_Visible) String() string { return proto.CompactTextString(m) }
+func (*SwapView_Visible) ProtoMessage() {}
+func (*SwapView_Visible) Descriptor() ([]byte, []int) {
+ return fileDescriptor_d1eba752ca2f0d70, []int{8, 0}
+}
+func (m *SwapView_Visible) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *SwapView_Visible) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_SwapView_Visible.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *SwapView_Visible) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_SwapView_Visible.Merge(m, src)
+}
+func (m *SwapView_Visible) XXX_Size() int {
+ return m.Size()
+}
+func (m *SwapView_Visible) XXX_DiscardUnknown() {
+ xxx_messageInfo_SwapView_Visible.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_SwapView_Visible proto.InternalMessageInfo
+
+func (m *SwapView_Visible) GetSwap() *Swap {
+ if m != nil {
+ return m.Swap
+ }
+ return nil
+}
+
+func (m *SwapView_Visible) GetSwapPlaintext() *SwapPlaintext {
+ if m != nil {
+ return m.SwapPlaintext
+ }
+ return nil
+}
+
+type SwapView_Opaque struct {
+ Swap *Swap `protobuf:"bytes,1,opt,name=swap,proto3" json:"swap,omitempty"`
+}
+
+func (m *SwapView_Opaque) Reset() { *m = SwapView_Opaque{} }
+func (m *SwapView_Opaque) String() string { return proto.CompactTextString(m) }
+func (*SwapView_Opaque) ProtoMessage() {}
+func (*SwapView_Opaque) Descriptor() ([]byte, []int) {
+ return fileDescriptor_d1eba752ca2f0d70, []int{8, 1}
+}
+func (m *SwapView_Opaque) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *SwapView_Opaque) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_SwapView_Opaque.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *SwapView_Opaque) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_SwapView_Opaque.Merge(m, src)
+}
+func (m *SwapView_Opaque) XXX_Size() int {
+ return m.Size()
+}
+func (m *SwapView_Opaque) XXX_DiscardUnknown() {
+ xxx_messageInfo_SwapView_Opaque.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_SwapView_Opaque proto.InternalMessageInfo
+
+func (m *SwapView_Opaque) GetSwap() *Swap {
+ if m != nil {
+ return m.Swap
+ }
+ return nil
+}
+
+type SwapClaimView struct {
+ // Types that are valid to be assigned to SwapClaimView:
+ //
+ // *SwapClaimView_Visible_
+ // *SwapClaimView_Opaque_
+ SwapClaimView isSwapClaimView_SwapClaimView `protobuf_oneof:"swap_claim_view"`
+}
+
+func (m *SwapClaimView) Reset() { *m = SwapClaimView{} }
+func (m *SwapClaimView) String() string { return proto.CompactTextString(m) }
+func (*SwapClaimView) ProtoMessage() {}
+func (*SwapClaimView) Descriptor() ([]byte, []int) {
+ return fileDescriptor_d1eba752ca2f0d70, []int{9}
+}
+func (m *SwapClaimView) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *SwapClaimView) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_SwapClaimView.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *SwapClaimView) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_SwapClaimView.Merge(m, src)
+}
+func (m *SwapClaimView) XXX_Size() int {
+ return m.Size()
+}
+func (m *SwapClaimView) XXX_DiscardUnknown() {
+ xxx_messageInfo_SwapClaimView.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_SwapClaimView proto.InternalMessageInfo
+
+type isSwapClaimView_SwapClaimView interface {
+ isSwapClaimView_SwapClaimView()
+ MarshalTo([]byte) (int, error)
+ Size() int
+}
+
+type SwapClaimView_Visible_ struct {
+ Visible *SwapClaimView_Visible `protobuf:"bytes,1,opt,name=visible,proto3,oneof" json:"visible,omitempty"`
+}
+type SwapClaimView_Opaque_ struct {
+ Opaque *SwapClaimView_Opaque `protobuf:"bytes,2,opt,name=opaque,proto3,oneof" json:"opaque,omitempty"`
+}
+
+func (*SwapClaimView_Visible_) isSwapClaimView_SwapClaimView() {}
+func (*SwapClaimView_Opaque_) isSwapClaimView_SwapClaimView() {}
+
+func (m *SwapClaimView) GetSwapClaimView() isSwapClaimView_SwapClaimView {
+ if m != nil {
+ return m.SwapClaimView
+ }
+ return nil
+}
+
+func (m *SwapClaimView) GetVisible() *SwapClaimView_Visible {
+ if x, ok := m.GetSwapClaimView().(*SwapClaimView_Visible_); ok {
+ return x.Visible
+ }
+ return nil
+}
+
+func (m *SwapClaimView) GetOpaque() *SwapClaimView_Opaque {
+ if x, ok := m.GetSwapClaimView().(*SwapClaimView_Opaque_); ok {
+ return x.Opaque
+ }
+ return nil
+}
+
+// XXX_OneofWrappers is for the internal use of the proto package.
+func (*SwapClaimView) XXX_OneofWrappers() []interface{} {
+ return []interface{}{
+ (*SwapClaimView_Visible_)(nil),
+ (*SwapClaimView_Opaque_)(nil),
+ }
+}
+
+type SwapClaimView_Visible struct {
+ SwapClaim *SwapClaim `protobuf:"bytes,1,opt,name=swap_claim,json=swapClaim,proto3" json:"swap_claim,omitempty"`
+ Output_1 *v1alpha1.NoteView `protobuf:"bytes,2,opt,name=output_1,json=output1,proto3" json:"output_1,omitempty"`
+ Output_2 *v1alpha1.NoteView `protobuf:"bytes,3,opt,name=output_2,json=output2,proto3" json:"output_2,omitempty"`
+}
+
+func (m *SwapClaimView_Visible) Reset() { *m = SwapClaimView_Visible{} }
+func (m *SwapClaimView_Visible) String() string { return proto.CompactTextString(m) }
+func (*SwapClaimView_Visible) ProtoMessage() {}
+func (*SwapClaimView_Visible) Descriptor() ([]byte, []int) {
+ return fileDescriptor_d1eba752ca2f0d70, []int{9, 0}
+}
+func (m *SwapClaimView_Visible) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *SwapClaimView_Visible) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_SwapClaimView_Visible.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *SwapClaimView_Visible) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_SwapClaimView_Visible.Merge(m, src)
+}
+func (m *SwapClaimView_Visible) XXX_Size() int {
+ return m.Size()
+}
+func (m *SwapClaimView_Visible) XXX_DiscardUnknown() {
+ xxx_messageInfo_SwapClaimView_Visible.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_SwapClaimView_Visible proto.InternalMessageInfo
+
+func (m *SwapClaimView_Visible) GetSwapClaim() *SwapClaim {
+ if m != nil {
+ return m.SwapClaim
+ }
+ return nil
+}
+
+func (m *SwapClaimView_Visible) GetOutput_1() *v1alpha1.NoteView {
+ if m != nil {
+ return m.Output_1
+ }
+ return nil
+}
+
+func (m *SwapClaimView_Visible) GetOutput_2() *v1alpha1.NoteView {
+ if m != nil {
+ return m.Output_2
+ }
+ return nil
+}
+
+type SwapClaimView_Opaque struct {
+ SwapClaim *SwapClaim `protobuf:"bytes,1,opt,name=swap_claim,json=swapClaim,proto3" json:"swap_claim,omitempty"`
+}
+
+func (m *SwapClaimView_Opaque) Reset() { *m = SwapClaimView_Opaque{} }
+func (m *SwapClaimView_Opaque) String() string { return proto.CompactTextString(m) }
+func (*SwapClaimView_Opaque) ProtoMessage() {}
+func (*SwapClaimView_Opaque) Descriptor() ([]byte, []int) {
+ return fileDescriptor_d1eba752ca2f0d70, []int{9, 1}
+}
+func (m *SwapClaimView_Opaque) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *SwapClaimView_Opaque) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_SwapClaimView_Opaque.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *SwapClaimView_Opaque) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_SwapClaimView_Opaque.Merge(m, src)
+}
+func (m *SwapClaimView_Opaque) XXX_Size() int {
+ return m.Size()
+}
+func (m *SwapClaimView_Opaque) XXX_DiscardUnknown() {
+ xxx_messageInfo_SwapClaimView_Opaque.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_SwapClaimView_Opaque proto.InternalMessageInfo
+
+func (m *SwapClaimView_Opaque) GetSwapClaim() *SwapClaim {
+ if m != nil {
+ return m.SwapClaim
+ }
+ return nil
+}
+
+// Holds two asset IDs. Ordering doesn't reflect trading direction. Instead, we
+// require `asset_1 < asset_2` as field elements, to ensure a canonical
+// representation of an unordered pair.
+type TradingPair struct {
+ // The first asset of the pair.
+ Asset_1 *v1alpha1.AssetId `protobuf:"bytes,1,opt,name=asset_1,json=asset1,proto3" json:"asset_1,omitempty"`
+ // The second asset of the pair.
+ Asset_2 *v1alpha1.AssetId `protobuf:"bytes,2,opt,name=asset_2,json=asset2,proto3" json:"asset_2,omitempty"`
+}
+
+func (m *TradingPair) Reset() { *m = TradingPair{} }
+func (m *TradingPair) String() string { return proto.CompactTextString(m) }
+func (*TradingPair) ProtoMessage() {}
+func (*TradingPair) Descriptor() ([]byte, []int) {
+ return fileDescriptor_d1eba752ca2f0d70, []int{10}
+}
+func (m *TradingPair) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *TradingPair) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_TradingPair.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *TradingPair) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_TradingPair.Merge(m, src)
+}
+func (m *TradingPair) XXX_Size() int {
+ return m.Size()
+}
+func (m *TradingPair) XXX_DiscardUnknown() {
+ xxx_messageInfo_TradingPair.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_TradingPair proto.InternalMessageInfo
+
+func (m *TradingPair) GetAsset_1() *v1alpha1.AssetId {
+ if m != nil {
+ return m.Asset_1
+ }
+ return nil
+}
+
+func (m *TradingPair) GetAsset_2() *v1alpha1.AssetId {
+ if m != nil {
+ return m.Asset_2
+ }
+ return nil
+}
+
+// Encodes a trading pair starting from asset `start`
+// and ending on asset `end`.
+type DirectedTradingPair struct {
+ // The start asset of the pair.
+ Start *v1alpha1.AssetId `protobuf:"bytes,1,opt,name=start,proto3" json:"start,omitempty"`
+ // The end asset of the pair.
+ End *v1alpha1.AssetId `protobuf:"bytes,2,opt,name=end,proto3" json:"end,omitempty"`
+}
+
+func (m *DirectedTradingPair) Reset() { *m = DirectedTradingPair{} }
+func (m *DirectedTradingPair) String() string { return proto.CompactTextString(m) }
+func (*DirectedTradingPair) ProtoMessage() {}
+func (*DirectedTradingPair) Descriptor() ([]byte, []int) {
+ return fileDescriptor_d1eba752ca2f0d70, []int{11}
+}
+func (m *DirectedTradingPair) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *DirectedTradingPair) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_DirectedTradingPair.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *DirectedTradingPair) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_DirectedTradingPair.Merge(m, src)
+}
+func (m *DirectedTradingPair) XXX_Size() int {
+ return m.Size()
+}
+func (m *DirectedTradingPair) XXX_DiscardUnknown() {
+ xxx_messageInfo_DirectedTradingPair.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_DirectedTradingPair proto.InternalMessageInfo
+
+func (m *DirectedTradingPair) GetStart() *v1alpha1.AssetId {
+ if m != nil {
+ return m.Start
+ }
+ return nil
+}
+
+func (m *DirectedTradingPair) GetEnd() *v1alpha1.AssetId {
+ if m != nil {
+ return m.End
+ }
+ return nil
+}
+
+// Records the result of a batch swap on-chain.
+//
+// Used as a public input to a swap claim proof, as it implies the effective
+// clearing price for the batch.
+type BatchSwapOutputData struct {
+ // The total amount of asset 1 that was input to the batch swap.
+ Delta_1 *v1alpha1.Amount `protobuf:"bytes,1,opt,name=delta_1,json=delta1,proto3" json:"delta_1,omitempty"`
+ // The total amount of asset 2 that was input to the batch swap.
+ Delta_2 *v1alpha1.Amount `protobuf:"bytes,2,opt,name=delta_2,json=delta2,proto3" json:"delta_2,omitempty"`
+ // The total amount of asset 1 that was output from the batch swap for 2=>1 trades.
+ Lambda_1 *v1alpha1.Amount `protobuf:"bytes,3,opt,name=lambda_1,json=lambda1,proto3" json:"lambda_1,omitempty"`
+ // The total amount of asset 2 that was output from the batch swap for 1=>2 trades.
+ Lambda_2 *v1alpha1.Amount `protobuf:"bytes,4,opt,name=lambda_2,json=lambda2,proto3" json:"lambda_2,omitempty"`
+ // The total amount of asset 1 that was returned unfilled from the batch swap for 1=>2 trades.
+ Unfilled_1 *v1alpha1.Amount `protobuf:"bytes,5,opt,name=unfilled_1,json=unfilled1,proto3" json:"unfilled_1,omitempty"`
+ // The total amount of asset 2 that was returned unfilled from the batch swap for 2=>1 trades.
+ Unfilled_2 *v1alpha1.Amount `protobuf:"bytes,6,opt,name=unfilled_2,json=unfilled2,proto3" json:"unfilled_2,omitempty"`
+ // The height for which the batch swap data is valid.
+ Height uint64 `protobuf:"varint,7,opt,name=height,proto3" json:"height,omitempty"`
+ // The trading pair associated with the batch swap.
+ TradingPair *TradingPair `protobuf:"bytes,8,opt,name=trading_pair,json=tradingPair,proto3" json:"trading_pair,omitempty"`
+ // The starting block height of the epoch for which the batch swap data is valid.
+ EpochStartingHeight uint64 `protobuf:"varint,9,opt,name=epoch_starting_height,json=epochStartingHeight,proto3" json:"epoch_starting_height,omitempty"`
+}
+
+func (m *BatchSwapOutputData) Reset() { *m = BatchSwapOutputData{} }
+func (m *BatchSwapOutputData) String() string { return proto.CompactTextString(m) }
+func (*BatchSwapOutputData) ProtoMessage() {}
+func (*BatchSwapOutputData) Descriptor() ([]byte, []int) {
+ return fileDescriptor_d1eba752ca2f0d70, []int{12}
+}
+func (m *BatchSwapOutputData) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *BatchSwapOutputData) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_BatchSwapOutputData.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *BatchSwapOutputData) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_BatchSwapOutputData.Merge(m, src)
+}
+func (m *BatchSwapOutputData) XXX_Size() int {
+ return m.Size()
+}
+func (m *BatchSwapOutputData) XXX_DiscardUnknown() {
+ xxx_messageInfo_BatchSwapOutputData.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_BatchSwapOutputData proto.InternalMessageInfo
+
+func (m *BatchSwapOutputData) GetDelta_1() *v1alpha1.Amount {
+ if m != nil {
+ return m.Delta_1
+ }
+ return nil
+}
+
+func (m *BatchSwapOutputData) GetDelta_2() *v1alpha1.Amount {
+ if m != nil {
+ return m.Delta_2
+ }
+ return nil
+}
+
+func (m *BatchSwapOutputData) GetLambda_1() *v1alpha1.Amount {
+ if m != nil {
+ return m.Lambda_1
+ }
+ return nil
+}
+
+func (m *BatchSwapOutputData) GetLambda_2() *v1alpha1.Amount {
+ if m != nil {
+ return m.Lambda_2
+ }
+ return nil
+}
+
+func (m *BatchSwapOutputData) GetUnfilled_1() *v1alpha1.Amount {
+ if m != nil {
+ return m.Unfilled_1
+ }
+ return nil
+}
+
+func (m *BatchSwapOutputData) GetUnfilled_2() *v1alpha1.Amount {
+ if m != nil {
+ return m.Unfilled_2
+ }
+ return nil
+}
+
+func (m *BatchSwapOutputData) GetHeight() uint64 {
+ if m != nil {
+ return m.Height
+ }
+ return 0
+}
+
+func (m *BatchSwapOutputData) GetTradingPair() *TradingPair {
+ if m != nil {
+ return m.TradingPair
+ }
+ return nil
+}
+
+func (m *BatchSwapOutputData) GetEpochStartingHeight() uint64 {
+ if m != nil {
+ return m.EpochStartingHeight
+ }
+ return 0
+}
+
+// The trading function for a specific pair.
+// For a pair (asset_1, asset_2), a trading function is defined by:
+// `phi(R) = p*R_1 + q*R_2` and `gamma = 1 - fee`.
+// The trading function is frequently referred to as "phi".
+type TradingFunction struct {
+ Component *BareTradingFunction `protobuf:"bytes,1,opt,name=component,proto3" json:"component,omitempty"`
+ Pair *TradingPair `protobuf:"bytes,2,opt,name=pair,proto3" json:"pair,omitempty"`
+}
+
+func (m *TradingFunction) Reset() { *m = TradingFunction{} }
+func (m *TradingFunction) String() string { return proto.CompactTextString(m) }
+func (*TradingFunction) ProtoMessage() {}
+func (*TradingFunction) Descriptor() ([]byte, []int) {
+ return fileDescriptor_d1eba752ca2f0d70, []int{13}
+}
+func (m *TradingFunction) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *TradingFunction) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_TradingFunction.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *TradingFunction) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_TradingFunction.Merge(m, src)
+}
+func (m *TradingFunction) XXX_Size() int {
+ return m.Size()
+}
+func (m *TradingFunction) XXX_DiscardUnknown() {
+ xxx_messageInfo_TradingFunction.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_TradingFunction proto.InternalMessageInfo
+
+func (m *TradingFunction) GetComponent() *BareTradingFunction {
+ if m != nil {
+ return m.Component
+ }
+ return nil
+}
+
+func (m *TradingFunction) GetPair() *TradingPair {
+ if m != nil {
+ return m.Pair
+ }
+ return nil
+}
+
+// The minimum amount of data describing a trading function.
+//
+// This implicitly treats the trading function as being between assets 1 and 2,
+// without specifying what those assets are, to avoid duplicating data (each
+// asset ID alone is twice the size of the trading function).
+type BareTradingFunction struct {
+ Fee uint32 `protobuf:"varint,1,opt,name=fee,proto3" json:"fee,omitempty"`
+ // This is not actually an amount, it's an integer the same width as an amount
+ P *v1alpha1.Amount `protobuf:"bytes,2,opt,name=p,proto3" json:"p,omitempty"`
+ // This is not actually an amount, it's an integer the same width as an amount
+ Q *v1alpha1.Amount `protobuf:"bytes,3,opt,name=q,proto3" json:"q,omitempty"`
+}
+
+func (m *BareTradingFunction) Reset() { *m = BareTradingFunction{} }
+func (m *BareTradingFunction) String() string { return proto.CompactTextString(m) }
+func (*BareTradingFunction) ProtoMessage() {}
+func (*BareTradingFunction) Descriptor() ([]byte, []int) {
+ return fileDescriptor_d1eba752ca2f0d70, []int{14}
+}
+func (m *BareTradingFunction) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *BareTradingFunction) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_BareTradingFunction.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *BareTradingFunction) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_BareTradingFunction.Merge(m, src)
+}
+func (m *BareTradingFunction) XXX_Size() int {
+ return m.Size()
+}
+func (m *BareTradingFunction) XXX_DiscardUnknown() {
+ xxx_messageInfo_BareTradingFunction.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_BareTradingFunction proto.InternalMessageInfo
+
+func (m *BareTradingFunction) GetFee() uint32 {
+ if m != nil {
+ return m.Fee
+ }
+ return 0
+}
+
+func (m *BareTradingFunction) GetP() *v1alpha1.Amount {
+ if m != nil {
+ return m.P
+ }
+ return nil
+}
+
+func (m *BareTradingFunction) GetQ() *v1alpha1.Amount {
+ if m != nil {
+ return m.Q
+ }
+ return nil
+}
+
+// The reserves of a position.
+//
+// Like a position, this implicitly treats the trading function as being
+// between assets 1 and 2, without specifying what those assets are, to avoid
+// duplicating data (each asset ID alone is four times the size of the
+// reserves).
+type Reserves struct {
+ R1 *v1alpha1.Amount `protobuf:"bytes,1,opt,name=r1,proto3" json:"r1,omitempty"`
+ R2 *v1alpha1.Amount `protobuf:"bytes,2,opt,name=r2,proto3" json:"r2,omitempty"`
+}
+
+func (m *Reserves) Reset() { *m = Reserves{} }
+func (m *Reserves) String() string { return proto.CompactTextString(m) }
+func (*Reserves) ProtoMessage() {}
+func (*Reserves) Descriptor() ([]byte, []int) {
+ return fileDescriptor_d1eba752ca2f0d70, []int{15}
+}
+func (m *Reserves) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *Reserves) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_Reserves.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *Reserves) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_Reserves.Merge(m, src)
+}
+func (m *Reserves) XXX_Size() int {
+ return m.Size()
+}
+func (m *Reserves) XXX_DiscardUnknown() {
+ xxx_messageInfo_Reserves.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_Reserves proto.InternalMessageInfo
+
+func (m *Reserves) GetR1() *v1alpha1.Amount {
+ if m != nil {
+ return m.R1
+ }
+ return nil
+}
+
+func (m *Reserves) GetR2() *v1alpha1.Amount {
+ if m != nil {
+ return m.R2
+ }
+ return nil
+}
+
+// Data identifying a position.
+type Position struct {
+ Phi *TradingFunction `protobuf:"bytes,1,opt,name=phi,proto3" json:"phi,omitempty"`
+ // A random value used to disambiguate different positions with the exact same
+ // trading function. The chain should reject newly created positions with the
+ // same nonce as an existing position. This ensures that `PositionId`s will
+ // be unique, and allows us to track position ownership with a
+ // sequence of stateful NFTs based on the `PositionId`.
+ Nonce []byte `protobuf:"bytes,2,opt,name=nonce,proto3" json:"nonce,omitempty"`
+ State *PositionState `protobuf:"bytes,3,opt,name=state,proto3" json:"state,omitempty"`
+ Reserves *Reserves `protobuf:"bytes,4,opt,name=reserves,proto3" json:"reserves,omitempty"`
+ // / If set to true, the position is a limit-order and will be closed
+ // / immediately after being filled.
+ CloseOnFill bool `protobuf:"varint,5,opt,name=close_on_fill,json=closeOnFill,proto3" json:"close_on_fill,omitempty"`
+}
+
+func (m *Position) Reset() { *m = Position{} }
+func (m *Position) String() string { return proto.CompactTextString(m) }
+func (*Position) ProtoMessage() {}
+func (*Position) Descriptor() ([]byte, []int) {
+ return fileDescriptor_d1eba752ca2f0d70, []int{16}
+}
+func (m *Position) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *Position) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_Position.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *Position) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_Position.Merge(m, src)
+}
+func (m *Position) XXX_Size() int {
+ return m.Size()
+}
+func (m *Position) XXX_DiscardUnknown() {
+ xxx_messageInfo_Position.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_Position proto.InternalMessageInfo
+
+func (m *Position) GetPhi() *TradingFunction {
+ if m != nil {
+ return m.Phi
+ }
+ return nil
+}
+
+func (m *Position) GetNonce() []byte {
+ if m != nil {
+ return m.Nonce
+ }
+ return nil
+}
+
+func (m *Position) GetState() *PositionState {
+ if m != nil {
+ return m.State
+ }
+ return nil
+}
+
+func (m *Position) GetReserves() *Reserves {
+ if m != nil {
+ return m.Reserves
+ }
+ return nil
+}
+
+func (m *Position) GetCloseOnFill() bool {
+ if m != nil {
+ return m.CloseOnFill
+ }
+ return false
+}
+
+// A hash of a `Position`.
+type PositionId struct {
+ // The bytes of the position ID.
+ Inner []byte `protobuf:"bytes,1,opt,name=inner,proto3" json:"inner,omitempty"`
+ // Alternatively, a Bech32m-encoded string representation of the `inner`
+ // bytes.
+ //
+ // NOTE: implementations are not required to support parsing this field.
+ // Implementations should prefer to encode the bytes in all messages they
+ // produce. Implementations must not accept messages with both `inner` and
+ // `alt_bech32m` set.
+ AltBech32M string `protobuf:"bytes,2,opt,name=alt_bech32m,json=altBech32m,proto3" json:"alt_bech32m,omitempty"`
+}
+
+func (m *PositionId) Reset() { *m = PositionId{} }
+func (m *PositionId) String() string { return proto.CompactTextString(m) }
+func (*PositionId) ProtoMessage() {}
+func (*PositionId) Descriptor() ([]byte, []int) {
+ return fileDescriptor_d1eba752ca2f0d70, []int{17}
+}
+func (m *PositionId) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *PositionId) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_PositionId.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *PositionId) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_PositionId.Merge(m, src)
+}
+func (m *PositionId) XXX_Size() int {
+ return m.Size()
+}
+func (m *PositionId) XXX_DiscardUnknown() {
+ xxx_messageInfo_PositionId.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_PositionId proto.InternalMessageInfo
+
+func (m *PositionId) GetInner() []byte {
+ if m != nil {
+ return m.Inner
+ }
+ return nil
+}
+
+func (m *PositionId) GetAltBech32M() string {
+ if m != nil {
+ return m.AltBech32M
+ }
+ return ""
+}
+
+// The state of a position.
+type PositionState struct {
+ State PositionState_PositionStateEnum `protobuf:"varint,1,opt,name=state,proto3,enum=penumbra.core.dex.v1alpha1.PositionState_PositionStateEnum" json:"state,omitempty"`
+}
+
+func (m *PositionState) Reset() { *m = PositionState{} }
+func (m *PositionState) String() string { return proto.CompactTextString(m) }
+func (*PositionState) ProtoMessage() {}
+func (*PositionState) Descriptor() ([]byte, []int) {
+ return fileDescriptor_d1eba752ca2f0d70, []int{18}
+}
+func (m *PositionState) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *PositionState) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_PositionState.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *PositionState) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_PositionState.Merge(m, src)
+}
+func (m *PositionState) XXX_Size() int {
+ return m.Size()
+}
+func (m *PositionState) XXX_DiscardUnknown() {
+ xxx_messageInfo_PositionState.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_PositionState proto.InternalMessageInfo
+
+func (m *PositionState) GetState() PositionState_PositionStateEnum {
+ if m != nil {
+ return m.State
+ }
+ return PositionState_POSITION_STATE_ENUM_UNSPECIFIED
+}
+
+// An LPNFT tracking both ownership and state of a position.
+//
+// Tracking the state as part of the LPNFT means that all LP-related actions can
+// be authorized by spending funds: a state transition (e.g., closing a
+// position) is modeled as spending an "open position LPNFT" and minting a
+// "closed position LPNFT" for the same (globally unique) position ID.
+//
+// This means that the LP mechanics can be agnostic to the mechanism used to
+// record custody and spend authorization. For instance, they can be recorded
+// in the shielded pool, where custody is based on off-chain keys, or they could
+// be recorded in a programmatic on-chain account (in the future, e.g., to
+// support interchain accounts). This also means that LP-related actions don't
+// require any cryptographic implementation (proofs, signatures, etc), other
+// than hooking into the value commitment mechanism used for transaction
+// balances.
+type LpNft struct {
+ PositionId *PositionId `protobuf:"bytes,1,opt,name=position_id,json=positionId,proto3" json:"position_id,omitempty"`
+ State *PositionState `protobuf:"bytes,2,opt,name=state,proto3" json:"state,omitempty"`
+}
+
+func (m *LpNft) Reset() { *m = LpNft{} }
+func (m *LpNft) String() string { return proto.CompactTextString(m) }
+func (*LpNft) ProtoMessage() {}
+func (*LpNft) Descriptor() ([]byte, []int) {
+ return fileDescriptor_d1eba752ca2f0d70, []int{19}
+}
+func (m *LpNft) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *LpNft) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_LpNft.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *LpNft) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_LpNft.Merge(m, src)
+}
+func (m *LpNft) XXX_Size() int {
+ return m.Size()
+}
+func (m *LpNft) XXX_DiscardUnknown() {
+ xxx_messageInfo_LpNft.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_LpNft proto.InternalMessageInfo
+
+func (m *LpNft) GetPositionId() *PositionId {
+ if m != nil {
+ return m.PositionId
+ }
+ return nil
+}
+
+func (m *LpNft) GetState() *PositionState {
+ if m != nil {
+ return m.State
+ }
+ return nil
+}
+
+// A transaction action that opens a new position.
+//
+// This action's contribution to the transaction's value balance is to consume
+// the initial reserves and contribute an opened position NFT.
+type PositionOpen struct {
+ // Contains the data defining the position, sufficient to compute its `PositionId`.
+ //
+ // Positions are immutable, so the `PositionData` (and hence the `PositionId`)
+ // are unchanged over the entire lifetime of the position.
+ Position *Position `protobuf:"bytes,1,opt,name=position,proto3" json:"position,omitempty"`
+}
+
+func (m *PositionOpen) Reset() { *m = PositionOpen{} }
+func (m *PositionOpen) String() string { return proto.CompactTextString(m) }
+func (*PositionOpen) ProtoMessage() {}
+func (*PositionOpen) Descriptor() ([]byte, []int) {
+ return fileDescriptor_d1eba752ca2f0d70, []int{20}
+}
+func (m *PositionOpen) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *PositionOpen) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_PositionOpen.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *PositionOpen) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_PositionOpen.Merge(m, src)
+}
+func (m *PositionOpen) XXX_Size() int {
+ return m.Size()
+}
+func (m *PositionOpen) XXX_DiscardUnknown() {
+ xxx_messageInfo_PositionOpen.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_PositionOpen proto.InternalMessageInfo
+
+func (m *PositionOpen) GetPosition() *Position {
+ if m != nil {
+ return m.Position
+ }
+ return nil
+}
+
+// A transaction action that closes a position.
+//
+// This action's contribution to the transaction's value balance is to consume
+// an opened position NFT and contribute a closed position NFT.
+//
+// Closing a position does not immediately withdraw funds, because Penumbra
+// transactions (like any ZK transaction model) are early-binding: the prover
+// must know the state transition they prove knowledge of, and they cannot know
+// the final reserves with certainty until after the position has been deactivated.
+type PositionClose struct {
+ PositionId *PositionId `protobuf:"bytes,1,opt,name=position_id,json=positionId,proto3" json:"position_id,omitempty"`
+}
+
+func (m *PositionClose) Reset() { *m = PositionClose{} }
+func (m *PositionClose) String() string { return proto.CompactTextString(m) }
+func (*PositionClose) ProtoMessage() {}
+func (*PositionClose) Descriptor() ([]byte, []int) {
+ return fileDescriptor_d1eba752ca2f0d70, []int{21}
+}
+func (m *PositionClose) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *PositionClose) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_PositionClose.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *PositionClose) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_PositionClose.Merge(m, src)
+}
+func (m *PositionClose) XXX_Size() int {
+ return m.Size()
+}
+func (m *PositionClose) XXX_DiscardUnknown() {
+ xxx_messageInfo_PositionClose.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_PositionClose proto.InternalMessageInfo
+
+func (m *PositionClose) GetPositionId() *PositionId {
+ if m != nil {
+ return m.PositionId
+ }
+ return nil
+}
+
+// A transaction action that withdraws funds from a closed position.
+//
+// This action's contribution to the transaction's value balance is to consume a
+// closed position NFT and contribute a withdrawn position NFT, as well as all
+// of the funds that were in the position at the time of closing.
+type PositionWithdraw struct {
+ PositionId *PositionId `protobuf:"bytes,1,opt,name=position_id,json=positionId,proto3" json:"position_id,omitempty"`
+ // A transparent (zero blinding factor) commitment to the position's final reserves and fees.
+ //
+ // The chain will check this commitment by recomputing it with the on-chain state.
+ ReservesCommitment *v1alpha1.BalanceCommitment `protobuf:"bytes,2,opt,name=reserves_commitment,json=reservesCommitment,proto3" json:"reserves_commitment,omitempty"`
+}
+
+func (m *PositionWithdraw) Reset() { *m = PositionWithdraw{} }
+func (m *PositionWithdraw) String() string { return proto.CompactTextString(m) }
+func (*PositionWithdraw) ProtoMessage() {}
+func (*PositionWithdraw) Descriptor() ([]byte, []int) {
+ return fileDescriptor_d1eba752ca2f0d70, []int{22}
+}
+func (m *PositionWithdraw) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *PositionWithdraw) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_PositionWithdraw.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *PositionWithdraw) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_PositionWithdraw.Merge(m, src)
+}
+func (m *PositionWithdraw) XXX_Size() int {
+ return m.Size()
+}
+func (m *PositionWithdraw) XXX_DiscardUnknown() {
+ xxx_messageInfo_PositionWithdraw.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_PositionWithdraw proto.InternalMessageInfo
+
+func (m *PositionWithdraw) GetPositionId() *PositionId {
+ if m != nil {
+ return m.PositionId
+ }
+ return nil
+}
+
+func (m *PositionWithdraw) GetReservesCommitment() *v1alpha1.BalanceCommitment {
+ if m != nil {
+ return m.ReservesCommitment
+ }
+ return nil
+}
+
+// A transaction action that claims retroactive rewards for a historical
+// position.
+//
+// This action's contribution to the transaction's value balance is to consume a
+// withdrawn position NFT and contribute its reward balance.
+type PositionRewardClaim struct {
+ PositionId *PositionId `protobuf:"bytes,1,opt,name=position_id,json=positionId,proto3" json:"position_id,omitempty"`
+ // A transparent (zero blinding factor) commitment to the position's accumulated rewards.
+ //
+ // The chain will check this commitment by recomputing it with the on-chain state.
+ RewardsCommitment *v1alpha1.BalanceCommitment `protobuf:"bytes,2,opt,name=rewards_commitment,json=rewardsCommitment,proto3" json:"rewards_commitment,omitempty"`
+}
+
+func (m *PositionRewardClaim) Reset() { *m = PositionRewardClaim{} }
+func (m *PositionRewardClaim) String() string { return proto.CompactTextString(m) }
+func (*PositionRewardClaim) ProtoMessage() {}
+func (*PositionRewardClaim) Descriptor() ([]byte, []int) {
+ return fileDescriptor_d1eba752ca2f0d70, []int{23}
+}
+func (m *PositionRewardClaim) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *PositionRewardClaim) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_PositionRewardClaim.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *PositionRewardClaim) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_PositionRewardClaim.Merge(m, src)
+}
+func (m *PositionRewardClaim) XXX_Size() int {
+ return m.Size()
+}
+func (m *PositionRewardClaim) XXX_DiscardUnknown() {
+ xxx_messageInfo_PositionRewardClaim.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_PositionRewardClaim proto.InternalMessageInfo
+
+func (m *PositionRewardClaim) GetPositionId() *PositionId {
+ if m != nil {
+ return m.PositionId
+ }
+ return nil
+}
+
+func (m *PositionRewardClaim) GetRewardsCommitment() *v1alpha1.BalanceCommitment {
+ if m != nil {
+ return m.RewardsCommitment
+ }
+ return nil
+}
+
+// Contains the entire execution of a particular swap.
+type SwapExecution struct {
+ Traces []*SwapExecution_Trace `protobuf:"bytes,1,rep,name=traces,proto3" json:"traces,omitempty"`
+ // The total input amount for this execution.
+ Input *v1alpha1.Value `protobuf:"bytes,2,opt,name=input,proto3" json:"input,omitempty"`
+ // The total output amount for this execution.
+ Output *v1alpha1.Value `protobuf:"bytes,3,opt,name=output,proto3" json:"output,omitempty"`
+}
+
+func (m *SwapExecution) Reset() { *m = SwapExecution{} }
+func (m *SwapExecution) String() string { return proto.CompactTextString(m) }
+func (*SwapExecution) ProtoMessage() {}
+func (*SwapExecution) Descriptor() ([]byte, []int) {
+ return fileDescriptor_d1eba752ca2f0d70, []int{24}
+}
+func (m *SwapExecution) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *SwapExecution) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_SwapExecution.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *SwapExecution) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_SwapExecution.Merge(m, src)
+}
+func (m *SwapExecution) XXX_Size() int {
+ return m.Size()
+}
+func (m *SwapExecution) XXX_DiscardUnknown() {
+ xxx_messageInfo_SwapExecution.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_SwapExecution proto.InternalMessageInfo
+
+func (m *SwapExecution) GetTraces() []*SwapExecution_Trace {
+ if m != nil {
+ return m.Traces
+ }
+ return nil
+}
+
+func (m *SwapExecution) GetInput() *v1alpha1.Value {
+ if m != nil {
+ return m.Input
+ }
+ return nil
+}
+
+func (m *SwapExecution) GetOutput() *v1alpha1.Value {
+ if m != nil {
+ return m.Output
+ }
+ return nil
+}
+
+// Contains all individual steps consisting of a trade trace.
+type SwapExecution_Trace struct {
+ // Each step in the trade trace.
+ Value []*v1alpha1.Value `protobuf:"bytes,1,rep,name=value,proto3" json:"value,omitempty"`
+}
+
+func (m *SwapExecution_Trace) Reset() { *m = SwapExecution_Trace{} }
+func (m *SwapExecution_Trace) String() string { return proto.CompactTextString(m) }
+func (*SwapExecution_Trace) ProtoMessage() {}
+func (*SwapExecution_Trace) Descriptor() ([]byte, []int) {
+ return fileDescriptor_d1eba752ca2f0d70, []int{24, 0}
+}
+func (m *SwapExecution_Trace) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *SwapExecution_Trace) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_SwapExecution_Trace.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *SwapExecution_Trace) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_SwapExecution_Trace.Merge(m, src)
+}
+func (m *SwapExecution_Trace) XXX_Size() int {
+ return m.Size()
+}
+func (m *SwapExecution_Trace) XXX_DiscardUnknown() {
+ xxx_messageInfo_SwapExecution_Trace.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_SwapExecution_Trace proto.InternalMessageInfo
+
+func (m *SwapExecution_Trace) GetValue() []*v1alpha1.Value {
+ if m != nil {
+ return m.Value
+ }
+ return nil
+}
+
+// Contains private and public data for withdrawing funds from a closed position.
+type PositionWithdrawPlan struct {
+ Reserves *Reserves `protobuf:"bytes,1,opt,name=reserves,proto3" json:"reserves,omitempty"`
+ PositionId *PositionId `protobuf:"bytes,2,opt,name=position_id,json=positionId,proto3" json:"position_id,omitempty"`
+ Pair *TradingPair `protobuf:"bytes,3,opt,name=pair,proto3" json:"pair,omitempty"`
+}
+
+func (m *PositionWithdrawPlan) Reset() { *m = PositionWithdrawPlan{} }
+func (m *PositionWithdrawPlan) String() string { return proto.CompactTextString(m) }
+func (*PositionWithdrawPlan) ProtoMessage() {}
+func (*PositionWithdrawPlan) Descriptor() ([]byte, []int) {
+ return fileDescriptor_d1eba752ca2f0d70, []int{25}
+}
+func (m *PositionWithdrawPlan) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *PositionWithdrawPlan) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_PositionWithdrawPlan.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *PositionWithdrawPlan) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_PositionWithdrawPlan.Merge(m, src)
+}
+func (m *PositionWithdrawPlan) XXX_Size() int {
+ return m.Size()
+}
+func (m *PositionWithdrawPlan) XXX_DiscardUnknown() {
+ xxx_messageInfo_PositionWithdrawPlan.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_PositionWithdrawPlan proto.InternalMessageInfo
+
+func (m *PositionWithdrawPlan) GetReserves() *Reserves {
+ if m != nil {
+ return m.Reserves
+ }
+ return nil
+}
+
+func (m *PositionWithdrawPlan) GetPositionId() *PositionId {
+ if m != nil {
+ return m.PositionId
+ }
+ return nil
+}
+
+func (m *PositionWithdrawPlan) GetPair() *TradingPair {
+ if m != nil {
+ return m.Pair
+ }
+ return nil
+}
+
+// Contains private and public data for claiming rewards from a position.
+type PositionRewardClaimPlan struct {
+ Reserves *Reserves `protobuf:"bytes,1,opt,name=reserves,proto3" json:"reserves,omitempty"`
+}
+
+func (m *PositionRewardClaimPlan) Reset() { *m = PositionRewardClaimPlan{} }
+func (m *PositionRewardClaimPlan) String() string { return proto.CompactTextString(m) }
+func (*PositionRewardClaimPlan) ProtoMessage() {}
+func (*PositionRewardClaimPlan) Descriptor() ([]byte, []int) {
+ return fileDescriptor_d1eba752ca2f0d70, []int{26}
+}
+func (m *PositionRewardClaimPlan) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *PositionRewardClaimPlan) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_PositionRewardClaimPlan.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *PositionRewardClaimPlan) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_PositionRewardClaimPlan.Merge(m, src)
+}
+func (m *PositionRewardClaimPlan) XXX_Size() int {
+ return m.Size()
+}
+func (m *PositionRewardClaimPlan) XXX_DiscardUnknown() {
+ xxx_messageInfo_PositionRewardClaimPlan.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_PositionRewardClaimPlan proto.InternalMessageInfo
+
+func (m *PositionRewardClaimPlan) GetReserves() *Reserves {
+ if m != nil {
+ return m.Reserves
+ }
+ return nil
+}
+
+func init() {
+ proto.RegisterEnum("penumbra.core.dex.v1alpha1.PositionState_PositionStateEnum", PositionState_PositionStateEnum_name, PositionState_PositionStateEnum_value)
+ proto.RegisterType((*Swap)(nil), "penumbra.core.dex.v1alpha1.Swap")
+ proto.RegisterType((*SwapClaim)(nil), "penumbra.core.dex.v1alpha1.SwapClaim")
+ proto.RegisterType((*SwapClaimBody)(nil), "penumbra.core.dex.v1alpha1.SwapClaimBody")
+ proto.RegisterType((*SwapBody)(nil), "penumbra.core.dex.v1alpha1.SwapBody")
+ proto.RegisterType((*SwapPayload)(nil), "penumbra.core.dex.v1alpha1.SwapPayload")
+ proto.RegisterType((*SwapPlaintext)(nil), "penumbra.core.dex.v1alpha1.SwapPlaintext")
+ proto.RegisterType((*SwapPlan)(nil), "penumbra.core.dex.v1alpha1.SwapPlan")
+ proto.RegisterType((*SwapClaimPlan)(nil), "penumbra.core.dex.v1alpha1.SwapClaimPlan")
+ proto.RegisterType((*SwapView)(nil), "penumbra.core.dex.v1alpha1.SwapView")
+ proto.RegisterType((*SwapView_Visible)(nil), "penumbra.core.dex.v1alpha1.SwapView.Visible")
+ proto.RegisterType((*SwapView_Opaque)(nil), "penumbra.core.dex.v1alpha1.SwapView.Opaque")
+ proto.RegisterType((*SwapClaimView)(nil), "penumbra.core.dex.v1alpha1.SwapClaimView")
+ proto.RegisterType((*SwapClaimView_Visible)(nil), "penumbra.core.dex.v1alpha1.SwapClaimView.Visible")
+ proto.RegisterType((*SwapClaimView_Opaque)(nil), "penumbra.core.dex.v1alpha1.SwapClaimView.Opaque")
+ proto.RegisterType((*TradingPair)(nil), "penumbra.core.dex.v1alpha1.TradingPair")
+ proto.RegisterType((*DirectedTradingPair)(nil), "penumbra.core.dex.v1alpha1.DirectedTradingPair")
+ proto.RegisterType((*BatchSwapOutputData)(nil), "penumbra.core.dex.v1alpha1.BatchSwapOutputData")
+ proto.RegisterType((*TradingFunction)(nil), "penumbra.core.dex.v1alpha1.TradingFunction")
+ proto.RegisterType((*BareTradingFunction)(nil), "penumbra.core.dex.v1alpha1.BareTradingFunction")
+ proto.RegisterType((*Reserves)(nil), "penumbra.core.dex.v1alpha1.Reserves")
+ proto.RegisterType((*Position)(nil), "penumbra.core.dex.v1alpha1.Position")
+ proto.RegisterType((*PositionId)(nil), "penumbra.core.dex.v1alpha1.PositionId")
+ proto.RegisterType((*PositionState)(nil), "penumbra.core.dex.v1alpha1.PositionState")
+ proto.RegisterType((*LpNft)(nil), "penumbra.core.dex.v1alpha1.LpNft")
+ proto.RegisterType((*PositionOpen)(nil), "penumbra.core.dex.v1alpha1.PositionOpen")
+ proto.RegisterType((*PositionClose)(nil), "penumbra.core.dex.v1alpha1.PositionClose")
+ proto.RegisterType((*PositionWithdraw)(nil), "penumbra.core.dex.v1alpha1.PositionWithdraw")
+ proto.RegisterType((*PositionRewardClaim)(nil), "penumbra.core.dex.v1alpha1.PositionRewardClaim")
+ proto.RegisterType((*SwapExecution)(nil), "penumbra.core.dex.v1alpha1.SwapExecution")
+ proto.RegisterType((*SwapExecution_Trace)(nil), "penumbra.core.dex.v1alpha1.SwapExecution.Trace")
+ proto.RegisterType((*PositionWithdrawPlan)(nil), "penumbra.core.dex.v1alpha1.PositionWithdrawPlan")
+ proto.RegisterType((*PositionRewardClaimPlan)(nil), "penumbra.core.dex.v1alpha1.PositionRewardClaimPlan")
+}
+
+func init() {
+ proto.RegisterFile("penumbra/core/dex/v1alpha1/dex.proto", fileDescriptor_d1eba752ca2f0d70)
+}
+
+var fileDescriptor_d1eba752ca2f0d70 = []byte{
+ // 1824 bytes of a gzipped FileDescriptorProto
+ 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xdc, 0x59, 0xcd, 0x6f, 0x1b, 0xc7,
+ 0x15, 0xd7, 0x2e, 0x29, 0x8a, 0x7c, 0xa4, 0x14, 0x79, 0x94, 0xb6, 0x02, 0x8b, 0xc8, 0xce, 0xd6,
+ 0x4e, 0xdc, 0xa4, 0xa0, 0xc2, 0x75, 0x0a, 0x04, 0x72, 0x12, 0x47, 0xfc, 0x90, 0xc5, 0x24, 0xa2,
+ 0xd8, 0x91, 0x62, 0x17, 0xa9, 0xd1, 0xc5, 0x68, 0x77, 0x64, 0x2e, 0xb0, 0xdc, 0x5d, 0xef, 0x0e,
+ 0x25, 0xea, 0x5a, 0xf4, 0xe3, 0x54, 0xb4, 0x39, 0xf5, 0x54, 0x14, 0xe9, 0xb1, 0x7f, 0x43, 0x3f,
+ 0xae, 0x45, 0x4e, 0x06, 0x7a, 0x68, 0x4f, 0x45, 0x61, 0x1f, 0x0a, 0xf4, 0x2f, 0xe8, 0xa1, 0x87,
+ 0x62, 0x66, 0x67, 0xc8, 0x95, 0x44, 0x99, 0xa4, 0xac, 0x5e, 0x7a, 0xe3, 0xcc, 0xbc, 0xdf, 0x6f,
+ 0xdf, 0xd7, 0xbc, 0xf7, 0x76, 0x09, 0x37, 0x43, 0xea, 0xf7, 0x7b, 0x07, 0x11, 0x59, 0xb7, 0x83,
+ 0x88, 0xae, 0x3b, 0x74, 0xb0, 0x7e, 0x54, 0x25, 0x5e, 0xd8, 0x25, 0x55, 0xbe, 0xa8, 0x84, 0x51,
+ 0xc0, 0x02, 0x54, 0x56, 0x52, 0x15, 0x2e, 0x55, 0xe1, 0x07, 0x4a, 0xaa, 0xfc, 0xd6, 0x69, 0x06,
+ 0x3b, 0x3a, 0x09, 0x59, 0x30, 0x22, 0x49, 0xd6, 0x09, 0x8f, 0xf1, 0x23, 0x0d, 0xb2, 0x7b, 0xc7,
+ 0x24, 0x44, 0x1f, 0xc1, 0x7c, 0x18, 0x05, 0xc1, 0xe1, 0xaa, 0x76, 0x43, 0xbb, 0x5d, 0x34, 0xdf,
+ 0xaa, 0x9c, 0x7e, 0x80, 0x04, 0x29, 0x92, 0xca, 0xe7, 0x9f, 0x70, 0x54, 0x87, 0x23, 0x70, 0x02,
+ 0x44, 0xef, 0x41, 0xf6, 0x20, 0x70, 0x4e, 0x56, 0xb3, 0x82, 0xe0, 0x66, 0xe5, 0x62, 0x0d, 0x2b,
+ 0x1c, 0x5b, 0x0b, 0x9c, 0x13, 0x2c, 0x10, 0xc6, 0xcf, 0x34, 0x28, 0xf0, 0xad, 0xba, 0x47, 0xdc,
+ 0x1e, 0x7a, 0x35, 0xad, 0x49, 0x49, 0xb1, 0x7f, 0x20, 0xd9, 0x75, 0xc1, 0xfe, 0xed, 0x49, 0xec,
+ 0x82, 0x6a, 0xf4, 0x08, 0x74, 0x0b, 0x96, 0x68, 0x18, 0xd8, 0x5d, 0xcb, 0xe9, 0x47, 0x84, 0xb9,
+ 0x81, 0xbf, 0xba, 0x70, 0x43, 0xbb, 0x9d, 0xc5, 0x8b, 0x62, 0xb7, 0x21, 0x37, 0x8d, 0xdf, 0x64,
+ 0x60, 0xf1, 0x14, 0x1c, 0x6d, 0x41, 0xc1, 0xef, 0x7b, 0x9e, 0x7b, 0xe8, 0xd2, 0x48, 0xfa, 0xe6,
+ 0xf6, 0x04, 0xdf, 0xb4, 0x95, 0x3c, 0x1e, 0x41, 0xd1, 0xbb, 0x90, 0x39, 0xa4, 0x54, 0xaa, 0x6f,
+ 0x4c, 0x60, 0xd8, 0xa2, 0x14, 0x73, 0x71, 0xf4, 0x43, 0x58, 0x09, 0xfa, 0x2c, 0xec, 0x33, 0xab,
+ 0x6a, 0xd9, 0x41, 0xaf, 0xe7, 0xb2, 0x1e, 0xf5, 0xd9, 0x6a, 0x46, 0xb0, 0x54, 0x26, 0xb0, 0xec,
+ 0x31, 0xc2, 0x68, 0x7d, 0x88, 0xc2, 0xd7, 0x12, 0xaa, 0xea, 0x68, 0x2b, 0xc5, 0x6f, 0xa6, 0xf9,
+ 0xb3, 0x2f, 0xc3, 0x6f, 0xa6, 0xf8, 0x3b, 0x50, 0x94, 0xfc, 0x0e, 0x61, 0x64, 0x35, 0x27, 0x78,
+ 0xd7, 0x5f, 0x14, 0xbc, 0x1a, 0x61, 0x76, 0x97, 0x87, 0x60, 0x57, 0xe0, 0x1a, 0x84, 0x11, 0x0c,
+ 0xc1, 0xf0, 0xb7, 0xf1, 0x6f, 0x1d, 0xf2, 0x2a, 0x7d, 0xd0, 0xc7, 0x50, 0x62, 0x11, 0x71, 0x5c,
+ 0xff, 0xb1, 0x15, 0x12, 0x57, 0xc5, 0xe7, 0xcd, 0x17, 0xf1, 0xef, 0x27, 0xf2, 0x1d, 0xe2, 0x46,
+ 0xb8, 0xc8, 0x46, 0x0b, 0xb4, 0x09, 0x05, 0x87, 0x7a, 0x8c, 0x58, 0x55, 0xcb, 0x95, 0x61, 0xba,
+ 0x35, 0xc1, 0x01, 0x9b, 0xbd, 0xa0, 0xef, 0x33, 0xbc, 0x20, 0x70, 0xd5, 0xd6, 0x88, 0xc2, 0xb4,
+ 0x5c, 0x19, 0xa3, 0x99, 0x28, 0xcc, 0x16, 0x7a, 0x08, 0x4b, 0x87, 0x94, 0x9e, 0x8f, 0xc5, 0x3b,
+ 0x13, 0x78, 0x6a, 0xc4, 0x23, 0xbe, 0x9d, 0x8e, 0xc6, 0xe2, 0x21, 0x4d, 0x2d, 0xd1, 0x26, 0x2c,
+ 0x84, 0xe4, 0xc4, 0x0b, 0x88, 0xb3, 0x3a, 0x3f, 0xd9, 0x4b, 0xe2, 0x72, 0x27, 0xe2, 0x58, 0xe1,
+ 0x8c, 0x1f, 0x6b, 0x50, 0x4c, 0x1d, 0xa0, 0x36, 0x40, 0x4a, 0x4f, 0xed, 0x52, 0x39, 0x93, 0x62,
+ 0x10, 0x77, 0xd4, 0x17, 0x00, 0xea, 0x58, 0xf1, 0x31, 0x09, 0x45, 0x18, 0x4a, 0x78, 0x71, 0xb8,
+ 0xcb, 0x9f, 0x6e, 0xfc, 0x44, 0xde, 0xd1, 0x8e, 0x47, 0x5c, 0x9f, 0xd1, 0x01, 0xfb, 0x3f, 0x4c,
+ 0x83, 0x7b, 0x50, 0xb0, 0x79, 0x09, 0xb2, 0x78, 0xcd, 0xc8, 0x4e, 0x5d, 0x33, 0xf2, 0x02, 0xb4,
+ 0x45, 0x29, 0xfa, 0x04, 0x16, 0x13, 0x02, 0xe2, 0x38, 0x11, 0x8d, 0x63, 0x19, 0xf4, 0x37, 0x26,
+ 0xe9, 0x91, 0x48, 0xe3, 0x92, 0x00, 0xcb, 0x15, 0xaf, 0xc8, 0x51, 0x4c, 0xa9, 0x23, 0xee, 0x6f,
+ 0x09, 0x27, 0x0b, 0xe3, 0x2f, 0x5a, 0x72, 0x13, 0x3b, 0x1e, 0xf1, 0x51, 0x07, 0x96, 0x78, 0xc4,
+ 0xac, 0x50, 0x05, 0x45, 0x06, 0x61, 0x62, 0xa1, 0x1e, 0x46, 0x11, 0x2f, 0xc6, 0xa7, 0x82, 0xfa,
+ 0x3a, 0x94, 0xf8, 0x4d, 0x38, 0xf0, 0x5c, 0x9f, 0x07, 0x47, 0xe6, 0x42, 0xf1, 0x90, 0xd2, 0x9a,
+ 0xdc, 0x42, 0xb7, 0x61, 0x59, 0x34, 0x87, 0xa1, 0x90, 0x15, 0x09, 0x7f, 0x97, 0xf0, 0x92, 0xd8,
+ 0x57, 0x82, 0x78, 0x8c, 0x64, 0x2c, 0xdc, 0x7a, 0x56, 0x72, 0xcf, 0xf8, 0x4a, 0x4f, 0x75, 0x80,
+ 0xff, 0x91, 0x69, 0x65, 0xc8, 0x87, 0x41, 0xec, 0x8a, 0x36, 0xa4, 0x8b, 0x36, 0x34, 0x5c, 0x9f,
+ 0xad, 0x98, 0x99, 0x97, 0xae, 0x98, 0x63, 0x5a, 0x5f, 0x76, 0x4c, 0xeb, 0x1b, 0xeb, 0xcc, 0xf9,
+ 0xa9, 0x9d, 0x99, 0x1b, 0xeb, 0xcc, 0xff, 0xc8, 0x62, 0xfd, 0xc0, 0xa5, 0xc7, 0x68, 0x1b, 0x16,
+ 0x8e, 0xdc, 0xd8, 0x3d, 0xf0, 0xa8, 0x74, 0xe0, 0x77, 0x26, 0x39, 0x90, 0xc3, 0x2a, 0x0f, 0x12,
+ 0xcc, 0xf6, 0x1c, 0x56, 0x70, 0xd4, 0x84, 0x5c, 0x10, 0x92, 0x27, 0x7d, 0xd5, 0x4e, 0xdf, 0x9e,
+ 0x8a, 0x68, 0x57, 0x40, 0xb6, 0xe7, 0xb0, 0x04, 0x97, 0xbf, 0xd0, 0x60, 0x41, 0xb2, 0xa3, 0x77,
+ 0x21, 0x2b, 0x2a, 0x4e, 0xa2, 0xd9, 0x8d, 0x49, 0x84, 0x58, 0x48, 0x8f, 0x49, 0x8d, 0xcc, 0xcb,
+ 0xa5, 0x46, 0xf9, 0x43, 0xc8, 0x25, 0x7a, 0x5e, 0x4e, 0xa3, 0x5a, 0x11, 0x0a, 0x42, 0xa3, 0x23,
+ 0x97, 0x1e, 0x1b, 0xff, 0x4c, 0x4f, 0x33, 0x22, 0x06, 0x3b, 0x67, 0x63, 0x50, 0x9d, 0x6a, 0x90,
+ 0xba, 0x28, 0x10, 0x1f, 0x9f, 0x09, 0xc4, 0x3b, 0xd3, 0xb3, 0x9d, 0x8b, 0xc6, 0x5f, 0x53, 0xd1,
+ 0x68, 0x00, 0x08, 0x2b, 0x44, 0x15, 0x92, 0x9a, 0xde, 0x9a, 0x8a, 0x1b, 0x0b, 0xf3, 0x93, 0x41,
+ 0xb2, 0x06, 0x79, 0x35, 0x3c, 0x49, 0xfd, 0xde, 0x9c, 0x34, 0xb9, 0x05, 0x8c, 0x72, 0xed, 0xf0,
+ 0x82, 0x1c, 0x95, 0x52, 0x1c, 0xa6, 0x8c, 0xed, 0xac, 0x1c, 0x66, 0xb9, 0x3d, 0x8c, 0xe9, 0x95,
+ 0xd8, 0x55, 0xbb, 0x06, 0xaf, 0x8c, 0x58, 0x92, 0x48, 0xff, 0x42, 0x83, 0x62, 0xaa, 0xa5, 0xa1,
+ 0x7b, 0xb0, 0x40, 0xe2, 0x98, 0x72, 0xcb, 0xb5, 0xe9, 0x0a, 0x3f, 0x97, 0x6e, 0x39, 0x38, 0x27,
+ 0x60, 0xd5, 0x11, 0x81, 0x29, 0x5d, 0x37, 0x1b, 0x81, 0x69, 0xfc, 0x5c, 0x83, 0x95, 0x86, 0x1b,
+ 0x51, 0x9b, 0x51, 0x27, 0xad, 0xd9, 0xfb, 0x30, 0x1f, 0x33, 0x12, 0xb1, 0x19, 0xf5, 0x4a, 0x40,
+ 0xe8, 0x3d, 0xc8, 0x50, 0xdf, 0x99, 0x51, 0x25, 0x0e, 0x31, 0xfe, 0x90, 0x85, 0x95, 0x31, 0x95,
+ 0x12, 0x7d, 0x08, 0x0b, 0xb2, 0xdf, 0x5f, 0x10, 0x8f, 0x0b, 0x5a, 0x75, 0x2e, 0xe9, 0xf6, 0x23,
+ 0xbc, 0x39, 0xdb, 0xb4, 0x90, 0xe0, 0x4d, 0xf4, 0x11, 0xe4, 0x3d, 0xd2, 0x3b, 0x70, 0xb8, 0x02,
+ 0xb3, 0xcd, 0x0a, 0x09, 0xac, 0x9a, 0x62, 0x30, 0xe5, 0xa8, 0x30, 0x1b, 0x83, 0xc9, 0xd3, 0xb2,
+ 0xef, 0x1f, 0xba, 0x9e, 0x47, 0x1d, 0xab, 0x2a, 0x27, 0x85, 0x29, 0x39, 0x0a, 0x0a, 0x58, 0x3d,
+ 0xc5, 0x62, 0xca, 0x51, 0x7f, 0x56, 0x16, 0x13, 0x7d, 0x1d, 0x72, 0x5d, 0xea, 0x3e, 0xee, 0x32,
+ 0xf9, 0x82, 0x26, 0x57, 0xe7, 0x66, 0xbc, 0xfc, 0x4b, 0xcc, 0x78, 0x26, 0x7c, 0x2d, 0xe9, 0x88,
+ 0x22, 0xa9, 0x38, 0xa5, 0x7c, 0x64, 0x41, 0x3c, 0x72, 0x45, 0x1c, 0xee, 0xc9, 0xb3, 0x6d, 0x71,
+ 0x64, 0xfc, 0x5a, 0x83, 0x57, 0x24, 0xe1, 0x56, 0xdf, 0xb7, 0x45, 0xcb, 0xdc, 0x81, 0x82, 0x1d,
+ 0xf4, 0xc2, 0xc0, 0x1f, 0xcd, 0xbf, 0x13, 0x3a, 0x75, 0x44, 0xcf, 0x70, 0xe0, 0x11, 0x03, 0xba,
+ 0x0b, 0x59, 0x61, 0x9a, 0x3e, 0x9b, 0x69, 0x02, 0x64, 0x7c, 0xa1, 0xf1, 0xfc, 0x3e, 0xc7, 0x8f,
+ 0x96, 0x93, 0xf7, 0x4e, 0xae, 0xdd, 0x62, 0xf2, 0x4e, 0x79, 0x07, 0xb4, 0x70, 0xb6, 0x5c, 0xd5,
+ 0x42, 0x0e, 0x7a, 0x32, 0x5b, 0x7e, 0x6a, 0x4f, 0x8c, 0x01, 0xe4, 0x31, 0x8d, 0x69, 0x74, 0x44,
+ 0x63, 0xf4, 0x5d, 0xd0, 0xa3, 0x19, 0xaf, 0x98, 0x1e, 0x55, 0x05, 0x6c, 0xc6, 0x9b, 0xa5, 0x47,
+ 0xa6, 0xf1, 0x53, 0x1d, 0xf2, 0x1d, 0x35, 0x52, 0x7d, 0x00, 0x99, 0xb0, 0xeb, 0xca, 0x67, 0xbf,
+ 0x3d, 0x85, 0x5b, 0x87, 0xc1, 0xe1, 0x38, 0x3e, 0xfd, 0xfa, 0x81, 0x6f, 0x53, 0x39, 0x81, 0x26,
+ 0x0b, 0x74, 0x4f, 0xd4, 0x31, 0x46, 0xa7, 0xe9, 0xf8, 0x4a, 0x13, 0xf1, 0xf2, 0x83, 0x13, 0x1c,
+ 0xbf, 0xb6, 0x91, 0x74, 0xce, 0x34, 0x9f, 0x4c, 0x94, 0x23, 0xf1, 0x10, 0x85, 0x0c, 0x3e, 0xe3,
+ 0x07, 0x31, 0xb5, 0x02, 0xdf, 0xe2, 0xd7, 0x47, 0xdc, 0xdc, 0x3c, 0x2e, 0x8a, 0xcd, 0x5d, 0x7f,
+ 0xcb, 0xf5, 0x3c, 0xa3, 0x0e, 0xa0, 0x9e, 0xde, 0x72, 0xb8, 0x29, 0xae, 0xef, 0xcb, 0x0f, 0x19,
+ 0x25, 0x9c, 0x2c, 0xd0, 0x75, 0x28, 0x12, 0x8f, 0x59, 0x07, 0xd4, 0xee, 0xde, 0x31, 0x7b, 0xc2,
+ 0xcc, 0x02, 0x06, 0xe2, 0xb1, 0x5a, 0xb2, 0x63, 0x7c, 0xa9, 0xc3, 0xe2, 0x29, 0x1b, 0xd0, 0xf7,
+ 0x94, 0xf5, 0x9c, 0x68, 0xc9, 0xbc, 0x3b, 0xb5, 0xf5, 0xa7, 0x57, 0x4d, 0xbf, 0xdf, 0x93, 0xfe,
+ 0x30, 0x7e, 0xaf, 0xc1, 0xb5, 0x73, 0x87, 0xe8, 0x5b, 0x70, 0xbd, 0xb3, 0xbb, 0xd7, 0xda, 0x6f,
+ 0xed, 0xb6, 0xad, 0xbd, 0xfd, 0xcd, 0xfd, 0xa6, 0xd5, 0x6c, 0x7f, 0xb6, 0x63, 0x7d, 0xd6, 0xde,
+ 0xeb, 0x34, 0xeb, 0xad, 0xad, 0x56, 0xb3, 0xb1, 0x3c, 0x87, 0xd6, 0xa0, 0x3c, 0x4e, 0x68, 0xb7,
+ 0xd3, 0x6c, 0x37, 0x1b, 0xcb, 0xda, 0x45, 0xe7, 0xf5, 0x4f, 0x77, 0xf7, 0x9a, 0x8d, 0x65, 0x1d,
+ 0xbd, 0x0e, 0xaf, 0x8d, 0x3b, 0x7f, 0xd8, 0xda, 0xdf, 0x6e, 0xe0, 0xcd, 0x87, 0xed, 0xe5, 0x0c,
+ 0xba, 0x0e, 0xdf, 0x1c, 0x4f, 0xb1, 0xd9, 0xda, 0x69, 0x36, 0x96, 0xb3, 0xfc, 0xfe, 0xcd, 0x7f,
+ 0x1a, 0xb6, 0x0f, 0x19, 0xba, 0x0f, 0x45, 0x35, 0xcd, 0x5b, 0xae, 0x73, 0x41, 0x9f, 0x1b, 0xeb,
+ 0xa1, 0x96, 0x83, 0x21, 0x1c, 0x45, 0x6b, 0x98, 0x62, 0xfa, 0xe5, 0x52, 0xcc, 0xe8, 0x40, 0x49,
+ 0xed, 0xef, 0x86, 0xd4, 0xe7, 0x29, 0x37, 0x7c, 0xef, 0xd0, 0x26, 0xa7, 0x9c, 0xc2, 0x8e, 0xde,
+ 0x4e, 0x8c, 0xef, 0x8f, 0x12, 0xa1, 0xce, 0xb3, 0xec, 0xca, 0x8c, 0x35, 0xfe, 0xa8, 0xc1, 0xb2,
+ 0x3a, 0x7a, 0xe8, 0xb2, 0xae, 0x13, 0x91, 0xe3, 0xab, 0x73, 0x25, 0x81, 0x15, 0x75, 0x6d, 0xd2,
+ 0xdf, 0x56, 0xf4, 0x4b, 0x7e, 0x5b, 0x41, 0x8a, 0x6c, 0xb4, 0x67, 0xfc, 0x49, 0x83, 0x95, 0xa1,
+ 0xc7, 0xe8, 0x31, 0x89, 0x9c, 0x64, 0x0a, 0xbd, 0x32, 0x1b, 0x2c, 0x40, 0x91, 0xe0, 0xbd, 0x12,
+ 0x13, 0xae, 0x49, 0xae, 0x94, 0x05, 0xbf, 0x92, 0xaf, 0xbe, 0xcd, 0x01, 0xb5, 0xfb, 0xa2, 0x72,
+ 0xde, 0x87, 0x1c, 0x8b, 0x88, 0x4d, 0xe3, 0x55, 0xed, 0x46, 0x66, 0x52, 0x77, 0x3b, 0x05, 0xe5,
+ 0xa5, 0xd4, 0xa6, 0x58, 0xc2, 0xd1, 0x06, 0x2f, 0x3c, 0x61, 0x5f, 0xa9, 0x7b, 0x73, 0x82, 0xba,
+ 0x0f, 0x88, 0xd7, 0xa7, 0x38, 0x81, 0xa0, 0xf7, 0x21, 0x97, 0x4c, 0xd2, 0xb2, 0xd4, 0x4e, 0x07,
+ 0x96, 0x98, 0x72, 0x1d, 0xe6, 0x85, 0x2a, 0x5c, 0x85, 0x23, 0x7e, 0x22, 0x4d, 0x99, 0x52, 0x05,
+ 0x01, 0x31, 0xfe, 0xae, 0xc1, 0xab, 0x67, 0x93, 0x53, 0x7c, 0x1b, 0x48, 0x17, 0x71, 0xed, 0x52,
+ 0x45, 0xfc, 0x4c, 0x7a, 0xe8, 0x97, 0x4e, 0x0f, 0x35, 0x3d, 0x64, 0x2e, 0x33, 0x3d, 0xfc, 0x00,
+ 0xbe, 0x31, 0x26, 0x77, 0xaf, 0xc6, 0xc4, 0xda, 0x97, 0xfa, 0x9f, 0x9f, 0xad, 0x69, 0x4f, 0x9f,
+ 0xad, 0x69, 0xff, 0x78, 0xb6, 0xa6, 0xfd, 0xf2, 0xf9, 0xda, 0xdc, 0xd3, 0xe7, 0x6b, 0x73, 0x7f,
+ 0x7b, 0xbe, 0x36, 0x07, 0x6b, 0x76, 0xd0, 0x7b, 0x01, 0x5b, 0x2d, 0xdf, 0xa0, 0x83, 0x4e, 0x14,
+ 0xb0, 0xa0, 0xa3, 0x7d, 0x8e, 0x1f, 0xbb, 0xac, 0xdb, 0x3f, 0xa8, 0xd8, 0x41, 0x6f, 0xdd, 0x0e,
+ 0xe2, 0x5e, 0x10, 0xaf, 0x47, 0xd4, 0x23, 0x27, 0x34, 0x5a, 0x3f, 0x32, 0x87, 0x3f, 0xed, 0x2e,
+ 0x71, 0xfd, 0x78, 0xfd, 0xe2, 0x3f, 0x51, 0xee, 0x3a, 0x74, 0xa0, 0x7e, 0xff, 0x56, 0xcf, 0x74,
+ 0xea, 0x8d, 0xdf, 0xe9, 0xe5, 0x8e, 0x52, 0xa1, 0xce, 0x55, 0x68, 0xd0, 0x41, 0xe5, 0x81, 0x14,
+ 0xf9, 0x6a, 0x74, 0xf8, 0x88, 0x1f, 0x3e, 0x6a, 0xd0, 0xc1, 0x23, 0x75, 0xf8, 0x4c, 0x7f, 0xe3,
+ 0xe2, 0xc3, 0x47, 0xf7, 0x3b, 0xb5, 0x1d, 0xca, 0x88, 0x43, 0x18, 0xf9, 0x97, 0xfe, 0x9a, 0x12,
+ 0xdc, 0xd8, 0xe0, 0x92, 0x1b, 0x1b, 0x0d, 0x3a, 0xd8, 0xd8, 0x50, 0xb2, 0x07, 0x39, 0xf1, 0x77,
+ 0xcc, 0x9d, 0xff, 0x06, 0x00, 0x00, 0xff, 0xff, 0x37, 0xdb, 0x43, 0xeb, 0xfe, 0x19, 0x00, 0x00,
+}
+
+func (m *Swap) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *Swap) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *Swap) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Body != nil {
+ {
+ size, err := m.Body.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x22
+ }
+ if m.Proof != nil {
+ {
+ size, err := m.Proof.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *SwapClaim) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *SwapClaim) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *SwapClaim) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.EpochDuration != 0 {
+ i = encodeVarintDex(dAtA, i, uint64(m.EpochDuration))
+ i--
+ dAtA[i] = 0x38
+ }
+ if m.Body != nil {
+ {
+ size, err := m.Body.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if len(m.Proof) > 0 {
+ i -= len(m.Proof)
+ copy(dAtA[i:], m.Proof)
+ i = encodeVarintDex(dAtA, i, uint64(len(m.Proof)))
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *SwapClaimBody) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *SwapClaimBody) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *SwapClaimBody) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.OutputData != nil {
+ {
+ size, err := m.OutputData.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x32
+ }
+ if m.Output_2Commitment != nil {
+ {
+ size, err := m.Output_2Commitment.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x22
+ }
+ if m.Output_1Commitment != nil {
+ {
+ size, err := m.Output_1Commitment.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1a
+ }
+ if m.Fee != nil {
+ {
+ size, err := m.Fee.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.Nullifier != nil {
+ {
+ size, err := m.Nullifier.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *SwapBody) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *SwapBody) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *SwapBody) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Payload != nil {
+ {
+ size, err := m.Payload.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x2a
+ }
+ if m.FeeCommitment != nil {
+ {
+ size, err := m.FeeCommitment.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x22
+ }
+ if m.Delta_2I != nil {
+ {
+ size, err := m.Delta_2I.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1a
+ }
+ if m.Delta_1I != nil {
+ {
+ size, err := m.Delta_1I.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.TradingPair != nil {
+ {
+ size, err := m.TradingPair.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *SwapPayload) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *SwapPayload) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *SwapPayload) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.EncryptedSwap) > 0 {
+ i -= len(m.EncryptedSwap)
+ copy(dAtA[i:], m.EncryptedSwap)
+ i = encodeVarintDex(dAtA, i, uint64(len(m.EncryptedSwap)))
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.Commitment != nil {
+ {
+ size, err := m.Commitment.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *SwapPlaintext) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *SwapPlaintext) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *SwapPlaintext) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.Rseed) > 0 {
+ i -= len(m.Rseed)
+ copy(dAtA[i:], m.Rseed)
+ i = encodeVarintDex(dAtA, i, uint64(len(m.Rseed)))
+ i--
+ dAtA[i] = 0x32
+ }
+ if m.ClaimAddress != nil {
+ {
+ size, err := m.ClaimAddress.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x2a
+ }
+ if m.ClaimFee != nil {
+ {
+ size, err := m.ClaimFee.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x22
+ }
+ if m.Delta_2I != nil {
+ {
+ size, err := m.Delta_2I.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1a
+ }
+ if m.Delta_1I != nil {
+ {
+ size, err := m.Delta_1I.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.TradingPair != nil {
+ {
+ size, err := m.TradingPair.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *SwapPlan) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *SwapPlan) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *SwapPlan) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.ProofBlindingS) > 0 {
+ i -= len(m.ProofBlindingS)
+ copy(dAtA[i:], m.ProofBlindingS)
+ i = encodeVarintDex(dAtA, i, uint64(len(m.ProofBlindingS)))
+ i--
+ dAtA[i] = 0x22
+ }
+ if len(m.ProofBlindingR) > 0 {
+ i -= len(m.ProofBlindingR)
+ copy(dAtA[i:], m.ProofBlindingR)
+ i = encodeVarintDex(dAtA, i, uint64(len(m.ProofBlindingR)))
+ i--
+ dAtA[i] = 0x1a
+ }
+ if len(m.FeeBlinding) > 0 {
+ i -= len(m.FeeBlinding)
+ copy(dAtA[i:], m.FeeBlinding)
+ i = encodeVarintDex(dAtA, i, uint64(len(m.FeeBlinding)))
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.SwapPlaintext != nil {
+ {
+ size, err := m.SwapPlaintext.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *SwapClaimPlan) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *SwapClaimPlan) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *SwapClaimPlan) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.ProofBlindingS) > 0 {
+ i -= len(m.ProofBlindingS)
+ copy(dAtA[i:], m.ProofBlindingS)
+ i = encodeVarintDex(dAtA, i, uint64(len(m.ProofBlindingS)))
+ i--
+ dAtA[i] = 0x32
+ }
+ if len(m.ProofBlindingR) > 0 {
+ i -= len(m.ProofBlindingR)
+ copy(dAtA[i:], m.ProofBlindingR)
+ i = encodeVarintDex(dAtA, i, uint64(len(m.ProofBlindingR)))
+ i--
+ dAtA[i] = 0x2a
+ }
+ if m.EpochDuration != 0 {
+ i = encodeVarintDex(dAtA, i, uint64(m.EpochDuration))
+ i--
+ dAtA[i] = 0x20
+ }
+ if m.OutputData != nil {
+ {
+ size, err := m.OutputData.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1a
+ }
+ if m.Position != 0 {
+ i = encodeVarintDex(dAtA, i, uint64(m.Position))
+ i--
+ dAtA[i] = 0x10
+ }
+ if m.SwapPlaintext != nil {
+ {
+ size, err := m.SwapPlaintext.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *SwapView) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *SwapView) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *SwapView) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.SwapView != nil {
+ {
+ size := m.SwapView.Size()
+ i -= size
+ if _, err := m.SwapView.MarshalTo(dAtA[i:]); err != nil {
+ return 0, err
+ }
+ }
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *SwapView_Visible_) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *SwapView_Visible_) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.Visible != nil {
+ {
+ size, err := m.Visible.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+func (m *SwapView_Opaque_) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *SwapView_Opaque_) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.Opaque != nil {
+ {
+ size, err := m.Opaque.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ return len(dAtA) - i, nil
+}
+func (m *SwapView_Visible) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *SwapView_Visible) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *SwapView_Visible) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.SwapPlaintext != nil {
+ {
+ size, err := m.SwapPlaintext.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1a
+ }
+ if m.Swap != nil {
+ {
+ size, err := m.Swap.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *SwapView_Opaque) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *SwapView_Opaque) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *SwapView_Opaque) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Swap != nil {
+ {
+ size, err := m.Swap.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *SwapClaimView) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *SwapClaimView) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *SwapClaimView) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.SwapClaimView != nil {
+ {
+ size := m.SwapClaimView.Size()
+ i -= size
+ if _, err := m.SwapClaimView.MarshalTo(dAtA[i:]); err != nil {
+ return 0, err
+ }
+ }
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *SwapClaimView_Visible_) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *SwapClaimView_Visible_) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.Visible != nil {
+ {
+ size, err := m.Visible.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+func (m *SwapClaimView_Opaque_) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *SwapClaimView_Opaque_) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.Opaque != nil {
+ {
+ size, err := m.Opaque.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ return len(dAtA) - i, nil
+}
+func (m *SwapClaimView_Visible) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *SwapClaimView_Visible) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *SwapClaimView_Visible) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Output_2 != nil {
+ {
+ size, err := m.Output_2.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1a
+ }
+ if m.Output_1 != nil {
+ {
+ size, err := m.Output_1.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.SwapClaim != nil {
+ {
+ size, err := m.SwapClaim.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *SwapClaimView_Opaque) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *SwapClaimView_Opaque) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *SwapClaimView_Opaque) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.SwapClaim != nil {
+ {
+ size, err := m.SwapClaim.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *TradingPair) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *TradingPair) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *TradingPair) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Asset_2 != nil {
+ {
+ size, err := m.Asset_2.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.Asset_1 != nil {
+ {
+ size, err := m.Asset_1.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *DirectedTradingPair) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *DirectedTradingPair) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *DirectedTradingPair) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.End != nil {
+ {
+ size, err := m.End.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.Start != nil {
+ {
+ size, err := m.Start.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *BatchSwapOutputData) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *BatchSwapOutputData) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *BatchSwapOutputData) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.EpochStartingHeight != 0 {
+ i = encodeVarintDex(dAtA, i, uint64(m.EpochStartingHeight))
+ i--
+ dAtA[i] = 0x48
+ }
+ if m.TradingPair != nil {
+ {
+ size, err := m.TradingPair.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x42
+ }
+ if m.Height != 0 {
+ i = encodeVarintDex(dAtA, i, uint64(m.Height))
+ i--
+ dAtA[i] = 0x38
+ }
+ if m.Unfilled_2 != nil {
+ {
+ size, err := m.Unfilled_2.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x32
+ }
+ if m.Unfilled_1 != nil {
+ {
+ size, err := m.Unfilled_1.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x2a
+ }
+ if m.Lambda_2 != nil {
+ {
+ size, err := m.Lambda_2.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x22
+ }
+ if m.Lambda_1 != nil {
+ {
+ size, err := m.Lambda_1.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1a
+ }
+ if m.Delta_2 != nil {
+ {
+ size, err := m.Delta_2.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.Delta_1 != nil {
+ {
+ size, err := m.Delta_1.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *TradingFunction) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *TradingFunction) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *TradingFunction) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Pair != nil {
+ {
+ size, err := m.Pair.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.Component != nil {
+ {
+ size, err := m.Component.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *BareTradingFunction) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *BareTradingFunction) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *BareTradingFunction) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Q != nil {
+ {
+ size, err := m.Q.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1a
+ }
+ if m.P != nil {
+ {
+ size, err := m.P.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.Fee != 0 {
+ i = encodeVarintDex(dAtA, i, uint64(m.Fee))
+ i--
+ dAtA[i] = 0x8
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *Reserves) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *Reserves) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *Reserves) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.R2 != nil {
+ {
+ size, err := m.R2.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.R1 != nil {
+ {
+ size, err := m.R1.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *Position) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *Position) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *Position) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.CloseOnFill {
+ i--
+ if m.CloseOnFill {
+ dAtA[i] = 1
+ } else {
+ dAtA[i] = 0
+ }
+ i--
+ dAtA[i] = 0x28
+ }
+ if m.Reserves != nil {
+ {
+ size, err := m.Reserves.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x22
+ }
+ if m.State != nil {
+ {
+ size, err := m.State.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1a
+ }
+ if len(m.Nonce) > 0 {
+ i -= len(m.Nonce)
+ copy(dAtA[i:], m.Nonce)
+ i = encodeVarintDex(dAtA, i, uint64(len(m.Nonce)))
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.Phi != nil {
+ {
+ size, err := m.Phi.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *PositionId) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *PositionId) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *PositionId) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.AltBech32M) > 0 {
+ i -= len(m.AltBech32M)
+ copy(dAtA[i:], m.AltBech32M)
+ i = encodeVarintDex(dAtA, i, uint64(len(m.AltBech32M)))
+ i--
+ dAtA[i] = 0x12
+ }
+ if len(m.Inner) > 0 {
+ i -= len(m.Inner)
+ copy(dAtA[i:], m.Inner)
+ i = encodeVarintDex(dAtA, i, uint64(len(m.Inner)))
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *PositionState) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *PositionState) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *PositionState) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.State != 0 {
+ i = encodeVarintDex(dAtA, i, uint64(m.State))
+ i--
+ dAtA[i] = 0x8
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *LpNft) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *LpNft) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *LpNft) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.State != nil {
+ {
+ size, err := m.State.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.PositionId != nil {
+ {
+ size, err := m.PositionId.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *PositionOpen) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *PositionOpen) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *PositionOpen) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Position != nil {
+ {
+ size, err := m.Position.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *PositionClose) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *PositionClose) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *PositionClose) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.PositionId != nil {
+ {
+ size, err := m.PositionId.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *PositionWithdraw) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *PositionWithdraw) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *PositionWithdraw) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.ReservesCommitment != nil {
+ {
+ size, err := m.ReservesCommitment.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.PositionId != nil {
+ {
+ size, err := m.PositionId.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *PositionRewardClaim) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *PositionRewardClaim) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *PositionRewardClaim) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.RewardsCommitment != nil {
+ {
+ size, err := m.RewardsCommitment.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.PositionId != nil {
+ {
+ size, err := m.PositionId.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *SwapExecution) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *SwapExecution) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *SwapExecution) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Output != nil {
+ {
+ size, err := m.Output.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1a
+ }
+ if m.Input != nil {
+ {
+ size, err := m.Input.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if len(m.Traces) > 0 {
+ for iNdEx := len(m.Traces) - 1; iNdEx >= 0; iNdEx-- {
+ {
+ size, err := m.Traces[iNdEx].MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *SwapExecution_Trace) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *SwapExecution_Trace) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *SwapExecution_Trace) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.Value) > 0 {
+ for iNdEx := len(m.Value) - 1; iNdEx >= 0; iNdEx-- {
+ {
+ size, err := m.Value[iNdEx].MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *PositionWithdrawPlan) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *PositionWithdrawPlan) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *PositionWithdrawPlan) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Pair != nil {
+ {
+ size, err := m.Pair.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1a
+ }
+ if m.PositionId != nil {
+ {
+ size, err := m.PositionId.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.Reserves != nil {
+ {
+ size, err := m.Reserves.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *PositionRewardClaimPlan) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *PositionRewardClaimPlan) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *PositionRewardClaimPlan) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Reserves != nil {
+ {
+ size, err := m.Reserves.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintDex(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func encodeVarintDex(dAtA []byte, offset int, v uint64) int {
+ offset -= sovDex(v)
+ base := offset
+ for v >= 1<<7 {
+ dAtA[offset] = uint8(v&0x7f | 0x80)
+ v >>= 7
+ offset++
+ }
+ dAtA[offset] = uint8(v)
+ return base
+}
+func (m *Swap) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Proof != nil {
+ l = m.Proof.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ if m.Body != nil {
+ l = m.Body.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ return n
+}
+
+func (m *SwapClaim) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ l = len(m.Proof)
+ if l > 0 {
+ n += 1 + l + sovDex(uint64(l))
+ }
+ if m.Body != nil {
+ l = m.Body.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ if m.EpochDuration != 0 {
+ n += 1 + sovDex(uint64(m.EpochDuration))
+ }
+ return n
+}
+
+func (m *SwapClaimBody) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Nullifier != nil {
+ l = m.Nullifier.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ if m.Fee != nil {
+ l = m.Fee.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ if m.Output_1Commitment != nil {
+ l = m.Output_1Commitment.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ if m.Output_2Commitment != nil {
+ l = m.Output_2Commitment.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ if m.OutputData != nil {
+ l = m.OutputData.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ return n
+}
+
+func (m *SwapBody) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.TradingPair != nil {
+ l = m.TradingPair.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ if m.Delta_1I != nil {
+ l = m.Delta_1I.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ if m.Delta_2I != nil {
+ l = m.Delta_2I.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ if m.FeeCommitment != nil {
+ l = m.FeeCommitment.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ if m.Payload != nil {
+ l = m.Payload.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ return n
+}
+
+func (m *SwapPayload) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Commitment != nil {
+ l = m.Commitment.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ l = len(m.EncryptedSwap)
+ if l > 0 {
+ n += 1 + l + sovDex(uint64(l))
+ }
+ return n
+}
+
+func (m *SwapPlaintext) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.TradingPair != nil {
+ l = m.TradingPair.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ if m.Delta_1I != nil {
+ l = m.Delta_1I.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ if m.Delta_2I != nil {
+ l = m.Delta_2I.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ if m.ClaimFee != nil {
+ l = m.ClaimFee.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ if m.ClaimAddress != nil {
+ l = m.ClaimAddress.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ l = len(m.Rseed)
+ if l > 0 {
+ n += 1 + l + sovDex(uint64(l))
+ }
+ return n
+}
+
+func (m *SwapPlan) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.SwapPlaintext != nil {
+ l = m.SwapPlaintext.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ l = len(m.FeeBlinding)
+ if l > 0 {
+ n += 1 + l + sovDex(uint64(l))
+ }
+ l = len(m.ProofBlindingR)
+ if l > 0 {
+ n += 1 + l + sovDex(uint64(l))
+ }
+ l = len(m.ProofBlindingS)
+ if l > 0 {
+ n += 1 + l + sovDex(uint64(l))
+ }
+ return n
+}
+
+func (m *SwapClaimPlan) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.SwapPlaintext != nil {
+ l = m.SwapPlaintext.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ if m.Position != 0 {
+ n += 1 + sovDex(uint64(m.Position))
+ }
+ if m.OutputData != nil {
+ l = m.OutputData.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ if m.EpochDuration != 0 {
+ n += 1 + sovDex(uint64(m.EpochDuration))
+ }
+ l = len(m.ProofBlindingR)
+ if l > 0 {
+ n += 1 + l + sovDex(uint64(l))
+ }
+ l = len(m.ProofBlindingS)
+ if l > 0 {
+ n += 1 + l + sovDex(uint64(l))
+ }
+ return n
+}
+
+func (m *SwapView) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.SwapView != nil {
+ n += m.SwapView.Size()
+ }
+ return n
+}
+
+func (m *SwapView_Visible_) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Visible != nil {
+ l = m.Visible.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ return n
+}
+func (m *SwapView_Opaque_) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Opaque != nil {
+ l = m.Opaque.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ return n
+}
+func (m *SwapView_Visible) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Swap != nil {
+ l = m.Swap.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ if m.SwapPlaintext != nil {
+ l = m.SwapPlaintext.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ return n
+}
+
+func (m *SwapView_Opaque) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Swap != nil {
+ l = m.Swap.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ return n
+}
+
+func (m *SwapClaimView) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.SwapClaimView != nil {
+ n += m.SwapClaimView.Size()
+ }
+ return n
+}
+
+func (m *SwapClaimView_Visible_) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Visible != nil {
+ l = m.Visible.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ return n
+}
+func (m *SwapClaimView_Opaque_) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Opaque != nil {
+ l = m.Opaque.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ return n
+}
+func (m *SwapClaimView_Visible) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.SwapClaim != nil {
+ l = m.SwapClaim.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ if m.Output_1 != nil {
+ l = m.Output_1.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ if m.Output_2 != nil {
+ l = m.Output_2.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ return n
+}
+
+func (m *SwapClaimView_Opaque) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.SwapClaim != nil {
+ l = m.SwapClaim.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ return n
+}
+
+func (m *TradingPair) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Asset_1 != nil {
+ l = m.Asset_1.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ if m.Asset_2 != nil {
+ l = m.Asset_2.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ return n
+}
+
+func (m *DirectedTradingPair) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Start != nil {
+ l = m.Start.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ if m.End != nil {
+ l = m.End.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ return n
+}
+
+func (m *BatchSwapOutputData) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Delta_1 != nil {
+ l = m.Delta_1.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ if m.Delta_2 != nil {
+ l = m.Delta_2.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ if m.Lambda_1 != nil {
+ l = m.Lambda_1.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ if m.Lambda_2 != nil {
+ l = m.Lambda_2.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ if m.Unfilled_1 != nil {
+ l = m.Unfilled_1.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ if m.Unfilled_2 != nil {
+ l = m.Unfilled_2.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ if m.Height != 0 {
+ n += 1 + sovDex(uint64(m.Height))
+ }
+ if m.TradingPair != nil {
+ l = m.TradingPair.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ if m.EpochStartingHeight != 0 {
+ n += 1 + sovDex(uint64(m.EpochStartingHeight))
+ }
+ return n
+}
+
+func (m *TradingFunction) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Component != nil {
+ l = m.Component.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ if m.Pair != nil {
+ l = m.Pair.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ return n
+}
+
+func (m *BareTradingFunction) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Fee != 0 {
+ n += 1 + sovDex(uint64(m.Fee))
+ }
+ if m.P != nil {
+ l = m.P.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ if m.Q != nil {
+ l = m.Q.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ return n
+}
+
+func (m *Reserves) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.R1 != nil {
+ l = m.R1.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ if m.R2 != nil {
+ l = m.R2.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ return n
+}
+
+func (m *Position) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Phi != nil {
+ l = m.Phi.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ l = len(m.Nonce)
+ if l > 0 {
+ n += 1 + l + sovDex(uint64(l))
+ }
+ if m.State != nil {
+ l = m.State.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ if m.Reserves != nil {
+ l = m.Reserves.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ if m.CloseOnFill {
+ n += 2
+ }
+ return n
+}
+
+func (m *PositionId) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ l = len(m.Inner)
+ if l > 0 {
+ n += 1 + l + sovDex(uint64(l))
+ }
+ l = len(m.AltBech32M)
+ if l > 0 {
+ n += 1 + l + sovDex(uint64(l))
+ }
+ return n
+}
+
+func (m *PositionState) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.State != 0 {
+ n += 1 + sovDex(uint64(m.State))
+ }
+ return n
+}
+
+func (m *LpNft) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.PositionId != nil {
+ l = m.PositionId.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ if m.State != nil {
+ l = m.State.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ return n
+}
+
+func (m *PositionOpen) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Position != nil {
+ l = m.Position.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ return n
+}
+
+func (m *PositionClose) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.PositionId != nil {
+ l = m.PositionId.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ return n
+}
+
+func (m *PositionWithdraw) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.PositionId != nil {
+ l = m.PositionId.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ if m.ReservesCommitment != nil {
+ l = m.ReservesCommitment.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ return n
+}
+
+func (m *PositionRewardClaim) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.PositionId != nil {
+ l = m.PositionId.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ if m.RewardsCommitment != nil {
+ l = m.RewardsCommitment.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ return n
+}
+
+func (m *SwapExecution) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if len(m.Traces) > 0 {
+ for _, e := range m.Traces {
+ l = e.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ }
+ if m.Input != nil {
+ l = m.Input.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ if m.Output != nil {
+ l = m.Output.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ return n
+}
+
+func (m *SwapExecution_Trace) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if len(m.Value) > 0 {
+ for _, e := range m.Value {
+ l = e.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ }
+ return n
+}
+
+func (m *PositionWithdrawPlan) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Reserves != nil {
+ l = m.Reserves.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ if m.PositionId != nil {
+ l = m.PositionId.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ if m.Pair != nil {
+ l = m.Pair.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ return n
+}
+
+func (m *PositionRewardClaimPlan) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Reserves != nil {
+ l = m.Reserves.Size()
+ n += 1 + l + sovDex(uint64(l))
+ }
+ return n
+}
+
+func sovDex(x uint64) (n int) {
+ return (math_bits.Len64(x|1) + 6) / 7
+}
+func sozDex(x uint64) (n int) {
+ return sovDex(uint64((x << 1) ^ uint64((int64(x) >> 63))))
+}
+func (m *Swap) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Swap: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Swap: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Proof", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Proof == nil {
+ m.Proof = &v1alpha1.ZKSwapProof{}
+ }
+ if err := m.Proof.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 4:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Body", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Body == nil {
+ m.Body = &SwapBody{}
+ }
+ if err := m.Body.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipDex(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthDex
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *SwapClaim) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: SwapClaim: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: SwapClaim: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Proof", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Proof = append(m.Proof[:0], dAtA[iNdEx:postIndex]...)
+ if m.Proof == nil {
+ m.Proof = []byte{}
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Body", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Body == nil {
+ m.Body = &SwapClaimBody{}
+ }
+ if err := m.Body.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 7:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field EpochDuration", wireType)
+ }
+ m.EpochDuration = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.EpochDuration |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ default:
+ iNdEx = preIndex
+ skippy, err := skipDex(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthDex
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *SwapClaimBody) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: SwapClaimBody: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: SwapClaimBody: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Nullifier", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Nullifier == nil {
+ m.Nullifier = &v1alpha1.Nullifier{}
+ }
+ if err := m.Nullifier.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Fee", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Fee == nil {
+ m.Fee = &v1alpha1.Fee{}
+ }
+ if err := m.Fee.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Output_1Commitment", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Output_1Commitment == nil {
+ m.Output_1Commitment = &v1alpha1.StateCommitment{}
+ }
+ if err := m.Output_1Commitment.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 4:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Output_2Commitment", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Output_2Commitment == nil {
+ m.Output_2Commitment = &v1alpha1.StateCommitment{}
+ }
+ if err := m.Output_2Commitment.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 6:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field OutputData", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.OutputData == nil {
+ m.OutputData = &BatchSwapOutputData{}
+ }
+ if err := m.OutputData.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipDex(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthDex
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *SwapBody) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: SwapBody: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: SwapBody: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field TradingPair", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.TradingPair == nil {
+ m.TradingPair = &TradingPair{}
+ }
+ if err := m.TradingPair.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Delta_1I", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Delta_1I == nil {
+ m.Delta_1I = &v1alpha1.Amount{}
+ }
+ if err := m.Delta_1I.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Delta_2I", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Delta_2I == nil {
+ m.Delta_2I = &v1alpha1.Amount{}
+ }
+ if err := m.Delta_2I.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 4:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field FeeCommitment", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.FeeCommitment == nil {
+ m.FeeCommitment = &v1alpha1.BalanceCommitment{}
+ }
+ if err := m.FeeCommitment.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 5:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Payload", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Payload == nil {
+ m.Payload = &SwapPayload{}
+ }
+ if err := m.Payload.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipDex(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthDex
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *SwapPayload) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: SwapPayload: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: SwapPayload: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Commitment", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Commitment == nil {
+ m.Commitment = &v1alpha1.StateCommitment{}
+ }
+ if err := m.Commitment.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field EncryptedSwap", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.EncryptedSwap = append(m.EncryptedSwap[:0], dAtA[iNdEx:postIndex]...)
+ if m.EncryptedSwap == nil {
+ m.EncryptedSwap = []byte{}
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipDex(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthDex
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *SwapPlaintext) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: SwapPlaintext: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: SwapPlaintext: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field TradingPair", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.TradingPair == nil {
+ m.TradingPair = &TradingPair{}
+ }
+ if err := m.TradingPair.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Delta_1I", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Delta_1I == nil {
+ m.Delta_1I = &v1alpha1.Amount{}
+ }
+ if err := m.Delta_1I.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Delta_2I", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Delta_2I == nil {
+ m.Delta_2I = &v1alpha1.Amount{}
+ }
+ if err := m.Delta_2I.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 4:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ClaimFee", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.ClaimFee == nil {
+ m.ClaimFee = &v1alpha1.Fee{}
+ }
+ if err := m.ClaimFee.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 5:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ClaimAddress", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.ClaimAddress == nil {
+ m.ClaimAddress = &v1alpha1.Address{}
+ }
+ if err := m.ClaimAddress.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 6:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Rseed", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Rseed = append(m.Rseed[:0], dAtA[iNdEx:postIndex]...)
+ if m.Rseed == nil {
+ m.Rseed = []byte{}
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipDex(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthDex
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *SwapPlan) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: SwapPlan: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: SwapPlan: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field SwapPlaintext", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.SwapPlaintext == nil {
+ m.SwapPlaintext = &SwapPlaintext{}
+ }
+ if err := m.SwapPlaintext.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field FeeBlinding", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.FeeBlinding = append(m.FeeBlinding[:0], dAtA[iNdEx:postIndex]...)
+ if m.FeeBlinding == nil {
+ m.FeeBlinding = []byte{}
+ }
+ iNdEx = postIndex
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ProofBlindingR", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.ProofBlindingR = append(m.ProofBlindingR[:0], dAtA[iNdEx:postIndex]...)
+ if m.ProofBlindingR == nil {
+ m.ProofBlindingR = []byte{}
+ }
+ iNdEx = postIndex
+ case 4:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ProofBlindingS", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.ProofBlindingS = append(m.ProofBlindingS[:0], dAtA[iNdEx:postIndex]...)
+ if m.ProofBlindingS == nil {
+ m.ProofBlindingS = []byte{}
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipDex(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthDex
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *SwapClaimPlan) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: SwapClaimPlan: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: SwapClaimPlan: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field SwapPlaintext", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.SwapPlaintext == nil {
+ m.SwapPlaintext = &SwapPlaintext{}
+ }
+ if err := m.SwapPlaintext.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Position", wireType)
+ }
+ m.Position = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.Position |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field OutputData", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.OutputData == nil {
+ m.OutputData = &BatchSwapOutputData{}
+ }
+ if err := m.OutputData.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 4:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field EpochDuration", wireType)
+ }
+ m.EpochDuration = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.EpochDuration |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 5:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ProofBlindingR", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.ProofBlindingR = append(m.ProofBlindingR[:0], dAtA[iNdEx:postIndex]...)
+ if m.ProofBlindingR == nil {
+ m.ProofBlindingR = []byte{}
+ }
+ iNdEx = postIndex
+ case 6:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ProofBlindingS", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.ProofBlindingS = append(m.ProofBlindingS[:0], dAtA[iNdEx:postIndex]...)
+ if m.ProofBlindingS == nil {
+ m.ProofBlindingS = []byte{}
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipDex(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthDex
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *SwapView) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: SwapView: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: SwapView: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Visible", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &SwapView_Visible{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.SwapView = &SwapView_Visible_{v}
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Opaque", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &SwapView_Opaque{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.SwapView = &SwapView_Opaque_{v}
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipDex(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthDex
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *SwapView_Visible) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Visible: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Visible: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Swap", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Swap == nil {
+ m.Swap = &Swap{}
+ }
+ if err := m.Swap.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field SwapPlaintext", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.SwapPlaintext == nil {
+ m.SwapPlaintext = &SwapPlaintext{}
+ }
+ if err := m.SwapPlaintext.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipDex(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthDex
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *SwapView_Opaque) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Opaque: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Opaque: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Swap", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Swap == nil {
+ m.Swap = &Swap{}
+ }
+ if err := m.Swap.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipDex(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthDex
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *SwapClaimView) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: SwapClaimView: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: SwapClaimView: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Visible", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &SwapClaimView_Visible{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.SwapClaimView = &SwapClaimView_Visible_{v}
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Opaque", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &SwapClaimView_Opaque{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.SwapClaimView = &SwapClaimView_Opaque_{v}
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipDex(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthDex
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *SwapClaimView_Visible) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Visible: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Visible: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field SwapClaim", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.SwapClaim == nil {
+ m.SwapClaim = &SwapClaim{}
+ }
+ if err := m.SwapClaim.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Output_1", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Output_1 == nil {
+ m.Output_1 = &v1alpha1.NoteView{}
+ }
+ if err := m.Output_1.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Output_2", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Output_2 == nil {
+ m.Output_2 = &v1alpha1.NoteView{}
+ }
+ if err := m.Output_2.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipDex(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthDex
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *SwapClaimView_Opaque) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Opaque: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Opaque: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field SwapClaim", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.SwapClaim == nil {
+ m.SwapClaim = &SwapClaim{}
+ }
+ if err := m.SwapClaim.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipDex(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthDex
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *TradingPair) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: TradingPair: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: TradingPair: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Asset_1", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Asset_1 == nil {
+ m.Asset_1 = &v1alpha1.AssetId{}
+ }
+ if err := m.Asset_1.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Asset_2", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Asset_2 == nil {
+ m.Asset_2 = &v1alpha1.AssetId{}
+ }
+ if err := m.Asset_2.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipDex(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthDex
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *DirectedTradingPair) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: DirectedTradingPair: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: DirectedTradingPair: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Start", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Start == nil {
+ m.Start = &v1alpha1.AssetId{}
+ }
+ if err := m.Start.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field End", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.End == nil {
+ m.End = &v1alpha1.AssetId{}
+ }
+ if err := m.End.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipDex(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthDex
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *BatchSwapOutputData) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: BatchSwapOutputData: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: BatchSwapOutputData: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Delta_1", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Delta_1 == nil {
+ m.Delta_1 = &v1alpha1.Amount{}
+ }
+ if err := m.Delta_1.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Delta_2", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Delta_2 == nil {
+ m.Delta_2 = &v1alpha1.Amount{}
+ }
+ if err := m.Delta_2.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Lambda_1", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Lambda_1 == nil {
+ m.Lambda_1 = &v1alpha1.Amount{}
+ }
+ if err := m.Lambda_1.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 4:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Lambda_2", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Lambda_2 == nil {
+ m.Lambda_2 = &v1alpha1.Amount{}
+ }
+ if err := m.Lambda_2.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 5:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Unfilled_1", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Unfilled_1 == nil {
+ m.Unfilled_1 = &v1alpha1.Amount{}
+ }
+ if err := m.Unfilled_1.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 6:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Unfilled_2", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Unfilled_2 == nil {
+ m.Unfilled_2 = &v1alpha1.Amount{}
+ }
+ if err := m.Unfilled_2.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 7:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Height", wireType)
+ }
+ m.Height = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.Height |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 8:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field TradingPair", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.TradingPair == nil {
+ m.TradingPair = &TradingPair{}
+ }
+ if err := m.TradingPair.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 9:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field EpochStartingHeight", wireType)
+ }
+ m.EpochStartingHeight = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.EpochStartingHeight |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ default:
+ iNdEx = preIndex
+ skippy, err := skipDex(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthDex
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *TradingFunction) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: TradingFunction: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: TradingFunction: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Component", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Component == nil {
+ m.Component = &BareTradingFunction{}
+ }
+ if err := m.Component.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Pair", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Pair == nil {
+ m.Pair = &TradingPair{}
+ }
+ if err := m.Pair.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipDex(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthDex
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *BareTradingFunction) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: BareTradingFunction: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: BareTradingFunction: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Fee", wireType)
+ }
+ m.Fee = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.Fee |= uint32(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field P", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.P == nil {
+ m.P = &v1alpha1.Amount{}
+ }
+ if err := m.P.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Q", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Q == nil {
+ m.Q = &v1alpha1.Amount{}
+ }
+ if err := m.Q.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipDex(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthDex
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *Reserves) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Reserves: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Reserves: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field R1", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.R1 == nil {
+ m.R1 = &v1alpha1.Amount{}
+ }
+ if err := m.R1.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field R2", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.R2 == nil {
+ m.R2 = &v1alpha1.Amount{}
+ }
+ if err := m.R2.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipDex(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthDex
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *Position) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Position: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Position: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Phi", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Phi == nil {
+ m.Phi = &TradingFunction{}
+ }
+ if err := m.Phi.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Nonce", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Nonce = append(m.Nonce[:0], dAtA[iNdEx:postIndex]...)
+ if m.Nonce == nil {
+ m.Nonce = []byte{}
+ }
+ iNdEx = postIndex
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field State", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.State == nil {
+ m.State = &PositionState{}
+ }
+ if err := m.State.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 4:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Reserves", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Reserves == nil {
+ m.Reserves = &Reserves{}
+ }
+ if err := m.Reserves.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 5:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field CloseOnFill", wireType)
+ }
+ var v int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ v |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ m.CloseOnFill = bool(v != 0)
+ default:
+ iNdEx = preIndex
+ skippy, err := skipDex(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthDex
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *PositionId) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: PositionId: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: PositionId: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Inner", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Inner = append(m.Inner[:0], dAtA[iNdEx:postIndex]...)
+ if m.Inner == nil {
+ m.Inner = []byte{}
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field AltBech32M", wireType)
+ }
+ var stringLen uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ stringLen |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ intStringLen := int(stringLen)
+ if intStringLen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + intStringLen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.AltBech32M = string(dAtA[iNdEx:postIndex])
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipDex(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthDex
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *PositionState) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: PositionState: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: PositionState: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field State", wireType)
+ }
+ m.State = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.State |= PositionState_PositionStateEnum(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ default:
+ iNdEx = preIndex
+ skippy, err := skipDex(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthDex
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *LpNft) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: LpNft: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: LpNft: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field PositionId", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.PositionId == nil {
+ m.PositionId = &PositionId{}
+ }
+ if err := m.PositionId.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field State", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.State == nil {
+ m.State = &PositionState{}
+ }
+ if err := m.State.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipDex(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthDex
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *PositionOpen) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: PositionOpen: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: PositionOpen: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Position", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Position == nil {
+ m.Position = &Position{}
+ }
+ if err := m.Position.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipDex(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthDex
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *PositionClose) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: PositionClose: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: PositionClose: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field PositionId", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.PositionId == nil {
+ m.PositionId = &PositionId{}
+ }
+ if err := m.PositionId.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipDex(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthDex
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *PositionWithdraw) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: PositionWithdraw: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: PositionWithdraw: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field PositionId", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.PositionId == nil {
+ m.PositionId = &PositionId{}
+ }
+ if err := m.PositionId.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ReservesCommitment", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.ReservesCommitment == nil {
+ m.ReservesCommitment = &v1alpha1.BalanceCommitment{}
+ }
+ if err := m.ReservesCommitment.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipDex(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthDex
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *PositionRewardClaim) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: PositionRewardClaim: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: PositionRewardClaim: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field PositionId", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.PositionId == nil {
+ m.PositionId = &PositionId{}
+ }
+ if err := m.PositionId.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field RewardsCommitment", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.RewardsCommitment == nil {
+ m.RewardsCommitment = &v1alpha1.BalanceCommitment{}
+ }
+ if err := m.RewardsCommitment.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipDex(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthDex
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *SwapExecution) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: SwapExecution: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: SwapExecution: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Traces", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Traces = append(m.Traces, &SwapExecution_Trace{})
+ if err := m.Traces[len(m.Traces)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Input", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Input == nil {
+ m.Input = &v1alpha1.Value{}
+ }
+ if err := m.Input.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Output", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Output == nil {
+ m.Output = &v1alpha1.Value{}
+ }
+ if err := m.Output.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipDex(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthDex
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *SwapExecution_Trace) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Trace: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Trace: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Value", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Value = append(m.Value, &v1alpha1.Value{})
+ if err := m.Value[len(m.Value)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipDex(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthDex
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *PositionWithdrawPlan) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: PositionWithdrawPlan: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: PositionWithdrawPlan: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Reserves", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Reserves == nil {
+ m.Reserves = &Reserves{}
+ }
+ if err := m.Reserves.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field PositionId", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.PositionId == nil {
+ m.PositionId = &PositionId{}
+ }
+ if err := m.PositionId.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Pair", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Pair == nil {
+ m.Pair = &TradingPair{}
+ }
+ if err := m.Pair.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipDex(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthDex
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *PositionRewardClaimPlan) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: PositionRewardClaimPlan: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: PositionRewardClaimPlan: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Reserves", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthDex
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthDex
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Reserves == nil {
+ m.Reserves = &Reserves{}
+ }
+ if err := m.Reserves.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipDex(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthDex
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func skipDex(dAtA []byte) (n int, err error) {
+ l := len(dAtA)
+ iNdEx := 0
+ depth := 0
+ for iNdEx < l {
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return 0, ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return 0, io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= (uint64(b) & 0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ wireType := int(wire & 0x7)
+ switch wireType {
+ case 0:
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return 0, ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return 0, io.ErrUnexpectedEOF
+ }
+ iNdEx++
+ if dAtA[iNdEx-1] < 0x80 {
+ break
+ }
+ }
+ case 1:
+ iNdEx += 8
+ case 2:
+ var length int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return 0, ErrIntOverflowDex
+ }
+ if iNdEx >= l {
+ return 0, io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ length |= (int(b) & 0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if length < 0 {
+ return 0, ErrInvalidLengthDex
+ }
+ iNdEx += length
+ case 3:
+ depth++
+ case 4:
+ if depth == 0 {
+ return 0, ErrUnexpectedEndOfGroupDex
+ }
+ depth--
+ case 5:
+ iNdEx += 4
+ default:
+ return 0, fmt.Errorf("proto: illegal wireType %d", wireType)
+ }
+ if iNdEx < 0 {
+ return 0, ErrInvalidLengthDex
+ }
+ if depth == 0 {
+ return iNdEx, nil
+ }
+ }
+ return 0, io.ErrUnexpectedEOF
+}
+
+var (
+ ErrInvalidLengthDex = fmt.Errorf("proto: negative length found during unmarshaling")
+ ErrIntOverflowDex = fmt.Errorf("proto: integer overflow")
+ ErrUnexpectedEndOfGroupDex = fmt.Errorf("proto: unexpected end of group")
+)
diff --git a/relayer/chains/penumbra/core/governance/v1alpha1/governance.pb.go b/relayer/chains/penumbra/core/governance/v1alpha1/governance.pb.go
new file mode 100644
index 000000000..80977b8d4
--- /dev/null
+++ b/relayer/chains/penumbra/core/governance/v1alpha1/governance.pb.go
@@ -0,0 +1,7343 @@
+// Code generated by protoc-gen-gogo. DO NOT EDIT.
+// source: penumbra/core/governance/v1alpha1/governance.proto
+
+package governancev1alpha1
+
+import (
+ fmt "fmt"
+ types "github.com/cosmos/cosmos-sdk/codec/types"
+ proto "github.com/cosmos/gogoproto/proto"
+ v1alpha11 "github.com/cosmos/relayer/v2/relayer/chains/penumbra/core/chain/v1alpha1"
+ v1alpha1 "github.com/cosmos/relayer/v2/relayer/chains/penumbra/core/crypto/v1alpha1"
+ io "io"
+ math "math"
+ math_bits "math/bits"
+)
+
+// Reference imports to suppress errors if they are not otherwise used.
+var _ = proto.Marshal
+var _ = fmt.Errorf
+var _ = math.Inf
+
+// This is a compile-time assertion to ensure that this generated file
+// is compatible with the proto package it is being compiled against.
+// A compilation error at this line likely means your copy of the
+// proto package needs to be updated.
+const _ = proto.GoGoProtoPackageIsVersion3 // please upgrade the proto package
+
+// A vote.
+type Vote_Vote int32
+
+const (
+ Vote_VOTE_UNSPECIFIED Vote_Vote = 0
+ Vote_VOTE_ABSTAIN Vote_Vote = 1
+ Vote_VOTE_YES Vote_Vote = 2
+ Vote_VOTE_NO Vote_Vote = 3
+)
+
+var Vote_Vote_name = map[int32]string{
+ 0: "VOTE_UNSPECIFIED",
+ 1: "VOTE_ABSTAIN",
+ 2: "VOTE_YES",
+ 3: "VOTE_NO",
+}
+
+var Vote_Vote_value = map[string]int32{
+ "VOTE_UNSPECIFIED": 0,
+ "VOTE_ABSTAIN": 1,
+ "VOTE_YES": 2,
+ "VOTE_NO": 3,
+}
+
+func (x Vote_Vote) String() string {
+ return proto.EnumName(Vote_Vote_name, int32(x))
+}
+
+func (Vote_Vote) EnumDescriptor() ([]byte, []int) {
+ return fileDescriptor_1bc89f5bf0aed114, []int{11, 0}
+}
+
+type ProposalSubmit struct {
+ // The proposal to be submitted.
+ Proposal *Proposal `protobuf:"bytes,1,opt,name=proposal,proto3" json:"proposal,omitempty"`
+ // The amount of the proposal deposit.
+ DepositAmount *v1alpha1.Amount `protobuf:"bytes,3,opt,name=deposit_amount,json=depositAmount,proto3" json:"deposit_amount,omitempty"`
+}
+
+func (m *ProposalSubmit) Reset() { *m = ProposalSubmit{} }
+func (m *ProposalSubmit) String() string { return proto.CompactTextString(m) }
+func (*ProposalSubmit) ProtoMessage() {}
+func (*ProposalSubmit) Descriptor() ([]byte, []int) {
+ return fileDescriptor_1bc89f5bf0aed114, []int{0}
+}
+func (m *ProposalSubmit) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *ProposalSubmit) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_ProposalSubmit.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *ProposalSubmit) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_ProposalSubmit.Merge(m, src)
+}
+func (m *ProposalSubmit) XXX_Size() int {
+ return m.Size()
+}
+func (m *ProposalSubmit) XXX_DiscardUnknown() {
+ xxx_messageInfo_ProposalSubmit.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_ProposalSubmit proto.InternalMessageInfo
+
+func (m *ProposalSubmit) GetProposal() *Proposal {
+ if m != nil {
+ return m.Proposal
+ }
+ return nil
+}
+
+func (m *ProposalSubmit) GetDepositAmount() *v1alpha1.Amount {
+ if m != nil {
+ return m.DepositAmount
+ }
+ return nil
+}
+
+type ProposalWithdraw struct {
+ // The proposal to be withdrawn.
+ Proposal uint64 `protobuf:"varint,1,opt,name=proposal,proto3" json:"proposal,omitempty"`
+ // The reason for the proposal being withdrawn.
+ Reason string `protobuf:"bytes,2,opt,name=reason,proto3" json:"reason,omitempty"`
+}
+
+func (m *ProposalWithdraw) Reset() { *m = ProposalWithdraw{} }
+func (m *ProposalWithdraw) String() string { return proto.CompactTextString(m) }
+func (*ProposalWithdraw) ProtoMessage() {}
+func (*ProposalWithdraw) Descriptor() ([]byte, []int) {
+ return fileDescriptor_1bc89f5bf0aed114, []int{1}
+}
+func (m *ProposalWithdraw) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *ProposalWithdraw) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_ProposalWithdraw.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *ProposalWithdraw) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_ProposalWithdraw.Merge(m, src)
+}
+func (m *ProposalWithdraw) XXX_Size() int {
+ return m.Size()
+}
+func (m *ProposalWithdraw) XXX_DiscardUnknown() {
+ xxx_messageInfo_ProposalWithdraw.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_ProposalWithdraw proto.InternalMessageInfo
+
+func (m *ProposalWithdraw) GetProposal() uint64 {
+ if m != nil {
+ return m.Proposal
+ }
+ return 0
+}
+
+func (m *ProposalWithdraw) GetReason() string {
+ if m != nil {
+ return m.Reason
+ }
+ return ""
+}
+
+type ProposalDepositClaim struct {
+ // The proposal to claim the deposit for.
+ Proposal uint64 `protobuf:"varint,1,opt,name=proposal,proto3" json:"proposal,omitempty"`
+ // The expected deposit amount.
+ DepositAmount *v1alpha1.Amount `protobuf:"bytes,2,opt,name=deposit_amount,json=depositAmount,proto3" json:"deposit_amount,omitempty"`
+ // The outcome of the proposal.
+ Outcome *ProposalOutcome `protobuf:"bytes,3,opt,name=outcome,proto3" json:"outcome,omitempty"`
+}
+
+func (m *ProposalDepositClaim) Reset() { *m = ProposalDepositClaim{} }
+func (m *ProposalDepositClaim) String() string { return proto.CompactTextString(m) }
+func (*ProposalDepositClaim) ProtoMessage() {}
+func (*ProposalDepositClaim) Descriptor() ([]byte, []int) {
+ return fileDescriptor_1bc89f5bf0aed114, []int{2}
+}
+func (m *ProposalDepositClaim) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *ProposalDepositClaim) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_ProposalDepositClaim.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *ProposalDepositClaim) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_ProposalDepositClaim.Merge(m, src)
+}
+func (m *ProposalDepositClaim) XXX_Size() int {
+ return m.Size()
+}
+func (m *ProposalDepositClaim) XXX_DiscardUnknown() {
+ xxx_messageInfo_ProposalDepositClaim.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_ProposalDepositClaim proto.InternalMessageInfo
+
+func (m *ProposalDepositClaim) GetProposal() uint64 {
+ if m != nil {
+ return m.Proposal
+ }
+ return 0
+}
+
+func (m *ProposalDepositClaim) GetDepositAmount() *v1alpha1.Amount {
+ if m != nil {
+ return m.DepositAmount
+ }
+ return nil
+}
+
+func (m *ProposalDepositClaim) GetOutcome() *ProposalOutcome {
+ if m != nil {
+ return m.Outcome
+ }
+ return nil
+}
+
+type ValidatorVote struct {
+ // The effecting data for the vote.
+ Body *ValidatorVoteBody `protobuf:"bytes,1,opt,name=body,proto3" json:"body,omitempty"`
+ // The vote authorization signature is authorizing data.
+ AuthSig *v1alpha1.SpendAuthSignature `protobuf:"bytes,2,opt,name=auth_sig,json=authSig,proto3" json:"auth_sig,omitempty"`
+}
+
+func (m *ValidatorVote) Reset() { *m = ValidatorVote{} }
+func (m *ValidatorVote) String() string { return proto.CompactTextString(m) }
+func (*ValidatorVote) ProtoMessage() {}
+func (*ValidatorVote) Descriptor() ([]byte, []int) {
+ return fileDescriptor_1bc89f5bf0aed114, []int{3}
+}
+func (m *ValidatorVote) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *ValidatorVote) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_ValidatorVote.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *ValidatorVote) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_ValidatorVote.Merge(m, src)
+}
+func (m *ValidatorVote) XXX_Size() int {
+ return m.Size()
+}
+func (m *ValidatorVote) XXX_DiscardUnknown() {
+ xxx_messageInfo_ValidatorVote.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_ValidatorVote proto.InternalMessageInfo
+
+func (m *ValidatorVote) GetBody() *ValidatorVoteBody {
+ if m != nil {
+ return m.Body
+ }
+ return nil
+}
+
+func (m *ValidatorVote) GetAuthSig() *v1alpha1.SpendAuthSignature {
+ if m != nil {
+ return m.AuthSig
+ }
+ return nil
+}
+
+type ValidatorVoteBody struct {
+ // The proposal being voted on.
+ Proposal uint64 `protobuf:"varint,1,opt,name=proposal,proto3" json:"proposal,omitempty"`
+ // The vote.
+ Vote *Vote `protobuf:"bytes,2,opt,name=vote,proto3" json:"vote,omitempty"`
+ // The validator identity.
+ IdentityKey *v1alpha1.IdentityKey `protobuf:"bytes,3,opt,name=identity_key,json=identityKey,proto3" json:"identity_key,omitempty"`
+ // The validator governance key.
+ GovernanceKey *v1alpha1.GovernanceKey `protobuf:"bytes,4,opt,name=governance_key,json=governanceKey,proto3" json:"governance_key,omitempty"`
+}
+
+func (m *ValidatorVoteBody) Reset() { *m = ValidatorVoteBody{} }
+func (m *ValidatorVoteBody) String() string { return proto.CompactTextString(m) }
+func (*ValidatorVoteBody) ProtoMessage() {}
+func (*ValidatorVoteBody) Descriptor() ([]byte, []int) {
+ return fileDescriptor_1bc89f5bf0aed114, []int{4}
+}
+func (m *ValidatorVoteBody) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *ValidatorVoteBody) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_ValidatorVoteBody.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *ValidatorVoteBody) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_ValidatorVoteBody.Merge(m, src)
+}
+func (m *ValidatorVoteBody) XXX_Size() int {
+ return m.Size()
+}
+func (m *ValidatorVoteBody) XXX_DiscardUnknown() {
+ xxx_messageInfo_ValidatorVoteBody.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_ValidatorVoteBody proto.InternalMessageInfo
+
+func (m *ValidatorVoteBody) GetProposal() uint64 {
+ if m != nil {
+ return m.Proposal
+ }
+ return 0
+}
+
+func (m *ValidatorVoteBody) GetVote() *Vote {
+ if m != nil {
+ return m.Vote
+ }
+ return nil
+}
+
+func (m *ValidatorVoteBody) GetIdentityKey() *v1alpha1.IdentityKey {
+ if m != nil {
+ return m.IdentityKey
+ }
+ return nil
+}
+
+func (m *ValidatorVoteBody) GetGovernanceKey() *v1alpha1.GovernanceKey {
+ if m != nil {
+ return m.GovernanceKey
+ }
+ return nil
+}
+
+type DelegatorVote struct {
+ // The effecting data for the vote.
+ Body *DelegatorVoteBody `protobuf:"bytes,1,opt,name=body,proto3" json:"body,omitempty"`
+ // The vote authorization signature is authorizing data.
+ AuthSig *v1alpha1.SpendAuthSignature `protobuf:"bytes,2,opt,name=auth_sig,json=authSig,proto3" json:"auth_sig,omitempty"`
+ // The vote proof is authorizing data.
+ Proof *v1alpha1.ZKDelegatorVoteProof `protobuf:"bytes,3,opt,name=proof,proto3" json:"proof,omitempty"`
+}
+
+func (m *DelegatorVote) Reset() { *m = DelegatorVote{} }
+func (m *DelegatorVote) String() string { return proto.CompactTextString(m) }
+func (*DelegatorVote) ProtoMessage() {}
+func (*DelegatorVote) Descriptor() ([]byte, []int) {
+ return fileDescriptor_1bc89f5bf0aed114, []int{5}
+}
+func (m *DelegatorVote) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *DelegatorVote) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_DelegatorVote.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *DelegatorVote) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_DelegatorVote.Merge(m, src)
+}
+func (m *DelegatorVote) XXX_Size() int {
+ return m.Size()
+}
+func (m *DelegatorVote) XXX_DiscardUnknown() {
+ xxx_messageInfo_DelegatorVote.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_DelegatorVote proto.InternalMessageInfo
+
+func (m *DelegatorVote) GetBody() *DelegatorVoteBody {
+ if m != nil {
+ return m.Body
+ }
+ return nil
+}
+
+func (m *DelegatorVote) GetAuthSig() *v1alpha1.SpendAuthSignature {
+ if m != nil {
+ return m.AuthSig
+ }
+ return nil
+}
+
+func (m *DelegatorVote) GetProof() *v1alpha1.ZKDelegatorVoteProof {
+ if m != nil {
+ return m.Proof
+ }
+ return nil
+}
+
+type DelegatorVoteBody struct {
+ // The proposal being voted on.
+ Proposal uint64 `protobuf:"varint,1,opt,name=proposal,proto3" json:"proposal,omitempty"`
+ // The start position of the proposal in the TCT.
+ StartPosition uint64 `protobuf:"varint,2,opt,name=start_position,json=startPosition,proto3" json:"start_position,omitempty"`
+ // The vote.
+ Vote *Vote `protobuf:"bytes,3,opt,name=vote,proto3" json:"vote,omitempty"`
+ // The value of the delegation note.
+ Value *v1alpha1.Value `protobuf:"bytes,4,opt,name=value,proto3" json:"value,omitempty"`
+ // The amount of the delegation note, in unbonded penumbra.
+ UnbondedAmount *v1alpha1.Amount `protobuf:"bytes,5,opt,name=unbonded_amount,json=unbondedAmount,proto3" json:"unbonded_amount,omitempty"`
+ // The nullifier of the input note.
+ Nullifier []byte `protobuf:"bytes,6,opt,name=nullifier,proto3" json:"nullifier,omitempty"`
+ // The randomized validating key for the spend authorization signature.
+ Rk []byte `protobuf:"bytes,7,opt,name=rk,proto3" json:"rk,omitempty"`
+}
+
+func (m *DelegatorVoteBody) Reset() { *m = DelegatorVoteBody{} }
+func (m *DelegatorVoteBody) String() string { return proto.CompactTextString(m) }
+func (*DelegatorVoteBody) ProtoMessage() {}
+func (*DelegatorVoteBody) Descriptor() ([]byte, []int) {
+ return fileDescriptor_1bc89f5bf0aed114, []int{6}
+}
+func (m *DelegatorVoteBody) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *DelegatorVoteBody) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_DelegatorVoteBody.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *DelegatorVoteBody) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_DelegatorVoteBody.Merge(m, src)
+}
+func (m *DelegatorVoteBody) XXX_Size() int {
+ return m.Size()
+}
+func (m *DelegatorVoteBody) XXX_DiscardUnknown() {
+ xxx_messageInfo_DelegatorVoteBody.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_DelegatorVoteBody proto.InternalMessageInfo
+
+func (m *DelegatorVoteBody) GetProposal() uint64 {
+ if m != nil {
+ return m.Proposal
+ }
+ return 0
+}
+
+func (m *DelegatorVoteBody) GetStartPosition() uint64 {
+ if m != nil {
+ return m.StartPosition
+ }
+ return 0
+}
+
+func (m *DelegatorVoteBody) GetVote() *Vote {
+ if m != nil {
+ return m.Vote
+ }
+ return nil
+}
+
+func (m *DelegatorVoteBody) GetValue() *v1alpha1.Value {
+ if m != nil {
+ return m.Value
+ }
+ return nil
+}
+
+func (m *DelegatorVoteBody) GetUnbondedAmount() *v1alpha1.Amount {
+ if m != nil {
+ return m.UnbondedAmount
+ }
+ return nil
+}
+
+func (m *DelegatorVoteBody) GetNullifier() []byte {
+ if m != nil {
+ return m.Nullifier
+ }
+ return nil
+}
+
+func (m *DelegatorVoteBody) GetRk() []byte {
+ if m != nil {
+ return m.Rk
+ }
+ return nil
+}
+
+type DelegatorVotePlan struct {
+ // The proposal to vote on.
+ Proposal uint64 `protobuf:"varint,1,opt,name=proposal,proto3" json:"proposal,omitempty"`
+ // The start position of the proposal in the TCT.
+ StartPosition uint64 `protobuf:"varint,2,opt,name=start_position,json=startPosition,proto3" json:"start_position,omitempty"`
+ // The vote to cast.
+ Vote *Vote `protobuf:"bytes,3,opt,name=vote,proto3" json:"vote,omitempty"`
+ // The delegation note to prove that we can vote.
+ StakedNote *v1alpha1.Note `protobuf:"bytes,4,opt,name=staked_note,json=stakedNote,proto3" json:"staked_note,omitempty"`
+ // The position of that delegation note.
+ StakedNotePosition uint64 `protobuf:"varint,5,opt,name=staked_note_position,json=stakedNotePosition,proto3" json:"staked_note_position,omitempty"`
+ // The unbonded amount equivalent to the delegation note.
+ UnbondedAmount *v1alpha1.Amount `protobuf:"bytes,6,opt,name=unbonded_amount,json=unbondedAmount,proto3" json:"unbonded_amount,omitempty"`
+ // The randomizer to use for the proof of spend capability.
+ Randomizer []byte `protobuf:"bytes,7,opt,name=randomizer,proto3" json:"randomizer,omitempty"`
+ // The first blinding factor to use for the ZK delegator vote proof.
+ ProofBlindingR []byte `protobuf:"bytes,8,opt,name=proof_blinding_r,json=proofBlindingR,proto3" json:"proof_blinding_r,omitempty"`
+ // The second blinding factor to use for the ZK delegator vote proof.
+ ProofBlindingS []byte `protobuf:"bytes,9,opt,name=proof_blinding_s,json=proofBlindingS,proto3" json:"proof_blinding_s,omitempty"`
+}
+
+func (m *DelegatorVotePlan) Reset() { *m = DelegatorVotePlan{} }
+func (m *DelegatorVotePlan) String() string { return proto.CompactTextString(m) }
+func (*DelegatorVotePlan) ProtoMessage() {}
+func (*DelegatorVotePlan) Descriptor() ([]byte, []int) {
+ return fileDescriptor_1bc89f5bf0aed114, []int{7}
+}
+func (m *DelegatorVotePlan) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *DelegatorVotePlan) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_DelegatorVotePlan.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *DelegatorVotePlan) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_DelegatorVotePlan.Merge(m, src)
+}
+func (m *DelegatorVotePlan) XXX_Size() int {
+ return m.Size()
+}
+func (m *DelegatorVotePlan) XXX_DiscardUnknown() {
+ xxx_messageInfo_DelegatorVotePlan.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_DelegatorVotePlan proto.InternalMessageInfo
+
+func (m *DelegatorVotePlan) GetProposal() uint64 {
+ if m != nil {
+ return m.Proposal
+ }
+ return 0
+}
+
+func (m *DelegatorVotePlan) GetStartPosition() uint64 {
+ if m != nil {
+ return m.StartPosition
+ }
+ return 0
+}
+
+func (m *DelegatorVotePlan) GetVote() *Vote {
+ if m != nil {
+ return m.Vote
+ }
+ return nil
+}
+
+func (m *DelegatorVotePlan) GetStakedNote() *v1alpha1.Note {
+ if m != nil {
+ return m.StakedNote
+ }
+ return nil
+}
+
+func (m *DelegatorVotePlan) GetStakedNotePosition() uint64 {
+ if m != nil {
+ return m.StakedNotePosition
+ }
+ return 0
+}
+
+func (m *DelegatorVotePlan) GetUnbondedAmount() *v1alpha1.Amount {
+ if m != nil {
+ return m.UnbondedAmount
+ }
+ return nil
+}
+
+func (m *DelegatorVotePlan) GetRandomizer() []byte {
+ if m != nil {
+ return m.Randomizer
+ }
+ return nil
+}
+
+func (m *DelegatorVotePlan) GetProofBlindingR() []byte {
+ if m != nil {
+ return m.ProofBlindingR
+ }
+ return nil
+}
+
+func (m *DelegatorVotePlan) GetProofBlindingS() []byte {
+ if m != nil {
+ return m.ProofBlindingS
+ }
+ return nil
+}
+
+type DaoDeposit struct {
+ // The value to deposit into the DAO.
+ Value *v1alpha1.Value `protobuf:"bytes,1,opt,name=value,proto3" json:"value,omitempty"`
+}
+
+func (m *DaoDeposit) Reset() { *m = DaoDeposit{} }
+func (m *DaoDeposit) String() string { return proto.CompactTextString(m) }
+func (*DaoDeposit) ProtoMessage() {}
+func (*DaoDeposit) Descriptor() ([]byte, []int) {
+ return fileDescriptor_1bc89f5bf0aed114, []int{8}
+}
+func (m *DaoDeposit) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *DaoDeposit) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_DaoDeposit.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *DaoDeposit) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_DaoDeposit.Merge(m, src)
+}
+func (m *DaoDeposit) XXX_Size() int {
+ return m.Size()
+}
+func (m *DaoDeposit) XXX_DiscardUnknown() {
+ xxx_messageInfo_DaoDeposit.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_DaoDeposit proto.InternalMessageInfo
+
+func (m *DaoDeposit) GetValue() *v1alpha1.Value {
+ if m != nil {
+ return m.Value
+ }
+ return nil
+}
+
+type DaoSpend struct {
+ // The value to spend from the DAO.
+ Value *v1alpha1.Value `protobuf:"bytes,1,opt,name=value,proto3" json:"value,omitempty"`
+}
+
+func (m *DaoSpend) Reset() { *m = DaoSpend{} }
+func (m *DaoSpend) String() string { return proto.CompactTextString(m) }
+func (*DaoSpend) ProtoMessage() {}
+func (*DaoSpend) Descriptor() ([]byte, []int) {
+ return fileDescriptor_1bc89f5bf0aed114, []int{9}
+}
+func (m *DaoSpend) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *DaoSpend) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_DaoSpend.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *DaoSpend) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_DaoSpend.Merge(m, src)
+}
+func (m *DaoSpend) XXX_Size() int {
+ return m.Size()
+}
+func (m *DaoSpend) XXX_DiscardUnknown() {
+ xxx_messageInfo_DaoSpend.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_DaoSpend proto.InternalMessageInfo
+
+func (m *DaoSpend) GetValue() *v1alpha1.Value {
+ if m != nil {
+ return m.Value
+ }
+ return nil
+}
+
+type DaoOutput struct {
+ // The value to output from the DAO.
+ Value *v1alpha1.Value `protobuf:"bytes,1,opt,name=value,proto3" json:"value,omitempty"`
+ // The address to send the output to.
+ Address *v1alpha1.Address `protobuf:"bytes,2,opt,name=address,proto3" json:"address,omitempty"`
+}
+
+func (m *DaoOutput) Reset() { *m = DaoOutput{} }
+func (m *DaoOutput) String() string { return proto.CompactTextString(m) }
+func (*DaoOutput) ProtoMessage() {}
+func (*DaoOutput) Descriptor() ([]byte, []int) {
+ return fileDescriptor_1bc89f5bf0aed114, []int{10}
+}
+func (m *DaoOutput) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *DaoOutput) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_DaoOutput.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *DaoOutput) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_DaoOutput.Merge(m, src)
+}
+func (m *DaoOutput) XXX_Size() int {
+ return m.Size()
+}
+func (m *DaoOutput) XXX_DiscardUnknown() {
+ xxx_messageInfo_DaoOutput.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_DaoOutput proto.InternalMessageInfo
+
+func (m *DaoOutput) GetValue() *v1alpha1.Value {
+ if m != nil {
+ return m.Value
+ }
+ return nil
+}
+
+func (m *DaoOutput) GetAddress() *v1alpha1.Address {
+ if m != nil {
+ return m.Address
+ }
+ return nil
+}
+
+// A vote on a proposal.
+type Vote struct {
+ // The vote.
+ Vote Vote_Vote `protobuf:"varint,1,opt,name=vote,proto3,enum=penumbra.core.governance.v1alpha1.Vote_Vote" json:"vote,omitempty"`
+}
+
+func (m *Vote) Reset() { *m = Vote{} }
+func (m *Vote) String() string { return proto.CompactTextString(m) }
+func (*Vote) ProtoMessage() {}
+func (*Vote) Descriptor() ([]byte, []int) {
+ return fileDescriptor_1bc89f5bf0aed114, []int{11}
+}
+func (m *Vote) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *Vote) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_Vote.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *Vote) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_Vote.Merge(m, src)
+}
+func (m *Vote) XXX_Size() int {
+ return m.Size()
+}
+func (m *Vote) XXX_DiscardUnknown() {
+ xxx_messageInfo_Vote.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_Vote proto.InternalMessageInfo
+
+func (m *Vote) GetVote() Vote_Vote {
+ if m != nil {
+ return m.Vote
+ }
+ return Vote_VOTE_UNSPECIFIED
+}
+
+// The current state of a proposal.
+type ProposalState struct {
+ // The state of the proposal.
+ //
+ // Types that are valid to be assigned to State:
+ // *ProposalState_Voting_
+ // *ProposalState_Withdrawn_
+ // *ProposalState_Finished_
+ // *ProposalState_Claimed_
+ State isProposalState_State `protobuf_oneof:"state"`
+}
+
+func (m *ProposalState) Reset() { *m = ProposalState{} }
+func (m *ProposalState) String() string { return proto.CompactTextString(m) }
+func (*ProposalState) ProtoMessage() {}
+func (*ProposalState) Descriptor() ([]byte, []int) {
+ return fileDescriptor_1bc89f5bf0aed114, []int{12}
+}
+func (m *ProposalState) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *ProposalState) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_ProposalState.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *ProposalState) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_ProposalState.Merge(m, src)
+}
+func (m *ProposalState) XXX_Size() int {
+ return m.Size()
+}
+func (m *ProposalState) XXX_DiscardUnknown() {
+ xxx_messageInfo_ProposalState.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_ProposalState proto.InternalMessageInfo
+
+type isProposalState_State interface {
+ isProposalState_State()
+ MarshalTo([]byte) (int, error)
+ Size() int
+}
+
+type ProposalState_Voting_ struct {
+ Voting *ProposalState_Voting `protobuf:"bytes,2,opt,name=voting,proto3,oneof" json:"voting,omitempty"`
+}
+type ProposalState_Withdrawn_ struct {
+ Withdrawn *ProposalState_Withdrawn `protobuf:"bytes,3,opt,name=withdrawn,proto3,oneof" json:"withdrawn,omitempty"`
+}
+type ProposalState_Finished_ struct {
+ Finished *ProposalState_Finished `protobuf:"bytes,4,opt,name=finished,proto3,oneof" json:"finished,omitempty"`
+}
+type ProposalState_Claimed_ struct {
+ Claimed *ProposalState_Claimed `protobuf:"bytes,5,opt,name=claimed,proto3,oneof" json:"claimed,omitempty"`
+}
+
+func (*ProposalState_Voting_) isProposalState_State() {}
+func (*ProposalState_Withdrawn_) isProposalState_State() {}
+func (*ProposalState_Finished_) isProposalState_State() {}
+func (*ProposalState_Claimed_) isProposalState_State() {}
+
+func (m *ProposalState) GetState() isProposalState_State {
+ if m != nil {
+ return m.State
+ }
+ return nil
+}
+
+func (m *ProposalState) GetVoting() *ProposalState_Voting {
+ if x, ok := m.GetState().(*ProposalState_Voting_); ok {
+ return x.Voting
+ }
+ return nil
+}
+
+func (m *ProposalState) GetWithdrawn() *ProposalState_Withdrawn {
+ if x, ok := m.GetState().(*ProposalState_Withdrawn_); ok {
+ return x.Withdrawn
+ }
+ return nil
+}
+
+func (m *ProposalState) GetFinished() *ProposalState_Finished {
+ if x, ok := m.GetState().(*ProposalState_Finished_); ok {
+ return x.Finished
+ }
+ return nil
+}
+
+func (m *ProposalState) GetClaimed() *ProposalState_Claimed {
+ if x, ok := m.GetState().(*ProposalState_Claimed_); ok {
+ return x.Claimed
+ }
+ return nil
+}
+
+// XXX_OneofWrappers is for the internal use of the proto package.
+func (*ProposalState) XXX_OneofWrappers() []interface{} {
+ return []interface{}{
+ (*ProposalState_Voting_)(nil),
+ (*ProposalState_Withdrawn_)(nil),
+ (*ProposalState_Finished_)(nil),
+ (*ProposalState_Claimed_)(nil),
+ }
+}
+
+// Voting is in progress and the proposal has not yet concluded voting or been withdrawn.
+type ProposalState_Voting struct {
+}
+
+func (m *ProposalState_Voting) Reset() { *m = ProposalState_Voting{} }
+func (m *ProposalState_Voting) String() string { return proto.CompactTextString(m) }
+func (*ProposalState_Voting) ProtoMessage() {}
+func (*ProposalState_Voting) Descriptor() ([]byte, []int) {
+ return fileDescriptor_1bc89f5bf0aed114, []int{12, 0}
+}
+func (m *ProposalState_Voting) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *ProposalState_Voting) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_ProposalState_Voting.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *ProposalState_Voting) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_ProposalState_Voting.Merge(m, src)
+}
+func (m *ProposalState_Voting) XXX_Size() int {
+ return m.Size()
+}
+func (m *ProposalState_Voting) XXX_DiscardUnknown() {
+ xxx_messageInfo_ProposalState_Voting.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_ProposalState_Voting proto.InternalMessageInfo
+
+// The proposal has been withdrawn but the voting period is not yet concluded.
+type ProposalState_Withdrawn struct {
+ // The reason for the withdrawal.
+ Reason string `protobuf:"bytes,1,opt,name=reason,proto3" json:"reason,omitempty"`
+}
+
+func (m *ProposalState_Withdrawn) Reset() { *m = ProposalState_Withdrawn{} }
+func (m *ProposalState_Withdrawn) String() string { return proto.CompactTextString(m) }
+func (*ProposalState_Withdrawn) ProtoMessage() {}
+func (*ProposalState_Withdrawn) Descriptor() ([]byte, []int) {
+ return fileDescriptor_1bc89f5bf0aed114, []int{12, 1}
+}
+func (m *ProposalState_Withdrawn) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *ProposalState_Withdrawn) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_ProposalState_Withdrawn.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *ProposalState_Withdrawn) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_ProposalState_Withdrawn.Merge(m, src)
+}
+func (m *ProposalState_Withdrawn) XXX_Size() int {
+ return m.Size()
+}
+func (m *ProposalState_Withdrawn) XXX_DiscardUnknown() {
+ xxx_messageInfo_ProposalState_Withdrawn.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_ProposalState_Withdrawn proto.InternalMessageInfo
+
+func (m *ProposalState_Withdrawn) GetReason() string {
+ if m != nil {
+ return m.Reason
+ }
+ return ""
+}
+
+// The voting period has ended, and the proposal has been assigned an outcome.
+type ProposalState_Finished struct {
+ Outcome *ProposalOutcome `protobuf:"bytes,1,opt,name=outcome,proto3" json:"outcome,omitempty"`
+}
+
+func (m *ProposalState_Finished) Reset() { *m = ProposalState_Finished{} }
+func (m *ProposalState_Finished) String() string { return proto.CompactTextString(m) }
+func (*ProposalState_Finished) ProtoMessage() {}
+func (*ProposalState_Finished) Descriptor() ([]byte, []int) {
+ return fileDescriptor_1bc89f5bf0aed114, []int{12, 2}
+}
+func (m *ProposalState_Finished) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *ProposalState_Finished) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_ProposalState_Finished.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *ProposalState_Finished) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_ProposalState_Finished.Merge(m, src)
+}
+func (m *ProposalState_Finished) XXX_Size() int {
+ return m.Size()
+}
+func (m *ProposalState_Finished) XXX_DiscardUnknown() {
+ xxx_messageInfo_ProposalState_Finished.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_ProposalState_Finished proto.InternalMessageInfo
+
+func (m *ProposalState_Finished) GetOutcome() *ProposalOutcome {
+ if m != nil {
+ return m.Outcome
+ }
+ return nil
+}
+
+// The voting period has ended, and the original proposer has claimed their deposit.
+type ProposalState_Claimed struct {
+ Outcome *ProposalOutcome `protobuf:"bytes,1,opt,name=outcome,proto3" json:"outcome,omitempty"`
+}
+
+func (m *ProposalState_Claimed) Reset() { *m = ProposalState_Claimed{} }
+func (m *ProposalState_Claimed) String() string { return proto.CompactTextString(m) }
+func (*ProposalState_Claimed) ProtoMessage() {}
+func (*ProposalState_Claimed) Descriptor() ([]byte, []int) {
+ return fileDescriptor_1bc89f5bf0aed114, []int{12, 3}
+}
+func (m *ProposalState_Claimed) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *ProposalState_Claimed) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_ProposalState_Claimed.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *ProposalState_Claimed) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_ProposalState_Claimed.Merge(m, src)
+}
+func (m *ProposalState_Claimed) XXX_Size() int {
+ return m.Size()
+}
+func (m *ProposalState_Claimed) XXX_DiscardUnknown() {
+ xxx_messageInfo_ProposalState_Claimed.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_ProposalState_Claimed proto.InternalMessageInfo
+
+func (m *ProposalState_Claimed) GetOutcome() *ProposalOutcome {
+ if m != nil {
+ return m.Outcome
+ }
+ return nil
+}
+
+// The outcome of a concluded proposal.
+type ProposalOutcome struct {
+ // Types that are valid to be assigned to Outcome:
+ //
+ // *ProposalOutcome_Passed_
+ // *ProposalOutcome_Failed_
+ // *ProposalOutcome_Slashed_
+ Outcome isProposalOutcome_Outcome `protobuf_oneof:"outcome"`
+}
+
+func (m *ProposalOutcome) Reset() { *m = ProposalOutcome{} }
+func (m *ProposalOutcome) String() string { return proto.CompactTextString(m) }
+func (*ProposalOutcome) ProtoMessage() {}
+func (*ProposalOutcome) Descriptor() ([]byte, []int) {
+ return fileDescriptor_1bc89f5bf0aed114, []int{13}
+}
+func (m *ProposalOutcome) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *ProposalOutcome) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_ProposalOutcome.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *ProposalOutcome) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_ProposalOutcome.Merge(m, src)
+}
+func (m *ProposalOutcome) XXX_Size() int {
+ return m.Size()
+}
+func (m *ProposalOutcome) XXX_DiscardUnknown() {
+ xxx_messageInfo_ProposalOutcome.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_ProposalOutcome proto.InternalMessageInfo
+
+type isProposalOutcome_Outcome interface {
+ isProposalOutcome_Outcome()
+ MarshalTo([]byte) (int, error)
+ Size() int
+}
+
+type ProposalOutcome_Passed_ struct {
+ Passed *ProposalOutcome_Passed `protobuf:"bytes,1,opt,name=passed,proto3,oneof" json:"passed,omitempty"`
+}
+type ProposalOutcome_Failed_ struct {
+ Failed *ProposalOutcome_Failed `protobuf:"bytes,2,opt,name=failed,proto3,oneof" json:"failed,omitempty"`
+}
+type ProposalOutcome_Slashed_ struct {
+ Slashed *ProposalOutcome_Slashed `protobuf:"bytes,3,opt,name=slashed,proto3,oneof" json:"slashed,omitempty"`
+}
+
+func (*ProposalOutcome_Passed_) isProposalOutcome_Outcome() {}
+func (*ProposalOutcome_Failed_) isProposalOutcome_Outcome() {}
+func (*ProposalOutcome_Slashed_) isProposalOutcome_Outcome() {}
+
+func (m *ProposalOutcome) GetOutcome() isProposalOutcome_Outcome {
+ if m != nil {
+ return m.Outcome
+ }
+ return nil
+}
+
+func (m *ProposalOutcome) GetPassed() *ProposalOutcome_Passed {
+ if x, ok := m.GetOutcome().(*ProposalOutcome_Passed_); ok {
+ return x.Passed
+ }
+ return nil
+}
+
+func (m *ProposalOutcome) GetFailed() *ProposalOutcome_Failed {
+ if x, ok := m.GetOutcome().(*ProposalOutcome_Failed_); ok {
+ return x.Failed
+ }
+ return nil
+}
+
+func (m *ProposalOutcome) GetSlashed() *ProposalOutcome_Slashed {
+ if x, ok := m.GetOutcome().(*ProposalOutcome_Slashed_); ok {
+ return x.Slashed
+ }
+ return nil
+}
+
+// XXX_OneofWrappers is for the internal use of the proto package.
+func (*ProposalOutcome) XXX_OneofWrappers() []interface{} {
+ return []interface{}{
+ (*ProposalOutcome_Passed_)(nil),
+ (*ProposalOutcome_Failed_)(nil),
+ (*ProposalOutcome_Slashed_)(nil),
+ }
+}
+
+// The proposal was passed.
+type ProposalOutcome_Passed struct {
+}
+
+func (m *ProposalOutcome_Passed) Reset() { *m = ProposalOutcome_Passed{} }
+func (m *ProposalOutcome_Passed) String() string { return proto.CompactTextString(m) }
+func (*ProposalOutcome_Passed) ProtoMessage() {}
+func (*ProposalOutcome_Passed) Descriptor() ([]byte, []int) {
+ return fileDescriptor_1bc89f5bf0aed114, []int{13, 0}
+}
+func (m *ProposalOutcome_Passed) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *ProposalOutcome_Passed) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_ProposalOutcome_Passed.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *ProposalOutcome_Passed) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_ProposalOutcome_Passed.Merge(m, src)
+}
+func (m *ProposalOutcome_Passed) XXX_Size() int {
+ return m.Size()
+}
+func (m *ProposalOutcome_Passed) XXX_DiscardUnknown() {
+ xxx_messageInfo_ProposalOutcome_Passed.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_ProposalOutcome_Passed proto.InternalMessageInfo
+
+// The proposal did not pass.
+type ProposalOutcome_Failed struct {
+ // Types that are valid to be assigned to XWithdrawnWithReason:
+ //
+ // *ProposalOutcome_Failed_WithdrawnWithReason
+ XWithdrawnWithReason isProposalOutcome_Failed_XWithdrawnWithReason `protobuf_oneof:"_withdrawn_with_reason"`
+}
+
+func (m *ProposalOutcome_Failed) Reset() { *m = ProposalOutcome_Failed{} }
+func (m *ProposalOutcome_Failed) String() string { return proto.CompactTextString(m) }
+func (*ProposalOutcome_Failed) ProtoMessage() {}
+func (*ProposalOutcome_Failed) Descriptor() ([]byte, []int) {
+ return fileDescriptor_1bc89f5bf0aed114, []int{13, 1}
+}
+func (m *ProposalOutcome_Failed) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *ProposalOutcome_Failed) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_ProposalOutcome_Failed.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *ProposalOutcome_Failed) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_ProposalOutcome_Failed.Merge(m, src)
+}
+func (m *ProposalOutcome_Failed) XXX_Size() int {
+ return m.Size()
+}
+func (m *ProposalOutcome_Failed) XXX_DiscardUnknown() {
+ xxx_messageInfo_ProposalOutcome_Failed.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_ProposalOutcome_Failed proto.InternalMessageInfo
+
+type isProposalOutcome_Failed_XWithdrawnWithReason interface {
+ isProposalOutcome_Failed_XWithdrawnWithReason()
+ MarshalTo([]byte) (int, error)
+ Size() int
+}
+
+type ProposalOutcome_Failed_WithdrawnWithReason struct {
+ WithdrawnWithReason string `protobuf:"bytes,1,opt,name=withdrawn_with_reason,json=withdrawnWithReason,proto3,oneof" json:"withdrawn_with_reason,omitempty"`
+}
+
+func (*ProposalOutcome_Failed_WithdrawnWithReason) isProposalOutcome_Failed_XWithdrawnWithReason() {}
+
+func (m *ProposalOutcome_Failed) GetXWithdrawnWithReason() isProposalOutcome_Failed_XWithdrawnWithReason {
+ if m != nil {
+ return m.XWithdrawnWithReason
+ }
+ return nil
+}
+
+func (m *ProposalOutcome_Failed) GetWithdrawnWithReason() string {
+ if x, ok := m.GetXWithdrawnWithReason().(*ProposalOutcome_Failed_WithdrawnWithReason); ok {
+ return x.WithdrawnWithReason
+ }
+ return ""
+}
+
+// XXX_OneofWrappers is for the internal use of the proto package.
+func (*ProposalOutcome_Failed) XXX_OneofWrappers() []interface{} {
+ return []interface{}{
+ (*ProposalOutcome_Failed_WithdrawnWithReason)(nil),
+ }
+}
+
+// The proposal did not pass, and was slashed.
+type ProposalOutcome_Slashed struct {
+ // Types that are valid to be assigned to XWithdrawnWithReason:
+ //
+ // *ProposalOutcome_Slashed_WithdrawnWithReason
+ XWithdrawnWithReason isProposalOutcome_Slashed_XWithdrawnWithReason `protobuf_oneof:"_withdrawn_with_reason"`
+}
+
+func (m *ProposalOutcome_Slashed) Reset() { *m = ProposalOutcome_Slashed{} }
+func (m *ProposalOutcome_Slashed) String() string { return proto.CompactTextString(m) }
+func (*ProposalOutcome_Slashed) ProtoMessage() {}
+func (*ProposalOutcome_Slashed) Descriptor() ([]byte, []int) {
+ return fileDescriptor_1bc89f5bf0aed114, []int{13, 2}
+}
+func (m *ProposalOutcome_Slashed) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *ProposalOutcome_Slashed) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_ProposalOutcome_Slashed.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *ProposalOutcome_Slashed) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_ProposalOutcome_Slashed.Merge(m, src)
+}
+func (m *ProposalOutcome_Slashed) XXX_Size() int {
+ return m.Size()
+}
+func (m *ProposalOutcome_Slashed) XXX_DiscardUnknown() {
+ xxx_messageInfo_ProposalOutcome_Slashed.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_ProposalOutcome_Slashed proto.InternalMessageInfo
+
+type isProposalOutcome_Slashed_XWithdrawnWithReason interface {
+ isProposalOutcome_Slashed_XWithdrawnWithReason()
+ MarshalTo([]byte) (int, error)
+ Size() int
+}
+
+type ProposalOutcome_Slashed_WithdrawnWithReason struct {
+ WithdrawnWithReason string `protobuf:"bytes,1,opt,name=withdrawn_with_reason,json=withdrawnWithReason,proto3,oneof" json:"withdrawn_with_reason,omitempty"`
+}
+
+func (*ProposalOutcome_Slashed_WithdrawnWithReason) isProposalOutcome_Slashed_XWithdrawnWithReason() {
+}
+
+func (m *ProposalOutcome_Slashed) GetXWithdrawnWithReason() isProposalOutcome_Slashed_XWithdrawnWithReason {
+ if m != nil {
+ return m.XWithdrawnWithReason
+ }
+ return nil
+}
+
+func (m *ProposalOutcome_Slashed) GetWithdrawnWithReason() string {
+ if x, ok := m.GetXWithdrawnWithReason().(*ProposalOutcome_Slashed_WithdrawnWithReason); ok {
+ return x.WithdrawnWithReason
+ }
+ return ""
+}
+
+// XXX_OneofWrappers is for the internal use of the proto package.
+func (*ProposalOutcome_Slashed) XXX_OneofWrappers() []interface{} {
+ return []interface{}{
+ (*ProposalOutcome_Slashed_WithdrawnWithReason)(nil),
+ }
+}
+
+// A tally of votes on a proposal.
+type Tally struct {
+ // The number of votes in favor of the proposal.
+ Yes uint64 `protobuf:"varint,1,opt,name=yes,proto3" json:"yes,omitempty"`
+ // The number of votes against the proposal.
+ No uint64 `protobuf:"varint,2,opt,name=no,proto3" json:"no,omitempty"`
+ // The number of abstentions.
+ Abstain uint64 `protobuf:"varint,3,opt,name=abstain,proto3" json:"abstain,omitempty"`
+}
+
+func (m *Tally) Reset() { *m = Tally{} }
+func (m *Tally) String() string { return proto.CompactTextString(m) }
+func (*Tally) ProtoMessage() {}
+func (*Tally) Descriptor() ([]byte, []int) {
+ return fileDescriptor_1bc89f5bf0aed114, []int{14}
+}
+func (m *Tally) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *Tally) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_Tally.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *Tally) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_Tally.Merge(m, src)
+}
+func (m *Tally) XXX_Size() int {
+ return m.Size()
+}
+func (m *Tally) XXX_DiscardUnknown() {
+ xxx_messageInfo_Tally.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_Tally proto.InternalMessageInfo
+
+func (m *Tally) GetYes() uint64 {
+ if m != nil {
+ return m.Yes
+ }
+ return 0
+}
+
+func (m *Tally) GetNo() uint64 {
+ if m != nil {
+ return m.No
+ }
+ return 0
+}
+
+func (m *Tally) GetAbstain() uint64 {
+ if m != nil {
+ return m.Abstain
+ }
+ return 0
+}
+
+// A proposal to be voted upon.
+type Proposal struct {
+ // The unique identifier of the proposal.
+ Id uint64 `protobuf:"varint,4,opt,name=id,proto3" json:"id,omitempty"`
+ // A short title for the proposal.
+ Title string `protobuf:"bytes,1,opt,name=title,proto3" json:"title,omitempty"`
+ // A natural-language description of the effect of the proposal and its justification.
+ Description string `protobuf:"bytes,2,opt,name=description,proto3" json:"description,omitempty"`
+ // The different kinds of proposal. Only one of these should be set.
+ Signaling *Proposal_Signaling `protobuf:"bytes,5,opt,name=signaling,proto3" json:"signaling,omitempty"`
+ Emergency *Proposal_Emergency `protobuf:"bytes,6,opt,name=emergency,proto3" json:"emergency,omitempty"`
+ ParameterChange *Proposal_ParameterChange `protobuf:"bytes,7,opt,name=parameter_change,json=parameterChange,proto3" json:"parameter_change,omitempty"`
+ DaoSpend *Proposal_DaoSpend `protobuf:"bytes,8,opt,name=dao_spend,json=daoSpend,proto3" json:"dao_spend,omitempty"`
+}
+
+func (m *Proposal) Reset() { *m = Proposal{} }
+func (m *Proposal) String() string { return proto.CompactTextString(m) }
+func (*Proposal) ProtoMessage() {}
+func (*Proposal) Descriptor() ([]byte, []int) {
+ return fileDescriptor_1bc89f5bf0aed114, []int{15}
+}
+func (m *Proposal) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *Proposal) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_Proposal.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *Proposal) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_Proposal.Merge(m, src)
+}
+func (m *Proposal) XXX_Size() int {
+ return m.Size()
+}
+func (m *Proposal) XXX_DiscardUnknown() {
+ xxx_messageInfo_Proposal.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_Proposal proto.InternalMessageInfo
+
+func (m *Proposal) GetId() uint64 {
+ if m != nil {
+ return m.Id
+ }
+ return 0
+}
+
+func (m *Proposal) GetTitle() string {
+ if m != nil {
+ return m.Title
+ }
+ return ""
+}
+
+func (m *Proposal) GetDescription() string {
+ if m != nil {
+ return m.Description
+ }
+ return ""
+}
+
+func (m *Proposal) GetSignaling() *Proposal_Signaling {
+ if m != nil {
+ return m.Signaling
+ }
+ return nil
+}
+
+func (m *Proposal) GetEmergency() *Proposal_Emergency {
+ if m != nil {
+ return m.Emergency
+ }
+ return nil
+}
+
+func (m *Proposal) GetParameterChange() *Proposal_ParameterChange {
+ if m != nil {
+ return m.ParameterChange
+ }
+ return nil
+}
+
+func (m *Proposal) GetDaoSpend() *Proposal_DaoSpend {
+ if m != nil {
+ return m.DaoSpend
+ }
+ return nil
+}
+
+// A signaling proposal is meant to register a vote on-chain, but does not have an automatic
+// effect when passed.
+//
+// It optionally contains a reference to a commit which contains code to upgrade the chain.
+type Proposal_Signaling struct {
+ // Types that are valid to be assigned to XCommit:
+ //
+ // *Proposal_Signaling_Commit
+ XCommit isProposal_Signaling_XCommit `protobuf_oneof:"_commit"`
+}
+
+func (m *Proposal_Signaling) Reset() { *m = Proposal_Signaling{} }
+func (m *Proposal_Signaling) String() string { return proto.CompactTextString(m) }
+func (*Proposal_Signaling) ProtoMessage() {}
+func (*Proposal_Signaling) Descriptor() ([]byte, []int) {
+ return fileDescriptor_1bc89f5bf0aed114, []int{15, 0}
+}
+func (m *Proposal_Signaling) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *Proposal_Signaling) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_Proposal_Signaling.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *Proposal_Signaling) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_Proposal_Signaling.Merge(m, src)
+}
+func (m *Proposal_Signaling) XXX_Size() int {
+ return m.Size()
+}
+func (m *Proposal_Signaling) XXX_DiscardUnknown() {
+ xxx_messageInfo_Proposal_Signaling.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_Proposal_Signaling proto.InternalMessageInfo
+
+type isProposal_Signaling_XCommit interface {
+ isProposal_Signaling_XCommit()
+ MarshalTo([]byte) (int, error)
+ Size() int
+}
+
+type Proposal_Signaling_Commit struct {
+ Commit string `protobuf:"bytes,1,opt,name=commit,proto3,oneof" json:"commit,omitempty"`
+}
+
+func (*Proposal_Signaling_Commit) isProposal_Signaling_XCommit() {}
+
+func (m *Proposal_Signaling) GetXCommit() isProposal_Signaling_XCommit {
+ if m != nil {
+ return m.XCommit
+ }
+ return nil
+}
+
+func (m *Proposal_Signaling) GetCommit() string {
+ if x, ok := m.GetXCommit().(*Proposal_Signaling_Commit); ok {
+ return x.Commit
+ }
+ return ""
+}
+
+// XXX_OneofWrappers is for the internal use of the proto package.
+func (*Proposal_Signaling) XXX_OneofWrappers() []interface{} {
+ return []interface{}{
+ (*Proposal_Signaling_Commit)(nil),
+ }
+}
+
+// An emergency proposal can be passed instantaneously by a 2/3 majority of validators, without
+// waiting for the voting period to expire.
+//
+// If the boolean `halt_chain` is set to `true`, then the chain will halt immediately when the
+// proposal is passed.
+type Proposal_Emergency struct {
+ // If `true`, the chain will halt immediately when the proposal is passed.
+ HaltChain bool `protobuf:"varint,1,opt,name=halt_chain,json=haltChain,proto3" json:"halt_chain,omitempty"`
+}
+
+func (m *Proposal_Emergency) Reset() { *m = Proposal_Emergency{} }
+func (m *Proposal_Emergency) String() string { return proto.CompactTextString(m) }
+func (*Proposal_Emergency) ProtoMessage() {}
+func (*Proposal_Emergency) Descriptor() ([]byte, []int) {
+ return fileDescriptor_1bc89f5bf0aed114, []int{15, 1}
+}
+func (m *Proposal_Emergency) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *Proposal_Emergency) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_Proposal_Emergency.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *Proposal_Emergency) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_Proposal_Emergency.Merge(m, src)
+}
+func (m *Proposal_Emergency) XXX_Size() int {
+ return m.Size()
+}
+func (m *Proposal_Emergency) XXX_DiscardUnknown() {
+ xxx_messageInfo_Proposal_Emergency.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_Proposal_Emergency proto.InternalMessageInfo
+
+func (m *Proposal_Emergency) GetHaltChain() bool {
+ if m != nil {
+ return m.HaltChain
+ }
+ return false
+}
+
+// A parameter change proposal describes a replacement of the chain parameters, which should take
+// effect when the proposal is passed.
+type Proposal_ParameterChange struct {
+ // The old chain parameters to be replaced: even if the proposal passes, the update will not be
+ // applied if the chain parameters have changed *at all* from these chain parameters. Usually,
+ // this should be set to the current chain parameters at time of proposal.
+ OldParameters *v1alpha11.ChainParameters `protobuf:"bytes,1,opt,name=old_parameters,json=oldParameters,proto3" json:"old_parameters,omitempty"`
+ // The new chain parameters to be set: the *entire* chain parameters will be replaced with these
+ // at the time the proposal is passed.
+ NewParameters *v1alpha11.ChainParameters `protobuf:"bytes,2,opt,name=new_parameters,json=newParameters,proto3" json:"new_parameters,omitempty"`
+}
+
+func (m *Proposal_ParameterChange) Reset() { *m = Proposal_ParameterChange{} }
+func (m *Proposal_ParameterChange) String() string { return proto.CompactTextString(m) }
+func (*Proposal_ParameterChange) ProtoMessage() {}
+func (*Proposal_ParameterChange) Descriptor() ([]byte, []int) {
+ return fileDescriptor_1bc89f5bf0aed114, []int{15, 2}
+}
+func (m *Proposal_ParameterChange) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *Proposal_ParameterChange) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_Proposal_ParameterChange.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *Proposal_ParameterChange) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_Proposal_ParameterChange.Merge(m, src)
+}
+func (m *Proposal_ParameterChange) XXX_Size() int {
+ return m.Size()
+}
+func (m *Proposal_ParameterChange) XXX_DiscardUnknown() {
+ xxx_messageInfo_Proposal_ParameterChange.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_Proposal_ParameterChange proto.InternalMessageInfo
+
+func (m *Proposal_ParameterChange) GetOldParameters() *v1alpha11.ChainParameters {
+ if m != nil {
+ return m.OldParameters
+ }
+ return nil
+}
+
+func (m *Proposal_ParameterChange) GetNewParameters() *v1alpha11.ChainParameters {
+ if m != nil {
+ return m.NewParameters
+ }
+ return nil
+}
+
+// A DAO spend proposal describes zero or more transactions to execute on behalf of the DAO, with
+// access to its funds, and zero or more scheduled transactions from previous passed proposals to
+// cancel.
+type Proposal_DaoSpend struct {
+ // The transaction plan to be executed at the time the proposal is passed. This must be a
+ // transaction plan which can be executed by the DAO, which means it can't require any witness
+ // data or authorization signatures, but it may use the `DaoSpend` action.
+ TransactionPlan *types.Any `protobuf:"bytes,2,opt,name=transaction_plan,json=transactionPlan,proto3" json:"transaction_plan,omitempty"`
+}
+
+func (m *Proposal_DaoSpend) Reset() { *m = Proposal_DaoSpend{} }
+func (m *Proposal_DaoSpend) String() string { return proto.CompactTextString(m) }
+func (*Proposal_DaoSpend) ProtoMessage() {}
+func (*Proposal_DaoSpend) Descriptor() ([]byte, []int) {
+ return fileDescriptor_1bc89f5bf0aed114, []int{15, 3}
+}
+func (m *Proposal_DaoSpend) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *Proposal_DaoSpend) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_Proposal_DaoSpend.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *Proposal_DaoSpend) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_Proposal_DaoSpend.Merge(m, src)
+}
+func (m *Proposal_DaoSpend) XXX_Size() int {
+ return m.Size()
+}
+func (m *Proposal_DaoSpend) XXX_DiscardUnknown() {
+ xxx_messageInfo_Proposal_DaoSpend.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_Proposal_DaoSpend proto.InternalMessageInfo
+
+func (m *Proposal_DaoSpend) GetTransactionPlan() *types.Any {
+ if m != nil {
+ return m.TransactionPlan
+ }
+ return nil
+}
+
+func init() {
+ proto.RegisterEnum("penumbra.core.governance.v1alpha1.Vote_Vote", Vote_Vote_name, Vote_Vote_value)
+ proto.RegisterType((*ProposalSubmit)(nil), "penumbra.core.governance.v1alpha1.ProposalSubmit")
+ proto.RegisterType((*ProposalWithdraw)(nil), "penumbra.core.governance.v1alpha1.ProposalWithdraw")
+ proto.RegisterType((*ProposalDepositClaim)(nil), "penumbra.core.governance.v1alpha1.ProposalDepositClaim")
+ proto.RegisterType((*ValidatorVote)(nil), "penumbra.core.governance.v1alpha1.ValidatorVote")
+ proto.RegisterType((*ValidatorVoteBody)(nil), "penumbra.core.governance.v1alpha1.ValidatorVoteBody")
+ proto.RegisterType((*DelegatorVote)(nil), "penumbra.core.governance.v1alpha1.DelegatorVote")
+ proto.RegisterType((*DelegatorVoteBody)(nil), "penumbra.core.governance.v1alpha1.DelegatorVoteBody")
+ proto.RegisterType((*DelegatorVotePlan)(nil), "penumbra.core.governance.v1alpha1.DelegatorVotePlan")
+ proto.RegisterType((*DaoDeposit)(nil), "penumbra.core.governance.v1alpha1.DaoDeposit")
+ proto.RegisterType((*DaoSpend)(nil), "penumbra.core.governance.v1alpha1.DaoSpend")
+ proto.RegisterType((*DaoOutput)(nil), "penumbra.core.governance.v1alpha1.DaoOutput")
+ proto.RegisterType((*Vote)(nil), "penumbra.core.governance.v1alpha1.Vote")
+ proto.RegisterType((*ProposalState)(nil), "penumbra.core.governance.v1alpha1.ProposalState")
+ proto.RegisterType((*ProposalState_Voting)(nil), "penumbra.core.governance.v1alpha1.ProposalState.Voting")
+ proto.RegisterType((*ProposalState_Withdrawn)(nil), "penumbra.core.governance.v1alpha1.ProposalState.Withdrawn")
+ proto.RegisterType((*ProposalState_Finished)(nil), "penumbra.core.governance.v1alpha1.ProposalState.Finished")
+ proto.RegisterType((*ProposalState_Claimed)(nil), "penumbra.core.governance.v1alpha1.ProposalState.Claimed")
+ proto.RegisterType((*ProposalOutcome)(nil), "penumbra.core.governance.v1alpha1.ProposalOutcome")
+ proto.RegisterType((*ProposalOutcome_Passed)(nil), "penumbra.core.governance.v1alpha1.ProposalOutcome.Passed")
+ proto.RegisterType((*ProposalOutcome_Failed)(nil), "penumbra.core.governance.v1alpha1.ProposalOutcome.Failed")
+ proto.RegisterType((*ProposalOutcome_Slashed)(nil), "penumbra.core.governance.v1alpha1.ProposalOutcome.Slashed")
+ proto.RegisterType((*Tally)(nil), "penumbra.core.governance.v1alpha1.Tally")
+ proto.RegisterType((*Proposal)(nil), "penumbra.core.governance.v1alpha1.Proposal")
+ proto.RegisterType((*Proposal_Signaling)(nil), "penumbra.core.governance.v1alpha1.Proposal.Signaling")
+ proto.RegisterType((*Proposal_Emergency)(nil), "penumbra.core.governance.v1alpha1.Proposal.Emergency")
+ proto.RegisterType((*Proposal_ParameterChange)(nil), "penumbra.core.governance.v1alpha1.Proposal.ParameterChange")
+ proto.RegisterType((*Proposal_DaoSpend)(nil), "penumbra.core.governance.v1alpha1.Proposal.DaoSpend")
+}
+
+func init() {
+ proto.RegisterFile("penumbra/core/governance/v1alpha1/governance.proto", fileDescriptor_1bc89f5bf0aed114)
+}
+
+var fileDescriptor_1bc89f5bf0aed114 = []byte{
+ // 1546 bytes of a gzipped FileDescriptorProto
+ 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xc4, 0x58, 0x5d, 0x6f, 0x1b, 0x45,
+ 0x17, 0xf6, 0x3a, 0x8e, 0x3f, 0x4e, 0x12, 0xc7, 0x9d, 0x37, 0x6f, 0xe5, 0xd7, 0x2f, 0x44, 0xa9,
+ 0xdb, 0x42, 0x54, 0xa8, 0x4d, 0x53, 0x50, 0xa9, 0x7b, 0x41, 0x63, 0xe7, 0x53, 0x6d, 0x13, 0x77,
+ 0x1d, 0x52, 0x28, 0x91, 0x96, 0xb1, 0x77, 0x62, 0xaf, 0xb2, 0x9e, 0xb1, 0x76, 0xc7, 0x89, 0xcc,
+ 0x2f, 0x80, 0xbb, 0x4a, 0xfc, 0x03, 0x24, 0x84, 0xc4, 0x7f, 0xe0, 0x1e, 0x21, 0x01, 0xbd, 0x2c,
+ 0x77, 0x28, 0xb9, 0xe3, 0x92, 0x5f, 0x80, 0x66, 0x76, 0xf6, 0x23, 0x1f, 0xd4, 0x75, 0x42, 0xc5,
+ 0xdd, 0x9c, 0xe3, 0xf3, 0x3c, 0xe7, 0x63, 0xce, 0xcc, 0x1c, 0x2f, 0x2c, 0xf4, 0x08, 0xed, 0x77,
+ 0x9b, 0x0e, 0x2e, 0xb7, 0x98, 0x43, 0xca, 0x6d, 0xb6, 0x4f, 0x1c, 0x8a, 0x69, 0x8b, 0x94, 0xf7,
+ 0x6f, 0x61, 0xbb, 0xd7, 0xc1, 0xb7, 0x22, 0xba, 0x52, 0xcf, 0x61, 0x9c, 0xa1, 0x2b, 0x3e, 0xa6,
+ 0x24, 0x30, 0xa5, 0xc8, 0xef, 0x3e, 0xa6, 0xf0, 0xbf, 0x36, 0x63, 0x6d, 0x9b, 0x94, 0x25, 0xa0,
+ 0xd9, 0xdf, 0x2d, 0x63, 0x3a, 0xf0, 0xd0, 0x85, 0x1b, 0xc7, 0x3d, 0xb6, 0x9c, 0x41, 0x8f, 0xb3,
+ 0xd0, 0x9b, 0x27, 0x2b, 0xdb, 0xf9, 0x13, 0xb6, 0x1d, 0x6c, 0xd1, 0x88, 0xa9, 0x10, 0x3d, 0xcb,
+ 0xe2, 0x77, 0x1a, 0x64, 0xeb, 0x0e, 0xeb, 0x31, 0x17, 0xdb, 0x8d, 0x7e, 0xb3, 0x6b, 0x71, 0xb4,
+ 0x0a, 0xe9, 0x9e, 0xd2, 0xe4, 0xb5, 0x39, 0x6d, 0x7e, 0x62, 0xe1, 0x9d, 0xd2, 0xd0, 0xc8, 0x4b,
+ 0x3e, 0x89, 0x1e, 0x80, 0xd1, 0x43, 0xc8, 0x9a, 0xa4, 0xc7, 0x5c, 0x8b, 0x1b, 0xb8, 0xcb, 0xfa,
+ 0x94, 0xe7, 0xc7, 0x24, 0xdd, 0xf5, 0x13, 0x74, 0x2a, 0xf4, 0x80, 0x6a, 0x51, 0x1a, 0xeb, 0x53,
+ 0x0a, 0xec, 0x89, 0xc5, 0x15, 0xc8, 0xf9, 0x3e, 0x9e, 0x58, 0xbc, 0x63, 0x3a, 0xf8, 0x00, 0x15,
+ 0x4e, 0x84, 0x9a, 0x88, 0x78, 0xbf, 0x0c, 0x49, 0x87, 0x60, 0x97, 0xd1, 0x7c, 0x7c, 0x4e, 0x9b,
+ 0xcf, 0xe8, 0x4a, 0x2a, 0xfe, 0xa2, 0xc1, 0x8c, 0x4f, 0xb4, 0xe4, 0x79, 0xa8, 0xd9, 0xd8, 0xea,
+ 0xbe, 0x94, 0xec, 0x74, 0x2a, 0xf1, 0xf3, 0xa7, 0x82, 0x1e, 0x42, 0x8a, 0xf5, 0x79, 0x8b, 0x75,
+ 0x89, 0xaa, 0xc8, 0xc2, 0x08, 0x05, 0xde, 0xf4, 0x90, 0xba, 0x4f, 0x21, 0xb6, 0x70, 0x6a, 0x1b,
+ 0xdb, 0x96, 0x89, 0x39, 0x73, 0xb6, 0x19, 0x27, 0x68, 0x0d, 0x12, 0x4d, 0x66, 0x0e, 0xd4, 0xee,
+ 0xbd, 0xff, 0x0a, 0xe4, 0xc7, 0xf0, 0x55, 0x66, 0x0e, 0x74, 0xc9, 0x80, 0x1e, 0x42, 0x1a, 0xf7,
+ 0x79, 0xc7, 0x70, 0xad, 0xb6, 0xca, 0xf8, 0xd6, 0x90, 0x8c, 0x1b, 0x3d, 0x42, 0xcd, 0xc5, 0x3e,
+ 0xef, 0x34, 0xac, 0x36, 0xc5, 0xbc, 0xef, 0x10, 0x3d, 0x85, 0x3d, 0xb1, 0xf8, 0x2c, 0x0e, 0x97,
+ 0x4e, 0x79, 0x7a, 0x69, 0xdd, 0xef, 0x41, 0x62, 0x9f, 0x71, 0xa2, 0x7c, 0xbf, 0xfd, 0x2a, 0x99,
+ 0x30, 0x4e, 0x74, 0x09, 0x42, 0x8f, 0x60, 0xd2, 0x32, 0x09, 0xe5, 0x16, 0x1f, 0x18, 0x7b, 0x64,
+ 0xa0, 0x6a, 0x7d, 0x63, 0x48, 0x02, 0xeb, 0x0a, 0xf2, 0x80, 0x0c, 0xf4, 0x09, 0x2b, 0x14, 0x50,
+ 0x03, 0xb2, 0xa1, 0x43, 0x49, 0x98, 0x90, 0x84, 0xef, 0x0e, 0x21, 0x5c, 0x0d, 0x40, 0x82, 0x72,
+ 0xaa, 0x1d, 0x15, 0x8b, 0x7f, 0x6a, 0x30, 0xb5, 0x44, 0x6c, 0xd2, 0xbe, 0xc0, 0xe6, 0x1d, 0xc3,
+ 0xbf, 0xae, 0xcd, 0x43, 0xeb, 0x30, 0xde, 0x73, 0x18, 0xdb, 0x55, 0x65, 0xbc, 0x3d, 0x84, 0xea,
+ 0xe9, 0x83, 0x63, 0x61, 0xd5, 0x05, 0x54, 0xf7, 0x18, 0x8a, 0x3f, 0xc7, 0xe1, 0xd2, 0xa9, 0xa0,
+ 0x5f, 0xda, 0x07, 0xd7, 0x21, 0xeb, 0x72, 0xec, 0x70, 0x43, 0x1e, 0x23, 0x4b, 0x1d, 0xea, 0x84,
+ 0x3e, 0x25, 0xb5, 0x75, 0xa5, 0x0c, 0xda, 0x65, 0xec, 0x3c, 0xed, 0x52, 0x81, 0xf1, 0x7d, 0x6c,
+ 0xf7, 0x89, 0xda, 0xd6, 0x6b, 0x43, 0x12, 0xdc, 0x16, 0xb6, 0xba, 0x07, 0x41, 0x1b, 0x30, 0xdd,
+ 0xa7, 0x4d, 0x46, 0x4d, 0x62, 0xfa, 0x17, 0xc4, 0xf8, 0x28, 0x17, 0x44, 0xd6, 0x47, 0xab, 0x1b,
+ 0xe2, 0x0d, 0xc8, 0xd0, 0xbe, 0x6d, 0x5b, 0xbb, 0x16, 0x71, 0xf2, 0xc9, 0x39, 0x6d, 0x7e, 0x52,
+ 0x0f, 0x15, 0x28, 0x0b, 0x71, 0x67, 0x2f, 0x9f, 0x92, 0xea, 0xb8, 0xb3, 0x57, 0xfc, 0x75, 0xec,
+ 0x44, 0x3d, 0xeb, 0x36, 0xa6, 0xff, 0x7a, 0x3d, 0x97, 0x60, 0xc2, 0xe5, 0x78, 0x8f, 0x98, 0x06,
+ 0x15, 0x1c, 0x5e, 0x55, 0xaf, 0x0e, 0xa9, 0xc7, 0x86, 0xc0, 0x83, 0x87, 0x13, 0x6b, 0xf4, 0x1e,
+ 0xcc, 0x44, 0x58, 0xc2, 0x78, 0xc7, 0x65, 0xbc, 0x28, 0xb4, 0x0c, 0x82, 0x3e, 0x63, 0x2f, 0x92,
+ 0x17, 0xd9, 0x8b, 0x59, 0x00, 0x07, 0x53, 0x93, 0x75, 0xad, 0x2f, 0x88, 0xa3, 0xaa, 0x1e, 0xd1,
+ 0xa0, 0x79, 0xc8, 0xc9, 0xb6, 0x36, 0x9a, 0xb6, 0x45, 0x4d, 0x8b, 0xb6, 0x0d, 0x27, 0x9f, 0x96,
+ 0x56, 0x59, 0xa9, 0xaf, 0x2a, 0xb5, 0x7e, 0x86, 0xa5, 0x9b, 0xcf, 0x9c, 0x61, 0xd9, 0x28, 0xae,
+ 0x01, 0x2c, 0x61, 0xa6, 0x9e, 0xa7, 0xb0, 0x33, 0xb5, 0x91, 0x3b, 0xb3, 0xb8, 0x02, 0xe9, 0x25,
+ 0xcc, 0xe4, 0xc1, 0xbe, 0x10, 0xcf, 0x57, 0x1a, 0x64, 0x96, 0x30, 0xdb, 0xec, 0xf3, 0x5e, 0xff,
+ 0x42, 0x11, 0xa1, 0xfb, 0x90, 0xc2, 0xa6, 0xe9, 0x10, 0xd7, 0x55, 0xb7, 0xd2, 0x5b, 0xc3, 0xf6,
+ 0xc5, 0xb3, 0xd6, 0x7d, 0x58, 0xf1, 0x6b, 0x0d, 0x12, 0xf2, 0xae, 0xbc, 0xaf, 0xfa, 0x53, 0x44,
+ 0x91, 0x3d, 0x75, 0x11, 0xff, 0x5d, 0x7f, 0x46, 0x9a, 0xb4, 0xb8, 0xae, 0x98, 0x66, 0x20, 0xb7,
+ 0xbd, 0xb9, 0xb5, 0x6c, 0x7c, 0xbc, 0xd1, 0xa8, 0x2f, 0xd7, 0xd6, 0x57, 0xd6, 0x97, 0x97, 0x72,
+ 0x31, 0x94, 0x83, 0x49, 0xa9, 0x5d, 0xac, 0x36, 0xb6, 0x16, 0xd7, 0x37, 0x72, 0x1a, 0x9a, 0x84,
+ 0xb4, 0xd4, 0x7c, 0xba, 0xdc, 0xc8, 0xc5, 0xd1, 0x04, 0xa4, 0xa4, 0xb4, 0xb1, 0x99, 0x1b, 0x2b,
+ 0xbe, 0x48, 0xc0, 0x54, 0x30, 0x4a, 0x71, 0xcc, 0x09, 0x7a, 0x0c, 0xc9, 0x7d, 0xc6, 0x2d, 0xea,
+ 0x5f, 0xbf, 0x77, 0x46, 0x78, 0xe6, 0x25, 0x83, 0x88, 0xd4, 0xa2, 0xed, 0xb5, 0x98, 0xae, 0x88,
+ 0xd0, 0x53, 0xc8, 0x1c, 0xa8, 0xe9, 0x87, 0xaa, 0x63, 0x59, 0x19, 0x99, 0xd5, 0x9f, 0x9f, 0xe8,
+ 0x5a, 0x4c, 0x0f, 0xe9, 0xd0, 0x13, 0x48, 0xef, 0x5a, 0xd4, 0x72, 0x3b, 0xc4, 0x54, 0xa7, 0xf5,
+ 0xee, 0xc8, 0xd4, 0x2b, 0x8a, 0x60, 0x2d, 0xa6, 0x07, 0x64, 0x68, 0x0b, 0x52, 0x2d, 0x31, 0x62,
+ 0x11, 0x53, 0xdd, 0x8a, 0x1f, 0x8e, 0xcc, 0x5b, 0xf3, 0xf0, 0x6b, 0x31, 0xdd, 0xa7, 0x2a, 0xa4,
+ 0x21, 0xe9, 0x95, 0xa7, 0x70, 0x15, 0x32, 0x41, 0x4a, 0x91, 0xb9, 0x4f, 0x8b, 0xce, 0x7d, 0x85,
+ 0x4f, 0x20, 0xed, 0x07, 0x17, 0x1d, 0xc0, 0xb4, 0x0b, 0x0f, 0x60, 0x85, 0x27, 0x90, 0x52, 0xe1,
+ 0xfd, 0xb3, 0xc4, 0xd5, 0x14, 0x8c, 0xbb, 0x22, 0xfb, 0xe2, 0xd1, 0x18, 0x4c, 0x9f, 0xb0, 0x42,
+ 0x0d, 0x48, 0xf6, 0xb0, 0xeb, 0x12, 0x53, 0x79, 0xba, 0x3b, 0xba, 0xa7, 0x52, 0x5d, 0x12, 0x88,
+ 0xf6, 0xf2, 0xa8, 0x04, 0xe9, 0x2e, 0xb6, 0x6c, 0x62, 0xaa, 0x8e, 0x3d, 0x0f, 0xe9, 0x8a, 0x24,
+ 0x10, 0xa4, 0x1e, 0x15, 0xda, 0x86, 0x94, 0x6b, 0x63, 0xd9, 0x56, 0xa3, 0x77, 0xac, 0xcf, 0xda,
+ 0xf0, 0x18, 0x44, 0x03, 0x28, 0x32, 0xd1, 0x00, 0x5e, 0x02, 0x85, 0xcf, 0x20, 0xe9, 0x79, 0x45,
+ 0x77, 0xe0, 0xbf, 0x41, 0x43, 0x1b, 0x62, 0x65, 0x44, 0x9b, 0x61, 0x2d, 0xa6, 0xff, 0x27, 0xf8,
+ 0x59, 0xb4, 0x8c, 0x2e, 0x7f, 0xfc, 0x52, 0xd3, 0xaa, 0x79, 0xb8, 0x6c, 0x9c, 0x89, 0x2c, 0xec,
+ 0x40, 0x4a, 0x39, 0x7f, 0x0d, 0xec, 0xd5, 0x4c, 0xd0, 0x31, 0xc5, 0x1a, 0x8c, 0x6f, 0x61, 0xdb,
+ 0x1e, 0xa0, 0x1c, 0x8c, 0x0d, 0x88, 0xab, 0x1e, 0x6d, 0xb1, 0x14, 0x2f, 0x3e, 0x65, 0xea, 0x8d,
+ 0x8e, 0x53, 0x86, 0xf2, 0x90, 0xc2, 0x4d, 0x97, 0x63, 0xcb, 0xbb, 0x04, 0x12, 0xba, 0x2f, 0x16,
+ 0xbf, 0x4d, 0x42, 0xda, 0xaf, 0x9d, 0x80, 0x59, 0xde, 0x59, 0x4e, 0xe8, 0x71, 0xcb, 0x44, 0x33,
+ 0x30, 0xce, 0x2d, 0x6e, 0x13, 0x75, 0x34, 0x3c, 0x01, 0xcd, 0xc1, 0x84, 0x49, 0xdc, 0x96, 0x63,
+ 0xf5, 0x82, 0x49, 0x20, 0xa3, 0x47, 0x55, 0xa8, 0x01, 0x19, 0x57, 0x4c, 0x84, 0xb6, 0xb8, 0xcb,
+ 0xbc, 0x23, 0xfc, 0xc1, 0x08, 0x7b, 0x58, 0x6a, 0xf8, 0x60, 0x3d, 0xe4, 0x11, 0xa4, 0xa4, 0x4b,
+ 0x9c, 0x36, 0xa1, 0xad, 0x81, 0x7a, 0xa1, 0x47, 0x22, 0x5d, 0xf6, 0xc1, 0x7a, 0xc8, 0x83, 0x76,
+ 0x21, 0xd7, 0xc3, 0x0e, 0xee, 0x12, 0x4e, 0x1c, 0xa3, 0xd5, 0xc1, 0xb4, 0x4d, 0xe4, 0x93, 0x3d,
+ 0xb1, 0x70, 0x6f, 0x14, 0xee, 0xba, 0xcf, 0x51, 0x93, 0x14, 0xfa, 0x74, 0xef, 0xb8, 0x02, 0x3d,
+ 0x86, 0x8c, 0x89, 0x99, 0xe1, 0x8a, 0x77, 0x55, 0xbe, 0xf6, 0xaf, 0x36, 0xaa, 0x07, 0x0e, 0xfc,
+ 0x37, 0x59, 0x4f, 0x9b, 0x6a, 0x55, 0xb8, 0x0d, 0x99, 0xa0, 0x4e, 0xe8, 0xff, 0x90, 0x6c, 0xb1,
+ 0x6e, 0xd7, 0xe2, 0x41, 0x6b, 0x29, 0x59, 0x74, 0x53, 0x06, 0x52, 0x86, 0x27, 0x15, 0x6e, 0x40,
+ 0x26, 0xa8, 0x03, 0x7a, 0x13, 0xa0, 0x83, 0x6d, 0x6e, 0xc8, 0x3f, 0xf8, 0x12, 0x98, 0xd6, 0x33,
+ 0x42, 0x53, 0x13, 0x8a, 0xc2, 0x0f, 0x1a, 0x4c, 0x9f, 0x48, 0x0c, 0x6d, 0x41, 0x96, 0xd9, 0xa6,
+ 0x11, 0xa4, 0xe7, 0xaa, 0xdb, 0xe4, 0xe6, 0xc9, 0x37, 0x59, 0x7e, 0x33, 0x08, 0xf2, 0x90, 0x84,
+ 0x01, 0x97, 0xab, 0x4f, 0x31, 0xdb, 0x0c, 0x45, 0xc1, 0x4a, 0xc9, 0x41, 0x94, 0x35, 0x7e, 0x2e,
+ 0x56, 0x4a, 0x0e, 0x42, 0xb1, 0xf0, 0x20, 0x32, 0xca, 0x7c, 0x04, 0x39, 0xee, 0x60, 0xea, 0xe2,
+ 0x96, 0x68, 0x50, 0xa3, 0x67, 0x63, 0xaa, 0x7c, 0xcc, 0x94, 0xbc, 0x6f, 0x28, 0x25, 0xff, 0x1b,
+ 0x4a, 0x69, 0x91, 0x0e, 0xf4, 0xe9, 0x88, 0xb5, 0x98, 0x8e, 0xab, 0xbf, 0xc5, 0x7f, 0x3c, 0x9c,
+ 0xd5, 0x9e, 0x1f, 0xce, 0x6a, 0xbf, 0x1f, 0xce, 0x6a, 0xcf, 0x8e, 0x66, 0x63, 0xcf, 0x8f, 0x66,
+ 0x63, 0x2f, 0x8e, 0x66, 0x63, 0x70, 0xbd, 0xc5, 0xba, 0xc3, 0xf7, 0xb2, 0x3a, 0x1d, 0xfe, 0xb1,
+ 0xab, 0x0b, 0x57, 0x75, 0xed, 0xe9, 0xe7, 0x6d, 0x8b, 0x77, 0xfa, 0xcd, 0x52, 0x8b, 0x75, 0xcb,
+ 0x2d, 0xe6, 0x76, 0x99, 0x5b, 0x76, 0x88, 0x8d, 0x07, 0xc4, 0x29, 0xef, 0x2f, 0x04, 0x4b, 0x99,
+ 0xb5, 0x5b, 0x1e, 0xfa, 0x05, 0xe9, 0x5e, 0xa8, 0xf3, 0x55, 0xdf, 0xc4, 0xc7, 0xea, 0xb5, 0xd5,
+ 0xef, 0xe3, 0x57, 0xea, 0x7e, 0x78, 0x35, 0x11, 0x5e, 0x18, 0x49, 0x69, 0x5b, 0x59, 0xfe, 0x14,
+ 0xda, 0xec, 0x08, 0x9b, 0x9d, 0xd0, 0x66, 0xc7, 0xb7, 0x39, 0x8c, 0xdf, 0x1c, 0x6a, 0xb3, 0xb3,
+ 0x5a, 0xaf, 0x3e, 0x22, 0x1c, 0x9b, 0x98, 0xe3, 0x3f, 0xe2, 0xd7, 0x7c, 0xfb, 0x4a, 0x45, 0x00,
+ 0x2a, 0x95, 0x10, 0x51, 0xa9, 0xf8, 0x90, 0x66, 0x52, 0x96, 0xfe, 0xf6, 0x5f, 0x01, 0x00, 0x00,
+ 0xff, 0xff, 0x07, 0xf0, 0xab, 0xae, 0x25, 0x13, 0x00, 0x00,
+}
+
+func (m *ProposalSubmit) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *ProposalSubmit) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ProposalSubmit) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.DepositAmount != nil {
+ {
+ size, err := m.DepositAmount.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintGovernance(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1a
+ }
+ if m.Proposal != nil {
+ {
+ size, err := m.Proposal.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintGovernance(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *ProposalWithdraw) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *ProposalWithdraw) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ProposalWithdraw) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.Reason) > 0 {
+ i -= len(m.Reason)
+ copy(dAtA[i:], m.Reason)
+ i = encodeVarintGovernance(dAtA, i, uint64(len(m.Reason)))
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.Proposal != 0 {
+ i = encodeVarintGovernance(dAtA, i, uint64(m.Proposal))
+ i--
+ dAtA[i] = 0x8
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *ProposalDepositClaim) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *ProposalDepositClaim) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ProposalDepositClaim) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Outcome != nil {
+ {
+ size, err := m.Outcome.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintGovernance(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1a
+ }
+ if m.DepositAmount != nil {
+ {
+ size, err := m.DepositAmount.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintGovernance(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.Proposal != 0 {
+ i = encodeVarintGovernance(dAtA, i, uint64(m.Proposal))
+ i--
+ dAtA[i] = 0x8
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *ValidatorVote) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *ValidatorVote) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ValidatorVote) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.AuthSig != nil {
+ {
+ size, err := m.AuthSig.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintGovernance(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.Body != nil {
+ {
+ size, err := m.Body.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintGovernance(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *ValidatorVoteBody) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *ValidatorVoteBody) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ValidatorVoteBody) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.GovernanceKey != nil {
+ {
+ size, err := m.GovernanceKey.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintGovernance(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x22
+ }
+ if m.IdentityKey != nil {
+ {
+ size, err := m.IdentityKey.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintGovernance(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1a
+ }
+ if m.Vote != nil {
+ {
+ size, err := m.Vote.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintGovernance(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.Proposal != 0 {
+ i = encodeVarintGovernance(dAtA, i, uint64(m.Proposal))
+ i--
+ dAtA[i] = 0x8
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *DelegatorVote) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *DelegatorVote) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *DelegatorVote) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Proof != nil {
+ {
+ size, err := m.Proof.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintGovernance(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1a
+ }
+ if m.AuthSig != nil {
+ {
+ size, err := m.AuthSig.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintGovernance(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.Body != nil {
+ {
+ size, err := m.Body.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintGovernance(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *DelegatorVoteBody) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *DelegatorVoteBody) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *DelegatorVoteBody) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.Rk) > 0 {
+ i -= len(m.Rk)
+ copy(dAtA[i:], m.Rk)
+ i = encodeVarintGovernance(dAtA, i, uint64(len(m.Rk)))
+ i--
+ dAtA[i] = 0x3a
+ }
+ if len(m.Nullifier) > 0 {
+ i -= len(m.Nullifier)
+ copy(dAtA[i:], m.Nullifier)
+ i = encodeVarintGovernance(dAtA, i, uint64(len(m.Nullifier)))
+ i--
+ dAtA[i] = 0x32
+ }
+ if m.UnbondedAmount != nil {
+ {
+ size, err := m.UnbondedAmount.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintGovernance(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x2a
+ }
+ if m.Value != nil {
+ {
+ size, err := m.Value.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintGovernance(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x22
+ }
+ if m.Vote != nil {
+ {
+ size, err := m.Vote.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintGovernance(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1a
+ }
+ if m.StartPosition != 0 {
+ i = encodeVarintGovernance(dAtA, i, uint64(m.StartPosition))
+ i--
+ dAtA[i] = 0x10
+ }
+ if m.Proposal != 0 {
+ i = encodeVarintGovernance(dAtA, i, uint64(m.Proposal))
+ i--
+ dAtA[i] = 0x8
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *DelegatorVotePlan) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *DelegatorVotePlan) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *DelegatorVotePlan) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.ProofBlindingS) > 0 {
+ i -= len(m.ProofBlindingS)
+ copy(dAtA[i:], m.ProofBlindingS)
+ i = encodeVarintGovernance(dAtA, i, uint64(len(m.ProofBlindingS)))
+ i--
+ dAtA[i] = 0x4a
+ }
+ if len(m.ProofBlindingR) > 0 {
+ i -= len(m.ProofBlindingR)
+ copy(dAtA[i:], m.ProofBlindingR)
+ i = encodeVarintGovernance(dAtA, i, uint64(len(m.ProofBlindingR)))
+ i--
+ dAtA[i] = 0x42
+ }
+ if len(m.Randomizer) > 0 {
+ i -= len(m.Randomizer)
+ copy(dAtA[i:], m.Randomizer)
+ i = encodeVarintGovernance(dAtA, i, uint64(len(m.Randomizer)))
+ i--
+ dAtA[i] = 0x3a
+ }
+ if m.UnbondedAmount != nil {
+ {
+ size, err := m.UnbondedAmount.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintGovernance(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x32
+ }
+ if m.StakedNotePosition != 0 {
+ i = encodeVarintGovernance(dAtA, i, uint64(m.StakedNotePosition))
+ i--
+ dAtA[i] = 0x28
+ }
+ if m.StakedNote != nil {
+ {
+ size, err := m.StakedNote.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintGovernance(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x22
+ }
+ if m.Vote != nil {
+ {
+ size, err := m.Vote.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintGovernance(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1a
+ }
+ if m.StartPosition != 0 {
+ i = encodeVarintGovernance(dAtA, i, uint64(m.StartPosition))
+ i--
+ dAtA[i] = 0x10
+ }
+ if m.Proposal != 0 {
+ i = encodeVarintGovernance(dAtA, i, uint64(m.Proposal))
+ i--
+ dAtA[i] = 0x8
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *DaoDeposit) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *DaoDeposit) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *DaoDeposit) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Value != nil {
+ {
+ size, err := m.Value.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintGovernance(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *DaoSpend) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *DaoSpend) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *DaoSpend) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Value != nil {
+ {
+ size, err := m.Value.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintGovernance(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *DaoOutput) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *DaoOutput) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *DaoOutput) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Address != nil {
+ {
+ size, err := m.Address.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintGovernance(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.Value != nil {
+ {
+ size, err := m.Value.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintGovernance(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *Vote) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *Vote) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *Vote) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Vote != 0 {
+ i = encodeVarintGovernance(dAtA, i, uint64(m.Vote))
+ i--
+ dAtA[i] = 0x8
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *ProposalState) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *ProposalState) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ProposalState) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.State != nil {
+ {
+ size := m.State.Size()
+ i -= size
+ if _, err := m.State.MarshalTo(dAtA[i:]); err != nil {
+ return 0, err
+ }
+ }
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *ProposalState_Voting_) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ProposalState_Voting_) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.Voting != nil {
+ {
+ size, err := m.Voting.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintGovernance(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ return len(dAtA) - i, nil
+}
+func (m *ProposalState_Withdrawn_) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ProposalState_Withdrawn_) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.Withdrawn != nil {
+ {
+ size, err := m.Withdrawn.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintGovernance(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1a
+ }
+ return len(dAtA) - i, nil
+}
+func (m *ProposalState_Finished_) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ProposalState_Finished_) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.Finished != nil {
+ {
+ size, err := m.Finished.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintGovernance(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x22
+ }
+ return len(dAtA) - i, nil
+}
+func (m *ProposalState_Claimed_) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ProposalState_Claimed_) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.Claimed != nil {
+ {
+ size, err := m.Claimed.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintGovernance(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x2a
+ }
+ return len(dAtA) - i, nil
+}
+func (m *ProposalState_Voting) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *ProposalState_Voting) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ProposalState_Voting) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ return len(dAtA) - i, nil
+}
+
+func (m *ProposalState_Withdrawn) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *ProposalState_Withdrawn) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ProposalState_Withdrawn) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.Reason) > 0 {
+ i -= len(m.Reason)
+ copy(dAtA[i:], m.Reason)
+ i = encodeVarintGovernance(dAtA, i, uint64(len(m.Reason)))
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *ProposalState_Finished) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *ProposalState_Finished) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ProposalState_Finished) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Outcome != nil {
+ {
+ size, err := m.Outcome.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintGovernance(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *ProposalState_Claimed) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *ProposalState_Claimed) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ProposalState_Claimed) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Outcome != nil {
+ {
+ size, err := m.Outcome.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintGovernance(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *ProposalOutcome) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *ProposalOutcome) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ProposalOutcome) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Outcome != nil {
+ {
+ size := m.Outcome.Size()
+ i -= size
+ if _, err := m.Outcome.MarshalTo(dAtA[i:]); err != nil {
+ return 0, err
+ }
+ }
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *ProposalOutcome_Passed_) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ProposalOutcome_Passed_) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.Passed != nil {
+ {
+ size, err := m.Passed.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintGovernance(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+func (m *ProposalOutcome_Failed_) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ProposalOutcome_Failed_) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.Failed != nil {
+ {
+ size, err := m.Failed.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintGovernance(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ return len(dAtA) - i, nil
+}
+func (m *ProposalOutcome_Slashed_) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ProposalOutcome_Slashed_) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.Slashed != nil {
+ {
+ size, err := m.Slashed.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintGovernance(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1a
+ }
+ return len(dAtA) - i, nil
+}
+func (m *ProposalOutcome_Passed) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *ProposalOutcome_Passed) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ProposalOutcome_Passed) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ return len(dAtA) - i, nil
+}
+
+func (m *ProposalOutcome_Failed) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *ProposalOutcome_Failed) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ProposalOutcome_Failed) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.XWithdrawnWithReason != nil {
+ {
+ size := m.XWithdrawnWithReason.Size()
+ i -= size
+ if _, err := m.XWithdrawnWithReason.MarshalTo(dAtA[i:]); err != nil {
+ return 0, err
+ }
+ }
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *ProposalOutcome_Failed_WithdrawnWithReason) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ProposalOutcome_Failed_WithdrawnWithReason) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ i -= len(m.WithdrawnWithReason)
+ copy(dAtA[i:], m.WithdrawnWithReason)
+ i = encodeVarintGovernance(dAtA, i, uint64(len(m.WithdrawnWithReason)))
+ i--
+ dAtA[i] = 0xa
+ return len(dAtA) - i, nil
+}
+func (m *ProposalOutcome_Slashed) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *ProposalOutcome_Slashed) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ProposalOutcome_Slashed) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.XWithdrawnWithReason != nil {
+ {
+ size := m.XWithdrawnWithReason.Size()
+ i -= size
+ if _, err := m.XWithdrawnWithReason.MarshalTo(dAtA[i:]); err != nil {
+ return 0, err
+ }
+ }
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *ProposalOutcome_Slashed_WithdrawnWithReason) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ProposalOutcome_Slashed_WithdrawnWithReason) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ i -= len(m.WithdrawnWithReason)
+ copy(dAtA[i:], m.WithdrawnWithReason)
+ i = encodeVarintGovernance(dAtA, i, uint64(len(m.WithdrawnWithReason)))
+ i--
+ dAtA[i] = 0xa
+ return len(dAtA) - i, nil
+}
+func (m *Tally) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *Tally) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *Tally) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Abstain != 0 {
+ i = encodeVarintGovernance(dAtA, i, uint64(m.Abstain))
+ i--
+ dAtA[i] = 0x18
+ }
+ if m.No != 0 {
+ i = encodeVarintGovernance(dAtA, i, uint64(m.No))
+ i--
+ dAtA[i] = 0x10
+ }
+ if m.Yes != 0 {
+ i = encodeVarintGovernance(dAtA, i, uint64(m.Yes))
+ i--
+ dAtA[i] = 0x8
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *Proposal) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *Proposal) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *Proposal) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.DaoSpend != nil {
+ {
+ size, err := m.DaoSpend.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintGovernance(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x42
+ }
+ if m.ParameterChange != nil {
+ {
+ size, err := m.ParameterChange.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintGovernance(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x3a
+ }
+ if m.Emergency != nil {
+ {
+ size, err := m.Emergency.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintGovernance(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x32
+ }
+ if m.Signaling != nil {
+ {
+ size, err := m.Signaling.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintGovernance(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x2a
+ }
+ if m.Id != 0 {
+ i = encodeVarintGovernance(dAtA, i, uint64(m.Id))
+ i--
+ dAtA[i] = 0x20
+ }
+ if len(m.Description) > 0 {
+ i -= len(m.Description)
+ copy(dAtA[i:], m.Description)
+ i = encodeVarintGovernance(dAtA, i, uint64(len(m.Description)))
+ i--
+ dAtA[i] = 0x12
+ }
+ if len(m.Title) > 0 {
+ i -= len(m.Title)
+ copy(dAtA[i:], m.Title)
+ i = encodeVarintGovernance(dAtA, i, uint64(len(m.Title)))
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *Proposal_Signaling) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *Proposal_Signaling) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *Proposal_Signaling) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.XCommit != nil {
+ {
+ size := m.XCommit.Size()
+ i -= size
+ if _, err := m.XCommit.MarshalTo(dAtA[i:]); err != nil {
+ return 0, err
+ }
+ }
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *Proposal_Signaling_Commit) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *Proposal_Signaling_Commit) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ i -= len(m.Commit)
+ copy(dAtA[i:], m.Commit)
+ i = encodeVarintGovernance(dAtA, i, uint64(len(m.Commit)))
+ i--
+ dAtA[i] = 0xa
+ return len(dAtA) - i, nil
+}
+func (m *Proposal_Emergency) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *Proposal_Emergency) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *Proposal_Emergency) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.HaltChain {
+ i--
+ if m.HaltChain {
+ dAtA[i] = 1
+ } else {
+ dAtA[i] = 0
+ }
+ i--
+ dAtA[i] = 0x8
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *Proposal_ParameterChange) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *Proposal_ParameterChange) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *Proposal_ParameterChange) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.NewParameters != nil {
+ {
+ size, err := m.NewParameters.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintGovernance(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.OldParameters != nil {
+ {
+ size, err := m.OldParameters.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintGovernance(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *Proposal_DaoSpend) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *Proposal_DaoSpend) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *Proposal_DaoSpend) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.TransactionPlan != nil {
+ {
+ size, err := m.TransactionPlan.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintGovernance(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ return len(dAtA) - i, nil
+}
+
+func encodeVarintGovernance(dAtA []byte, offset int, v uint64) int {
+ offset -= sovGovernance(v)
+ base := offset
+ for v >= 1<<7 {
+ dAtA[offset] = uint8(v&0x7f | 0x80)
+ v >>= 7
+ offset++
+ }
+ dAtA[offset] = uint8(v)
+ return base
+}
+func (m *ProposalSubmit) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Proposal != nil {
+ l = m.Proposal.Size()
+ n += 1 + l + sovGovernance(uint64(l))
+ }
+ if m.DepositAmount != nil {
+ l = m.DepositAmount.Size()
+ n += 1 + l + sovGovernance(uint64(l))
+ }
+ return n
+}
+
+func (m *ProposalWithdraw) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Proposal != 0 {
+ n += 1 + sovGovernance(uint64(m.Proposal))
+ }
+ l = len(m.Reason)
+ if l > 0 {
+ n += 1 + l + sovGovernance(uint64(l))
+ }
+ return n
+}
+
+func (m *ProposalDepositClaim) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Proposal != 0 {
+ n += 1 + sovGovernance(uint64(m.Proposal))
+ }
+ if m.DepositAmount != nil {
+ l = m.DepositAmount.Size()
+ n += 1 + l + sovGovernance(uint64(l))
+ }
+ if m.Outcome != nil {
+ l = m.Outcome.Size()
+ n += 1 + l + sovGovernance(uint64(l))
+ }
+ return n
+}
+
+func (m *ValidatorVote) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Body != nil {
+ l = m.Body.Size()
+ n += 1 + l + sovGovernance(uint64(l))
+ }
+ if m.AuthSig != nil {
+ l = m.AuthSig.Size()
+ n += 1 + l + sovGovernance(uint64(l))
+ }
+ return n
+}
+
+func (m *ValidatorVoteBody) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Proposal != 0 {
+ n += 1 + sovGovernance(uint64(m.Proposal))
+ }
+ if m.Vote != nil {
+ l = m.Vote.Size()
+ n += 1 + l + sovGovernance(uint64(l))
+ }
+ if m.IdentityKey != nil {
+ l = m.IdentityKey.Size()
+ n += 1 + l + sovGovernance(uint64(l))
+ }
+ if m.GovernanceKey != nil {
+ l = m.GovernanceKey.Size()
+ n += 1 + l + sovGovernance(uint64(l))
+ }
+ return n
+}
+
+func (m *DelegatorVote) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Body != nil {
+ l = m.Body.Size()
+ n += 1 + l + sovGovernance(uint64(l))
+ }
+ if m.AuthSig != nil {
+ l = m.AuthSig.Size()
+ n += 1 + l + sovGovernance(uint64(l))
+ }
+ if m.Proof != nil {
+ l = m.Proof.Size()
+ n += 1 + l + sovGovernance(uint64(l))
+ }
+ return n
+}
+
+func (m *DelegatorVoteBody) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Proposal != 0 {
+ n += 1 + sovGovernance(uint64(m.Proposal))
+ }
+ if m.StartPosition != 0 {
+ n += 1 + sovGovernance(uint64(m.StartPosition))
+ }
+ if m.Vote != nil {
+ l = m.Vote.Size()
+ n += 1 + l + sovGovernance(uint64(l))
+ }
+ if m.Value != nil {
+ l = m.Value.Size()
+ n += 1 + l + sovGovernance(uint64(l))
+ }
+ if m.UnbondedAmount != nil {
+ l = m.UnbondedAmount.Size()
+ n += 1 + l + sovGovernance(uint64(l))
+ }
+ l = len(m.Nullifier)
+ if l > 0 {
+ n += 1 + l + sovGovernance(uint64(l))
+ }
+ l = len(m.Rk)
+ if l > 0 {
+ n += 1 + l + sovGovernance(uint64(l))
+ }
+ return n
+}
+
+func (m *DelegatorVotePlan) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Proposal != 0 {
+ n += 1 + sovGovernance(uint64(m.Proposal))
+ }
+ if m.StartPosition != 0 {
+ n += 1 + sovGovernance(uint64(m.StartPosition))
+ }
+ if m.Vote != nil {
+ l = m.Vote.Size()
+ n += 1 + l + sovGovernance(uint64(l))
+ }
+ if m.StakedNote != nil {
+ l = m.StakedNote.Size()
+ n += 1 + l + sovGovernance(uint64(l))
+ }
+ if m.StakedNotePosition != 0 {
+ n += 1 + sovGovernance(uint64(m.StakedNotePosition))
+ }
+ if m.UnbondedAmount != nil {
+ l = m.UnbondedAmount.Size()
+ n += 1 + l + sovGovernance(uint64(l))
+ }
+ l = len(m.Randomizer)
+ if l > 0 {
+ n += 1 + l + sovGovernance(uint64(l))
+ }
+ l = len(m.ProofBlindingR)
+ if l > 0 {
+ n += 1 + l + sovGovernance(uint64(l))
+ }
+ l = len(m.ProofBlindingS)
+ if l > 0 {
+ n += 1 + l + sovGovernance(uint64(l))
+ }
+ return n
+}
+
+func (m *DaoDeposit) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Value != nil {
+ l = m.Value.Size()
+ n += 1 + l + sovGovernance(uint64(l))
+ }
+ return n
+}
+
+func (m *DaoSpend) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Value != nil {
+ l = m.Value.Size()
+ n += 1 + l + sovGovernance(uint64(l))
+ }
+ return n
+}
+
+func (m *DaoOutput) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Value != nil {
+ l = m.Value.Size()
+ n += 1 + l + sovGovernance(uint64(l))
+ }
+ if m.Address != nil {
+ l = m.Address.Size()
+ n += 1 + l + sovGovernance(uint64(l))
+ }
+ return n
+}
+
+func (m *Vote) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Vote != 0 {
+ n += 1 + sovGovernance(uint64(m.Vote))
+ }
+ return n
+}
+
+func (m *ProposalState) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.State != nil {
+ n += m.State.Size()
+ }
+ return n
+}
+
+func (m *ProposalState_Voting_) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Voting != nil {
+ l = m.Voting.Size()
+ n += 1 + l + sovGovernance(uint64(l))
+ }
+ return n
+}
+func (m *ProposalState_Withdrawn_) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Withdrawn != nil {
+ l = m.Withdrawn.Size()
+ n += 1 + l + sovGovernance(uint64(l))
+ }
+ return n
+}
+func (m *ProposalState_Finished_) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Finished != nil {
+ l = m.Finished.Size()
+ n += 1 + l + sovGovernance(uint64(l))
+ }
+ return n
+}
+func (m *ProposalState_Claimed_) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Claimed != nil {
+ l = m.Claimed.Size()
+ n += 1 + l + sovGovernance(uint64(l))
+ }
+ return n
+}
+func (m *ProposalState_Voting) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ return n
+}
+
+func (m *ProposalState_Withdrawn) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ l = len(m.Reason)
+ if l > 0 {
+ n += 1 + l + sovGovernance(uint64(l))
+ }
+ return n
+}
+
+func (m *ProposalState_Finished) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Outcome != nil {
+ l = m.Outcome.Size()
+ n += 1 + l + sovGovernance(uint64(l))
+ }
+ return n
+}
+
+func (m *ProposalState_Claimed) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Outcome != nil {
+ l = m.Outcome.Size()
+ n += 1 + l + sovGovernance(uint64(l))
+ }
+ return n
+}
+
+func (m *ProposalOutcome) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Outcome != nil {
+ n += m.Outcome.Size()
+ }
+ return n
+}
+
+func (m *ProposalOutcome_Passed_) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Passed != nil {
+ l = m.Passed.Size()
+ n += 1 + l + sovGovernance(uint64(l))
+ }
+ return n
+}
+func (m *ProposalOutcome_Failed_) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Failed != nil {
+ l = m.Failed.Size()
+ n += 1 + l + sovGovernance(uint64(l))
+ }
+ return n
+}
+func (m *ProposalOutcome_Slashed_) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Slashed != nil {
+ l = m.Slashed.Size()
+ n += 1 + l + sovGovernance(uint64(l))
+ }
+ return n
+}
+func (m *ProposalOutcome_Passed) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ return n
+}
+
+func (m *ProposalOutcome_Failed) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.XWithdrawnWithReason != nil {
+ n += m.XWithdrawnWithReason.Size()
+ }
+ return n
+}
+
+func (m *ProposalOutcome_Failed_WithdrawnWithReason) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ l = len(m.WithdrawnWithReason)
+ n += 1 + l + sovGovernance(uint64(l))
+ return n
+}
+func (m *ProposalOutcome_Slashed) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.XWithdrawnWithReason != nil {
+ n += m.XWithdrawnWithReason.Size()
+ }
+ return n
+}
+
+func (m *ProposalOutcome_Slashed_WithdrawnWithReason) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ l = len(m.WithdrawnWithReason)
+ n += 1 + l + sovGovernance(uint64(l))
+ return n
+}
+func (m *Tally) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Yes != 0 {
+ n += 1 + sovGovernance(uint64(m.Yes))
+ }
+ if m.No != 0 {
+ n += 1 + sovGovernance(uint64(m.No))
+ }
+ if m.Abstain != 0 {
+ n += 1 + sovGovernance(uint64(m.Abstain))
+ }
+ return n
+}
+
+func (m *Proposal) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ l = len(m.Title)
+ if l > 0 {
+ n += 1 + l + sovGovernance(uint64(l))
+ }
+ l = len(m.Description)
+ if l > 0 {
+ n += 1 + l + sovGovernance(uint64(l))
+ }
+ if m.Id != 0 {
+ n += 1 + sovGovernance(uint64(m.Id))
+ }
+ if m.Signaling != nil {
+ l = m.Signaling.Size()
+ n += 1 + l + sovGovernance(uint64(l))
+ }
+ if m.Emergency != nil {
+ l = m.Emergency.Size()
+ n += 1 + l + sovGovernance(uint64(l))
+ }
+ if m.ParameterChange != nil {
+ l = m.ParameterChange.Size()
+ n += 1 + l + sovGovernance(uint64(l))
+ }
+ if m.DaoSpend != nil {
+ l = m.DaoSpend.Size()
+ n += 1 + l + sovGovernance(uint64(l))
+ }
+ return n
+}
+
+func (m *Proposal_Signaling) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.XCommit != nil {
+ n += m.XCommit.Size()
+ }
+ return n
+}
+
+func (m *Proposal_Signaling_Commit) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ l = len(m.Commit)
+ n += 1 + l + sovGovernance(uint64(l))
+ return n
+}
+func (m *Proposal_Emergency) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.HaltChain {
+ n += 2
+ }
+ return n
+}
+
+func (m *Proposal_ParameterChange) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.OldParameters != nil {
+ l = m.OldParameters.Size()
+ n += 1 + l + sovGovernance(uint64(l))
+ }
+ if m.NewParameters != nil {
+ l = m.NewParameters.Size()
+ n += 1 + l + sovGovernance(uint64(l))
+ }
+ return n
+}
+
+func (m *Proposal_DaoSpend) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.TransactionPlan != nil {
+ l = m.TransactionPlan.Size()
+ n += 1 + l + sovGovernance(uint64(l))
+ }
+ return n
+}
+
+func sovGovernance(x uint64) (n int) {
+ return (math_bits.Len64(x|1) + 6) / 7
+}
+func sozGovernance(x uint64) (n int) {
+ return sovGovernance(uint64((x << 1) ^ uint64((int64(x) >> 63))))
+}
+func (m *ProposalSubmit) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: ProposalSubmit: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: ProposalSubmit: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Proposal", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Proposal == nil {
+ m.Proposal = &Proposal{}
+ }
+ if err := m.Proposal.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field DepositAmount", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.DepositAmount == nil {
+ m.DepositAmount = &v1alpha1.Amount{}
+ }
+ if err := m.DepositAmount.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipGovernance(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *ProposalWithdraw) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: ProposalWithdraw: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: ProposalWithdraw: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Proposal", wireType)
+ }
+ m.Proposal = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.Proposal |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Reason", wireType)
+ }
+ var stringLen uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ stringLen |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ intStringLen := int(stringLen)
+ if intStringLen < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ postIndex := iNdEx + intStringLen
+ if postIndex < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Reason = string(dAtA[iNdEx:postIndex])
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipGovernance(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *ProposalDepositClaim) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: ProposalDepositClaim: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: ProposalDepositClaim: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Proposal", wireType)
+ }
+ m.Proposal = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.Proposal |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field DepositAmount", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.DepositAmount == nil {
+ m.DepositAmount = &v1alpha1.Amount{}
+ }
+ if err := m.DepositAmount.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Outcome", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Outcome == nil {
+ m.Outcome = &ProposalOutcome{}
+ }
+ if err := m.Outcome.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipGovernance(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *ValidatorVote) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: ValidatorVote: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: ValidatorVote: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Body", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Body == nil {
+ m.Body = &ValidatorVoteBody{}
+ }
+ if err := m.Body.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field AuthSig", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.AuthSig == nil {
+ m.AuthSig = &v1alpha1.SpendAuthSignature{}
+ }
+ if err := m.AuthSig.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipGovernance(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *ValidatorVoteBody) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: ValidatorVoteBody: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: ValidatorVoteBody: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Proposal", wireType)
+ }
+ m.Proposal = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.Proposal |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Vote", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Vote == nil {
+ m.Vote = &Vote{}
+ }
+ if err := m.Vote.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field IdentityKey", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.IdentityKey == nil {
+ m.IdentityKey = &v1alpha1.IdentityKey{}
+ }
+ if err := m.IdentityKey.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 4:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field GovernanceKey", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.GovernanceKey == nil {
+ m.GovernanceKey = &v1alpha1.GovernanceKey{}
+ }
+ if err := m.GovernanceKey.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipGovernance(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *DelegatorVote) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: DelegatorVote: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: DelegatorVote: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Body", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Body == nil {
+ m.Body = &DelegatorVoteBody{}
+ }
+ if err := m.Body.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field AuthSig", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.AuthSig == nil {
+ m.AuthSig = &v1alpha1.SpendAuthSignature{}
+ }
+ if err := m.AuthSig.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Proof", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Proof == nil {
+ m.Proof = &v1alpha1.ZKDelegatorVoteProof{}
+ }
+ if err := m.Proof.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipGovernance(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *DelegatorVoteBody) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: DelegatorVoteBody: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: DelegatorVoteBody: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Proposal", wireType)
+ }
+ m.Proposal = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.Proposal |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 2:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field StartPosition", wireType)
+ }
+ m.StartPosition = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.StartPosition |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Vote", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Vote == nil {
+ m.Vote = &Vote{}
+ }
+ if err := m.Vote.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 4:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Value", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Value == nil {
+ m.Value = &v1alpha1.Value{}
+ }
+ if err := m.Value.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 5:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field UnbondedAmount", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.UnbondedAmount == nil {
+ m.UnbondedAmount = &v1alpha1.Amount{}
+ }
+ if err := m.UnbondedAmount.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 6:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Nullifier", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Nullifier = append(m.Nullifier[:0], dAtA[iNdEx:postIndex]...)
+ if m.Nullifier == nil {
+ m.Nullifier = []byte{}
+ }
+ iNdEx = postIndex
+ case 7:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Rk", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Rk = append(m.Rk[:0], dAtA[iNdEx:postIndex]...)
+ if m.Rk == nil {
+ m.Rk = []byte{}
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipGovernance(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *DelegatorVotePlan) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: DelegatorVotePlan: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: DelegatorVotePlan: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Proposal", wireType)
+ }
+ m.Proposal = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.Proposal |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 2:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field StartPosition", wireType)
+ }
+ m.StartPosition = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.StartPosition |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Vote", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Vote == nil {
+ m.Vote = &Vote{}
+ }
+ if err := m.Vote.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 4:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field StakedNote", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.StakedNote == nil {
+ m.StakedNote = &v1alpha1.Note{}
+ }
+ if err := m.StakedNote.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 5:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field StakedNotePosition", wireType)
+ }
+ m.StakedNotePosition = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.StakedNotePosition |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 6:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field UnbondedAmount", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.UnbondedAmount == nil {
+ m.UnbondedAmount = &v1alpha1.Amount{}
+ }
+ if err := m.UnbondedAmount.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 7:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Randomizer", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Randomizer = append(m.Randomizer[:0], dAtA[iNdEx:postIndex]...)
+ if m.Randomizer == nil {
+ m.Randomizer = []byte{}
+ }
+ iNdEx = postIndex
+ case 8:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ProofBlindingR", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.ProofBlindingR = append(m.ProofBlindingR[:0], dAtA[iNdEx:postIndex]...)
+ if m.ProofBlindingR == nil {
+ m.ProofBlindingR = []byte{}
+ }
+ iNdEx = postIndex
+ case 9:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ProofBlindingS", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.ProofBlindingS = append(m.ProofBlindingS[:0], dAtA[iNdEx:postIndex]...)
+ if m.ProofBlindingS == nil {
+ m.ProofBlindingS = []byte{}
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipGovernance(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *DaoDeposit) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: DaoDeposit: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: DaoDeposit: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Value", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Value == nil {
+ m.Value = &v1alpha1.Value{}
+ }
+ if err := m.Value.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipGovernance(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *DaoSpend) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: DaoSpend: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: DaoSpend: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Value", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Value == nil {
+ m.Value = &v1alpha1.Value{}
+ }
+ if err := m.Value.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipGovernance(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *DaoOutput) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: DaoOutput: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: DaoOutput: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Value", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Value == nil {
+ m.Value = &v1alpha1.Value{}
+ }
+ if err := m.Value.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Address", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Address == nil {
+ m.Address = &v1alpha1.Address{}
+ }
+ if err := m.Address.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipGovernance(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *Vote) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Vote: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Vote: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Vote", wireType)
+ }
+ m.Vote = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.Vote |= Vote_Vote(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ default:
+ iNdEx = preIndex
+ skippy, err := skipGovernance(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *ProposalState) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: ProposalState: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: ProposalState: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Voting", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &ProposalState_Voting{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.State = &ProposalState_Voting_{v}
+ iNdEx = postIndex
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Withdrawn", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &ProposalState_Withdrawn{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.State = &ProposalState_Withdrawn_{v}
+ iNdEx = postIndex
+ case 4:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Finished", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &ProposalState_Finished{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.State = &ProposalState_Finished_{v}
+ iNdEx = postIndex
+ case 5:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Claimed", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &ProposalState_Claimed{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.State = &ProposalState_Claimed_{v}
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipGovernance(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *ProposalState_Voting) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Voting: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Voting: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ default:
+ iNdEx = preIndex
+ skippy, err := skipGovernance(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *ProposalState_Withdrawn) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Withdrawn: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Withdrawn: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Reason", wireType)
+ }
+ var stringLen uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ stringLen |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ intStringLen := int(stringLen)
+ if intStringLen < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ postIndex := iNdEx + intStringLen
+ if postIndex < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Reason = string(dAtA[iNdEx:postIndex])
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipGovernance(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *ProposalState_Finished) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Finished: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Finished: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Outcome", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Outcome == nil {
+ m.Outcome = &ProposalOutcome{}
+ }
+ if err := m.Outcome.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipGovernance(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *ProposalState_Claimed) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Claimed: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Claimed: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Outcome", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Outcome == nil {
+ m.Outcome = &ProposalOutcome{}
+ }
+ if err := m.Outcome.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipGovernance(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *ProposalOutcome) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: ProposalOutcome: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: ProposalOutcome: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Passed", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &ProposalOutcome_Passed{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.Outcome = &ProposalOutcome_Passed_{v}
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Failed", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &ProposalOutcome_Failed{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.Outcome = &ProposalOutcome_Failed_{v}
+ iNdEx = postIndex
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Slashed", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &ProposalOutcome_Slashed{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.Outcome = &ProposalOutcome_Slashed_{v}
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipGovernance(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *ProposalOutcome_Passed) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Passed: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Passed: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ default:
+ iNdEx = preIndex
+ skippy, err := skipGovernance(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *ProposalOutcome_Failed) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Failed: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Failed: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field WithdrawnWithReason", wireType)
+ }
+ var stringLen uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ stringLen |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ intStringLen := int(stringLen)
+ if intStringLen < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ postIndex := iNdEx + intStringLen
+ if postIndex < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.XWithdrawnWithReason = &ProposalOutcome_Failed_WithdrawnWithReason{string(dAtA[iNdEx:postIndex])}
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipGovernance(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *ProposalOutcome_Slashed) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Slashed: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Slashed: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field WithdrawnWithReason", wireType)
+ }
+ var stringLen uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ stringLen |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ intStringLen := int(stringLen)
+ if intStringLen < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ postIndex := iNdEx + intStringLen
+ if postIndex < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.XWithdrawnWithReason = &ProposalOutcome_Slashed_WithdrawnWithReason{string(dAtA[iNdEx:postIndex])}
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipGovernance(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *Tally) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Tally: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Tally: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Yes", wireType)
+ }
+ m.Yes = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.Yes |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 2:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field No", wireType)
+ }
+ m.No = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.No |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 3:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Abstain", wireType)
+ }
+ m.Abstain = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.Abstain |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ default:
+ iNdEx = preIndex
+ skippy, err := skipGovernance(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *Proposal) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Proposal: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Proposal: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Title", wireType)
+ }
+ var stringLen uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ stringLen |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ intStringLen := int(stringLen)
+ if intStringLen < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ postIndex := iNdEx + intStringLen
+ if postIndex < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Title = string(dAtA[iNdEx:postIndex])
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Description", wireType)
+ }
+ var stringLen uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ stringLen |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ intStringLen := int(stringLen)
+ if intStringLen < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ postIndex := iNdEx + intStringLen
+ if postIndex < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Description = string(dAtA[iNdEx:postIndex])
+ iNdEx = postIndex
+ case 4:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Id", wireType)
+ }
+ m.Id = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.Id |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 5:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Signaling", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Signaling == nil {
+ m.Signaling = &Proposal_Signaling{}
+ }
+ if err := m.Signaling.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 6:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Emergency", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Emergency == nil {
+ m.Emergency = &Proposal_Emergency{}
+ }
+ if err := m.Emergency.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 7:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ParameterChange", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.ParameterChange == nil {
+ m.ParameterChange = &Proposal_ParameterChange{}
+ }
+ if err := m.ParameterChange.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 8:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field DaoSpend", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.DaoSpend == nil {
+ m.DaoSpend = &Proposal_DaoSpend{}
+ }
+ if err := m.DaoSpend.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipGovernance(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *Proposal_Signaling) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Signaling: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Signaling: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Commit", wireType)
+ }
+ var stringLen uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ stringLen |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ intStringLen := int(stringLen)
+ if intStringLen < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ postIndex := iNdEx + intStringLen
+ if postIndex < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.XCommit = &Proposal_Signaling_Commit{string(dAtA[iNdEx:postIndex])}
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipGovernance(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *Proposal_Emergency) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Emergency: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Emergency: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field HaltChain", wireType)
+ }
+ var v int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ v |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ m.HaltChain = bool(v != 0)
+ default:
+ iNdEx = preIndex
+ skippy, err := skipGovernance(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *Proposal_ParameterChange) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: ParameterChange: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: ParameterChange: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field OldParameters", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.OldParameters == nil {
+ m.OldParameters = &v1alpha11.ChainParameters{}
+ }
+ if err := m.OldParameters.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field NewParameters", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.NewParameters == nil {
+ m.NewParameters = &v1alpha11.ChainParameters{}
+ }
+ if err := m.NewParameters.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipGovernance(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *Proposal_DaoSpend) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: DaoSpend: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: DaoSpend: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field TransactionPlan", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.TransactionPlan == nil {
+ m.TransactionPlan = &types.Any{}
+ }
+ if err := m.TransactionPlan.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipGovernance(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthGovernance
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func skipGovernance(dAtA []byte) (n int, err error) {
+ l := len(dAtA)
+ iNdEx := 0
+ depth := 0
+ for iNdEx < l {
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return 0, ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return 0, io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= (uint64(b) & 0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ wireType := int(wire & 0x7)
+ switch wireType {
+ case 0:
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return 0, ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return 0, io.ErrUnexpectedEOF
+ }
+ iNdEx++
+ if dAtA[iNdEx-1] < 0x80 {
+ break
+ }
+ }
+ case 1:
+ iNdEx += 8
+ case 2:
+ var length int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return 0, ErrIntOverflowGovernance
+ }
+ if iNdEx >= l {
+ return 0, io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ length |= (int(b) & 0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if length < 0 {
+ return 0, ErrInvalidLengthGovernance
+ }
+ iNdEx += length
+ case 3:
+ depth++
+ case 4:
+ if depth == 0 {
+ return 0, ErrUnexpectedEndOfGroupGovernance
+ }
+ depth--
+ case 5:
+ iNdEx += 4
+ default:
+ return 0, fmt.Errorf("proto: illegal wireType %d", wireType)
+ }
+ if iNdEx < 0 {
+ return 0, ErrInvalidLengthGovernance
+ }
+ if depth == 0 {
+ return iNdEx, nil
+ }
+ }
+ return 0, io.ErrUnexpectedEOF
+}
+
+var (
+ ErrInvalidLengthGovernance = fmt.Errorf("proto: negative length found during unmarshaling")
+ ErrIntOverflowGovernance = fmt.Errorf("proto: integer overflow")
+ ErrUnexpectedEndOfGroupGovernance = fmt.Errorf("proto: unexpected end of group")
+)
diff --git a/relayer/chains/penumbra/core/ibc/v1alpha1/ibc.pb.go b/relayer/chains/penumbra/core/ibc/v1alpha1/ibc.pb.go
new file mode 100644
index 000000000..8bf6ff767
--- /dev/null
+++ b/relayer/chains/penumbra/core/ibc/v1alpha1/ibc.pb.go
@@ -0,0 +1,2359 @@
+// Code generated by protoc-gen-gogo. DO NOT EDIT.
+// source: penumbra/core/ibc/v1alpha1/ibc.proto
+
+package ibcv1alpha1
+
+import (
+ fmt "fmt"
+ types "github.com/cosmos/cosmos-sdk/codec/types"
+ proto "github.com/cosmos/gogoproto/proto"
+ types1 "github.com/cosmos/ibc-go/v7/modules/core/02-client/types"
+ v1alpha1 "github.com/cosmos/relayer/v2/relayer/chains/penumbra/core/crypto/v1alpha1"
+ io "io"
+ math "math"
+ math_bits "math/bits"
+)
+
+// Reference imports to suppress errors if they are not otherwise used.
+var _ = proto.Marshal
+var _ = fmt.Errorf
+var _ = math.Inf
+
+// This is a compile-time assertion to ensure that this generated file
+// is compatible with the proto package it is being compiled against.
+// A compilation error at this line likely means your copy of the
+// proto package needs to be updated.
+const _ = proto.GoGoProtoPackageIsVersion3 // please upgrade the proto package
+
+type IbcAction struct {
+ //
+ // oneof action {
+ // .ibc.core.connection.v1.MsgConnectionOpenInit connection_open_init = 1;
+ // .ibc.core.connection.v1.MsgConnectionOpenTry connection_open_try = 2;
+ // .ibc.core.connection.v1.MsgConnectionOpenAck connection_open_ack = 3;
+ // .ibc.core.connection.v1.MsgConnectionOpenConfirm connection_open_confirm = 4;
+ //
+ // .ibc.core.channel.v1.MsgChannelOpenInit channel_open_init = 5;
+ // .ibc.core.channel.v1.MsgChannelOpenTry channel_open_try = 6;
+ // .ibc.core.channel.v1.MsgChannelOpenAck channel_open_ack = 7;
+ // .ibc.core.channel.v1.MsgChannelOpenConfirm channel_open_confirm = 8;
+ // .ibc.core.channel.v1.MsgChannelCloseInit channel_close_init = 9;
+ // .ibc.core.channel.v1.MsgChannelCloseConfirm channel_close_confirm = 10;
+ //
+ // .ibc.core.channel.v1.MsgRecvPacket recv_packet = 11;
+ // .ibc.core.channel.v1.MsgTimeout timeout = 12;
+ // .ibc.core.channel.v1.MsgAcknowledgement acknowledgement = 13;
+ //
+ // .ibc.core.client.v1.MsgCreateClient create_client = 14;
+ // .ibc.core.client.v1.MsgUpdateClient update_client = 15;
+ // .ibc.core.client.v1.MsgUpgradeClient upgrade_client = 16;
+ // .ibc.core.client.v1.MsgSubmitMisbehaviour submit_misbehaviour = 17;
+ // }
+ RawAction *types.Any `protobuf:"bytes,1,opt,name=raw_action,json=rawAction,proto3" json:"raw_action,omitempty"`
+}
+
+func (m *IbcAction) Reset() { *m = IbcAction{} }
+func (m *IbcAction) String() string { return proto.CompactTextString(m) }
+func (*IbcAction) ProtoMessage() {}
+func (*IbcAction) Descriptor() ([]byte, []int) {
+ return fileDescriptor_6509740287584c65, []int{0}
+}
+func (m *IbcAction) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *IbcAction) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_IbcAction.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *IbcAction) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_IbcAction.Merge(m, src)
+}
+func (m *IbcAction) XXX_Size() int {
+ return m.Size()
+}
+func (m *IbcAction) XXX_DiscardUnknown() {
+ xxx_messageInfo_IbcAction.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_IbcAction proto.InternalMessageInfo
+
+func (m *IbcAction) GetRawAction() *types.Any {
+ if m != nil {
+ return m.RawAction
+ }
+ return nil
+}
+
+// FungibleTokenPacketData defines a struct for the packet payload
+// See FungibleTokenPacketData spec:
+// https://github.com/cosmos/ibc/tree/master/spec/app/ics-020-fungible-token-transfer#data-structures
+type FungibleTokenPacketData struct {
+ // the token denomination to be transferred
+ Denom string `protobuf:"bytes,1,opt,name=denom,proto3" json:"denom,omitempty"`
+ // the token amount to be transferred
+ Amount string `protobuf:"bytes,2,opt,name=amount,proto3" json:"amount,omitempty"`
+ // the sender address
+ Sender string `protobuf:"bytes,3,opt,name=sender,proto3" json:"sender,omitempty"`
+ // the recipient address on the destination chain
+ Receiver string `protobuf:"bytes,4,opt,name=receiver,proto3" json:"receiver,omitempty"`
+}
+
+func (m *FungibleTokenPacketData) Reset() { *m = FungibleTokenPacketData{} }
+func (m *FungibleTokenPacketData) String() string { return proto.CompactTextString(m) }
+func (*FungibleTokenPacketData) ProtoMessage() {}
+func (*FungibleTokenPacketData) Descriptor() ([]byte, []int) {
+ return fileDescriptor_6509740287584c65, []int{1}
+}
+func (m *FungibleTokenPacketData) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *FungibleTokenPacketData) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_FungibleTokenPacketData.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *FungibleTokenPacketData) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_FungibleTokenPacketData.Merge(m, src)
+}
+func (m *FungibleTokenPacketData) XXX_Size() int {
+ return m.Size()
+}
+func (m *FungibleTokenPacketData) XXX_DiscardUnknown() {
+ xxx_messageInfo_FungibleTokenPacketData.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_FungibleTokenPacketData proto.InternalMessageInfo
+
+func (m *FungibleTokenPacketData) GetDenom() string {
+ if m != nil {
+ return m.Denom
+ }
+ return ""
+}
+
+func (m *FungibleTokenPacketData) GetAmount() string {
+ if m != nil {
+ return m.Amount
+ }
+ return ""
+}
+
+func (m *FungibleTokenPacketData) GetSender() string {
+ if m != nil {
+ return m.Sender
+ }
+ return ""
+}
+
+func (m *FungibleTokenPacketData) GetReceiver() string {
+ if m != nil {
+ return m.Receiver
+ }
+ return ""
+}
+
+type Ics20Withdrawal struct {
+ Amount *v1alpha1.Amount `protobuf:"bytes,1,opt,name=amount,proto3" json:"amount,omitempty"`
+ Denom *v1alpha1.Denom `protobuf:"bytes,2,opt,name=denom,proto3" json:"denom,omitempty"`
+ // the address on the destination chain to send the transfer to
+ DestinationChainAddress string `protobuf:"bytes,3,opt,name=destination_chain_address,json=destinationChainAddress,proto3" json:"destination_chain_address,omitempty"`
+ // a "sender" penumbra address to use to return funds from this withdrawal.
+ // this should be an ephemeral address
+ ReturnAddress *v1alpha1.Address `protobuf:"bytes,4,opt,name=return_address,json=returnAddress,proto3" json:"return_address,omitempty"`
+ // the height (on Penumbra) at which this transfer expires (and funds are sent
+ // back to the sender address?). NOTE: if funds are sent back to the sender,
+ // we MUST verify a nonexistence proof before accepting the timeout, to
+ // prevent relayer censorship attacks. The core IBC implementation does this
+ // in its handling of validation of timeouts.
+ TimeoutHeight uint64 `protobuf:"varint,5,opt,name=timeout_height,json=timeoutHeight,proto3" json:"timeout_height,omitempty"`
+ // the timestamp at which this transfer expires.
+ TimeoutTime uint64 `protobuf:"varint,6,opt,name=timeout_time,json=timeoutTime,proto3" json:"timeout_time,omitempty"`
+ // the source channel used for the withdrawal
+ SourceChannel string `protobuf:"bytes,7,opt,name=source_channel,json=sourceChannel,proto3" json:"source_channel,omitempty"`
+}
+
+func (m *Ics20Withdrawal) Reset() { *m = Ics20Withdrawal{} }
+func (m *Ics20Withdrawal) String() string { return proto.CompactTextString(m) }
+func (*Ics20Withdrawal) ProtoMessage() {}
+func (*Ics20Withdrawal) Descriptor() ([]byte, []int) {
+ return fileDescriptor_6509740287584c65, []int{2}
+}
+func (m *Ics20Withdrawal) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *Ics20Withdrawal) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_Ics20Withdrawal.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *Ics20Withdrawal) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_Ics20Withdrawal.Merge(m, src)
+}
+func (m *Ics20Withdrawal) XXX_Size() int {
+ return m.Size()
+}
+func (m *Ics20Withdrawal) XXX_DiscardUnknown() {
+ xxx_messageInfo_Ics20Withdrawal.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_Ics20Withdrawal proto.InternalMessageInfo
+
+func (m *Ics20Withdrawal) GetAmount() *v1alpha1.Amount {
+ if m != nil {
+ return m.Amount
+ }
+ return nil
+}
+
+func (m *Ics20Withdrawal) GetDenom() *v1alpha1.Denom {
+ if m != nil {
+ return m.Denom
+ }
+ return nil
+}
+
+func (m *Ics20Withdrawal) GetDestinationChainAddress() string {
+ if m != nil {
+ return m.DestinationChainAddress
+ }
+ return ""
+}
+
+func (m *Ics20Withdrawal) GetReturnAddress() *v1alpha1.Address {
+ if m != nil {
+ return m.ReturnAddress
+ }
+ return nil
+}
+
+func (m *Ics20Withdrawal) GetTimeoutHeight() uint64 {
+ if m != nil {
+ return m.TimeoutHeight
+ }
+ return 0
+}
+
+func (m *Ics20Withdrawal) GetTimeoutTime() uint64 {
+ if m != nil {
+ return m.TimeoutTime
+ }
+ return 0
+}
+
+func (m *Ics20Withdrawal) GetSourceChannel() string {
+ if m != nil {
+ return m.SourceChannel
+ }
+ return ""
+}
+
+type ClientData struct {
+ ClientId string `protobuf:"bytes,1,opt,name=client_id,json=clientId,proto3" json:"client_id,omitempty"`
+ ClientState *types.Any `protobuf:"bytes,2,opt,name=client_state,json=clientState,proto3" json:"client_state,omitempty"`
+ ProcessedTime string `protobuf:"bytes,3,opt,name=processed_time,json=processedTime,proto3" json:"processed_time,omitempty"`
+ ProcessedHeight uint64 `protobuf:"varint,4,opt,name=processed_height,json=processedHeight,proto3" json:"processed_height,omitempty"`
+}
+
+func (m *ClientData) Reset() { *m = ClientData{} }
+func (m *ClientData) String() string { return proto.CompactTextString(m) }
+func (*ClientData) ProtoMessage() {}
+func (*ClientData) Descriptor() ([]byte, []int) {
+ return fileDescriptor_6509740287584c65, []int{3}
+}
+func (m *ClientData) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *ClientData) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_ClientData.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *ClientData) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_ClientData.Merge(m, src)
+}
+func (m *ClientData) XXX_Size() int {
+ return m.Size()
+}
+func (m *ClientData) XXX_DiscardUnknown() {
+ xxx_messageInfo_ClientData.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_ClientData proto.InternalMessageInfo
+
+func (m *ClientData) GetClientId() string {
+ if m != nil {
+ return m.ClientId
+ }
+ return ""
+}
+
+func (m *ClientData) GetClientState() *types.Any {
+ if m != nil {
+ return m.ClientState
+ }
+ return nil
+}
+
+func (m *ClientData) GetProcessedTime() string {
+ if m != nil {
+ return m.ProcessedTime
+ }
+ return ""
+}
+
+func (m *ClientData) GetProcessedHeight() uint64 {
+ if m != nil {
+ return m.ProcessedHeight
+ }
+ return 0
+}
+
+type ClientCounter struct {
+ Counter uint64 `protobuf:"varint,1,opt,name=counter,proto3" json:"counter,omitempty"`
+}
+
+func (m *ClientCounter) Reset() { *m = ClientCounter{} }
+func (m *ClientCounter) String() string { return proto.CompactTextString(m) }
+func (*ClientCounter) ProtoMessage() {}
+func (*ClientCounter) Descriptor() ([]byte, []int) {
+ return fileDescriptor_6509740287584c65, []int{4}
+}
+func (m *ClientCounter) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *ClientCounter) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_ClientCounter.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *ClientCounter) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_ClientCounter.Merge(m, src)
+}
+func (m *ClientCounter) XXX_Size() int {
+ return m.Size()
+}
+func (m *ClientCounter) XXX_DiscardUnknown() {
+ xxx_messageInfo_ClientCounter.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_ClientCounter proto.InternalMessageInfo
+
+func (m *ClientCounter) GetCounter() uint64 {
+ if m != nil {
+ return m.Counter
+ }
+ return 0
+}
+
+type ConsensusState struct {
+ ConsensusState *types.Any `protobuf:"bytes,1,opt,name=consensus_state,json=consensusState,proto3" json:"consensus_state,omitempty"`
+}
+
+func (m *ConsensusState) Reset() { *m = ConsensusState{} }
+func (m *ConsensusState) String() string { return proto.CompactTextString(m) }
+func (*ConsensusState) ProtoMessage() {}
+func (*ConsensusState) Descriptor() ([]byte, []int) {
+ return fileDescriptor_6509740287584c65, []int{5}
+}
+func (m *ConsensusState) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *ConsensusState) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_ConsensusState.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *ConsensusState) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_ConsensusState.Merge(m, src)
+}
+func (m *ConsensusState) XXX_Size() int {
+ return m.Size()
+}
+func (m *ConsensusState) XXX_DiscardUnknown() {
+ xxx_messageInfo_ConsensusState.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_ConsensusState proto.InternalMessageInfo
+
+func (m *ConsensusState) GetConsensusState() *types.Any {
+ if m != nil {
+ return m.ConsensusState
+ }
+ return nil
+}
+
+type VerifiedHeights struct {
+ Heights []*types1.Height `protobuf:"bytes,1,rep,name=heights,proto3" json:"heights,omitempty"`
+}
+
+func (m *VerifiedHeights) Reset() { *m = VerifiedHeights{} }
+func (m *VerifiedHeights) String() string { return proto.CompactTextString(m) }
+func (*VerifiedHeights) ProtoMessage() {}
+func (*VerifiedHeights) Descriptor() ([]byte, []int) {
+ return fileDescriptor_6509740287584c65, []int{6}
+}
+func (m *VerifiedHeights) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *VerifiedHeights) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_VerifiedHeights.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *VerifiedHeights) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_VerifiedHeights.Merge(m, src)
+}
+func (m *VerifiedHeights) XXX_Size() int {
+ return m.Size()
+}
+func (m *VerifiedHeights) XXX_DiscardUnknown() {
+ xxx_messageInfo_VerifiedHeights.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_VerifiedHeights proto.InternalMessageInfo
+
+func (m *VerifiedHeights) GetHeights() []*types1.Height {
+ if m != nil {
+ return m.Heights
+ }
+ return nil
+}
+
+type ConnectionCounter struct {
+ Counter uint64 `protobuf:"varint,1,opt,name=counter,proto3" json:"counter,omitempty"`
+}
+
+func (m *ConnectionCounter) Reset() { *m = ConnectionCounter{} }
+func (m *ConnectionCounter) String() string { return proto.CompactTextString(m) }
+func (*ConnectionCounter) ProtoMessage() {}
+func (*ConnectionCounter) Descriptor() ([]byte, []int) {
+ return fileDescriptor_6509740287584c65, []int{7}
+}
+func (m *ConnectionCounter) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *ConnectionCounter) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_ConnectionCounter.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *ConnectionCounter) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_ConnectionCounter.Merge(m, src)
+}
+func (m *ConnectionCounter) XXX_Size() int {
+ return m.Size()
+}
+func (m *ConnectionCounter) XXX_DiscardUnknown() {
+ xxx_messageInfo_ConnectionCounter.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_ConnectionCounter proto.InternalMessageInfo
+
+func (m *ConnectionCounter) GetCounter() uint64 {
+ if m != nil {
+ return m.Counter
+ }
+ return 0
+}
+
+type ClientConnections struct {
+ Connections []string `protobuf:"bytes,1,rep,name=connections,proto3" json:"connections,omitempty"`
+}
+
+func (m *ClientConnections) Reset() { *m = ClientConnections{} }
+func (m *ClientConnections) String() string { return proto.CompactTextString(m) }
+func (*ClientConnections) ProtoMessage() {}
+func (*ClientConnections) Descriptor() ([]byte, []int) {
+ return fileDescriptor_6509740287584c65, []int{8}
+}
+func (m *ClientConnections) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *ClientConnections) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_ClientConnections.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *ClientConnections) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_ClientConnections.Merge(m, src)
+}
+func (m *ClientConnections) XXX_Size() int {
+ return m.Size()
+}
+func (m *ClientConnections) XXX_DiscardUnknown() {
+ xxx_messageInfo_ClientConnections.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_ClientConnections proto.InternalMessageInfo
+
+func (m *ClientConnections) GetConnections() []string {
+ if m != nil {
+ return m.Connections
+ }
+ return nil
+}
+
+func init() {
+ proto.RegisterType((*IbcAction)(nil), "penumbra.core.ibc.v1alpha1.IbcAction")
+ proto.RegisterType((*FungibleTokenPacketData)(nil), "penumbra.core.ibc.v1alpha1.FungibleTokenPacketData")
+ proto.RegisterType((*Ics20Withdrawal)(nil), "penumbra.core.ibc.v1alpha1.Ics20Withdrawal")
+ proto.RegisterType((*ClientData)(nil), "penumbra.core.ibc.v1alpha1.ClientData")
+ proto.RegisterType((*ClientCounter)(nil), "penumbra.core.ibc.v1alpha1.ClientCounter")
+ proto.RegisterType((*ConsensusState)(nil), "penumbra.core.ibc.v1alpha1.ConsensusState")
+ proto.RegisterType((*VerifiedHeights)(nil), "penumbra.core.ibc.v1alpha1.VerifiedHeights")
+ proto.RegisterType((*ConnectionCounter)(nil), "penumbra.core.ibc.v1alpha1.ConnectionCounter")
+ proto.RegisterType((*ClientConnections)(nil), "penumbra.core.ibc.v1alpha1.ClientConnections")
+}
+
+func init() {
+ proto.RegisterFile("penumbra/core/ibc/v1alpha1/ibc.proto", fileDescriptor_6509740287584c65)
+}
+
+var fileDescriptor_6509740287584c65 = []byte{
+ // 773 bytes of a gzipped FileDescriptorProto
+ 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x84, 0x54, 0x41, 0x8f, 0x1b, 0x35,
+ 0x14, 0xde, 0x49, 0xd2, 0xdd, 0x8d, 0xd3, 0x24, 0x74, 0x54, 0xd1, 0x69, 0x10, 0x21, 0x8c, 0xda,
+ 0x6a, 0x8b, 0xc4, 0x0c, 0x49, 0x41, 0x48, 0x83, 0x2a, 0x91, 0x9d, 0x8a, 0x32, 0x87, 0x8a, 0x68,
+ 0xa8, 0x8a, 0x84, 0x22, 0x45, 0x1e, 0x8f, 0x9b, 0x58, 0x9b, 0xb1, 0x23, 0xdb, 0x93, 0x55, 0xc4,
+ 0x1f, 0xe0, 0xc8, 0x5f, 0x80, 0x23, 0x67, 0x7e, 0x04, 0xe2, 0xb4, 0x47, 0x8e, 0x28, 0x7b, 0xe3,
+ 0x57, 0x20, 0xdb, 0xe3, 0x64, 0x57, 0x62, 0xbb, 0xa7, 0xf8, 0x7d, 0xef, 0x7b, 0x2f, 0xdf, 0xf7,
+ 0xde, 0xd8, 0xe0, 0xd1, 0x0a, 0xd3, 0xb2, 0xc8, 0x38, 0x0c, 0x11, 0xe3, 0x38, 0x24, 0x19, 0x0a,
+ 0xd7, 0x43, 0xb8, 0x5c, 0x2d, 0xe0, 0x50, 0x05, 0xc1, 0x8a, 0x33, 0xc9, 0xdc, 0x9e, 0x65, 0x05,
+ 0x8a, 0x15, 0xa8, 0x84, 0x65, 0xf5, 0x3e, 0xb9, 0xde, 0x01, 0xf1, 0xcd, 0x4a, 0xb2, 0x7d, 0x13,
+ 0x13, 0x9b, 0x3e, 0xbd, 0x8f, 0x54, 0x7f, 0x43, 0x5b, 0x12, 0x4c, 0x65, 0xb8, 0x1e, 0x56, 0xa7,
+ 0x8a, 0xf0, 0x70, 0xce, 0xd8, 0x7c, 0x89, 0x43, 0x1d, 0x65, 0xe5, 0xdb, 0x10, 0xd2, 0x8d, 0x49,
+ 0xf9, 0x5f, 0x83, 0x66, 0x92, 0xa1, 0x31, 0x92, 0x84, 0x51, 0xf7, 0x19, 0x00, 0x1c, 0x9e, 0xcf,
+ 0xa0, 0x8e, 0x3c, 0x67, 0xe0, 0x9c, 0xb4, 0x46, 0xf7, 0x03, 0x53, 0x1c, 0xd8, 0xe2, 0x60, 0x4c,
+ 0x37, 0x69, 0x93, 0xc3, 0x73, 0x53, 0xe4, 0xff, 0x04, 0x1e, 0x7c, 0x53, 0xd2, 0x39, 0xc9, 0x96,
+ 0xf8, 0x35, 0x3b, 0xc3, 0x74, 0x02, 0xd1, 0x19, 0x96, 0x2f, 0xa0, 0x84, 0xee, 0x7d, 0x70, 0x27,
+ 0xc7, 0x94, 0x15, 0xba, 0x55, 0x33, 0x35, 0x81, 0xfb, 0x3e, 0x38, 0x84, 0x05, 0x2b, 0xa9, 0xf4,
+ 0x6a, 0x1a, 0xae, 0x22, 0x85, 0x0b, 0x4c, 0x73, 0xcc, 0xbd, 0xba, 0xc1, 0x4d, 0xe4, 0xf6, 0xc0,
+ 0x31, 0xc7, 0x08, 0x93, 0x35, 0xe6, 0x5e, 0x43, 0x67, 0x76, 0xb1, 0xff, 0x73, 0x1d, 0x74, 0x13,
+ 0x24, 0x46, 0x9f, 0xfd, 0x40, 0xe4, 0x22, 0xe7, 0xf0, 0x1c, 0x2e, 0xdd, 0xe7, 0xbb, 0xfe, 0xc6,
+ 0xc1, 0xe3, 0xe0, 0xfa, 0x9c, 0xab, 0xd9, 0xd9, 0x59, 0x06, 0x63, 0x4d, 0xde, 0xc9, 0x88, 0xac,
+ 0xe8, 0x9a, 0xae, 0x7e, 0x74, 0x4b, 0xf5, 0x0b, 0xc5, 0xb5, 0xd6, 0x22, 0xf0, 0x30, 0xc7, 0x42,
+ 0x12, 0x0a, 0xd5, 0x68, 0x66, 0x68, 0x01, 0x09, 0x9d, 0xc1, 0x3c, 0xe7, 0x58, 0x88, 0xca, 0xd5,
+ 0x83, 0x2b, 0x84, 0x58, 0xe5, 0xc7, 0x26, 0xed, 0xbe, 0x02, 0x1d, 0x8e, 0x65, 0xc9, 0xf7, 0x05,
+ 0x0d, 0x2d, 0xe0, 0xc9, 0x6d, 0xf2, 0x0d, 0x3b, 0x6d, 0x9b, 0x6a, 0xdb, 0xee, 0x31, 0xe8, 0x48,
+ 0x52, 0x60, 0x56, 0xca, 0xd9, 0x02, 0x93, 0xf9, 0x42, 0x7a, 0x77, 0x06, 0xce, 0x49, 0x23, 0x6d,
+ 0x57, 0xe8, 0xb7, 0x1a, 0x74, 0x3f, 0x06, 0x77, 0x2d, 0x4d, 0xfd, 0x7a, 0x87, 0x9a, 0xd4, 0xaa,
+ 0xb0, 0xd7, 0xa4, 0xc0, 0xaa, 0x93, 0x60, 0x25, 0x47, 0x58, 0xf9, 0xa1, 0x14, 0x2f, 0xbd, 0x23,
+ 0xed, 0xa4, 0x6d, 0xd0, 0xd8, 0x80, 0xfe, 0x1f, 0x0e, 0x00, 0xb1, 0xfe, 0xea, 0xf4, 0xee, 0x3f,
+ 0x00, 0x4d, 0xf3, 0x0d, 0xce, 0x48, 0x5e, 0xed, 0xff, 0xd8, 0x00, 0x49, 0xee, 0x7e, 0x09, 0xee,
+ 0x56, 0x49, 0x21, 0xa1, 0xc4, 0xd5, 0xa8, 0xff, 0xff, 0x53, 0x6b, 0x19, 0xe6, 0xf7, 0x8a, 0xa8,
+ 0xb4, 0xac, 0x38, 0x43, 0x58, 0x08, 0x9c, 0x1b, 0xc1, 0x66, 0xaa, 0xed, 0x1d, 0xaa, 0x25, 0x3f,
+ 0x05, 0xef, 0xed, 0x69, 0x95, 0xfd, 0x86, 0x76, 0xd6, 0xdd, 0xe1, 0x66, 0x00, 0xfe, 0x53, 0xd0,
+ 0x36, 0xaa, 0x63, 0xb5, 0x7d, 0xcc, 0x5d, 0x0f, 0x1c, 0x21, 0x73, 0xd4, 0xb2, 0x1b, 0xa9, 0x0d,
+ 0xfd, 0xef, 0x40, 0x27, 0x66, 0x54, 0x60, 0x2a, 0x4a, 0x61, 0xe4, 0x3c, 0x07, 0x5d, 0x64, 0x91,
+ 0xca, 0xca, 0xbb, 0x6e, 0x4d, 0x07, 0x5d, 0x2b, 0xf7, 0x5f, 0x82, 0xee, 0x1b, 0xcc, 0xc9, 0x5b,
+ 0x62, 0xd5, 0x08, 0xf7, 0x73, 0x70, 0x64, 0xf4, 0x0a, 0xcf, 0x19, 0xd4, 0x4f, 0x5a, 0xa3, 0x9e,
+ 0x7e, 0x17, 0xcc, 0xe6, 0xcd, 0x9d, 0x5e, 0x0f, 0x03, 0xc3, 0x4e, 0x2d, 0xd5, 0xff, 0x14, 0xdc,
+ 0x8b, 0x19, 0xa5, 0x58, 0xdf, 0xc8, 0xdb, 0x8d, 0x7c, 0x01, 0xee, 0x59, 0xcf, 0xb6, 0x48, 0xb8,
+ 0x03, 0xd0, 0x42, 0xfb, 0x50, 0xff, 0x7b, 0x33, 0xbd, 0x0a, 0x9d, 0xfe, 0x5a, 0xfb, 0x73, 0xdb,
+ 0x77, 0x2e, 0xb6, 0x7d, 0xe7, 0x9f, 0x6d, 0xdf, 0xf9, 0xe5, 0xb2, 0x7f, 0x70, 0x71, 0xd9, 0x3f,
+ 0xf8, 0xfb, 0xb2, 0x7f, 0x00, 0xfa, 0x88, 0x15, 0xc1, 0xcd, 0xcf, 0xd9, 0xe9, 0x71, 0x92, 0xa1,
+ 0x89, 0x1a, 0xc5, 0xc4, 0xf9, 0x31, 0x9d, 0x13, 0xb9, 0x28, 0xb3, 0x00, 0xb1, 0x22, 0x44, 0x4c,
+ 0x14, 0x4c, 0x84, 0x1c, 0x2f, 0xe1, 0x06, 0xf3, 0x70, 0x3d, 0xda, 0x1d, 0xf5, 0xdd, 0x11, 0xe1,
+ 0xcd, 0x0f, 0xe9, 0x57, 0x24, 0x43, 0xf6, 0xfc, 0x5b, 0xad, 0x3e, 0x89, 0x93, 0xdf, 0x6b, 0xbd,
+ 0x89, 0x95, 0x10, 0x2b, 0x09, 0x49, 0x86, 0x82, 0x37, 0x15, 0xe5, 0xaf, 0x7d, 0x72, 0xaa, 0x92,
+ 0xd3, 0x24, 0x43, 0x53, 0x9b, 0xdc, 0xd6, 0x9e, 0xdc, 0x9c, 0x9c, 0xbe, 0x9c, 0x9c, 0xbe, 0xc2,
+ 0x12, 0xe6, 0x50, 0xc2, 0x7f, 0x6b, 0x1f, 0x5a, 0x62, 0x14, 0x29, 0x66, 0x14, 0x25, 0x19, 0x8a,
+ 0x22, 0xcb, 0xcd, 0x0e, 0xf5, 0xc2, 0x9f, 0xfd, 0x17, 0x00, 0x00, 0xff, 0xff, 0x1b, 0x2a, 0x21,
+ 0xe0, 0x02, 0x06, 0x00, 0x00,
+}
+
+func (m *IbcAction) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *IbcAction) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *IbcAction) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.RawAction != nil {
+ {
+ size, err := m.RawAction.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintIbc(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *FungibleTokenPacketData) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *FungibleTokenPacketData) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *FungibleTokenPacketData) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.Receiver) > 0 {
+ i -= len(m.Receiver)
+ copy(dAtA[i:], m.Receiver)
+ i = encodeVarintIbc(dAtA, i, uint64(len(m.Receiver)))
+ i--
+ dAtA[i] = 0x22
+ }
+ if len(m.Sender) > 0 {
+ i -= len(m.Sender)
+ copy(dAtA[i:], m.Sender)
+ i = encodeVarintIbc(dAtA, i, uint64(len(m.Sender)))
+ i--
+ dAtA[i] = 0x1a
+ }
+ if len(m.Amount) > 0 {
+ i -= len(m.Amount)
+ copy(dAtA[i:], m.Amount)
+ i = encodeVarintIbc(dAtA, i, uint64(len(m.Amount)))
+ i--
+ dAtA[i] = 0x12
+ }
+ if len(m.Denom) > 0 {
+ i -= len(m.Denom)
+ copy(dAtA[i:], m.Denom)
+ i = encodeVarintIbc(dAtA, i, uint64(len(m.Denom)))
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *Ics20Withdrawal) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *Ics20Withdrawal) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *Ics20Withdrawal) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.SourceChannel) > 0 {
+ i -= len(m.SourceChannel)
+ copy(dAtA[i:], m.SourceChannel)
+ i = encodeVarintIbc(dAtA, i, uint64(len(m.SourceChannel)))
+ i--
+ dAtA[i] = 0x3a
+ }
+ if m.TimeoutTime != 0 {
+ i = encodeVarintIbc(dAtA, i, uint64(m.TimeoutTime))
+ i--
+ dAtA[i] = 0x30
+ }
+ if m.TimeoutHeight != 0 {
+ i = encodeVarintIbc(dAtA, i, uint64(m.TimeoutHeight))
+ i--
+ dAtA[i] = 0x28
+ }
+ if m.ReturnAddress != nil {
+ {
+ size, err := m.ReturnAddress.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintIbc(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x22
+ }
+ if len(m.DestinationChainAddress) > 0 {
+ i -= len(m.DestinationChainAddress)
+ copy(dAtA[i:], m.DestinationChainAddress)
+ i = encodeVarintIbc(dAtA, i, uint64(len(m.DestinationChainAddress)))
+ i--
+ dAtA[i] = 0x1a
+ }
+ if m.Denom != nil {
+ {
+ size, err := m.Denom.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintIbc(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.Amount != nil {
+ {
+ size, err := m.Amount.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintIbc(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *ClientData) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *ClientData) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ClientData) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.ProcessedHeight != 0 {
+ i = encodeVarintIbc(dAtA, i, uint64(m.ProcessedHeight))
+ i--
+ dAtA[i] = 0x20
+ }
+ if len(m.ProcessedTime) > 0 {
+ i -= len(m.ProcessedTime)
+ copy(dAtA[i:], m.ProcessedTime)
+ i = encodeVarintIbc(dAtA, i, uint64(len(m.ProcessedTime)))
+ i--
+ dAtA[i] = 0x1a
+ }
+ if m.ClientState != nil {
+ {
+ size, err := m.ClientState.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintIbc(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if len(m.ClientId) > 0 {
+ i -= len(m.ClientId)
+ copy(dAtA[i:], m.ClientId)
+ i = encodeVarintIbc(dAtA, i, uint64(len(m.ClientId)))
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *ClientCounter) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *ClientCounter) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ClientCounter) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Counter != 0 {
+ i = encodeVarintIbc(dAtA, i, uint64(m.Counter))
+ i--
+ dAtA[i] = 0x8
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *ConsensusState) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *ConsensusState) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ConsensusState) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.ConsensusState != nil {
+ {
+ size, err := m.ConsensusState.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintIbc(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *VerifiedHeights) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *VerifiedHeights) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *VerifiedHeights) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.Heights) > 0 {
+ for iNdEx := len(m.Heights) - 1; iNdEx >= 0; iNdEx-- {
+ {
+ size, err := m.Heights[iNdEx].MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintIbc(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *ConnectionCounter) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *ConnectionCounter) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ConnectionCounter) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Counter != 0 {
+ i = encodeVarintIbc(dAtA, i, uint64(m.Counter))
+ i--
+ dAtA[i] = 0x8
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *ClientConnections) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *ClientConnections) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ClientConnections) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.Connections) > 0 {
+ for iNdEx := len(m.Connections) - 1; iNdEx >= 0; iNdEx-- {
+ i -= len(m.Connections[iNdEx])
+ copy(dAtA[i:], m.Connections[iNdEx])
+ i = encodeVarintIbc(dAtA, i, uint64(len(m.Connections[iNdEx])))
+ i--
+ dAtA[i] = 0xa
+ }
+ }
+ return len(dAtA) - i, nil
+}
+
+func encodeVarintIbc(dAtA []byte, offset int, v uint64) int {
+ offset -= sovIbc(v)
+ base := offset
+ for v >= 1<<7 {
+ dAtA[offset] = uint8(v&0x7f | 0x80)
+ v >>= 7
+ offset++
+ }
+ dAtA[offset] = uint8(v)
+ return base
+}
+func (m *IbcAction) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.RawAction != nil {
+ l = m.RawAction.Size()
+ n += 1 + l + sovIbc(uint64(l))
+ }
+ return n
+}
+
+func (m *FungibleTokenPacketData) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ l = len(m.Denom)
+ if l > 0 {
+ n += 1 + l + sovIbc(uint64(l))
+ }
+ l = len(m.Amount)
+ if l > 0 {
+ n += 1 + l + sovIbc(uint64(l))
+ }
+ l = len(m.Sender)
+ if l > 0 {
+ n += 1 + l + sovIbc(uint64(l))
+ }
+ l = len(m.Receiver)
+ if l > 0 {
+ n += 1 + l + sovIbc(uint64(l))
+ }
+ return n
+}
+
+func (m *Ics20Withdrawal) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Amount != nil {
+ l = m.Amount.Size()
+ n += 1 + l + sovIbc(uint64(l))
+ }
+ if m.Denom != nil {
+ l = m.Denom.Size()
+ n += 1 + l + sovIbc(uint64(l))
+ }
+ l = len(m.DestinationChainAddress)
+ if l > 0 {
+ n += 1 + l + sovIbc(uint64(l))
+ }
+ if m.ReturnAddress != nil {
+ l = m.ReturnAddress.Size()
+ n += 1 + l + sovIbc(uint64(l))
+ }
+ if m.TimeoutHeight != 0 {
+ n += 1 + sovIbc(uint64(m.TimeoutHeight))
+ }
+ if m.TimeoutTime != 0 {
+ n += 1 + sovIbc(uint64(m.TimeoutTime))
+ }
+ l = len(m.SourceChannel)
+ if l > 0 {
+ n += 1 + l + sovIbc(uint64(l))
+ }
+ return n
+}
+
+func (m *ClientData) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ l = len(m.ClientId)
+ if l > 0 {
+ n += 1 + l + sovIbc(uint64(l))
+ }
+ if m.ClientState != nil {
+ l = m.ClientState.Size()
+ n += 1 + l + sovIbc(uint64(l))
+ }
+ l = len(m.ProcessedTime)
+ if l > 0 {
+ n += 1 + l + sovIbc(uint64(l))
+ }
+ if m.ProcessedHeight != 0 {
+ n += 1 + sovIbc(uint64(m.ProcessedHeight))
+ }
+ return n
+}
+
+func (m *ClientCounter) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Counter != 0 {
+ n += 1 + sovIbc(uint64(m.Counter))
+ }
+ return n
+}
+
+func (m *ConsensusState) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.ConsensusState != nil {
+ l = m.ConsensusState.Size()
+ n += 1 + l + sovIbc(uint64(l))
+ }
+ return n
+}
+
+func (m *VerifiedHeights) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if len(m.Heights) > 0 {
+ for _, e := range m.Heights {
+ l = e.Size()
+ n += 1 + l + sovIbc(uint64(l))
+ }
+ }
+ return n
+}
+
+func (m *ConnectionCounter) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Counter != 0 {
+ n += 1 + sovIbc(uint64(m.Counter))
+ }
+ return n
+}
+
+func (m *ClientConnections) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if len(m.Connections) > 0 {
+ for _, s := range m.Connections {
+ l = len(s)
+ n += 1 + l + sovIbc(uint64(l))
+ }
+ }
+ return n
+}
+
+func sovIbc(x uint64) (n int) {
+ return (math_bits.Len64(x|1) + 6) / 7
+}
+func sozIbc(x uint64) (n int) {
+ return sovIbc(uint64((x << 1) ^ uint64((int64(x) >> 63))))
+}
+func (m *IbcAction) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowIbc
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: IbcAction: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: IbcAction: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field RawAction", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowIbc
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthIbc
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthIbc
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.RawAction == nil {
+ m.RawAction = &types.Any{}
+ }
+ if err := m.RawAction.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipIbc(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthIbc
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *FungibleTokenPacketData) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowIbc
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: FungibleTokenPacketData: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: FungibleTokenPacketData: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Denom", wireType)
+ }
+ var stringLen uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowIbc
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ stringLen |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ intStringLen := int(stringLen)
+ if intStringLen < 0 {
+ return ErrInvalidLengthIbc
+ }
+ postIndex := iNdEx + intStringLen
+ if postIndex < 0 {
+ return ErrInvalidLengthIbc
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Denom = string(dAtA[iNdEx:postIndex])
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Amount", wireType)
+ }
+ var stringLen uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowIbc
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ stringLen |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ intStringLen := int(stringLen)
+ if intStringLen < 0 {
+ return ErrInvalidLengthIbc
+ }
+ postIndex := iNdEx + intStringLen
+ if postIndex < 0 {
+ return ErrInvalidLengthIbc
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Amount = string(dAtA[iNdEx:postIndex])
+ iNdEx = postIndex
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Sender", wireType)
+ }
+ var stringLen uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowIbc
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ stringLen |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ intStringLen := int(stringLen)
+ if intStringLen < 0 {
+ return ErrInvalidLengthIbc
+ }
+ postIndex := iNdEx + intStringLen
+ if postIndex < 0 {
+ return ErrInvalidLengthIbc
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Sender = string(dAtA[iNdEx:postIndex])
+ iNdEx = postIndex
+ case 4:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Receiver", wireType)
+ }
+ var stringLen uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowIbc
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ stringLen |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ intStringLen := int(stringLen)
+ if intStringLen < 0 {
+ return ErrInvalidLengthIbc
+ }
+ postIndex := iNdEx + intStringLen
+ if postIndex < 0 {
+ return ErrInvalidLengthIbc
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Receiver = string(dAtA[iNdEx:postIndex])
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipIbc(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthIbc
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *Ics20Withdrawal) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowIbc
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Ics20Withdrawal: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Ics20Withdrawal: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Amount", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowIbc
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthIbc
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthIbc
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Amount == nil {
+ m.Amount = &v1alpha1.Amount{}
+ }
+ if err := m.Amount.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Denom", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowIbc
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthIbc
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthIbc
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Denom == nil {
+ m.Denom = &v1alpha1.Denom{}
+ }
+ if err := m.Denom.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field DestinationChainAddress", wireType)
+ }
+ var stringLen uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowIbc
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ stringLen |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ intStringLen := int(stringLen)
+ if intStringLen < 0 {
+ return ErrInvalidLengthIbc
+ }
+ postIndex := iNdEx + intStringLen
+ if postIndex < 0 {
+ return ErrInvalidLengthIbc
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.DestinationChainAddress = string(dAtA[iNdEx:postIndex])
+ iNdEx = postIndex
+ case 4:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ReturnAddress", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowIbc
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthIbc
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthIbc
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.ReturnAddress == nil {
+ m.ReturnAddress = &v1alpha1.Address{}
+ }
+ if err := m.ReturnAddress.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 5:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field TimeoutHeight", wireType)
+ }
+ m.TimeoutHeight = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowIbc
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.TimeoutHeight |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 6:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field TimeoutTime", wireType)
+ }
+ m.TimeoutTime = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowIbc
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.TimeoutTime |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 7:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field SourceChannel", wireType)
+ }
+ var stringLen uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowIbc
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ stringLen |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ intStringLen := int(stringLen)
+ if intStringLen < 0 {
+ return ErrInvalidLengthIbc
+ }
+ postIndex := iNdEx + intStringLen
+ if postIndex < 0 {
+ return ErrInvalidLengthIbc
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.SourceChannel = string(dAtA[iNdEx:postIndex])
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipIbc(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthIbc
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *ClientData) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowIbc
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: ClientData: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: ClientData: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ClientId", wireType)
+ }
+ var stringLen uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowIbc
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ stringLen |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ intStringLen := int(stringLen)
+ if intStringLen < 0 {
+ return ErrInvalidLengthIbc
+ }
+ postIndex := iNdEx + intStringLen
+ if postIndex < 0 {
+ return ErrInvalidLengthIbc
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.ClientId = string(dAtA[iNdEx:postIndex])
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ClientState", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowIbc
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthIbc
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthIbc
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.ClientState == nil {
+ m.ClientState = &types.Any{}
+ }
+ if err := m.ClientState.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ProcessedTime", wireType)
+ }
+ var stringLen uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowIbc
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ stringLen |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ intStringLen := int(stringLen)
+ if intStringLen < 0 {
+ return ErrInvalidLengthIbc
+ }
+ postIndex := iNdEx + intStringLen
+ if postIndex < 0 {
+ return ErrInvalidLengthIbc
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.ProcessedTime = string(dAtA[iNdEx:postIndex])
+ iNdEx = postIndex
+ case 4:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ProcessedHeight", wireType)
+ }
+ m.ProcessedHeight = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowIbc
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.ProcessedHeight |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ default:
+ iNdEx = preIndex
+ skippy, err := skipIbc(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthIbc
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *ClientCounter) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowIbc
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: ClientCounter: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: ClientCounter: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Counter", wireType)
+ }
+ m.Counter = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowIbc
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.Counter |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ default:
+ iNdEx = preIndex
+ skippy, err := skipIbc(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthIbc
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *ConsensusState) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowIbc
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: ConsensusState: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: ConsensusState: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ConsensusState", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowIbc
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthIbc
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthIbc
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.ConsensusState == nil {
+ m.ConsensusState = &types.Any{}
+ }
+ if err := m.ConsensusState.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipIbc(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthIbc
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *VerifiedHeights) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowIbc
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: VerifiedHeights: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: VerifiedHeights: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Heights", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowIbc
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthIbc
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthIbc
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Heights = append(m.Heights, &types1.Height{})
+ if err := m.Heights[len(m.Heights)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipIbc(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthIbc
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *ConnectionCounter) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowIbc
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: ConnectionCounter: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: ConnectionCounter: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Counter", wireType)
+ }
+ m.Counter = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowIbc
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.Counter |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ default:
+ iNdEx = preIndex
+ skippy, err := skipIbc(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthIbc
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *ClientConnections) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowIbc
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: ClientConnections: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: ClientConnections: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Connections", wireType)
+ }
+ var stringLen uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowIbc
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ stringLen |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ intStringLen := int(stringLen)
+ if intStringLen < 0 {
+ return ErrInvalidLengthIbc
+ }
+ postIndex := iNdEx + intStringLen
+ if postIndex < 0 {
+ return ErrInvalidLengthIbc
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Connections = append(m.Connections, string(dAtA[iNdEx:postIndex]))
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipIbc(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthIbc
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func skipIbc(dAtA []byte) (n int, err error) {
+ l := len(dAtA)
+ iNdEx := 0
+ depth := 0
+ for iNdEx < l {
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return 0, ErrIntOverflowIbc
+ }
+ if iNdEx >= l {
+ return 0, io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= (uint64(b) & 0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ wireType := int(wire & 0x7)
+ switch wireType {
+ case 0:
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return 0, ErrIntOverflowIbc
+ }
+ if iNdEx >= l {
+ return 0, io.ErrUnexpectedEOF
+ }
+ iNdEx++
+ if dAtA[iNdEx-1] < 0x80 {
+ break
+ }
+ }
+ case 1:
+ iNdEx += 8
+ case 2:
+ var length int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return 0, ErrIntOverflowIbc
+ }
+ if iNdEx >= l {
+ return 0, io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ length |= (int(b) & 0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if length < 0 {
+ return 0, ErrInvalidLengthIbc
+ }
+ iNdEx += length
+ case 3:
+ depth++
+ case 4:
+ if depth == 0 {
+ return 0, ErrUnexpectedEndOfGroupIbc
+ }
+ depth--
+ case 5:
+ iNdEx += 4
+ default:
+ return 0, fmt.Errorf("proto: illegal wireType %d", wireType)
+ }
+ if iNdEx < 0 {
+ return 0, ErrInvalidLengthIbc
+ }
+ if depth == 0 {
+ return iNdEx, nil
+ }
+ }
+ return 0, io.ErrUnexpectedEOF
+}
+
+var (
+ ErrInvalidLengthIbc = fmt.Errorf("proto: negative length found during unmarshaling")
+ ErrIntOverflowIbc = fmt.Errorf("proto: integer overflow")
+ ErrUnexpectedEndOfGroupIbc = fmt.Errorf("proto: unexpected end of group")
+)
diff --git a/relayer/chains/penumbra/core/stake/v1alpha1/stake.pb.go b/relayer/chains/penumbra/core/stake/v1alpha1/stake.pb.go
new file mode 100644
index 000000000..690e79f23
--- /dev/null
+++ b/relayer/chains/penumbra/core/stake/v1alpha1/stake.pb.go
@@ -0,0 +1,6135 @@
+// Code generated by protoc-gen-gogo. DO NOT EDIT.
+// source: penumbra/core/stake/v1alpha1/stake.proto
+
+package stakev1alpha1
+
+import (
+ fmt "fmt"
+ proto "github.com/cosmos/gogoproto/proto"
+ v1alpha1 "github.com/cosmos/relayer/v2/relayer/chains/penumbra/core/crypto/v1alpha1"
+ io "io"
+ math "math"
+ math_bits "math/bits"
+)
+
+// Reference imports to suppress errors if they are not otherwise used.
+var _ = proto.Marshal
+var _ = fmt.Errorf
+var _ = math.Inf
+
+// This is a compile-time assertion to ensure that this generated file
+// is compatible with the proto package it is being compiled against.
+// A compilation error at this line likely means your copy of the
+// proto package needs to be updated.
+const _ = proto.GoGoProtoPackageIsVersion3 // please upgrade the proto package
+
+type BondingState_BondingStateEnum int32
+
+const (
+ BondingState_BONDING_STATE_ENUM_UNSPECIFIED BondingState_BondingStateEnum = 0
+ BondingState_BONDING_STATE_ENUM_BONDED BondingState_BondingStateEnum = 1
+ BondingState_BONDING_STATE_ENUM_UNBONDING BondingState_BondingStateEnum = 2
+ BondingState_BONDING_STATE_ENUM_UNBONDED BondingState_BondingStateEnum = 3
+)
+
+var BondingState_BondingStateEnum_name = map[int32]string{
+ 0: "BONDING_STATE_ENUM_UNSPECIFIED",
+ 1: "BONDING_STATE_ENUM_BONDED",
+ 2: "BONDING_STATE_ENUM_UNBONDING",
+ 3: "BONDING_STATE_ENUM_UNBONDED",
+}
+
+var BondingState_BondingStateEnum_value = map[string]int32{
+ "BONDING_STATE_ENUM_UNSPECIFIED": 0,
+ "BONDING_STATE_ENUM_BONDED": 1,
+ "BONDING_STATE_ENUM_UNBONDING": 2,
+ "BONDING_STATE_ENUM_UNBONDED": 3,
+}
+
+func (x BondingState_BondingStateEnum) String() string {
+ return proto.EnumName(BondingState_BondingStateEnum_name, int32(x))
+}
+
+func (BondingState_BondingStateEnum) EnumDescriptor() ([]byte, []int) {
+ return fileDescriptor_022d012c8e7b3ca5, []int{6, 0}
+}
+
+type ValidatorState_ValidatorStateEnum int32
+
+const (
+ ValidatorState_VALIDATOR_STATE_ENUM_UNSPECIFIED ValidatorState_ValidatorStateEnum = 0
+ ValidatorState_VALIDATOR_STATE_ENUM_INACTIVE ValidatorState_ValidatorStateEnum = 1
+ ValidatorState_VALIDATOR_STATE_ENUM_ACTIVE ValidatorState_ValidatorStateEnum = 2
+ ValidatorState_VALIDATOR_STATE_ENUM_JAILED ValidatorState_ValidatorStateEnum = 3
+ ValidatorState_VALIDATOR_STATE_ENUM_TOMBSTONED ValidatorState_ValidatorStateEnum = 4
+ ValidatorState_VALIDATOR_STATE_ENUM_DISABLED ValidatorState_ValidatorStateEnum = 5
+)
+
+var ValidatorState_ValidatorStateEnum_name = map[int32]string{
+ 0: "VALIDATOR_STATE_ENUM_UNSPECIFIED",
+ 1: "VALIDATOR_STATE_ENUM_INACTIVE",
+ 2: "VALIDATOR_STATE_ENUM_ACTIVE",
+ 3: "VALIDATOR_STATE_ENUM_JAILED",
+ 4: "VALIDATOR_STATE_ENUM_TOMBSTONED",
+ 5: "VALIDATOR_STATE_ENUM_DISABLED",
+}
+
+var ValidatorState_ValidatorStateEnum_value = map[string]int32{
+ "VALIDATOR_STATE_ENUM_UNSPECIFIED": 0,
+ "VALIDATOR_STATE_ENUM_INACTIVE": 1,
+ "VALIDATOR_STATE_ENUM_ACTIVE": 2,
+ "VALIDATOR_STATE_ENUM_JAILED": 3,
+ "VALIDATOR_STATE_ENUM_TOMBSTONED": 4,
+ "VALIDATOR_STATE_ENUM_DISABLED": 5,
+}
+
+func (x ValidatorState_ValidatorStateEnum) String() string {
+ return proto.EnumName(ValidatorState_ValidatorStateEnum_name, int32(x))
+}
+
+func (ValidatorState_ValidatorStateEnum) EnumDescriptor() ([]byte, []int) {
+ return fileDescriptor_022d012c8e7b3ca5, []int{7, 0}
+}
+
+// Describes a validator's configuration data.
+type Validator struct {
+ // The validator's identity verification key.
+ IdentityKey *v1alpha1.IdentityKey `protobuf:"bytes,1,opt,name=identity_key,json=identityKey,proto3" json:"identity_key,omitempty"`
+ // The validator's consensus pubkey for use in Tendermint (Ed25519).
+ ConsensusKey []byte `protobuf:"bytes,2,opt,name=consensus_key,json=consensusKey,proto3" json:"consensus_key,omitempty"`
+ // The validator's (human-readable) name.
+ Name string `protobuf:"bytes,3,opt,name=name,proto3" json:"name,omitempty"`
+ // The validator's website.
+ Website string `protobuf:"bytes,4,opt,name=website,proto3" json:"website,omitempty"`
+ // The validator's description.
+ Description string `protobuf:"bytes,5,opt,name=description,proto3" json:"description,omitempty"`
+ // Whether the validator is enabled or not.
+ //
+ // Disabled validators cannot be delegated to, and immediately begin unbonding.
+ Enabled bool `protobuf:"varint,8,opt,name=enabled,proto3" json:"enabled,omitempty"`
+ // A list of funding streams describing the validator's commission.
+ FundingStreams []*FundingStream `protobuf:"bytes,6,rep,name=funding_streams,json=fundingStreams,proto3" json:"funding_streams,omitempty"`
+ // The sequence number determines which validator data takes priority, and
+ // prevents replay attacks. The chain only accepts new validator definitions
+ // with increasing sequence numbers.
+ SequenceNumber uint32 `protobuf:"varint,7,opt,name=sequence_number,json=sequenceNumber,proto3" json:"sequence_number,omitempty"`
+ // The validator's governance key.
+ GovernanceKey *v1alpha1.GovernanceKey `protobuf:"bytes,9,opt,name=governance_key,json=governanceKey,proto3" json:"governance_key,omitempty"`
+}
+
+func (m *Validator) Reset() { *m = Validator{} }
+func (m *Validator) String() string { return proto.CompactTextString(m) }
+func (*Validator) ProtoMessage() {}
+func (*Validator) Descriptor() ([]byte, []int) {
+ return fileDescriptor_022d012c8e7b3ca5, []int{0}
+}
+func (m *Validator) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *Validator) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_Validator.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *Validator) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_Validator.Merge(m, src)
+}
+func (m *Validator) XXX_Size() int {
+ return m.Size()
+}
+func (m *Validator) XXX_DiscardUnknown() {
+ xxx_messageInfo_Validator.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_Validator proto.InternalMessageInfo
+
+func (m *Validator) GetIdentityKey() *v1alpha1.IdentityKey {
+ if m != nil {
+ return m.IdentityKey
+ }
+ return nil
+}
+
+func (m *Validator) GetConsensusKey() []byte {
+ if m != nil {
+ return m.ConsensusKey
+ }
+ return nil
+}
+
+func (m *Validator) GetName() string {
+ if m != nil {
+ return m.Name
+ }
+ return ""
+}
+
+func (m *Validator) GetWebsite() string {
+ if m != nil {
+ return m.Website
+ }
+ return ""
+}
+
+func (m *Validator) GetDescription() string {
+ if m != nil {
+ return m.Description
+ }
+ return ""
+}
+
+func (m *Validator) GetEnabled() bool {
+ if m != nil {
+ return m.Enabled
+ }
+ return false
+}
+
+func (m *Validator) GetFundingStreams() []*FundingStream {
+ if m != nil {
+ return m.FundingStreams
+ }
+ return nil
+}
+
+func (m *Validator) GetSequenceNumber() uint32 {
+ if m != nil {
+ return m.SequenceNumber
+ }
+ return 0
+}
+
+func (m *Validator) GetGovernanceKey() *v1alpha1.GovernanceKey {
+ if m != nil {
+ return m.GovernanceKey
+ }
+ return nil
+}
+
+// For storing the list of keys of known validators.
+type ValidatorList struct {
+ ValidatorKeys []*v1alpha1.IdentityKey `protobuf:"bytes,1,rep,name=validator_keys,json=validatorKeys,proto3" json:"validator_keys,omitempty"`
+}
+
+func (m *ValidatorList) Reset() { *m = ValidatorList{} }
+func (m *ValidatorList) String() string { return proto.CompactTextString(m) }
+func (*ValidatorList) ProtoMessage() {}
+func (*ValidatorList) Descriptor() ([]byte, []int) {
+ return fileDescriptor_022d012c8e7b3ca5, []int{1}
+}
+func (m *ValidatorList) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *ValidatorList) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_ValidatorList.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *ValidatorList) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_ValidatorList.Merge(m, src)
+}
+func (m *ValidatorList) XXX_Size() int {
+ return m.Size()
+}
+func (m *ValidatorList) XXX_DiscardUnknown() {
+ xxx_messageInfo_ValidatorList.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_ValidatorList proto.InternalMessageInfo
+
+func (m *ValidatorList) GetValidatorKeys() []*v1alpha1.IdentityKey {
+ if m != nil {
+ return m.ValidatorKeys
+ }
+ return nil
+}
+
+// A portion of a validator's commission.
+type FundingStream struct {
+ // The recipient of the funding stream.
+ //
+ // Types that are valid to be assigned to Recipient:
+ // *FundingStream_ToAddress_
+ // *FundingStream_ToDao_
+ Recipient isFundingStream_Recipient `protobuf_oneof:"recipient"`
+}
+
+func (m *FundingStream) Reset() { *m = FundingStream{} }
+func (m *FundingStream) String() string { return proto.CompactTextString(m) }
+func (*FundingStream) ProtoMessage() {}
+func (*FundingStream) Descriptor() ([]byte, []int) {
+ return fileDescriptor_022d012c8e7b3ca5, []int{2}
+}
+func (m *FundingStream) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *FundingStream) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_FundingStream.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *FundingStream) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_FundingStream.Merge(m, src)
+}
+func (m *FundingStream) XXX_Size() int {
+ return m.Size()
+}
+func (m *FundingStream) XXX_DiscardUnknown() {
+ xxx_messageInfo_FundingStream.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_FundingStream proto.InternalMessageInfo
+
+type isFundingStream_Recipient interface {
+ isFundingStream_Recipient()
+ MarshalTo([]byte) (int, error)
+ Size() int
+}
+
+type FundingStream_ToAddress_ struct {
+ ToAddress *FundingStream_ToAddress `protobuf:"bytes,1,opt,name=to_address,json=toAddress,proto3,oneof" json:"to_address,omitempty"`
+}
+type FundingStream_ToDao_ struct {
+ ToDao *FundingStream_ToDao `protobuf:"bytes,2,opt,name=to_dao,json=toDao,proto3,oneof" json:"to_dao,omitempty"`
+}
+
+func (*FundingStream_ToAddress_) isFundingStream_Recipient() {}
+func (*FundingStream_ToDao_) isFundingStream_Recipient() {}
+
+func (m *FundingStream) GetRecipient() isFundingStream_Recipient {
+ if m != nil {
+ return m.Recipient
+ }
+ return nil
+}
+
+func (m *FundingStream) GetToAddress() *FundingStream_ToAddress {
+ if x, ok := m.GetRecipient().(*FundingStream_ToAddress_); ok {
+ return x.ToAddress
+ }
+ return nil
+}
+
+func (m *FundingStream) GetToDao() *FundingStream_ToDao {
+ if x, ok := m.GetRecipient().(*FundingStream_ToDao_); ok {
+ return x.ToDao
+ }
+ return nil
+}
+
+// XXX_OneofWrappers is for the internal use of the proto package.
+func (*FundingStream) XXX_OneofWrappers() []interface{} {
+ return []interface{}{
+ (*FundingStream_ToAddress_)(nil),
+ (*FundingStream_ToDao_)(nil),
+ }
+}
+
+type FundingStream_ToAddress struct {
+ // The destination address for the funding stream.
+ Address string `protobuf:"bytes,1,opt,name=address,proto3" json:"address,omitempty"`
+ // The portion of the staking reward for the entire delegation pool
+ // allocated to this funding stream, specified in basis points.
+ RateBps uint32 `protobuf:"varint,2,opt,name=rate_bps,json=rateBps,proto3" json:"rate_bps,omitempty"`
+}
+
+func (m *FundingStream_ToAddress) Reset() { *m = FundingStream_ToAddress{} }
+func (m *FundingStream_ToAddress) String() string { return proto.CompactTextString(m) }
+func (*FundingStream_ToAddress) ProtoMessage() {}
+func (*FundingStream_ToAddress) Descriptor() ([]byte, []int) {
+ return fileDescriptor_022d012c8e7b3ca5, []int{2, 0}
+}
+func (m *FundingStream_ToAddress) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *FundingStream_ToAddress) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_FundingStream_ToAddress.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *FundingStream_ToAddress) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_FundingStream_ToAddress.Merge(m, src)
+}
+func (m *FundingStream_ToAddress) XXX_Size() int {
+ return m.Size()
+}
+func (m *FundingStream_ToAddress) XXX_DiscardUnknown() {
+ xxx_messageInfo_FundingStream_ToAddress.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_FundingStream_ToAddress proto.InternalMessageInfo
+
+func (m *FundingStream_ToAddress) GetAddress() string {
+ if m != nil {
+ return m.Address
+ }
+ return ""
+}
+
+func (m *FundingStream_ToAddress) GetRateBps() uint32 {
+ if m != nil {
+ return m.RateBps
+ }
+ return 0
+}
+
+type FundingStream_ToDao struct {
+ // The portion of the staking reward for the entire delegation pool
+ // allocated to this funding stream, specified in basis points.
+ RateBps uint32 `protobuf:"varint,2,opt,name=rate_bps,json=rateBps,proto3" json:"rate_bps,omitempty"`
+}
+
+func (m *FundingStream_ToDao) Reset() { *m = FundingStream_ToDao{} }
+func (m *FundingStream_ToDao) String() string { return proto.CompactTextString(m) }
+func (*FundingStream_ToDao) ProtoMessage() {}
+func (*FundingStream_ToDao) Descriptor() ([]byte, []int) {
+ return fileDescriptor_022d012c8e7b3ca5, []int{2, 1}
+}
+func (m *FundingStream_ToDao) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *FundingStream_ToDao) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_FundingStream_ToDao.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *FundingStream_ToDao) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_FundingStream_ToDao.Merge(m, src)
+}
+func (m *FundingStream_ToDao) XXX_Size() int {
+ return m.Size()
+}
+func (m *FundingStream_ToDao) XXX_DiscardUnknown() {
+ xxx_messageInfo_FundingStream_ToDao.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_FundingStream_ToDao proto.InternalMessageInfo
+
+func (m *FundingStream_ToDao) GetRateBps() uint32 {
+ if m != nil {
+ return m.RateBps
+ }
+ return 0
+}
+
+// Describes the reward and exchange rates and voting power for a validator in some epoch.
+type RateData struct {
+ IdentityKey *v1alpha1.IdentityKey `protobuf:"bytes,1,opt,name=identity_key,json=identityKey,proto3" json:"identity_key,omitempty"`
+ EpochIndex uint64 `protobuf:"varint,2,opt,name=epoch_index,json=epochIndex,proto3" json:"epoch_index,omitempty"`
+ ValidatorRewardRate uint64 `protobuf:"varint,4,opt,name=validator_reward_rate,json=validatorRewardRate,proto3" json:"validator_reward_rate,omitempty"`
+ ValidatorExchangeRate uint64 `protobuf:"varint,5,opt,name=validator_exchange_rate,json=validatorExchangeRate,proto3" json:"validator_exchange_rate,omitempty"`
+}
+
+func (m *RateData) Reset() { *m = RateData{} }
+func (m *RateData) String() string { return proto.CompactTextString(m) }
+func (*RateData) ProtoMessage() {}
+func (*RateData) Descriptor() ([]byte, []int) {
+ return fileDescriptor_022d012c8e7b3ca5, []int{3}
+}
+func (m *RateData) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *RateData) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_RateData.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *RateData) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_RateData.Merge(m, src)
+}
+func (m *RateData) XXX_Size() int {
+ return m.Size()
+}
+func (m *RateData) XXX_DiscardUnknown() {
+ xxx_messageInfo_RateData.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_RateData proto.InternalMessageInfo
+
+func (m *RateData) GetIdentityKey() *v1alpha1.IdentityKey {
+ if m != nil {
+ return m.IdentityKey
+ }
+ return nil
+}
+
+func (m *RateData) GetEpochIndex() uint64 {
+ if m != nil {
+ return m.EpochIndex
+ }
+ return 0
+}
+
+func (m *RateData) GetValidatorRewardRate() uint64 {
+ if m != nil {
+ return m.ValidatorRewardRate
+ }
+ return 0
+}
+
+func (m *RateData) GetValidatorExchangeRate() uint64 {
+ if m != nil {
+ return m.ValidatorExchangeRate
+ }
+ return 0
+}
+
+// Describes the base reward and exchange rates in some epoch.
+type BaseRateData struct {
+ EpochIndex uint64 `protobuf:"varint,1,opt,name=epoch_index,json=epochIndex,proto3" json:"epoch_index,omitempty"`
+ BaseRewardRate uint64 `protobuf:"varint,2,opt,name=base_reward_rate,json=baseRewardRate,proto3" json:"base_reward_rate,omitempty"`
+ BaseExchangeRate uint64 `protobuf:"varint,3,opt,name=base_exchange_rate,json=baseExchangeRate,proto3" json:"base_exchange_rate,omitempty"`
+}
+
+func (m *BaseRateData) Reset() { *m = BaseRateData{} }
+func (m *BaseRateData) String() string { return proto.CompactTextString(m) }
+func (*BaseRateData) ProtoMessage() {}
+func (*BaseRateData) Descriptor() ([]byte, []int) {
+ return fileDescriptor_022d012c8e7b3ca5, []int{4}
+}
+func (m *BaseRateData) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *BaseRateData) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_BaseRateData.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *BaseRateData) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_BaseRateData.Merge(m, src)
+}
+func (m *BaseRateData) XXX_Size() int {
+ return m.Size()
+}
+func (m *BaseRateData) XXX_DiscardUnknown() {
+ xxx_messageInfo_BaseRateData.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_BaseRateData proto.InternalMessageInfo
+
+func (m *BaseRateData) GetEpochIndex() uint64 {
+ if m != nil {
+ return m.EpochIndex
+ }
+ return 0
+}
+
+func (m *BaseRateData) GetBaseRewardRate() uint64 {
+ if m != nil {
+ return m.BaseRewardRate
+ }
+ return 0
+}
+
+func (m *BaseRateData) GetBaseExchangeRate() uint64 {
+ if m != nil {
+ return m.BaseExchangeRate
+ }
+ return 0
+}
+
+// Describes the current state of a validator on-chain
+type ValidatorStatus struct {
+ IdentityKey *v1alpha1.IdentityKey `protobuf:"bytes,1,opt,name=identity_key,json=identityKey,proto3" json:"identity_key,omitempty"`
+ State *ValidatorState `protobuf:"bytes,2,opt,name=state,proto3" json:"state,omitempty"`
+ VotingPower uint64 `protobuf:"varint,3,opt,name=voting_power,json=votingPower,proto3" json:"voting_power,omitempty"`
+ BondingState *BondingState `protobuf:"bytes,4,opt,name=bonding_state,json=bondingState,proto3" json:"bonding_state,omitempty"`
+}
+
+func (m *ValidatorStatus) Reset() { *m = ValidatorStatus{} }
+func (m *ValidatorStatus) String() string { return proto.CompactTextString(m) }
+func (*ValidatorStatus) ProtoMessage() {}
+func (*ValidatorStatus) Descriptor() ([]byte, []int) {
+ return fileDescriptor_022d012c8e7b3ca5, []int{5}
+}
+func (m *ValidatorStatus) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *ValidatorStatus) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_ValidatorStatus.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *ValidatorStatus) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_ValidatorStatus.Merge(m, src)
+}
+func (m *ValidatorStatus) XXX_Size() int {
+ return m.Size()
+}
+func (m *ValidatorStatus) XXX_DiscardUnknown() {
+ xxx_messageInfo_ValidatorStatus.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_ValidatorStatus proto.InternalMessageInfo
+
+func (m *ValidatorStatus) GetIdentityKey() *v1alpha1.IdentityKey {
+ if m != nil {
+ return m.IdentityKey
+ }
+ return nil
+}
+
+func (m *ValidatorStatus) GetState() *ValidatorState {
+ if m != nil {
+ return m.State
+ }
+ return nil
+}
+
+func (m *ValidatorStatus) GetVotingPower() uint64 {
+ if m != nil {
+ return m.VotingPower
+ }
+ return 0
+}
+
+func (m *ValidatorStatus) GetBondingState() *BondingState {
+ if m != nil {
+ return m.BondingState
+ }
+ return nil
+}
+
+// Describes the unbonding state of a validator's stake pool.
+type BondingState struct {
+ State BondingState_BondingStateEnum `protobuf:"varint,1,opt,name=state,proto3,enum=penumbra.core.stake.v1alpha1.BondingState_BondingStateEnum" json:"state,omitempty"`
+ // Types that are valid to be assigned to XUnbondingEpoch:
+ // *BondingState_UnbondingEpoch
+ XUnbondingEpoch isBondingState_XUnbondingEpoch `protobuf_oneof:"_unbonding_epoch"`
+}
+
+func (m *BondingState) Reset() { *m = BondingState{} }
+func (m *BondingState) String() string { return proto.CompactTextString(m) }
+func (*BondingState) ProtoMessage() {}
+func (*BondingState) Descriptor() ([]byte, []int) {
+ return fileDescriptor_022d012c8e7b3ca5, []int{6}
+}
+func (m *BondingState) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *BondingState) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_BondingState.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *BondingState) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_BondingState.Merge(m, src)
+}
+func (m *BondingState) XXX_Size() int {
+ return m.Size()
+}
+func (m *BondingState) XXX_DiscardUnknown() {
+ xxx_messageInfo_BondingState.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_BondingState proto.InternalMessageInfo
+
+type isBondingState_XUnbondingEpoch interface {
+ isBondingState_XUnbondingEpoch()
+ MarshalTo([]byte) (int, error)
+ Size() int
+}
+
+type BondingState_UnbondingEpoch struct {
+ UnbondingEpoch uint64 `protobuf:"varint,2,opt,name=unbonding_epoch,json=unbondingEpoch,proto3,oneof" json:"unbonding_epoch,omitempty"`
+}
+
+func (*BondingState_UnbondingEpoch) isBondingState_XUnbondingEpoch() {}
+
+func (m *BondingState) GetXUnbondingEpoch() isBondingState_XUnbondingEpoch {
+ if m != nil {
+ return m.XUnbondingEpoch
+ }
+ return nil
+}
+
+func (m *BondingState) GetState() BondingState_BondingStateEnum {
+ if m != nil {
+ return m.State
+ }
+ return BondingState_BONDING_STATE_ENUM_UNSPECIFIED
+}
+
+func (m *BondingState) GetUnbondingEpoch() uint64 {
+ if x, ok := m.GetXUnbondingEpoch().(*BondingState_UnbondingEpoch); ok {
+ return x.UnbondingEpoch
+ }
+ return 0
+}
+
+// XXX_OneofWrappers is for the internal use of the proto package.
+func (*BondingState) XXX_OneofWrappers() []interface{} {
+ return []interface{}{
+ (*BondingState_UnbondingEpoch)(nil),
+ }
+}
+
+// Describes the state of a validator
+type ValidatorState struct {
+ State ValidatorState_ValidatorStateEnum `protobuf:"varint,1,opt,name=state,proto3,enum=penumbra.core.stake.v1alpha1.ValidatorState_ValidatorStateEnum" json:"state,omitempty"`
+}
+
+func (m *ValidatorState) Reset() { *m = ValidatorState{} }
+func (m *ValidatorState) String() string { return proto.CompactTextString(m) }
+func (*ValidatorState) ProtoMessage() {}
+func (*ValidatorState) Descriptor() ([]byte, []int) {
+ return fileDescriptor_022d012c8e7b3ca5, []int{7}
+}
+func (m *ValidatorState) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *ValidatorState) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_ValidatorState.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *ValidatorState) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_ValidatorState.Merge(m, src)
+}
+func (m *ValidatorState) XXX_Size() int {
+ return m.Size()
+}
+func (m *ValidatorState) XXX_DiscardUnknown() {
+ xxx_messageInfo_ValidatorState.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_ValidatorState proto.InternalMessageInfo
+
+func (m *ValidatorState) GetState() ValidatorState_ValidatorStateEnum {
+ if m != nil {
+ return m.State
+ }
+ return ValidatorState_VALIDATOR_STATE_ENUM_UNSPECIFIED
+}
+
+// Combines all validator info into a single packet.
+type ValidatorInfo struct {
+ Validator *Validator `protobuf:"bytes,1,opt,name=validator,proto3" json:"validator,omitempty"`
+ Status *ValidatorStatus `protobuf:"bytes,2,opt,name=status,proto3" json:"status,omitempty"`
+ RateData *RateData `protobuf:"bytes,3,opt,name=rate_data,json=rateData,proto3" json:"rate_data,omitempty"`
+}
+
+func (m *ValidatorInfo) Reset() { *m = ValidatorInfo{} }
+func (m *ValidatorInfo) String() string { return proto.CompactTextString(m) }
+func (*ValidatorInfo) ProtoMessage() {}
+func (*ValidatorInfo) Descriptor() ([]byte, []int) {
+ return fileDescriptor_022d012c8e7b3ca5, []int{8}
+}
+func (m *ValidatorInfo) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *ValidatorInfo) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_ValidatorInfo.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *ValidatorInfo) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_ValidatorInfo.Merge(m, src)
+}
+func (m *ValidatorInfo) XXX_Size() int {
+ return m.Size()
+}
+func (m *ValidatorInfo) XXX_DiscardUnknown() {
+ xxx_messageInfo_ValidatorInfo.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_ValidatorInfo proto.InternalMessageInfo
+
+func (m *ValidatorInfo) GetValidator() *Validator {
+ if m != nil {
+ return m.Validator
+ }
+ return nil
+}
+
+func (m *ValidatorInfo) GetStatus() *ValidatorStatus {
+ if m != nil {
+ return m.Status
+ }
+ return nil
+}
+
+func (m *ValidatorInfo) GetRateData() *RateData {
+ if m != nil {
+ return m.RateData
+ }
+ return nil
+}
+
+// A transaction action (re)defining a validator.
+type ValidatorDefinition struct {
+ // The configuration data for the validator.
+ Validator *Validator `protobuf:"bytes,1,opt,name=validator,proto3" json:"validator,omitempty"`
+ // A signature by the validator's identity key over the validator data.
+ AuthSig []byte `protobuf:"bytes,2,opt,name=auth_sig,json=authSig,proto3" json:"auth_sig,omitempty"`
+}
+
+func (m *ValidatorDefinition) Reset() { *m = ValidatorDefinition{} }
+func (m *ValidatorDefinition) String() string { return proto.CompactTextString(m) }
+func (*ValidatorDefinition) ProtoMessage() {}
+func (*ValidatorDefinition) Descriptor() ([]byte, []int) {
+ return fileDescriptor_022d012c8e7b3ca5, []int{9}
+}
+func (m *ValidatorDefinition) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *ValidatorDefinition) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_ValidatorDefinition.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *ValidatorDefinition) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_ValidatorDefinition.Merge(m, src)
+}
+func (m *ValidatorDefinition) XXX_Size() int {
+ return m.Size()
+}
+func (m *ValidatorDefinition) XXX_DiscardUnknown() {
+ xxx_messageInfo_ValidatorDefinition.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_ValidatorDefinition proto.InternalMessageInfo
+
+func (m *ValidatorDefinition) GetValidator() *Validator {
+ if m != nil {
+ return m.Validator
+ }
+ return nil
+}
+
+func (m *ValidatorDefinition) GetAuthSig() []byte {
+ if m != nil {
+ return m.AuthSig
+ }
+ return nil
+}
+
+// A transaction action adding stake to a validator's delegation pool.
+type Delegate struct {
+ // The identity key of the validator to delegate to.
+ ValidatorIdentity *v1alpha1.IdentityKey `protobuf:"bytes,1,opt,name=validator_identity,json=validatorIdentity,proto3" json:"validator_identity,omitempty"`
+ // The index of the epoch in which this delegation was performed.
+ // The delegation takes effect in the next epoch.
+ EpochIndex uint64 `protobuf:"varint,2,opt,name=epoch_index,json=epochIndex,proto3" json:"epoch_index,omitempty"`
+ // The delegation amount, in units of unbonded stake.
+ // TODO: use flow aggregation to hide this, replacing it with bytes amount_ciphertext;
+ UnbondedAmount *v1alpha1.Amount `protobuf:"bytes,3,opt,name=unbonded_amount,json=unbondedAmount,proto3" json:"unbonded_amount,omitempty"`
+ // The amount of delegation tokens produced by this action.
+ //
+ // This is implied by the validator's exchange rate in the specified epoch
+ // (and should be checked in transaction validation!), but including it allows
+ // stateless verification that the transaction is internally consistent.
+ DelegationAmount *v1alpha1.Amount `protobuf:"bytes,4,opt,name=delegation_amount,json=delegationAmount,proto3" json:"delegation_amount,omitempty"`
+}
+
+func (m *Delegate) Reset() { *m = Delegate{} }
+func (m *Delegate) String() string { return proto.CompactTextString(m) }
+func (*Delegate) ProtoMessage() {}
+func (*Delegate) Descriptor() ([]byte, []int) {
+ return fileDescriptor_022d012c8e7b3ca5, []int{10}
+}
+func (m *Delegate) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *Delegate) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_Delegate.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *Delegate) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_Delegate.Merge(m, src)
+}
+func (m *Delegate) XXX_Size() int {
+ return m.Size()
+}
+func (m *Delegate) XXX_DiscardUnknown() {
+ xxx_messageInfo_Delegate.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_Delegate proto.InternalMessageInfo
+
+func (m *Delegate) GetValidatorIdentity() *v1alpha1.IdentityKey {
+ if m != nil {
+ return m.ValidatorIdentity
+ }
+ return nil
+}
+
+func (m *Delegate) GetEpochIndex() uint64 {
+ if m != nil {
+ return m.EpochIndex
+ }
+ return 0
+}
+
+func (m *Delegate) GetUnbondedAmount() *v1alpha1.Amount {
+ if m != nil {
+ return m.UnbondedAmount
+ }
+ return nil
+}
+
+func (m *Delegate) GetDelegationAmount() *v1alpha1.Amount {
+ if m != nil {
+ return m.DelegationAmount
+ }
+ return nil
+}
+
+// A transaction action withdrawing stake from a validator's delegation pool.
+type Undelegate struct {
+ // The identity key of the validator to undelegate from.
+ ValidatorIdentity *v1alpha1.IdentityKey `protobuf:"bytes,1,opt,name=validator_identity,json=validatorIdentity,proto3" json:"validator_identity,omitempty"`
+ // The index of the epoch in which this undelegation was performed.
+ StartEpochIndex uint64 `protobuf:"varint,2,opt,name=start_epoch_index,json=startEpochIndex,proto3" json:"start_epoch_index,omitempty"`
+ // The amount to undelegate, in units of unbonding tokens.
+ UnbondedAmount *v1alpha1.Amount `protobuf:"bytes,3,opt,name=unbonded_amount,json=unbondedAmount,proto3" json:"unbonded_amount,omitempty"`
+ // The amount of delegation tokens consumed by this action.
+ //
+ // This is implied by the validator's exchange rate in the specified epoch
+ // (and should be checked in transaction validation!), but including it allows
+ // stateless verification that the transaction is internally consistent.
+ DelegationAmount *v1alpha1.Amount `protobuf:"bytes,4,opt,name=delegation_amount,json=delegationAmount,proto3" json:"delegation_amount,omitempty"`
+}
+
+func (m *Undelegate) Reset() { *m = Undelegate{} }
+func (m *Undelegate) String() string { return proto.CompactTextString(m) }
+func (*Undelegate) ProtoMessage() {}
+func (*Undelegate) Descriptor() ([]byte, []int) {
+ return fileDescriptor_022d012c8e7b3ca5, []int{11}
+}
+func (m *Undelegate) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *Undelegate) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_Undelegate.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *Undelegate) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_Undelegate.Merge(m, src)
+}
+func (m *Undelegate) XXX_Size() int {
+ return m.Size()
+}
+func (m *Undelegate) XXX_DiscardUnknown() {
+ xxx_messageInfo_Undelegate.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_Undelegate proto.InternalMessageInfo
+
+func (m *Undelegate) GetValidatorIdentity() *v1alpha1.IdentityKey {
+ if m != nil {
+ return m.ValidatorIdentity
+ }
+ return nil
+}
+
+func (m *Undelegate) GetStartEpochIndex() uint64 {
+ if m != nil {
+ return m.StartEpochIndex
+ }
+ return 0
+}
+
+func (m *Undelegate) GetUnbondedAmount() *v1alpha1.Amount {
+ if m != nil {
+ return m.UnbondedAmount
+ }
+ return nil
+}
+
+func (m *Undelegate) GetDelegationAmount() *v1alpha1.Amount {
+ if m != nil {
+ return m.DelegationAmount
+ }
+ return nil
+}
+
+// A transaction action finishing an undelegation, converting (slashable)
+// "unbonding tokens" to (unslashable) staking tokens.
+type UndelegateClaim struct {
+ Body *UndelegateClaimBody `protobuf:"bytes,1,opt,name=body,proto3" json:"body,omitempty"`
+ Proof []byte `protobuf:"bytes,2,opt,name=proof,proto3" json:"proof,omitempty"`
+}
+
+func (m *UndelegateClaim) Reset() { *m = UndelegateClaim{} }
+func (m *UndelegateClaim) String() string { return proto.CompactTextString(m) }
+func (*UndelegateClaim) ProtoMessage() {}
+func (*UndelegateClaim) Descriptor() ([]byte, []int) {
+ return fileDescriptor_022d012c8e7b3ca5, []int{12}
+}
+func (m *UndelegateClaim) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *UndelegateClaim) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_UndelegateClaim.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *UndelegateClaim) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_UndelegateClaim.Merge(m, src)
+}
+func (m *UndelegateClaim) XXX_Size() int {
+ return m.Size()
+}
+func (m *UndelegateClaim) XXX_DiscardUnknown() {
+ xxx_messageInfo_UndelegateClaim.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_UndelegateClaim proto.InternalMessageInfo
+
+func (m *UndelegateClaim) GetBody() *UndelegateClaimBody {
+ if m != nil {
+ return m.Body
+ }
+ return nil
+}
+
+func (m *UndelegateClaim) GetProof() []byte {
+ if m != nil {
+ return m.Proof
+ }
+ return nil
+}
+
+type UndelegateClaimBody struct {
+ // The identity key of the validator to finish undelegating from.
+ ValidatorIdentity *v1alpha1.IdentityKey `protobuf:"bytes,1,opt,name=validator_identity,json=validatorIdentity,proto3" json:"validator_identity,omitempty"`
+ // The epoch in which unbonding began, used to verify the penalty.
+ StartEpochIndex uint64 `protobuf:"varint,2,opt,name=start_epoch_index,json=startEpochIndex,proto3" json:"start_epoch_index,omitempty"`
+ // The penalty applied to undelegation, in bps^2 (10e-8).
+ // In the happy path (no slashing), this is 0.
+ Penalty *Penalty `protobuf:"bytes,3,opt,name=penalty,proto3" json:"penalty,omitempty"`
+ // The action's contribution to the transaction's value balance.
+ BalanceCommitment *v1alpha1.BalanceCommitment `protobuf:"bytes,4,opt,name=balance_commitment,json=balanceCommitment,proto3" json:"balance_commitment,omitempty"`
+}
+
+func (m *UndelegateClaimBody) Reset() { *m = UndelegateClaimBody{} }
+func (m *UndelegateClaimBody) String() string { return proto.CompactTextString(m) }
+func (*UndelegateClaimBody) ProtoMessage() {}
+func (*UndelegateClaimBody) Descriptor() ([]byte, []int) {
+ return fileDescriptor_022d012c8e7b3ca5, []int{13}
+}
+func (m *UndelegateClaimBody) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *UndelegateClaimBody) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_UndelegateClaimBody.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *UndelegateClaimBody) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_UndelegateClaimBody.Merge(m, src)
+}
+func (m *UndelegateClaimBody) XXX_Size() int {
+ return m.Size()
+}
+func (m *UndelegateClaimBody) XXX_DiscardUnknown() {
+ xxx_messageInfo_UndelegateClaimBody.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_UndelegateClaimBody proto.InternalMessageInfo
+
+func (m *UndelegateClaimBody) GetValidatorIdentity() *v1alpha1.IdentityKey {
+ if m != nil {
+ return m.ValidatorIdentity
+ }
+ return nil
+}
+
+func (m *UndelegateClaimBody) GetStartEpochIndex() uint64 {
+ if m != nil {
+ return m.StartEpochIndex
+ }
+ return 0
+}
+
+func (m *UndelegateClaimBody) GetPenalty() *Penalty {
+ if m != nil {
+ return m.Penalty
+ }
+ return nil
+}
+
+func (m *UndelegateClaimBody) GetBalanceCommitment() *v1alpha1.BalanceCommitment {
+ if m != nil {
+ return m.BalanceCommitment
+ }
+ return nil
+}
+
+type UndelegateClaimPlan struct {
+ // The identity key of the validator to finish undelegating from.
+ ValidatorIdentity *v1alpha1.IdentityKey `protobuf:"bytes,1,opt,name=validator_identity,json=validatorIdentity,proto3" json:"validator_identity,omitempty"`
+ // The epoch in which unbonding began, used to verify the penalty.
+ StartEpochIndex uint64 `protobuf:"varint,2,opt,name=start_epoch_index,json=startEpochIndex,proto3" json:"start_epoch_index,omitempty"`
+ // The penalty applied to undelegation, in bps^2 (10e-8).
+ // In the happy path (no slashing), this is 0.
+ Penalty *Penalty `protobuf:"bytes,4,opt,name=penalty,proto3" json:"penalty,omitempty"`
+ // The amount of unbonding tokens to claim.
+ // This is a bare number because its denom is determined by the preceding data.
+ UnbondingAmount *v1alpha1.Amount `protobuf:"bytes,5,opt,name=unbonding_amount,json=unbondingAmount,proto3" json:"unbonding_amount,omitempty"`
+ // The blinding factor to use for the balance commitment.
+ BalanceBlinding []byte `protobuf:"bytes,6,opt,name=balance_blinding,json=balanceBlinding,proto3" json:"balance_blinding,omitempty"`
+ // The first blinding factor to use for the ZK undelegate claim proof.
+ ProofBlindingR []byte `protobuf:"bytes,7,opt,name=proof_blinding_r,json=proofBlindingR,proto3" json:"proof_blinding_r,omitempty"`
+ // The second blinding factor to use for the ZK undelegate claim proof.
+ ProofBlindingS []byte `protobuf:"bytes,8,opt,name=proof_blinding_s,json=proofBlindingS,proto3" json:"proof_blinding_s,omitempty"`
+}
+
+func (m *UndelegateClaimPlan) Reset() { *m = UndelegateClaimPlan{} }
+func (m *UndelegateClaimPlan) String() string { return proto.CompactTextString(m) }
+func (*UndelegateClaimPlan) ProtoMessage() {}
+func (*UndelegateClaimPlan) Descriptor() ([]byte, []int) {
+ return fileDescriptor_022d012c8e7b3ca5, []int{14}
+}
+func (m *UndelegateClaimPlan) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *UndelegateClaimPlan) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_UndelegateClaimPlan.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *UndelegateClaimPlan) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_UndelegateClaimPlan.Merge(m, src)
+}
+func (m *UndelegateClaimPlan) XXX_Size() int {
+ return m.Size()
+}
+func (m *UndelegateClaimPlan) XXX_DiscardUnknown() {
+ xxx_messageInfo_UndelegateClaimPlan.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_UndelegateClaimPlan proto.InternalMessageInfo
+
+func (m *UndelegateClaimPlan) GetValidatorIdentity() *v1alpha1.IdentityKey {
+ if m != nil {
+ return m.ValidatorIdentity
+ }
+ return nil
+}
+
+func (m *UndelegateClaimPlan) GetStartEpochIndex() uint64 {
+ if m != nil {
+ return m.StartEpochIndex
+ }
+ return 0
+}
+
+func (m *UndelegateClaimPlan) GetPenalty() *Penalty {
+ if m != nil {
+ return m.Penalty
+ }
+ return nil
+}
+
+func (m *UndelegateClaimPlan) GetUnbondingAmount() *v1alpha1.Amount {
+ if m != nil {
+ return m.UnbondingAmount
+ }
+ return nil
+}
+
+func (m *UndelegateClaimPlan) GetBalanceBlinding() []byte {
+ if m != nil {
+ return m.BalanceBlinding
+ }
+ return nil
+}
+
+func (m *UndelegateClaimPlan) GetProofBlindingR() []byte {
+ if m != nil {
+ return m.ProofBlindingR
+ }
+ return nil
+}
+
+func (m *UndelegateClaimPlan) GetProofBlindingS() []byte {
+ if m != nil {
+ return m.ProofBlindingS
+ }
+ return nil
+}
+
+// A list of pending delegations and undelegations.
+type DelegationChanges struct {
+ Delegations []*Delegate `protobuf:"bytes,1,rep,name=delegations,proto3" json:"delegations,omitempty"`
+ Undelegations []*Undelegate `protobuf:"bytes,2,rep,name=undelegations,proto3" json:"undelegations,omitempty"`
+}
+
+func (m *DelegationChanges) Reset() { *m = DelegationChanges{} }
+func (m *DelegationChanges) String() string { return proto.CompactTextString(m) }
+func (*DelegationChanges) ProtoMessage() {}
+func (*DelegationChanges) Descriptor() ([]byte, []int) {
+ return fileDescriptor_022d012c8e7b3ca5, []int{15}
+}
+func (m *DelegationChanges) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *DelegationChanges) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_DelegationChanges.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *DelegationChanges) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_DelegationChanges.Merge(m, src)
+}
+func (m *DelegationChanges) XXX_Size() int {
+ return m.Size()
+}
+func (m *DelegationChanges) XXX_DiscardUnknown() {
+ xxx_messageInfo_DelegationChanges.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_DelegationChanges proto.InternalMessageInfo
+
+func (m *DelegationChanges) GetDelegations() []*Delegate {
+ if m != nil {
+ return m.Delegations
+ }
+ return nil
+}
+
+func (m *DelegationChanges) GetUndelegations() []*Undelegate {
+ if m != nil {
+ return m.Undelegations
+ }
+ return nil
+}
+
+// Track's a validator's uptime.
+type Uptime struct {
+ AsOfBlockHeight uint64 `protobuf:"varint,1,opt,name=as_of_block_height,json=asOfBlockHeight,proto3" json:"as_of_block_height,omitempty"`
+ WindowLen uint32 `protobuf:"varint,2,opt,name=window_len,json=windowLen,proto3" json:"window_len,omitempty"`
+ Bitvec []byte `protobuf:"bytes,3,opt,name=bitvec,proto3" json:"bitvec,omitempty"`
+}
+
+func (m *Uptime) Reset() { *m = Uptime{} }
+func (m *Uptime) String() string { return proto.CompactTextString(m) }
+func (*Uptime) ProtoMessage() {}
+func (*Uptime) Descriptor() ([]byte, []int) {
+ return fileDescriptor_022d012c8e7b3ca5, []int{16}
+}
+func (m *Uptime) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *Uptime) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_Uptime.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *Uptime) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_Uptime.Merge(m, src)
+}
+func (m *Uptime) XXX_Size() int {
+ return m.Size()
+}
+func (m *Uptime) XXX_DiscardUnknown() {
+ xxx_messageInfo_Uptime.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_Uptime proto.InternalMessageInfo
+
+func (m *Uptime) GetAsOfBlockHeight() uint64 {
+ if m != nil {
+ return m.AsOfBlockHeight
+ }
+ return 0
+}
+
+func (m *Uptime) GetWindowLen() uint32 {
+ if m != nil {
+ return m.WindowLen
+ }
+ return 0
+}
+
+func (m *Uptime) GetBitvec() []byte {
+ if m != nil {
+ return m.Bitvec
+ }
+ return nil
+}
+
+// Tracks our view of Tendermint's view of the validator set, so we can keep it
+// from getting confused.
+type CurrentConsensusKeys struct {
+ ConsensusKeys []*v1alpha1.ConsensusKey `protobuf:"bytes,1,rep,name=consensus_keys,json=consensusKeys,proto3" json:"consensus_keys,omitempty"`
+}
+
+func (m *CurrentConsensusKeys) Reset() { *m = CurrentConsensusKeys{} }
+func (m *CurrentConsensusKeys) String() string { return proto.CompactTextString(m) }
+func (*CurrentConsensusKeys) ProtoMessage() {}
+func (*CurrentConsensusKeys) Descriptor() ([]byte, []int) {
+ return fileDescriptor_022d012c8e7b3ca5, []int{17}
+}
+func (m *CurrentConsensusKeys) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *CurrentConsensusKeys) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_CurrentConsensusKeys.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *CurrentConsensusKeys) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_CurrentConsensusKeys.Merge(m, src)
+}
+func (m *CurrentConsensusKeys) XXX_Size() int {
+ return m.Size()
+}
+func (m *CurrentConsensusKeys) XXX_DiscardUnknown() {
+ xxx_messageInfo_CurrentConsensusKeys.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_CurrentConsensusKeys proto.InternalMessageInfo
+
+func (m *CurrentConsensusKeys) GetConsensusKeys() []*v1alpha1.ConsensusKey {
+ if m != nil {
+ return m.ConsensusKeys
+ }
+ return nil
+}
+
+// Tracks slashing penalties applied to a validator in some epoch.
+type Penalty struct {
+ Inner uint64 `protobuf:"varint,1,opt,name=inner,proto3" json:"inner,omitempty"`
+}
+
+func (m *Penalty) Reset() { *m = Penalty{} }
+func (m *Penalty) String() string { return proto.CompactTextString(m) }
+func (*Penalty) ProtoMessage() {}
+func (*Penalty) Descriptor() ([]byte, []int) {
+ return fileDescriptor_022d012c8e7b3ca5, []int{18}
+}
+func (m *Penalty) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *Penalty) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_Penalty.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *Penalty) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_Penalty.Merge(m, src)
+}
+func (m *Penalty) XXX_Size() int {
+ return m.Size()
+}
+func (m *Penalty) XXX_DiscardUnknown() {
+ xxx_messageInfo_Penalty.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_Penalty proto.InternalMessageInfo
+
+func (m *Penalty) GetInner() uint64 {
+ if m != nil {
+ return m.Inner
+ }
+ return 0
+}
+
+func init() {
+ proto.RegisterEnum("penumbra.core.stake.v1alpha1.BondingState_BondingStateEnum", BondingState_BondingStateEnum_name, BondingState_BondingStateEnum_value)
+ proto.RegisterEnum("penumbra.core.stake.v1alpha1.ValidatorState_ValidatorStateEnum", ValidatorState_ValidatorStateEnum_name, ValidatorState_ValidatorStateEnum_value)
+ proto.RegisterType((*Validator)(nil), "penumbra.core.stake.v1alpha1.Validator")
+ proto.RegisterType((*ValidatorList)(nil), "penumbra.core.stake.v1alpha1.ValidatorList")
+ proto.RegisterType((*FundingStream)(nil), "penumbra.core.stake.v1alpha1.FundingStream")
+ proto.RegisterType((*FundingStream_ToAddress)(nil), "penumbra.core.stake.v1alpha1.FundingStream.ToAddress")
+ proto.RegisterType((*FundingStream_ToDao)(nil), "penumbra.core.stake.v1alpha1.FundingStream.ToDao")
+ proto.RegisterType((*RateData)(nil), "penumbra.core.stake.v1alpha1.RateData")
+ proto.RegisterType((*BaseRateData)(nil), "penumbra.core.stake.v1alpha1.BaseRateData")
+ proto.RegisterType((*ValidatorStatus)(nil), "penumbra.core.stake.v1alpha1.ValidatorStatus")
+ proto.RegisterType((*BondingState)(nil), "penumbra.core.stake.v1alpha1.BondingState")
+ proto.RegisterType((*ValidatorState)(nil), "penumbra.core.stake.v1alpha1.ValidatorState")
+ proto.RegisterType((*ValidatorInfo)(nil), "penumbra.core.stake.v1alpha1.ValidatorInfo")
+ proto.RegisterType((*ValidatorDefinition)(nil), "penumbra.core.stake.v1alpha1.ValidatorDefinition")
+ proto.RegisterType((*Delegate)(nil), "penumbra.core.stake.v1alpha1.Delegate")
+ proto.RegisterType((*Undelegate)(nil), "penumbra.core.stake.v1alpha1.Undelegate")
+ proto.RegisterType((*UndelegateClaim)(nil), "penumbra.core.stake.v1alpha1.UndelegateClaim")
+ proto.RegisterType((*UndelegateClaimBody)(nil), "penumbra.core.stake.v1alpha1.UndelegateClaimBody")
+ proto.RegisterType((*UndelegateClaimPlan)(nil), "penumbra.core.stake.v1alpha1.UndelegateClaimPlan")
+ proto.RegisterType((*DelegationChanges)(nil), "penumbra.core.stake.v1alpha1.DelegationChanges")
+ proto.RegisterType((*Uptime)(nil), "penumbra.core.stake.v1alpha1.Uptime")
+ proto.RegisterType((*CurrentConsensusKeys)(nil), "penumbra.core.stake.v1alpha1.CurrentConsensusKeys")
+ proto.RegisterType((*Penalty)(nil), "penumbra.core.stake.v1alpha1.Penalty")
+}
+
+func init() {
+ proto.RegisterFile("penumbra/core/stake/v1alpha1/stake.proto", fileDescriptor_022d012c8e7b3ca5)
+}
+
+var fileDescriptor_022d012c8e7b3ca5 = []byte{
+ // 1578 bytes of a gzipped FileDescriptorProto
+ 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xd4, 0x58, 0xcd, 0x6f, 0x23, 0x49,
+ 0x15, 0x4f, 0x3b, 0x76, 0x12, 0x3f, 0x7f, 0xa6, 0x66, 0x01, 0xcf, 0x30, 0x93, 0x78, 0x7b, 0x81,
+ 0x35, 0x33, 0x83, 0xc3, 0x04, 0xc1, 0x21, 0x7b, 0x58, 0xdc, 0xb6, 0x77, 0xe2, 0xdd, 0xc4, 0xf1,
+ 0xb6, 0x9d, 0x48, 0xa0, 0x48, 0xad, 0xb2, 0xbb, 0x62, 0x37, 0x63, 0x57, 0x99, 0xae, 0x72, 0xb2,
+ 0xfe, 0x0b, 0xe0, 0xc8, 0x71, 0xcf, 0x1c, 0x38, 0xac, 0x04, 0x12, 0x27, 0x4e, 0x70, 0x46, 0x9c,
+ 0x96, 0x1b, 0x47, 0x94, 0x91, 0x40, 0xe2, 0xaf, 0x40, 0x55, 0xdd, 0xd5, 0xfe, 0xc8, 0xd7, 0x64,
+ 0x35, 0x42, 0xcb, 0xad, 0xdf, 0x7b, 0xbf, 0xf7, 0xea, 0xbd, 0x5f, 0xd5, 0xab, 0x8f, 0x86, 0xd2,
+ 0x98, 0xd0, 0xc9, 0xa8, 0xeb, 0xe3, 0x9d, 0x1e, 0xf3, 0xc9, 0x0e, 0x17, 0xf8, 0x15, 0xd9, 0x39,
+ 0x7f, 0x81, 0x87, 0xe3, 0x01, 0x7e, 0x11, 0x88, 0xe5, 0xb1, 0xcf, 0x04, 0x43, 0x8f, 0x35, 0xb2,
+ 0x2c, 0x91, 0xe5, 0xc0, 0xa4, 0x91, 0x8f, 0x9e, 0x2e, 0xc6, 0xe9, 0xf9, 0xd3, 0xb1, 0x60, 0xb3,
+ 0x40, 0x81, 0x1c, 0x44, 0x32, 0xff, 0xbc, 0x0a, 0xc9, 0x13, 0x3c, 0xf4, 0x5c, 0x2c, 0x98, 0x8f,
+ 0x0e, 0x21, 0xed, 0xb9, 0x84, 0x0a, 0x4f, 0x4c, 0x9d, 0x57, 0x64, 0x5a, 0x30, 0x8a, 0x46, 0x29,
+ 0xb5, 0xfb, 0xb4, 0xbc, 0x38, 0x5c, 0x18, 0x40, 0x07, 0x2c, 0x37, 0x42, 0x97, 0x4f, 0xc8, 0xd4,
+ 0x4e, 0x79, 0x33, 0x01, 0xbd, 0x07, 0x99, 0x1e, 0xa3, 0x9c, 0x50, 0x3e, 0xe1, 0x2a, 0x5e, 0xac,
+ 0x68, 0x94, 0xd2, 0x76, 0x3a, 0x52, 0x4a, 0x10, 0x82, 0x38, 0xc5, 0x23, 0x52, 0x58, 0x2d, 0x1a,
+ 0xa5, 0xa4, 0xad, 0xbe, 0x51, 0x01, 0xd6, 0x2f, 0x48, 0x97, 0x7b, 0x82, 0x14, 0xe2, 0x4a, 0xad,
+ 0x45, 0x54, 0x84, 0x94, 0x4b, 0x78, 0xcf, 0xf7, 0xc6, 0xc2, 0x63, 0xb4, 0x90, 0x50, 0xd6, 0x79,
+ 0x95, 0xf4, 0x25, 0x14, 0x77, 0x87, 0xc4, 0x2d, 0x6c, 0x14, 0x8d, 0xd2, 0x86, 0xad, 0x45, 0xd4,
+ 0x81, 0xdc, 0xd9, 0x84, 0xba, 0x1e, 0xed, 0x3b, 0x5c, 0xf8, 0x04, 0x8f, 0x78, 0x61, 0xad, 0xb8,
+ 0x5a, 0x4a, 0xed, 0x3e, 0x2b, 0xdf, 0xc6, 0x67, 0xf9, 0xa3, 0xc0, 0xa9, 0xad, 0x7c, 0xec, 0xec,
+ 0xd9, 0xbc, 0xc8, 0xd1, 0xfb, 0x90, 0xe3, 0xe4, 0x97, 0x13, 0x42, 0x7b, 0xc4, 0x91, 0x41, 0x88,
+ 0x5f, 0x58, 0x2f, 0x1a, 0xa5, 0x8c, 0x9d, 0xd5, 0xea, 0xa6, 0xd2, 0xa2, 0x36, 0x64, 0xfb, 0xec,
+ 0x9c, 0xf8, 0x14, 0x4b, 0xa8, 0xa4, 0x23, 0xa9, 0xe8, 0x7d, 0x7e, 0x07, 0xbd, 0x2f, 0x23, 0x27,
+ 0x49, 0x70, 0xa6, 0x3f, 0x2f, 0x9a, 0x5d, 0xc8, 0x44, 0xd3, 0x77, 0xe0, 0x71, 0x81, 0x3e, 0x85,
+ 0xec, 0xb9, 0x56, 0xc8, 0x41, 0x78, 0xc1, 0x50, 0x35, 0xde, 0x67, 0x12, 0x33, 0x51, 0x84, 0x4f,
+ 0xc8, 0x94, 0x9b, 0xbf, 0x8b, 0x41, 0x66, 0x81, 0x03, 0x74, 0x02, 0x20, 0x98, 0x83, 0x5d, 0xd7,
+ 0x27, 0x9c, 0x87, 0xab, 0xe4, 0xc7, 0xf7, 0x20, 0xb1, 0xdc, 0x61, 0x95, 0xc0, 0x79, 0x7f, 0xc5,
+ 0x4e, 0x0a, 0x2d, 0xa0, 0x8f, 0x61, 0x4d, 0x30, 0xc7, 0xc5, 0x4c, 0xad, 0x94, 0xd4, 0xee, 0x8b,
+ 0xfb, 0xc5, 0xac, 0x61, 0xb6, 0xbf, 0x62, 0x27, 0x84, 0xfc, 0x78, 0xf4, 0x53, 0x48, 0x46, 0xa3,
+ 0xc8, 0x45, 0x31, 0x9f, 0x6d, 0xd2, 0xd6, 0x22, 0x7a, 0x08, 0x1b, 0x3e, 0x16, 0xc4, 0xe9, 0x8e,
+ 0xb9, 0x1a, 0x34, 0x63, 0xaf, 0x4b, 0xd9, 0x1a, 0xf3, 0x47, 0x26, 0x24, 0x54, 0xcc, 0x5b, 0x30,
+ 0x56, 0x0a, 0x92, 0x3e, 0xe9, 0x79, 0x63, 0x8f, 0x50, 0x61, 0xfe, 0xcb, 0x80, 0x0d, 0x1b, 0x0b,
+ 0x52, 0xc3, 0x02, 0xbf, 0xed, 0x5e, 0xda, 0x86, 0x14, 0x19, 0xb3, 0xde, 0xc0, 0xf1, 0xa8, 0x4b,
+ 0x3e, 0x53, 0x69, 0xc4, 0x6d, 0x50, 0xaa, 0x86, 0xd4, 0xa0, 0x5d, 0xf8, 0xc6, 0x6c, 0xe2, 0x7d,
+ 0x72, 0x81, 0x7d, 0xd7, 0x91, 0x59, 0xaa, 0x0e, 0x8a, 0xdb, 0x0f, 0x22, 0xa3, 0xad, 0x6c, 0x32,
+ 0x4f, 0xf4, 0x13, 0xf8, 0xd6, 0xcc, 0x87, 0x7c, 0xd6, 0x1b, 0x60, 0xda, 0x27, 0x81, 0x57, 0x42,
+ 0x79, 0xcd, 0x42, 0xd6, 0x43, 0xab, 0xf4, 0x33, 0x7f, 0x65, 0x40, 0xda, 0xc2, 0x9c, 0x44, 0xc5,
+ 0x2e, 0x65, 0x67, 0x5c, 0xc9, 0xae, 0x04, 0xf9, 0x2e, 0xe6, 0x64, 0x21, 0xb1, 0xa0, 0x86, 0xac,
+ 0xd4, 0xcf, 0xe5, 0xf4, 0x1c, 0x90, 0x42, 0x2e, 0xa6, 0xb3, 0xaa, 0xb0, 0x2a, 0xc6, 0x42, 0x26,
+ 0x9f, 0xc7, 0x20, 0x17, 0x35, 0x40, 0x5b, 0x60, 0x31, 0xe1, 0x6f, 0x9b, 0x79, 0x0b, 0x12, 0x5c,
+ 0xe8, 0x7c, 0xaf, 0xb6, 0xeb, 0xd2, 0x9a, 0x5c, 0x48, 0x86, 0xd8, 0x81, 0x2b, 0x7a, 0x17, 0xd2,
+ 0xe7, 0x4c, 0xc8, 0x9d, 0x67, 0xcc, 0x2e, 0x88, 0x1f, 0x96, 0x93, 0x0a, 0x74, 0x2d, 0xa9, 0x42,
+ 0x47, 0x90, 0xe9, 0x32, 0xbd, 0x3b, 0xe9, 0x79, 0xbb, 0x9a, 0xf6, 0xd2, 0x70, 0x16, 0x0b, 0x5b,
+ 0x40, 0x0e, 0x96, 0xee, 0xce, 0x49, 0xe6, 0x5f, 0x62, 0x90, 0x9e, 0x37, 0xa3, 0x4f, 0x75, 0x21,
+ 0x92, 0x90, 0xec, 0xee, 0x07, 0x6f, 0x1e, 0x79, 0x41, 0xa8, 0xd3, 0xc9, 0x48, 0xd7, 0xf5, 0x1c,
+ 0x72, 0x13, 0xaa, 0xd3, 0x56, 0xd3, 0x1d, 0xcc, 0xea, 0xfe, 0x8a, 0x9d, 0x8d, 0x0c, 0x75, 0xa9,
+ 0xff, 0xb5, 0x61, 0x98, 0x9f, 0x1b, 0x90, 0x5f, 0x8e, 0x84, 0x4c, 0xd8, 0xb2, 0x8e, 0x9a, 0xb5,
+ 0x46, 0xf3, 0xa5, 0xd3, 0xee, 0x54, 0x3a, 0x75, 0xa7, 0xde, 0x3c, 0x3e, 0x74, 0x8e, 0x9b, 0xed,
+ 0x56, 0xbd, 0xda, 0xf8, 0xa8, 0x51, 0xaf, 0xe5, 0x57, 0xd0, 0x13, 0x78, 0x78, 0x0d, 0x46, 0xaa,
+ 0xea, 0xb5, 0xbc, 0x81, 0x8a, 0xf0, 0xf8, 0xda, 0x10, 0xa1, 0x32, 0x1f, 0x43, 0xdb, 0xf0, 0xed,
+ 0x1b, 0x11, 0xf5, 0x5a, 0x7e, 0xd5, 0x42, 0x90, 0x77, 0x96, 0x2a, 0x31, 0xff, 0x1e, 0x83, 0xec,
+ 0xe2, 0x74, 0xa2, 0xe3, 0x45, 0x0a, 0x3f, 0xbc, 0xcf, 0x5a, 0x58, 0x12, 0xe7, 0x68, 0x34, 0xff,
+ 0x6d, 0x00, 0xba, 0x6a, 0x45, 0xdf, 0x81, 0xe2, 0x49, 0xe5, 0xa0, 0x51, 0xab, 0x74, 0x8e, 0xec,
+ 0x9b, 0xc9, 0x79, 0x17, 0x9e, 0x5c, 0x8b, 0x6a, 0x34, 0x2b, 0xd5, 0x4e, 0xe3, 0xa4, 0x9e, 0x37,
+ 0x64, 0xf9, 0xd7, 0x42, 0x42, 0x40, 0xec, 0x46, 0xc0, 0xc7, 0x95, 0xc6, 0x81, 0xe4, 0x07, 0xbd,
+ 0x07, 0xdb, 0xd7, 0x02, 0x3a, 0x47, 0x87, 0x56, 0xbb, 0x73, 0xd4, 0xac, 0xd7, 0xf2, 0xf1, 0x1b,
+ 0x33, 0xa9, 0x35, 0xda, 0x15, 0x4b, 0xc6, 0x49, 0x98, 0x97, 0xc6, 0xdc, 0x81, 0xd5, 0xa0, 0x67,
+ 0x0c, 0xd5, 0x21, 0x19, 0x6d, 0x32, 0x61, 0xab, 0xbe, 0xff, 0x86, 0xb4, 0xda, 0x33, 0x4f, 0x54,
+ 0x87, 0x35, 0xae, 0xda, 0x3f, 0x6c, 0xd3, 0x1f, 0xdc, 0x63, 0x6a, 0x26, 0xdc, 0x0e, 0x9d, 0x51,
+ 0x15, 0x92, 0x6a, 0xab, 0x77, 0xb1, 0xc0, 0xaa, 0x4b, 0x53, 0xbb, 0xdf, 0xbb, 0x3d, 0x92, 0xde,
+ 0x03, 0x6d, 0x75, 0x46, 0xc8, 0x2f, 0xf3, 0x02, 0x1e, 0x44, 0xf1, 0x6b, 0xe4, 0xcc, 0xa3, 0x9e,
+ 0xba, 0x99, 0xbc, 0xa5, 0x4a, 0x1f, 0xc2, 0x06, 0x9e, 0x88, 0x81, 0xc3, 0xbd, 0x7e, 0x78, 0xa1,
+ 0x5a, 0x97, 0x72, 0xdb, 0xeb, 0x9b, 0x5f, 0xc4, 0x60, 0xa3, 0x46, 0x86, 0xa4, 0x2f, 0xd7, 0xea,
+ 0xcf, 0x00, 0xcd, 0x36, 0x77, 0xbd, 0xa1, 0x7d, 0x85, 0xcd, 0x70, 0x33, 0x8a, 0xa2, 0xb5, 0x77,
+ 0x1f, 0x46, 0x4d, 0xbd, 0x2f, 0x10, 0xd7, 0xc1, 0x23, 0x36, 0xa1, 0x22, 0x24, 0xf3, 0xbb, 0x77,
+ 0x0c, 0x5c, 0x51, 0x60, 0xbd, 0x79, 0x10, 0x37, 0x90, 0x91, 0x0d, 0x9b, 0x6e, 0x50, 0x97, 0xc7,
+ 0xa8, 0x8e, 0x18, 0xbf, 0x4f, 0xc4, 0xfc, 0xcc, 0x3f, 0xd0, 0x98, 0x7f, 0x8a, 0x01, 0x1c, 0x53,
+ 0xf7, 0x7f, 0x40, 0xd7, 0x53, 0xd8, 0xe4, 0x02, 0xfb, 0xc2, 0xb9, 0x4a, 0x5a, 0x4e, 0x19, 0xea,
+ 0xff, 0x5f, 0xcc, 0x51, 0xc8, 0xcd, 0x88, 0xab, 0x0e, 0xb1, 0x37, 0x42, 0x75, 0x88, 0x77, 0x99,
+ 0xab, 0xf9, 0xba, 0xe3, 0xde, 0xb6, 0xe4, 0x6c, 0x31, 0x77, 0x6a, 0x2b, 0x77, 0xf4, 0x0e, 0x24,
+ 0xc6, 0x3e, 0x63, 0x67, 0xe1, 0xc2, 0x0e, 0x04, 0x79, 0x92, 0x3d, 0xb8, 0xc6, 0xe7, 0xeb, 0x32,
+ 0x65, 0x1f, 0xc2, 0xfa, 0x98, 0x50, 0x3c, 0x14, 0xd3, 0x1b, 0xa6, 0x6a, 0xa9, 0xfc, 0x56, 0x00,
+ 0xb6, 0xb5, 0x17, 0x72, 0xe4, 0x95, 0x67, 0xa8, 0x9e, 0x05, 0x3d, 0x36, 0x1a, 0x79, 0x62, 0x44,
+ 0xa2, 0x49, 0xfa, 0xe1, 0x1d, 0x75, 0x58, 0x81, 0x63, 0x35, 0xf2, 0xb3, 0x37, 0xbb, 0xcb, 0x2a,
+ 0xf3, 0x0f, 0xab, 0x57, 0x08, 0x6c, 0x0d, 0x31, 0xfd, 0x1a, 0x12, 0x18, 0xff, 0x4a, 0x04, 0xb6,
+ 0x20, 0x3f, 0x3b, 0xbc, 0xc3, 0x35, 0x9e, 0xb8, 0xcf, 0x1a, 0x9f, 0xdd, 0x62, 0xc2, 0xb6, 0xf9,
+ 0xbe, 0xbc, 0xaf, 0x06, 0x53, 0xd2, 0x1d, 0x7a, 0xca, 0x52, 0x58, 0x53, 0x6b, 0x32, 0x17, 0xea,
+ 0xad, 0x50, 0x2d, 0xaf, 0xb6, 0x6a, 0x99, 0x46, 0x40, 0x27, 0x78, 0x01, 0xa6, 0xed, 0xac, 0xd2,
+ 0x6b, 0xa0, 0x7d, 0x0d, 0x92, 0xab, 0x37, 0xea, 0x32, 0xb2, 0x6d, 0xfe, 0xde, 0x80, 0xcd, 0x5a,
+ 0xd4, 0x76, 0x55, 0x75, 0xdf, 0xe5, 0x68, 0x5f, 0x3e, 0x7e, 0xb5, 0x52, 0x3f, 0xec, 0xee, 0x38,
+ 0x9e, 0xf4, 0x71, 0x60, 0xcf, 0xbb, 0xa2, 0x26, 0x64, 0x26, 0x74, 0x3e, 0x56, 0x4c, 0xc5, 0x2a,
+ 0xbd, 0x69, 0xdf, 0xda, 0x8b, 0xee, 0xe6, 0x10, 0xd6, 0x8e, 0xc7, 0xc2, 0x1b, 0x11, 0xf4, 0x0c,
+ 0x10, 0xe6, 0x8e, 0xaa, 0x91, 0xf5, 0x5e, 0x39, 0x03, 0xe2, 0xf5, 0x07, 0x22, 0x7c, 0x10, 0xe4,
+ 0x30, 0x3f, 0x3a, 0xb3, 0xa4, 0x7e, 0x5f, 0xa9, 0xd1, 0x13, 0x80, 0x0b, 0x8f, 0xba, 0xec, 0xc2,
+ 0x19, 0x12, 0x1a, 0x3e, 0xad, 0x92, 0x81, 0xe6, 0x80, 0x50, 0xf4, 0x4d, 0x58, 0xeb, 0x7a, 0xe2,
+ 0x9c, 0xf4, 0x54, 0x5f, 0xa5, 0xed, 0x50, 0x32, 0x7f, 0x01, 0xef, 0x54, 0x27, 0xbe, 0x4f, 0xa8,
+ 0xa8, 0xce, 0xfd, 0x49, 0xe0, 0xc8, 0x86, 0xec, 0xc2, 0xff, 0x06, 0x4d, 0xd1, 0xb3, 0x3b, 0x16,
+ 0xc1, 0x7c, 0x14, 0x3b, 0x33, 0xff, 0x77, 0x82, 0x9b, 0xdb, 0xb0, 0x1e, 0x2e, 0x37, 0xb9, 0x39,
+ 0x79, 0x94, 0x12, 0x3f, 0xac, 0x26, 0x10, 0xac, 0x3f, 0xc6, 0xfe, 0x7a, 0xb9, 0x65, 0x7c, 0x79,
+ 0xb9, 0x65, 0xfc, 0xf3, 0x72, 0xcb, 0xf8, 0xcd, 0xeb, 0xad, 0x95, 0x2f, 0x5f, 0x6f, 0xad, 0xfc,
+ 0xe3, 0xf5, 0xd6, 0x0a, 0x14, 0x7b, 0x6c, 0x74, 0x2b, 0xa3, 0x16, 0xb4, 0xa5, 0xdc, 0xf2, 0x99,
+ 0x60, 0x2d, 0xe3, 0xe7, 0x27, 0x7d, 0x4f, 0x0c, 0x26, 0xdd, 0x72, 0x8f, 0x8d, 0x76, 0x7a, 0x8c,
+ 0x8f, 0x18, 0xdf, 0xf1, 0xc9, 0x10, 0x4f, 0x89, 0xbf, 0x73, 0xbe, 0x1b, 0x7d, 0xf6, 0x06, 0xd8,
+ 0xa3, 0x7c, 0xe7, 0xb6, 0x9f, 0x45, 0x1f, 0x28, 0x51, 0x4b, 0xbf, 0x8d, 0xad, 0xb6, 0xaa, 0xed,
+ 0x2f, 0x62, 0x8f, 0x5b, 0x3a, 0x95, 0xaa, 0x4c, 0x45, 0x0d, 0x5d, 0x3e, 0x09, 0x41, 0x7f, 0x9b,
+ 0x99, 0x4f, 0xa5, 0xf9, 0x54, 0x99, 0x4f, 0xb5, 0xf9, 0x32, 0x56, 0xba, 0xcd, 0x7c, 0xfa, 0xb2,
+ 0x65, 0x1d, 0x12, 0x81, 0xe5, 0xb5, 0xe9, 0x3f, 0xb1, 0x6d, 0x0d, 0xdd, 0xdb, 0x93, 0xd8, 0xbd,
+ 0x3d, 0x05, 0xde, 0xdb, 0xd3, 0xe8, 0xee, 0x9a, 0xfa, 0xf9, 0xf4, 0xa3, 0xff, 0x06, 0x00, 0x00,
+ 0xff, 0xff, 0x34, 0xe3, 0xd1, 0x50, 0xf2, 0x12, 0x00, 0x00,
+}
+
+func (m *Validator) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *Validator) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *Validator) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.GovernanceKey != nil {
+ {
+ size, err := m.GovernanceKey.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintStake(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x4a
+ }
+ if m.Enabled {
+ i--
+ if m.Enabled {
+ dAtA[i] = 1
+ } else {
+ dAtA[i] = 0
+ }
+ i--
+ dAtA[i] = 0x40
+ }
+ if m.SequenceNumber != 0 {
+ i = encodeVarintStake(dAtA, i, uint64(m.SequenceNumber))
+ i--
+ dAtA[i] = 0x38
+ }
+ if len(m.FundingStreams) > 0 {
+ for iNdEx := len(m.FundingStreams) - 1; iNdEx >= 0; iNdEx-- {
+ {
+ size, err := m.FundingStreams[iNdEx].MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintStake(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x32
+ }
+ }
+ if len(m.Description) > 0 {
+ i -= len(m.Description)
+ copy(dAtA[i:], m.Description)
+ i = encodeVarintStake(dAtA, i, uint64(len(m.Description)))
+ i--
+ dAtA[i] = 0x2a
+ }
+ if len(m.Website) > 0 {
+ i -= len(m.Website)
+ copy(dAtA[i:], m.Website)
+ i = encodeVarintStake(dAtA, i, uint64(len(m.Website)))
+ i--
+ dAtA[i] = 0x22
+ }
+ if len(m.Name) > 0 {
+ i -= len(m.Name)
+ copy(dAtA[i:], m.Name)
+ i = encodeVarintStake(dAtA, i, uint64(len(m.Name)))
+ i--
+ dAtA[i] = 0x1a
+ }
+ if len(m.ConsensusKey) > 0 {
+ i -= len(m.ConsensusKey)
+ copy(dAtA[i:], m.ConsensusKey)
+ i = encodeVarintStake(dAtA, i, uint64(len(m.ConsensusKey)))
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.IdentityKey != nil {
+ {
+ size, err := m.IdentityKey.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintStake(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *ValidatorList) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *ValidatorList) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ValidatorList) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.ValidatorKeys) > 0 {
+ for iNdEx := len(m.ValidatorKeys) - 1; iNdEx >= 0; iNdEx-- {
+ {
+ size, err := m.ValidatorKeys[iNdEx].MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintStake(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *FundingStream) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *FundingStream) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *FundingStream) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Recipient != nil {
+ {
+ size := m.Recipient.Size()
+ i -= size
+ if _, err := m.Recipient.MarshalTo(dAtA[i:]); err != nil {
+ return 0, err
+ }
+ }
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *FundingStream_ToAddress_) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *FundingStream_ToAddress_) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.ToAddress != nil {
+ {
+ size, err := m.ToAddress.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintStake(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+func (m *FundingStream_ToDao_) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *FundingStream_ToDao_) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.ToDao != nil {
+ {
+ size, err := m.ToDao.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintStake(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ return len(dAtA) - i, nil
+}
+func (m *FundingStream_ToAddress) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *FundingStream_ToAddress) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *FundingStream_ToAddress) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.RateBps != 0 {
+ i = encodeVarintStake(dAtA, i, uint64(m.RateBps))
+ i--
+ dAtA[i] = 0x10
+ }
+ if len(m.Address) > 0 {
+ i -= len(m.Address)
+ copy(dAtA[i:], m.Address)
+ i = encodeVarintStake(dAtA, i, uint64(len(m.Address)))
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *FundingStream_ToDao) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *FundingStream_ToDao) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *FundingStream_ToDao) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.RateBps != 0 {
+ i = encodeVarintStake(dAtA, i, uint64(m.RateBps))
+ i--
+ dAtA[i] = 0x10
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *RateData) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *RateData) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *RateData) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.ValidatorExchangeRate != 0 {
+ i = encodeVarintStake(dAtA, i, uint64(m.ValidatorExchangeRate))
+ i--
+ dAtA[i] = 0x28
+ }
+ if m.ValidatorRewardRate != 0 {
+ i = encodeVarintStake(dAtA, i, uint64(m.ValidatorRewardRate))
+ i--
+ dAtA[i] = 0x20
+ }
+ if m.EpochIndex != 0 {
+ i = encodeVarintStake(dAtA, i, uint64(m.EpochIndex))
+ i--
+ dAtA[i] = 0x10
+ }
+ if m.IdentityKey != nil {
+ {
+ size, err := m.IdentityKey.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintStake(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *BaseRateData) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *BaseRateData) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *BaseRateData) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.BaseExchangeRate != 0 {
+ i = encodeVarintStake(dAtA, i, uint64(m.BaseExchangeRate))
+ i--
+ dAtA[i] = 0x18
+ }
+ if m.BaseRewardRate != 0 {
+ i = encodeVarintStake(dAtA, i, uint64(m.BaseRewardRate))
+ i--
+ dAtA[i] = 0x10
+ }
+ if m.EpochIndex != 0 {
+ i = encodeVarintStake(dAtA, i, uint64(m.EpochIndex))
+ i--
+ dAtA[i] = 0x8
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *ValidatorStatus) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *ValidatorStatus) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ValidatorStatus) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.BondingState != nil {
+ {
+ size, err := m.BondingState.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintStake(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x22
+ }
+ if m.VotingPower != 0 {
+ i = encodeVarintStake(dAtA, i, uint64(m.VotingPower))
+ i--
+ dAtA[i] = 0x18
+ }
+ if m.State != nil {
+ {
+ size, err := m.State.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintStake(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.IdentityKey != nil {
+ {
+ size, err := m.IdentityKey.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintStake(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *BondingState) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *BondingState) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *BondingState) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.XUnbondingEpoch != nil {
+ {
+ size := m.XUnbondingEpoch.Size()
+ i -= size
+ if _, err := m.XUnbondingEpoch.MarshalTo(dAtA[i:]); err != nil {
+ return 0, err
+ }
+ }
+ }
+ if m.State != 0 {
+ i = encodeVarintStake(dAtA, i, uint64(m.State))
+ i--
+ dAtA[i] = 0x8
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *BondingState_UnbondingEpoch) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *BondingState_UnbondingEpoch) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ i = encodeVarintStake(dAtA, i, uint64(m.UnbondingEpoch))
+ i--
+ dAtA[i] = 0x10
+ return len(dAtA) - i, nil
+}
+func (m *ValidatorState) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *ValidatorState) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ValidatorState) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.State != 0 {
+ i = encodeVarintStake(dAtA, i, uint64(m.State))
+ i--
+ dAtA[i] = 0x8
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *ValidatorInfo) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *ValidatorInfo) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ValidatorInfo) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.RateData != nil {
+ {
+ size, err := m.RateData.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintStake(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1a
+ }
+ if m.Status != nil {
+ {
+ size, err := m.Status.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintStake(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.Validator != nil {
+ {
+ size, err := m.Validator.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintStake(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *ValidatorDefinition) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *ValidatorDefinition) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ValidatorDefinition) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.AuthSig) > 0 {
+ i -= len(m.AuthSig)
+ copy(dAtA[i:], m.AuthSig)
+ i = encodeVarintStake(dAtA, i, uint64(len(m.AuthSig)))
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.Validator != nil {
+ {
+ size, err := m.Validator.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintStake(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *Delegate) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *Delegate) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *Delegate) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.DelegationAmount != nil {
+ {
+ size, err := m.DelegationAmount.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintStake(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x22
+ }
+ if m.UnbondedAmount != nil {
+ {
+ size, err := m.UnbondedAmount.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintStake(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1a
+ }
+ if m.EpochIndex != 0 {
+ i = encodeVarintStake(dAtA, i, uint64(m.EpochIndex))
+ i--
+ dAtA[i] = 0x10
+ }
+ if m.ValidatorIdentity != nil {
+ {
+ size, err := m.ValidatorIdentity.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintStake(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *Undelegate) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *Undelegate) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *Undelegate) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.DelegationAmount != nil {
+ {
+ size, err := m.DelegationAmount.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintStake(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x22
+ }
+ if m.UnbondedAmount != nil {
+ {
+ size, err := m.UnbondedAmount.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintStake(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1a
+ }
+ if m.StartEpochIndex != 0 {
+ i = encodeVarintStake(dAtA, i, uint64(m.StartEpochIndex))
+ i--
+ dAtA[i] = 0x10
+ }
+ if m.ValidatorIdentity != nil {
+ {
+ size, err := m.ValidatorIdentity.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintStake(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *UndelegateClaim) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *UndelegateClaim) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *UndelegateClaim) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.Proof) > 0 {
+ i -= len(m.Proof)
+ copy(dAtA[i:], m.Proof)
+ i = encodeVarintStake(dAtA, i, uint64(len(m.Proof)))
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.Body != nil {
+ {
+ size, err := m.Body.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintStake(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *UndelegateClaimBody) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *UndelegateClaimBody) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *UndelegateClaimBody) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.BalanceCommitment != nil {
+ {
+ size, err := m.BalanceCommitment.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintStake(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x22
+ }
+ if m.Penalty != nil {
+ {
+ size, err := m.Penalty.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintStake(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1a
+ }
+ if m.StartEpochIndex != 0 {
+ i = encodeVarintStake(dAtA, i, uint64(m.StartEpochIndex))
+ i--
+ dAtA[i] = 0x10
+ }
+ if m.ValidatorIdentity != nil {
+ {
+ size, err := m.ValidatorIdentity.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintStake(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *UndelegateClaimPlan) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *UndelegateClaimPlan) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *UndelegateClaimPlan) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.ProofBlindingS) > 0 {
+ i -= len(m.ProofBlindingS)
+ copy(dAtA[i:], m.ProofBlindingS)
+ i = encodeVarintStake(dAtA, i, uint64(len(m.ProofBlindingS)))
+ i--
+ dAtA[i] = 0x42
+ }
+ if len(m.ProofBlindingR) > 0 {
+ i -= len(m.ProofBlindingR)
+ copy(dAtA[i:], m.ProofBlindingR)
+ i = encodeVarintStake(dAtA, i, uint64(len(m.ProofBlindingR)))
+ i--
+ dAtA[i] = 0x3a
+ }
+ if len(m.BalanceBlinding) > 0 {
+ i -= len(m.BalanceBlinding)
+ copy(dAtA[i:], m.BalanceBlinding)
+ i = encodeVarintStake(dAtA, i, uint64(len(m.BalanceBlinding)))
+ i--
+ dAtA[i] = 0x32
+ }
+ if m.UnbondingAmount != nil {
+ {
+ size, err := m.UnbondingAmount.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintStake(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x2a
+ }
+ if m.Penalty != nil {
+ {
+ size, err := m.Penalty.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintStake(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x22
+ }
+ if m.StartEpochIndex != 0 {
+ i = encodeVarintStake(dAtA, i, uint64(m.StartEpochIndex))
+ i--
+ dAtA[i] = 0x10
+ }
+ if m.ValidatorIdentity != nil {
+ {
+ size, err := m.ValidatorIdentity.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintStake(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *DelegationChanges) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *DelegationChanges) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *DelegationChanges) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.Undelegations) > 0 {
+ for iNdEx := len(m.Undelegations) - 1; iNdEx >= 0; iNdEx-- {
+ {
+ size, err := m.Undelegations[iNdEx].MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintStake(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ }
+ if len(m.Delegations) > 0 {
+ for iNdEx := len(m.Delegations) - 1; iNdEx >= 0; iNdEx-- {
+ {
+ size, err := m.Delegations[iNdEx].MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintStake(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *Uptime) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *Uptime) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *Uptime) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.Bitvec) > 0 {
+ i -= len(m.Bitvec)
+ copy(dAtA[i:], m.Bitvec)
+ i = encodeVarintStake(dAtA, i, uint64(len(m.Bitvec)))
+ i--
+ dAtA[i] = 0x1a
+ }
+ if m.WindowLen != 0 {
+ i = encodeVarintStake(dAtA, i, uint64(m.WindowLen))
+ i--
+ dAtA[i] = 0x10
+ }
+ if m.AsOfBlockHeight != 0 {
+ i = encodeVarintStake(dAtA, i, uint64(m.AsOfBlockHeight))
+ i--
+ dAtA[i] = 0x8
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *CurrentConsensusKeys) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *CurrentConsensusKeys) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *CurrentConsensusKeys) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.ConsensusKeys) > 0 {
+ for iNdEx := len(m.ConsensusKeys) - 1; iNdEx >= 0; iNdEx-- {
+ {
+ size, err := m.ConsensusKeys[iNdEx].MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintStake(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *Penalty) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *Penalty) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *Penalty) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Inner != 0 {
+ i = encodeVarintStake(dAtA, i, uint64(m.Inner))
+ i--
+ dAtA[i] = 0x8
+ }
+ return len(dAtA) - i, nil
+}
+
+func encodeVarintStake(dAtA []byte, offset int, v uint64) int {
+ offset -= sovStake(v)
+ base := offset
+ for v >= 1<<7 {
+ dAtA[offset] = uint8(v&0x7f | 0x80)
+ v >>= 7
+ offset++
+ }
+ dAtA[offset] = uint8(v)
+ return base
+}
+func (m *Validator) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.IdentityKey != nil {
+ l = m.IdentityKey.Size()
+ n += 1 + l + sovStake(uint64(l))
+ }
+ l = len(m.ConsensusKey)
+ if l > 0 {
+ n += 1 + l + sovStake(uint64(l))
+ }
+ l = len(m.Name)
+ if l > 0 {
+ n += 1 + l + sovStake(uint64(l))
+ }
+ l = len(m.Website)
+ if l > 0 {
+ n += 1 + l + sovStake(uint64(l))
+ }
+ l = len(m.Description)
+ if l > 0 {
+ n += 1 + l + sovStake(uint64(l))
+ }
+ if len(m.FundingStreams) > 0 {
+ for _, e := range m.FundingStreams {
+ l = e.Size()
+ n += 1 + l + sovStake(uint64(l))
+ }
+ }
+ if m.SequenceNumber != 0 {
+ n += 1 + sovStake(uint64(m.SequenceNumber))
+ }
+ if m.Enabled {
+ n += 2
+ }
+ if m.GovernanceKey != nil {
+ l = m.GovernanceKey.Size()
+ n += 1 + l + sovStake(uint64(l))
+ }
+ return n
+}
+
+func (m *ValidatorList) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if len(m.ValidatorKeys) > 0 {
+ for _, e := range m.ValidatorKeys {
+ l = e.Size()
+ n += 1 + l + sovStake(uint64(l))
+ }
+ }
+ return n
+}
+
+func (m *FundingStream) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Recipient != nil {
+ n += m.Recipient.Size()
+ }
+ return n
+}
+
+func (m *FundingStream_ToAddress_) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.ToAddress != nil {
+ l = m.ToAddress.Size()
+ n += 1 + l + sovStake(uint64(l))
+ }
+ return n
+}
+func (m *FundingStream_ToDao_) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.ToDao != nil {
+ l = m.ToDao.Size()
+ n += 1 + l + sovStake(uint64(l))
+ }
+ return n
+}
+func (m *FundingStream_ToAddress) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ l = len(m.Address)
+ if l > 0 {
+ n += 1 + l + sovStake(uint64(l))
+ }
+ if m.RateBps != 0 {
+ n += 1 + sovStake(uint64(m.RateBps))
+ }
+ return n
+}
+
+func (m *FundingStream_ToDao) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.RateBps != 0 {
+ n += 1 + sovStake(uint64(m.RateBps))
+ }
+ return n
+}
+
+func (m *RateData) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.IdentityKey != nil {
+ l = m.IdentityKey.Size()
+ n += 1 + l + sovStake(uint64(l))
+ }
+ if m.EpochIndex != 0 {
+ n += 1 + sovStake(uint64(m.EpochIndex))
+ }
+ if m.ValidatorRewardRate != 0 {
+ n += 1 + sovStake(uint64(m.ValidatorRewardRate))
+ }
+ if m.ValidatorExchangeRate != 0 {
+ n += 1 + sovStake(uint64(m.ValidatorExchangeRate))
+ }
+ return n
+}
+
+func (m *BaseRateData) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.EpochIndex != 0 {
+ n += 1 + sovStake(uint64(m.EpochIndex))
+ }
+ if m.BaseRewardRate != 0 {
+ n += 1 + sovStake(uint64(m.BaseRewardRate))
+ }
+ if m.BaseExchangeRate != 0 {
+ n += 1 + sovStake(uint64(m.BaseExchangeRate))
+ }
+ return n
+}
+
+func (m *ValidatorStatus) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.IdentityKey != nil {
+ l = m.IdentityKey.Size()
+ n += 1 + l + sovStake(uint64(l))
+ }
+ if m.State != nil {
+ l = m.State.Size()
+ n += 1 + l + sovStake(uint64(l))
+ }
+ if m.VotingPower != 0 {
+ n += 1 + sovStake(uint64(m.VotingPower))
+ }
+ if m.BondingState != nil {
+ l = m.BondingState.Size()
+ n += 1 + l + sovStake(uint64(l))
+ }
+ return n
+}
+
+func (m *BondingState) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.State != 0 {
+ n += 1 + sovStake(uint64(m.State))
+ }
+ if m.XUnbondingEpoch != nil {
+ n += m.XUnbondingEpoch.Size()
+ }
+ return n
+}
+
+func (m *BondingState_UnbondingEpoch) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ n += 1 + sovStake(uint64(m.UnbondingEpoch))
+ return n
+}
+func (m *ValidatorState) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.State != 0 {
+ n += 1 + sovStake(uint64(m.State))
+ }
+ return n
+}
+
+func (m *ValidatorInfo) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Validator != nil {
+ l = m.Validator.Size()
+ n += 1 + l + sovStake(uint64(l))
+ }
+ if m.Status != nil {
+ l = m.Status.Size()
+ n += 1 + l + sovStake(uint64(l))
+ }
+ if m.RateData != nil {
+ l = m.RateData.Size()
+ n += 1 + l + sovStake(uint64(l))
+ }
+ return n
+}
+
+func (m *ValidatorDefinition) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Validator != nil {
+ l = m.Validator.Size()
+ n += 1 + l + sovStake(uint64(l))
+ }
+ l = len(m.AuthSig)
+ if l > 0 {
+ n += 1 + l + sovStake(uint64(l))
+ }
+ return n
+}
+
+func (m *Delegate) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.ValidatorIdentity != nil {
+ l = m.ValidatorIdentity.Size()
+ n += 1 + l + sovStake(uint64(l))
+ }
+ if m.EpochIndex != 0 {
+ n += 1 + sovStake(uint64(m.EpochIndex))
+ }
+ if m.UnbondedAmount != nil {
+ l = m.UnbondedAmount.Size()
+ n += 1 + l + sovStake(uint64(l))
+ }
+ if m.DelegationAmount != nil {
+ l = m.DelegationAmount.Size()
+ n += 1 + l + sovStake(uint64(l))
+ }
+ return n
+}
+
+func (m *Undelegate) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.ValidatorIdentity != nil {
+ l = m.ValidatorIdentity.Size()
+ n += 1 + l + sovStake(uint64(l))
+ }
+ if m.StartEpochIndex != 0 {
+ n += 1 + sovStake(uint64(m.StartEpochIndex))
+ }
+ if m.UnbondedAmount != nil {
+ l = m.UnbondedAmount.Size()
+ n += 1 + l + sovStake(uint64(l))
+ }
+ if m.DelegationAmount != nil {
+ l = m.DelegationAmount.Size()
+ n += 1 + l + sovStake(uint64(l))
+ }
+ return n
+}
+
+func (m *UndelegateClaim) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Body != nil {
+ l = m.Body.Size()
+ n += 1 + l + sovStake(uint64(l))
+ }
+ l = len(m.Proof)
+ if l > 0 {
+ n += 1 + l + sovStake(uint64(l))
+ }
+ return n
+}
+
+func (m *UndelegateClaimBody) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.ValidatorIdentity != nil {
+ l = m.ValidatorIdentity.Size()
+ n += 1 + l + sovStake(uint64(l))
+ }
+ if m.StartEpochIndex != 0 {
+ n += 1 + sovStake(uint64(m.StartEpochIndex))
+ }
+ if m.Penalty != nil {
+ l = m.Penalty.Size()
+ n += 1 + l + sovStake(uint64(l))
+ }
+ if m.BalanceCommitment != nil {
+ l = m.BalanceCommitment.Size()
+ n += 1 + l + sovStake(uint64(l))
+ }
+ return n
+}
+
+func (m *UndelegateClaimPlan) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.ValidatorIdentity != nil {
+ l = m.ValidatorIdentity.Size()
+ n += 1 + l + sovStake(uint64(l))
+ }
+ if m.StartEpochIndex != 0 {
+ n += 1 + sovStake(uint64(m.StartEpochIndex))
+ }
+ if m.Penalty != nil {
+ l = m.Penalty.Size()
+ n += 1 + l + sovStake(uint64(l))
+ }
+ if m.UnbondingAmount != nil {
+ l = m.UnbondingAmount.Size()
+ n += 1 + l + sovStake(uint64(l))
+ }
+ l = len(m.BalanceBlinding)
+ if l > 0 {
+ n += 1 + l + sovStake(uint64(l))
+ }
+ l = len(m.ProofBlindingR)
+ if l > 0 {
+ n += 1 + l + sovStake(uint64(l))
+ }
+ l = len(m.ProofBlindingS)
+ if l > 0 {
+ n += 1 + l + sovStake(uint64(l))
+ }
+ return n
+}
+
+func (m *DelegationChanges) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if len(m.Delegations) > 0 {
+ for _, e := range m.Delegations {
+ l = e.Size()
+ n += 1 + l + sovStake(uint64(l))
+ }
+ }
+ if len(m.Undelegations) > 0 {
+ for _, e := range m.Undelegations {
+ l = e.Size()
+ n += 1 + l + sovStake(uint64(l))
+ }
+ }
+ return n
+}
+
+func (m *Uptime) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.AsOfBlockHeight != 0 {
+ n += 1 + sovStake(uint64(m.AsOfBlockHeight))
+ }
+ if m.WindowLen != 0 {
+ n += 1 + sovStake(uint64(m.WindowLen))
+ }
+ l = len(m.Bitvec)
+ if l > 0 {
+ n += 1 + l + sovStake(uint64(l))
+ }
+ return n
+}
+
+func (m *CurrentConsensusKeys) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if len(m.ConsensusKeys) > 0 {
+ for _, e := range m.ConsensusKeys {
+ l = e.Size()
+ n += 1 + l + sovStake(uint64(l))
+ }
+ }
+ return n
+}
+
+func (m *Penalty) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Inner != 0 {
+ n += 1 + sovStake(uint64(m.Inner))
+ }
+ return n
+}
+
+func sovStake(x uint64) (n int) {
+ return (math_bits.Len64(x|1) + 6) / 7
+}
+func sozStake(x uint64) (n int) {
+ return sovStake(uint64((x << 1) ^ uint64((int64(x) >> 63))))
+}
+func (m *Validator) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Validator: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Validator: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field IdentityKey", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthStake
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthStake
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.IdentityKey == nil {
+ m.IdentityKey = &v1alpha1.IdentityKey{}
+ }
+ if err := m.IdentityKey.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ConsensusKey", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthStake
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthStake
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.ConsensusKey = append(m.ConsensusKey[:0], dAtA[iNdEx:postIndex]...)
+ if m.ConsensusKey == nil {
+ m.ConsensusKey = []byte{}
+ }
+ iNdEx = postIndex
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Name", wireType)
+ }
+ var stringLen uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ stringLen |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ intStringLen := int(stringLen)
+ if intStringLen < 0 {
+ return ErrInvalidLengthStake
+ }
+ postIndex := iNdEx + intStringLen
+ if postIndex < 0 {
+ return ErrInvalidLengthStake
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Name = string(dAtA[iNdEx:postIndex])
+ iNdEx = postIndex
+ case 4:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Website", wireType)
+ }
+ var stringLen uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ stringLen |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ intStringLen := int(stringLen)
+ if intStringLen < 0 {
+ return ErrInvalidLengthStake
+ }
+ postIndex := iNdEx + intStringLen
+ if postIndex < 0 {
+ return ErrInvalidLengthStake
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Website = string(dAtA[iNdEx:postIndex])
+ iNdEx = postIndex
+ case 5:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Description", wireType)
+ }
+ var stringLen uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ stringLen |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ intStringLen := int(stringLen)
+ if intStringLen < 0 {
+ return ErrInvalidLengthStake
+ }
+ postIndex := iNdEx + intStringLen
+ if postIndex < 0 {
+ return ErrInvalidLengthStake
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Description = string(dAtA[iNdEx:postIndex])
+ iNdEx = postIndex
+ case 6:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field FundingStreams", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthStake
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthStake
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.FundingStreams = append(m.FundingStreams, &FundingStream{})
+ if err := m.FundingStreams[len(m.FundingStreams)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 7:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field SequenceNumber", wireType)
+ }
+ m.SequenceNumber = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.SequenceNumber |= uint32(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 8:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Enabled", wireType)
+ }
+ var v int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ v |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ m.Enabled = bool(v != 0)
+ case 9:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field GovernanceKey", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthStake
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthStake
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.GovernanceKey == nil {
+ m.GovernanceKey = &v1alpha1.GovernanceKey{}
+ }
+ if err := m.GovernanceKey.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipStake(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthStake
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *ValidatorList) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: ValidatorList: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: ValidatorList: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ValidatorKeys", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthStake
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthStake
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.ValidatorKeys = append(m.ValidatorKeys, &v1alpha1.IdentityKey{})
+ if err := m.ValidatorKeys[len(m.ValidatorKeys)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipStake(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthStake
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *FundingStream) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: FundingStream: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: FundingStream: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ToAddress", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthStake
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthStake
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &FundingStream_ToAddress{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.Recipient = &FundingStream_ToAddress_{v}
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ToDao", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthStake
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthStake
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &FundingStream_ToDao{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.Recipient = &FundingStream_ToDao_{v}
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipStake(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthStake
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *FundingStream_ToAddress) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: ToAddress: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: ToAddress: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Address", wireType)
+ }
+ var stringLen uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ stringLen |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ intStringLen := int(stringLen)
+ if intStringLen < 0 {
+ return ErrInvalidLengthStake
+ }
+ postIndex := iNdEx + intStringLen
+ if postIndex < 0 {
+ return ErrInvalidLengthStake
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Address = string(dAtA[iNdEx:postIndex])
+ iNdEx = postIndex
+ case 2:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field RateBps", wireType)
+ }
+ m.RateBps = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.RateBps |= uint32(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ default:
+ iNdEx = preIndex
+ skippy, err := skipStake(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthStake
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *FundingStream_ToDao) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: ToDao: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: ToDao: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 2:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field RateBps", wireType)
+ }
+ m.RateBps = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.RateBps |= uint32(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ default:
+ iNdEx = preIndex
+ skippy, err := skipStake(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthStake
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *RateData) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: RateData: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: RateData: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field IdentityKey", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthStake
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthStake
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.IdentityKey == nil {
+ m.IdentityKey = &v1alpha1.IdentityKey{}
+ }
+ if err := m.IdentityKey.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field EpochIndex", wireType)
+ }
+ m.EpochIndex = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.EpochIndex |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 4:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ValidatorRewardRate", wireType)
+ }
+ m.ValidatorRewardRate = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.ValidatorRewardRate |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 5:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ValidatorExchangeRate", wireType)
+ }
+ m.ValidatorExchangeRate = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.ValidatorExchangeRate |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ default:
+ iNdEx = preIndex
+ skippy, err := skipStake(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthStake
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *BaseRateData) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: BaseRateData: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: BaseRateData: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field EpochIndex", wireType)
+ }
+ m.EpochIndex = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.EpochIndex |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 2:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field BaseRewardRate", wireType)
+ }
+ m.BaseRewardRate = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.BaseRewardRate |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 3:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field BaseExchangeRate", wireType)
+ }
+ m.BaseExchangeRate = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.BaseExchangeRate |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ default:
+ iNdEx = preIndex
+ skippy, err := skipStake(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthStake
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *ValidatorStatus) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: ValidatorStatus: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: ValidatorStatus: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field IdentityKey", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthStake
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthStake
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.IdentityKey == nil {
+ m.IdentityKey = &v1alpha1.IdentityKey{}
+ }
+ if err := m.IdentityKey.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field State", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthStake
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthStake
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.State == nil {
+ m.State = &ValidatorState{}
+ }
+ if err := m.State.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 3:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field VotingPower", wireType)
+ }
+ m.VotingPower = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.VotingPower |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 4:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field BondingState", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthStake
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthStake
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.BondingState == nil {
+ m.BondingState = &BondingState{}
+ }
+ if err := m.BondingState.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipStake(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthStake
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *BondingState) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: BondingState: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: BondingState: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field State", wireType)
+ }
+ m.State = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.State |= BondingState_BondingStateEnum(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 2:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field UnbondingEpoch", wireType)
+ }
+ var v uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ v |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ m.XUnbondingEpoch = &BondingState_UnbondingEpoch{v}
+ default:
+ iNdEx = preIndex
+ skippy, err := skipStake(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthStake
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *ValidatorState) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: ValidatorState: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: ValidatorState: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field State", wireType)
+ }
+ m.State = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.State |= ValidatorState_ValidatorStateEnum(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ default:
+ iNdEx = preIndex
+ skippy, err := skipStake(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthStake
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *ValidatorInfo) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: ValidatorInfo: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: ValidatorInfo: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Validator", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthStake
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthStake
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Validator == nil {
+ m.Validator = &Validator{}
+ }
+ if err := m.Validator.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Status", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthStake
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthStake
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Status == nil {
+ m.Status = &ValidatorStatus{}
+ }
+ if err := m.Status.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field RateData", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthStake
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthStake
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.RateData == nil {
+ m.RateData = &RateData{}
+ }
+ if err := m.RateData.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipStake(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthStake
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *ValidatorDefinition) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: ValidatorDefinition: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: ValidatorDefinition: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Validator", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthStake
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthStake
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Validator == nil {
+ m.Validator = &Validator{}
+ }
+ if err := m.Validator.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field AuthSig", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthStake
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthStake
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.AuthSig = append(m.AuthSig[:0], dAtA[iNdEx:postIndex]...)
+ if m.AuthSig == nil {
+ m.AuthSig = []byte{}
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipStake(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthStake
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *Delegate) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Delegate: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Delegate: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ValidatorIdentity", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthStake
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthStake
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.ValidatorIdentity == nil {
+ m.ValidatorIdentity = &v1alpha1.IdentityKey{}
+ }
+ if err := m.ValidatorIdentity.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field EpochIndex", wireType)
+ }
+ m.EpochIndex = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.EpochIndex |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field UnbondedAmount", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthStake
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthStake
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.UnbondedAmount == nil {
+ m.UnbondedAmount = &v1alpha1.Amount{}
+ }
+ if err := m.UnbondedAmount.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 4:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field DelegationAmount", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthStake
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthStake
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.DelegationAmount == nil {
+ m.DelegationAmount = &v1alpha1.Amount{}
+ }
+ if err := m.DelegationAmount.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipStake(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthStake
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *Undelegate) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Undelegate: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Undelegate: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ValidatorIdentity", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthStake
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthStake
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.ValidatorIdentity == nil {
+ m.ValidatorIdentity = &v1alpha1.IdentityKey{}
+ }
+ if err := m.ValidatorIdentity.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field StartEpochIndex", wireType)
+ }
+ m.StartEpochIndex = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.StartEpochIndex |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field UnbondedAmount", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthStake
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthStake
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.UnbondedAmount == nil {
+ m.UnbondedAmount = &v1alpha1.Amount{}
+ }
+ if err := m.UnbondedAmount.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 4:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field DelegationAmount", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthStake
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthStake
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.DelegationAmount == nil {
+ m.DelegationAmount = &v1alpha1.Amount{}
+ }
+ if err := m.DelegationAmount.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipStake(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthStake
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *UndelegateClaim) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: UndelegateClaim: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: UndelegateClaim: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Body", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthStake
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthStake
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Body == nil {
+ m.Body = &UndelegateClaimBody{}
+ }
+ if err := m.Body.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Proof", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthStake
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthStake
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Proof = append(m.Proof[:0], dAtA[iNdEx:postIndex]...)
+ if m.Proof == nil {
+ m.Proof = []byte{}
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipStake(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthStake
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *UndelegateClaimBody) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: UndelegateClaimBody: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: UndelegateClaimBody: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ValidatorIdentity", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthStake
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthStake
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.ValidatorIdentity == nil {
+ m.ValidatorIdentity = &v1alpha1.IdentityKey{}
+ }
+ if err := m.ValidatorIdentity.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field StartEpochIndex", wireType)
+ }
+ m.StartEpochIndex = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.StartEpochIndex |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Penalty", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthStake
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthStake
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Penalty == nil {
+ m.Penalty = &Penalty{}
+ }
+ if err := m.Penalty.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 4:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field BalanceCommitment", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthStake
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthStake
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.BalanceCommitment == nil {
+ m.BalanceCommitment = &v1alpha1.BalanceCommitment{}
+ }
+ if err := m.BalanceCommitment.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipStake(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthStake
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *UndelegateClaimPlan) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: UndelegateClaimPlan: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: UndelegateClaimPlan: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ValidatorIdentity", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthStake
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthStake
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.ValidatorIdentity == nil {
+ m.ValidatorIdentity = &v1alpha1.IdentityKey{}
+ }
+ if err := m.ValidatorIdentity.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field StartEpochIndex", wireType)
+ }
+ m.StartEpochIndex = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.StartEpochIndex |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 4:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Penalty", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthStake
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthStake
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Penalty == nil {
+ m.Penalty = &Penalty{}
+ }
+ if err := m.Penalty.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 5:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field UnbondingAmount", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthStake
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthStake
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.UnbondingAmount == nil {
+ m.UnbondingAmount = &v1alpha1.Amount{}
+ }
+ if err := m.UnbondingAmount.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 6:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field BalanceBlinding", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthStake
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthStake
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.BalanceBlinding = append(m.BalanceBlinding[:0], dAtA[iNdEx:postIndex]...)
+ if m.BalanceBlinding == nil {
+ m.BalanceBlinding = []byte{}
+ }
+ iNdEx = postIndex
+ case 7:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ProofBlindingR", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthStake
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthStake
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.ProofBlindingR = append(m.ProofBlindingR[:0], dAtA[iNdEx:postIndex]...)
+ if m.ProofBlindingR == nil {
+ m.ProofBlindingR = []byte{}
+ }
+ iNdEx = postIndex
+ case 8:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ProofBlindingS", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthStake
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthStake
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.ProofBlindingS = append(m.ProofBlindingS[:0], dAtA[iNdEx:postIndex]...)
+ if m.ProofBlindingS == nil {
+ m.ProofBlindingS = []byte{}
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipStake(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthStake
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *DelegationChanges) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: DelegationChanges: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: DelegationChanges: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Delegations", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthStake
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthStake
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Delegations = append(m.Delegations, &Delegate{})
+ if err := m.Delegations[len(m.Delegations)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Undelegations", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthStake
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthStake
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Undelegations = append(m.Undelegations, &Undelegate{})
+ if err := m.Undelegations[len(m.Undelegations)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipStake(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthStake
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *Uptime) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Uptime: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Uptime: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field AsOfBlockHeight", wireType)
+ }
+ m.AsOfBlockHeight = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.AsOfBlockHeight |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 2:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field WindowLen", wireType)
+ }
+ m.WindowLen = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.WindowLen |= uint32(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Bitvec", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthStake
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthStake
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Bitvec = append(m.Bitvec[:0], dAtA[iNdEx:postIndex]...)
+ if m.Bitvec == nil {
+ m.Bitvec = []byte{}
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipStake(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthStake
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *CurrentConsensusKeys) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: CurrentConsensusKeys: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: CurrentConsensusKeys: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ConsensusKeys", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthStake
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthStake
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.ConsensusKeys = append(m.ConsensusKeys, &v1alpha1.ConsensusKey{})
+ if err := m.ConsensusKeys[len(m.ConsensusKeys)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipStake(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthStake
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *Penalty) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Penalty: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Penalty: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Inner", wireType)
+ }
+ m.Inner = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.Inner |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ default:
+ iNdEx = preIndex
+ skippy, err := skipStake(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthStake
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func skipStake(dAtA []byte) (n int, err error) {
+ l := len(dAtA)
+ iNdEx := 0
+ depth := 0
+ for iNdEx < l {
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return 0, ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return 0, io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= (uint64(b) & 0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ wireType := int(wire & 0x7)
+ switch wireType {
+ case 0:
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return 0, ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return 0, io.ErrUnexpectedEOF
+ }
+ iNdEx++
+ if dAtA[iNdEx-1] < 0x80 {
+ break
+ }
+ }
+ case 1:
+ iNdEx += 8
+ case 2:
+ var length int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return 0, ErrIntOverflowStake
+ }
+ if iNdEx >= l {
+ return 0, io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ length |= (int(b) & 0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if length < 0 {
+ return 0, ErrInvalidLengthStake
+ }
+ iNdEx += length
+ case 3:
+ depth++
+ case 4:
+ if depth == 0 {
+ return 0, ErrUnexpectedEndOfGroupStake
+ }
+ depth--
+ case 5:
+ iNdEx += 4
+ default:
+ return 0, fmt.Errorf("proto: illegal wireType %d", wireType)
+ }
+ if iNdEx < 0 {
+ return 0, ErrInvalidLengthStake
+ }
+ if depth == 0 {
+ return iNdEx, nil
+ }
+ }
+ return 0, io.ErrUnexpectedEOF
+}
+
+var (
+ ErrInvalidLengthStake = fmt.Errorf("proto: negative length found during unmarshaling")
+ ErrIntOverflowStake = fmt.Errorf("proto: integer overflow")
+ ErrUnexpectedEndOfGroupStake = fmt.Errorf("proto: unexpected end of group")
+)
diff --git a/relayer/chains/penumbra/core/transaction/v1alpha1/transaction.pb.go b/relayer/chains/penumbra/core/transaction/v1alpha1/transaction.pb.go
new file mode 100644
index 000000000..c22d6f2ae
--- /dev/null
+++ b/relayer/chains/penumbra/core/transaction/v1alpha1/transaction.pb.go
@@ -0,0 +1,16898 @@
+// Code generated by protoc-gen-gogo. DO NOT EDIT.
+// source: penumbra/core/transaction/v1alpha1/transaction.proto
+
+package transactionv1alpha1
+
+import (
+ fmt "fmt"
+ proto "github.com/cosmos/gogoproto/proto"
+ v1alpha1 "github.com/cosmos/relayer/v2/relayer/chains/penumbra/core/crypto/v1alpha1"
+ v1alpha11 "github.com/cosmos/relayer/v2/relayer/chains/penumbra/core/dex/v1alpha1"
+ v1alpha14 "github.com/cosmos/relayer/v2/relayer/chains/penumbra/core/governance/v1alpha1"
+ v1alpha13 "github.com/cosmos/relayer/v2/relayer/chains/penumbra/core/ibc/v1alpha1"
+ v1alpha12 "github.com/cosmos/relayer/v2/relayer/chains/penumbra/core/stake/v1alpha1"
+ io "io"
+ math "math"
+ math_bits "math/bits"
+)
+
+// Reference imports to suppress errors if they are not otherwise used.
+var _ = proto.Marshal
+var _ = fmt.Errorf
+var _ = math.Inf
+
+// This is a compile-time assertion to ensure that this generated file
+// is compatible with the proto package it is being compiled against.
+// A compilation error at this line likely means your copy of the
+// proto package needs to be updated.
+const _ = proto.GoGoProtoPackageIsVersion3 // please upgrade the proto package
+
+// A Penumbra transaction.
+type Transaction struct {
+ Body *TransactionBody `protobuf:"bytes,1,opt,name=body,proto3" json:"body,omitempty"`
+ // The binding signature is stored separately from the transaction body that it signs.
+ BindingSig []byte `protobuf:"bytes,2,opt,name=binding_sig,json=bindingSig,proto3" json:"binding_sig,omitempty"`
+ // The root of some previous state of the state commitment tree, used as an anchor for all
+ // ZK state transition proofs.
+ Anchor *v1alpha1.MerkleRoot `protobuf:"bytes,3,opt,name=anchor,proto3" json:"anchor,omitempty"`
+}
+
+func (m *Transaction) Reset() { *m = Transaction{} }
+func (m *Transaction) String() string { return proto.CompactTextString(m) }
+func (*Transaction) ProtoMessage() {}
+func (*Transaction) Descriptor() ([]byte, []int) {
+ return fileDescriptor_cd20ea79758052c4, []int{0}
+}
+func (m *Transaction) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *Transaction) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_Transaction.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *Transaction) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_Transaction.Merge(m, src)
+}
+func (m *Transaction) XXX_Size() int {
+ return m.Size()
+}
+func (m *Transaction) XXX_DiscardUnknown() {
+ xxx_messageInfo_Transaction.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_Transaction proto.InternalMessageInfo
+
+func (m *Transaction) GetBody() *TransactionBody {
+ if m != nil {
+ return m.Body
+ }
+ return nil
+}
+
+func (m *Transaction) GetBindingSig() []byte {
+ if m != nil {
+ return m.BindingSig
+ }
+ return nil
+}
+
+func (m *Transaction) GetAnchor() *v1alpha1.MerkleRoot {
+ if m != nil {
+ return m.Anchor
+ }
+ return nil
+}
+
+// A transaction ID, the Sha256 hash of a transaction.
+type Id struct {
+ Hash []byte `protobuf:"bytes,1,opt,name=hash,proto3" json:"hash,omitempty"`
+}
+
+func (m *Id) Reset() { *m = Id{} }
+func (m *Id) String() string { return proto.CompactTextString(m) }
+func (*Id) ProtoMessage() {}
+func (*Id) Descriptor() ([]byte, []int) {
+ return fileDescriptor_cd20ea79758052c4, []int{1}
+}
+func (m *Id) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *Id) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_Id.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *Id) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_Id.Merge(m, src)
+}
+func (m *Id) XXX_Size() int {
+ return m.Size()
+}
+func (m *Id) XXX_DiscardUnknown() {
+ xxx_messageInfo_Id.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_Id proto.InternalMessageInfo
+
+func (m *Id) GetHash() []byte {
+ if m != nil {
+ return m.Hash
+ }
+ return nil
+}
+
+type EffectHash struct {
+ Inner []byte `protobuf:"bytes,1,opt,name=inner,proto3" json:"inner,omitempty"`
+}
+
+func (m *EffectHash) Reset() { *m = EffectHash{} }
+func (m *EffectHash) String() string { return proto.CompactTextString(m) }
+func (*EffectHash) ProtoMessage() {}
+func (*EffectHash) Descriptor() ([]byte, []int) {
+ return fileDescriptor_cd20ea79758052c4, []int{2}
+}
+func (m *EffectHash) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *EffectHash) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_EffectHash.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *EffectHash) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_EffectHash.Merge(m, src)
+}
+func (m *EffectHash) XXX_Size() int {
+ return m.Size()
+}
+func (m *EffectHash) XXX_DiscardUnknown() {
+ xxx_messageInfo_EffectHash.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_EffectHash proto.InternalMessageInfo
+
+func (m *EffectHash) GetInner() []byte {
+ if m != nil {
+ return m.Inner
+ }
+ return nil
+}
+
+// The body of a transaction.
+type TransactionBody struct {
+ // A list of actions (state changes) performed by this transaction.
+ Actions []*Action `protobuf:"bytes,1,rep,name=actions,proto3" json:"actions,omitempty"`
+ // Parameters determining if a transaction should be accepted by this chain.
+ TransactionParameters *TransactionParameters `protobuf:"bytes,2,opt,name=transaction_parameters,json=transactionParameters,proto3" json:"transaction_parameters,omitempty"`
+ // The transaction fee.
+ Fee *v1alpha1.Fee `protobuf:"bytes,3,opt,name=fee,proto3" json:"fee,omitempty"`
+ // Detection data for use with Fuzzy Message Detection
+ DetectionData *DetectionData `protobuf:"bytes,4,opt,name=detection_data,json=detectionData,proto3" json:"detection_data,omitempty"`
+ // Sub-message containing memo ciphertext if a memo was added to the transaction.
+ MemoData *MemoData `protobuf:"bytes,5,opt,name=memo_data,json=memoData,proto3" json:"memo_data,omitempty"`
+}
+
+func (m *TransactionBody) Reset() { *m = TransactionBody{} }
+func (m *TransactionBody) String() string { return proto.CompactTextString(m) }
+func (*TransactionBody) ProtoMessage() {}
+func (*TransactionBody) Descriptor() ([]byte, []int) {
+ return fileDescriptor_cd20ea79758052c4, []int{3}
+}
+func (m *TransactionBody) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *TransactionBody) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_TransactionBody.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *TransactionBody) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_TransactionBody.Merge(m, src)
+}
+func (m *TransactionBody) XXX_Size() int {
+ return m.Size()
+}
+func (m *TransactionBody) XXX_DiscardUnknown() {
+ xxx_messageInfo_TransactionBody.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_TransactionBody proto.InternalMessageInfo
+
+func (m *TransactionBody) GetActions() []*Action {
+ if m != nil {
+ return m.Actions
+ }
+ return nil
+}
+
+func (m *TransactionBody) GetTransactionParameters() *TransactionParameters {
+ if m != nil {
+ return m.TransactionParameters
+ }
+ return nil
+}
+
+func (m *TransactionBody) GetFee() *v1alpha1.Fee {
+ if m != nil {
+ return m.Fee
+ }
+ return nil
+}
+
+func (m *TransactionBody) GetDetectionData() *DetectionData {
+ if m != nil {
+ return m.DetectionData
+ }
+ return nil
+}
+
+func (m *TransactionBody) GetMemoData() *MemoData {
+ if m != nil {
+ return m.MemoData
+ }
+ return nil
+}
+
+// Represents the encrypted memo data.
+type MemoData struct {
+ // Types that are valid to be assigned to XEncryptedMemo:
+ // *MemoData_EncryptedMemo
+ XEncryptedMemo isMemoData_XEncryptedMemo `protobuf_oneof:"_encrypted_memo"`
+}
+
+func (m *MemoData) Reset() { *m = MemoData{} }
+func (m *MemoData) String() string { return proto.CompactTextString(m) }
+func (*MemoData) ProtoMessage() {}
+func (*MemoData) Descriptor() ([]byte, []int) {
+ return fileDescriptor_cd20ea79758052c4, []int{4}
+}
+func (m *MemoData) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *MemoData) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_MemoData.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *MemoData) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_MemoData.Merge(m, src)
+}
+func (m *MemoData) XXX_Size() int {
+ return m.Size()
+}
+func (m *MemoData) XXX_DiscardUnknown() {
+ xxx_messageInfo_MemoData.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_MemoData proto.InternalMessageInfo
+
+type isMemoData_XEncryptedMemo interface {
+ isMemoData_XEncryptedMemo()
+ MarshalTo([]byte) (int, error)
+ Size() int
+}
+
+type MemoData_EncryptedMemo struct {
+ EncryptedMemo []byte `protobuf:"bytes,1,opt,name=encrypted_memo,json=encryptedMemo,proto3,oneof" json:"encrypted_memo,omitempty"`
+}
+
+func (*MemoData_EncryptedMemo) isMemoData_XEncryptedMemo() {}
+
+func (m *MemoData) GetXEncryptedMemo() isMemoData_XEncryptedMemo {
+ if m != nil {
+ return m.XEncryptedMemo
+ }
+ return nil
+}
+
+func (m *MemoData) GetEncryptedMemo() []byte {
+ if x, ok := m.GetXEncryptedMemo().(*MemoData_EncryptedMemo); ok {
+ return x.EncryptedMemo
+ }
+ return nil
+}
+
+// XXX_OneofWrappers is for the internal use of the proto package.
+func (*MemoData) XXX_OneofWrappers() []interface{} {
+ return []interface{}{
+ (*MemoData_EncryptedMemo)(nil),
+ }
+}
+
+// The parameters determining if a transaction should be accepted by the chain.
+type TransactionParameters struct {
+ // The maximum height that this transaction can be included in the chain.
+ //
+ // If zero, there is no maximum.
+ ExpiryHeight uint64 `protobuf:"varint,1,opt,name=expiry_height,json=expiryHeight,proto3" json:"expiry_height,omitempty"`
+ // The chain this transaction is intended for. Including this prevents
+ // replaying a transaction on one chain onto a different chain.
+ ChainId string `protobuf:"bytes,2,opt,name=chain_id,json=chainId,proto3" json:"chain_id,omitempty"`
+}
+
+func (m *TransactionParameters) Reset() { *m = TransactionParameters{} }
+func (m *TransactionParameters) String() string { return proto.CompactTextString(m) }
+func (*TransactionParameters) ProtoMessage() {}
+func (*TransactionParameters) Descriptor() ([]byte, []int) {
+ return fileDescriptor_cd20ea79758052c4, []int{5}
+}
+func (m *TransactionParameters) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *TransactionParameters) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_TransactionParameters.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *TransactionParameters) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_TransactionParameters.Merge(m, src)
+}
+func (m *TransactionParameters) XXX_Size() int {
+ return m.Size()
+}
+func (m *TransactionParameters) XXX_DiscardUnknown() {
+ xxx_messageInfo_TransactionParameters.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_TransactionParameters proto.InternalMessageInfo
+
+func (m *TransactionParameters) GetExpiryHeight() uint64 {
+ if m != nil {
+ return m.ExpiryHeight
+ }
+ return 0
+}
+
+func (m *TransactionParameters) GetChainId() string {
+ if m != nil {
+ return m.ChainId
+ }
+ return ""
+}
+
+// Detection data used by a detection server performing Fuzzy Message Detection.
+type DetectionData struct {
+ // A list of clues for use with Fuzzy Message Detection.
+ FmdClues []*v1alpha1.Clue `protobuf:"bytes,4,rep,name=fmd_clues,json=fmdClues,proto3" json:"fmd_clues,omitempty"`
+}
+
+func (m *DetectionData) Reset() { *m = DetectionData{} }
+func (m *DetectionData) String() string { return proto.CompactTextString(m) }
+func (*DetectionData) ProtoMessage() {}
+func (*DetectionData) Descriptor() ([]byte, []int) {
+ return fileDescriptor_cd20ea79758052c4, []int{6}
+}
+func (m *DetectionData) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *DetectionData) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_DetectionData.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *DetectionData) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_DetectionData.Merge(m, src)
+}
+func (m *DetectionData) XXX_Size() int {
+ return m.Size()
+}
+func (m *DetectionData) XXX_DiscardUnknown() {
+ xxx_messageInfo_DetectionData.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_DetectionData proto.InternalMessageInfo
+
+func (m *DetectionData) GetFmdClues() []*v1alpha1.Clue {
+ if m != nil {
+ return m.FmdClues
+ }
+ return nil
+}
+
+// A state change performed by a transaction.
+type Action struct {
+ // Types that are valid to be assigned to Action:
+ // *Action_Spend
+ // *Action_Output
+ // *Action_Swap
+ // *Action_SwapClaim
+ // *Action_ValidatorDefinition
+ // *Action_IbcAction
+ // *Action_ProposalSubmit
+ // *Action_ProposalWithdraw
+ // *Action_ValidatorVote
+ // *Action_DelegatorVote
+ // *Action_ProposalDepositClaim
+ // *Action_PositionOpen
+ // *Action_PositionClose
+ // *Action_PositionWithdraw
+ // *Action_PositionRewardClaim
+ // *Action_Delegate
+ // *Action_Undelegate
+ // *Action_UndelegateClaim
+ // *Action_DaoSpend
+ // *Action_DaoOutput
+ // *Action_DaoDeposit
+ // *Action_Ics20Withdrawal
+ Action isAction_Action `protobuf_oneof:"action"`
+}
+
+func (m *Action) Reset() { *m = Action{} }
+func (m *Action) String() string { return proto.CompactTextString(m) }
+func (*Action) ProtoMessage() {}
+func (*Action) Descriptor() ([]byte, []int) {
+ return fileDescriptor_cd20ea79758052c4, []int{7}
+}
+func (m *Action) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *Action) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_Action.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *Action) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_Action.Merge(m, src)
+}
+func (m *Action) XXX_Size() int {
+ return m.Size()
+}
+func (m *Action) XXX_DiscardUnknown() {
+ xxx_messageInfo_Action.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_Action proto.InternalMessageInfo
+
+type isAction_Action interface {
+ isAction_Action()
+ MarshalTo([]byte) (int, error)
+ Size() int
+}
+
+type Action_Spend struct {
+ Spend *Spend `protobuf:"bytes,1,opt,name=spend,proto3,oneof" json:"spend,omitempty"`
+}
+type Action_Output struct {
+ Output *Output `protobuf:"bytes,2,opt,name=output,proto3,oneof" json:"output,omitempty"`
+}
+type Action_Swap struct {
+ Swap *v1alpha11.Swap `protobuf:"bytes,3,opt,name=swap,proto3,oneof" json:"swap,omitempty"`
+}
+type Action_SwapClaim struct {
+ SwapClaim *v1alpha11.SwapClaim `protobuf:"bytes,4,opt,name=swap_claim,json=swapClaim,proto3,oneof" json:"swap_claim,omitempty"`
+}
+type Action_ValidatorDefinition struct {
+ ValidatorDefinition *v1alpha12.ValidatorDefinition `protobuf:"bytes,16,opt,name=validator_definition,json=validatorDefinition,proto3,oneof" json:"validator_definition,omitempty"`
+}
+type Action_IbcAction struct {
+ IbcAction *v1alpha13.IbcAction `protobuf:"bytes,17,opt,name=ibc_action,json=ibcAction,proto3,oneof" json:"ibc_action,omitempty"`
+}
+type Action_ProposalSubmit struct {
+ ProposalSubmit *v1alpha14.ProposalSubmit `protobuf:"bytes,18,opt,name=proposal_submit,json=proposalSubmit,proto3,oneof" json:"proposal_submit,omitempty"`
+}
+type Action_ProposalWithdraw struct {
+ ProposalWithdraw *v1alpha14.ProposalWithdraw `protobuf:"bytes,19,opt,name=proposal_withdraw,json=proposalWithdraw,proto3,oneof" json:"proposal_withdraw,omitempty"`
+}
+type Action_ValidatorVote struct {
+ ValidatorVote *v1alpha14.ValidatorVote `protobuf:"bytes,20,opt,name=validator_vote,json=validatorVote,proto3,oneof" json:"validator_vote,omitempty"`
+}
+type Action_DelegatorVote struct {
+ DelegatorVote *v1alpha14.DelegatorVote `protobuf:"bytes,21,opt,name=delegator_vote,json=delegatorVote,proto3,oneof" json:"delegator_vote,omitempty"`
+}
+type Action_ProposalDepositClaim struct {
+ ProposalDepositClaim *v1alpha14.ProposalDepositClaim `protobuf:"bytes,22,opt,name=proposal_deposit_claim,json=proposalDepositClaim,proto3,oneof" json:"proposal_deposit_claim,omitempty"`
+}
+type Action_PositionOpen struct {
+ PositionOpen *v1alpha11.PositionOpen `protobuf:"bytes,30,opt,name=position_open,json=positionOpen,proto3,oneof" json:"position_open,omitempty"`
+}
+type Action_PositionClose struct {
+ PositionClose *v1alpha11.PositionClose `protobuf:"bytes,31,opt,name=position_close,json=positionClose,proto3,oneof" json:"position_close,omitempty"`
+}
+type Action_PositionWithdraw struct {
+ PositionWithdraw *v1alpha11.PositionWithdraw `protobuf:"bytes,32,opt,name=position_withdraw,json=positionWithdraw,proto3,oneof" json:"position_withdraw,omitempty"`
+}
+type Action_PositionRewardClaim struct {
+ PositionRewardClaim *v1alpha11.PositionRewardClaim `protobuf:"bytes,34,opt,name=position_reward_claim,json=positionRewardClaim,proto3,oneof" json:"position_reward_claim,omitempty"`
+}
+type Action_Delegate struct {
+ Delegate *v1alpha12.Delegate `protobuf:"bytes,40,opt,name=delegate,proto3,oneof" json:"delegate,omitempty"`
+}
+type Action_Undelegate struct {
+ Undelegate *v1alpha12.Undelegate `protobuf:"bytes,41,opt,name=undelegate,proto3,oneof" json:"undelegate,omitempty"`
+}
+type Action_UndelegateClaim struct {
+ UndelegateClaim *v1alpha12.UndelegateClaim `protobuf:"bytes,42,opt,name=undelegate_claim,json=undelegateClaim,proto3,oneof" json:"undelegate_claim,omitempty"`
+}
+type Action_DaoSpend struct {
+ DaoSpend *v1alpha14.DaoSpend `protobuf:"bytes,50,opt,name=dao_spend,json=daoSpend,proto3,oneof" json:"dao_spend,omitempty"`
+}
+type Action_DaoOutput struct {
+ DaoOutput *v1alpha14.DaoOutput `protobuf:"bytes,51,opt,name=dao_output,json=daoOutput,proto3,oneof" json:"dao_output,omitempty"`
+}
+type Action_DaoDeposit struct {
+ DaoDeposit *v1alpha14.DaoDeposit `protobuf:"bytes,52,opt,name=dao_deposit,json=daoDeposit,proto3,oneof" json:"dao_deposit,omitempty"`
+}
+type Action_Ics20Withdrawal struct {
+ Ics20Withdrawal *v1alpha13.Ics20Withdrawal `protobuf:"bytes,200,opt,name=ics20_withdrawal,json=ics20Withdrawal,proto3,oneof" json:"ics20_withdrawal,omitempty"`
+}
+
+func (*Action_Spend) isAction_Action() {}
+func (*Action_Output) isAction_Action() {}
+func (*Action_Swap) isAction_Action() {}
+func (*Action_SwapClaim) isAction_Action() {}
+func (*Action_ValidatorDefinition) isAction_Action() {}
+func (*Action_IbcAction) isAction_Action() {}
+func (*Action_ProposalSubmit) isAction_Action() {}
+func (*Action_ProposalWithdraw) isAction_Action() {}
+func (*Action_ValidatorVote) isAction_Action() {}
+func (*Action_DelegatorVote) isAction_Action() {}
+func (*Action_ProposalDepositClaim) isAction_Action() {}
+func (*Action_PositionOpen) isAction_Action() {}
+func (*Action_PositionClose) isAction_Action() {}
+func (*Action_PositionWithdraw) isAction_Action() {}
+func (*Action_PositionRewardClaim) isAction_Action() {}
+func (*Action_Delegate) isAction_Action() {}
+func (*Action_Undelegate) isAction_Action() {}
+func (*Action_UndelegateClaim) isAction_Action() {}
+func (*Action_DaoSpend) isAction_Action() {}
+func (*Action_DaoOutput) isAction_Action() {}
+func (*Action_DaoDeposit) isAction_Action() {}
+func (*Action_Ics20Withdrawal) isAction_Action() {}
+
+func (m *Action) GetAction() isAction_Action {
+ if m != nil {
+ return m.Action
+ }
+ return nil
+}
+
+func (m *Action) GetSpend() *Spend {
+ if x, ok := m.GetAction().(*Action_Spend); ok {
+ return x.Spend
+ }
+ return nil
+}
+
+func (m *Action) GetOutput() *Output {
+ if x, ok := m.GetAction().(*Action_Output); ok {
+ return x.Output
+ }
+ return nil
+}
+
+func (m *Action) GetSwap() *v1alpha11.Swap {
+ if x, ok := m.GetAction().(*Action_Swap); ok {
+ return x.Swap
+ }
+ return nil
+}
+
+func (m *Action) GetSwapClaim() *v1alpha11.SwapClaim {
+ if x, ok := m.GetAction().(*Action_SwapClaim); ok {
+ return x.SwapClaim
+ }
+ return nil
+}
+
+func (m *Action) GetValidatorDefinition() *v1alpha12.ValidatorDefinition {
+ if x, ok := m.GetAction().(*Action_ValidatorDefinition); ok {
+ return x.ValidatorDefinition
+ }
+ return nil
+}
+
+func (m *Action) GetIbcAction() *v1alpha13.IbcAction {
+ if x, ok := m.GetAction().(*Action_IbcAction); ok {
+ return x.IbcAction
+ }
+ return nil
+}
+
+func (m *Action) GetProposalSubmit() *v1alpha14.ProposalSubmit {
+ if x, ok := m.GetAction().(*Action_ProposalSubmit); ok {
+ return x.ProposalSubmit
+ }
+ return nil
+}
+
+func (m *Action) GetProposalWithdraw() *v1alpha14.ProposalWithdraw {
+ if x, ok := m.GetAction().(*Action_ProposalWithdraw); ok {
+ return x.ProposalWithdraw
+ }
+ return nil
+}
+
+func (m *Action) GetValidatorVote() *v1alpha14.ValidatorVote {
+ if x, ok := m.GetAction().(*Action_ValidatorVote); ok {
+ return x.ValidatorVote
+ }
+ return nil
+}
+
+func (m *Action) GetDelegatorVote() *v1alpha14.DelegatorVote {
+ if x, ok := m.GetAction().(*Action_DelegatorVote); ok {
+ return x.DelegatorVote
+ }
+ return nil
+}
+
+func (m *Action) GetProposalDepositClaim() *v1alpha14.ProposalDepositClaim {
+ if x, ok := m.GetAction().(*Action_ProposalDepositClaim); ok {
+ return x.ProposalDepositClaim
+ }
+ return nil
+}
+
+func (m *Action) GetPositionOpen() *v1alpha11.PositionOpen {
+ if x, ok := m.GetAction().(*Action_PositionOpen); ok {
+ return x.PositionOpen
+ }
+ return nil
+}
+
+func (m *Action) GetPositionClose() *v1alpha11.PositionClose {
+ if x, ok := m.GetAction().(*Action_PositionClose); ok {
+ return x.PositionClose
+ }
+ return nil
+}
+
+func (m *Action) GetPositionWithdraw() *v1alpha11.PositionWithdraw {
+ if x, ok := m.GetAction().(*Action_PositionWithdraw); ok {
+ return x.PositionWithdraw
+ }
+ return nil
+}
+
+func (m *Action) GetPositionRewardClaim() *v1alpha11.PositionRewardClaim {
+ if x, ok := m.GetAction().(*Action_PositionRewardClaim); ok {
+ return x.PositionRewardClaim
+ }
+ return nil
+}
+
+func (m *Action) GetDelegate() *v1alpha12.Delegate {
+ if x, ok := m.GetAction().(*Action_Delegate); ok {
+ return x.Delegate
+ }
+ return nil
+}
+
+func (m *Action) GetUndelegate() *v1alpha12.Undelegate {
+ if x, ok := m.GetAction().(*Action_Undelegate); ok {
+ return x.Undelegate
+ }
+ return nil
+}
+
+func (m *Action) GetUndelegateClaim() *v1alpha12.UndelegateClaim {
+ if x, ok := m.GetAction().(*Action_UndelegateClaim); ok {
+ return x.UndelegateClaim
+ }
+ return nil
+}
+
+func (m *Action) GetDaoSpend() *v1alpha14.DaoSpend {
+ if x, ok := m.GetAction().(*Action_DaoSpend); ok {
+ return x.DaoSpend
+ }
+ return nil
+}
+
+func (m *Action) GetDaoOutput() *v1alpha14.DaoOutput {
+ if x, ok := m.GetAction().(*Action_DaoOutput); ok {
+ return x.DaoOutput
+ }
+ return nil
+}
+
+func (m *Action) GetDaoDeposit() *v1alpha14.DaoDeposit {
+ if x, ok := m.GetAction().(*Action_DaoDeposit); ok {
+ return x.DaoDeposit
+ }
+ return nil
+}
+
+func (m *Action) GetIcs20Withdrawal() *v1alpha13.Ics20Withdrawal {
+ if x, ok := m.GetAction().(*Action_Ics20Withdrawal); ok {
+ return x.Ics20Withdrawal
+ }
+ return nil
+}
+
+// XXX_OneofWrappers is for the internal use of the proto package.
+func (*Action) XXX_OneofWrappers() []interface{} {
+ return []interface{}{
+ (*Action_Spend)(nil),
+ (*Action_Output)(nil),
+ (*Action_Swap)(nil),
+ (*Action_SwapClaim)(nil),
+ (*Action_ValidatorDefinition)(nil),
+ (*Action_IbcAction)(nil),
+ (*Action_ProposalSubmit)(nil),
+ (*Action_ProposalWithdraw)(nil),
+ (*Action_ValidatorVote)(nil),
+ (*Action_DelegatorVote)(nil),
+ (*Action_ProposalDepositClaim)(nil),
+ (*Action_PositionOpen)(nil),
+ (*Action_PositionClose)(nil),
+ (*Action_PositionWithdraw)(nil),
+ (*Action_PositionRewardClaim)(nil),
+ (*Action_Delegate)(nil),
+ (*Action_Undelegate)(nil),
+ (*Action_UndelegateClaim)(nil),
+ (*Action_DaoSpend)(nil),
+ (*Action_DaoOutput)(nil),
+ (*Action_DaoDeposit)(nil),
+ (*Action_Ics20Withdrawal)(nil),
+ }
+}
+
+// A transaction perspective is a bundle of key material and commitment openings
+// that allow generating a view of a transaction from that perspective.
+type TransactionPerspective struct {
+ PayloadKeys []*PayloadKeyWithCommitment `protobuf:"bytes,1,rep,name=payload_keys,json=payloadKeys,proto3" json:"payload_keys,omitempty"`
+ SpendNullifiers []*NullifierWithNote `protobuf:"bytes,2,rep,name=spend_nullifiers,json=spendNullifiers,proto3" json:"spend_nullifiers,omitempty"`
+ // The openings of note commitments referred to in the transaction
+ // but not included in the transaction.
+ AdviceNotes []*v1alpha1.Note `protobuf:"bytes,3,rep,name=advice_notes,json=adviceNotes,proto3" json:"advice_notes,omitempty"`
+ // Any relevant address views.
+ AddressViews []*v1alpha1.AddressView `protobuf:"bytes,4,rep,name=address_views,json=addressViews,proto3" json:"address_views,omitempty"`
+ // Any relevant denoms for viewed assets.
+ Denoms []*v1alpha1.DenomMetadata `protobuf:"bytes,5,rep,name=denoms,proto3" json:"denoms,omitempty"`
+ // The transaction ID associated with this TransactionPerspective
+ TransactionId *Id `protobuf:"bytes,6,opt,name=transaction_id,json=transactionId,proto3" json:"transaction_id,omitempty"`
+}
+
+func (m *TransactionPerspective) Reset() { *m = TransactionPerspective{} }
+func (m *TransactionPerspective) String() string { return proto.CompactTextString(m) }
+func (*TransactionPerspective) ProtoMessage() {}
+func (*TransactionPerspective) Descriptor() ([]byte, []int) {
+ return fileDescriptor_cd20ea79758052c4, []int{8}
+}
+func (m *TransactionPerspective) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *TransactionPerspective) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_TransactionPerspective.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *TransactionPerspective) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_TransactionPerspective.Merge(m, src)
+}
+func (m *TransactionPerspective) XXX_Size() int {
+ return m.Size()
+}
+func (m *TransactionPerspective) XXX_DiscardUnknown() {
+ xxx_messageInfo_TransactionPerspective.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_TransactionPerspective proto.InternalMessageInfo
+
+func (m *TransactionPerspective) GetPayloadKeys() []*PayloadKeyWithCommitment {
+ if m != nil {
+ return m.PayloadKeys
+ }
+ return nil
+}
+
+func (m *TransactionPerspective) GetSpendNullifiers() []*NullifierWithNote {
+ if m != nil {
+ return m.SpendNullifiers
+ }
+ return nil
+}
+
+func (m *TransactionPerspective) GetAdviceNotes() []*v1alpha1.Note {
+ if m != nil {
+ return m.AdviceNotes
+ }
+ return nil
+}
+
+func (m *TransactionPerspective) GetAddressViews() []*v1alpha1.AddressView {
+ if m != nil {
+ return m.AddressViews
+ }
+ return nil
+}
+
+func (m *TransactionPerspective) GetDenoms() []*v1alpha1.DenomMetadata {
+ if m != nil {
+ return m.Denoms
+ }
+ return nil
+}
+
+func (m *TransactionPerspective) GetTransactionId() *Id {
+ if m != nil {
+ return m.TransactionId
+ }
+ return nil
+}
+
+type PayloadKey struct {
+ Inner []byte `protobuf:"bytes,1,opt,name=inner,proto3" json:"inner,omitempty"`
+}
+
+func (m *PayloadKey) Reset() { *m = PayloadKey{} }
+func (m *PayloadKey) String() string { return proto.CompactTextString(m) }
+func (*PayloadKey) ProtoMessage() {}
+func (*PayloadKey) Descriptor() ([]byte, []int) {
+ return fileDescriptor_cd20ea79758052c4, []int{9}
+}
+func (m *PayloadKey) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *PayloadKey) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_PayloadKey.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *PayloadKey) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_PayloadKey.Merge(m, src)
+}
+func (m *PayloadKey) XXX_Size() int {
+ return m.Size()
+}
+func (m *PayloadKey) XXX_DiscardUnknown() {
+ xxx_messageInfo_PayloadKey.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_PayloadKey proto.InternalMessageInfo
+
+func (m *PayloadKey) GetInner() []byte {
+ if m != nil {
+ return m.Inner
+ }
+ return nil
+}
+
+type PayloadKeyWithCommitment struct {
+ PayloadKey *PayloadKey `protobuf:"bytes,1,opt,name=payload_key,json=payloadKey,proto3" json:"payload_key,omitempty"`
+ Commitment *v1alpha1.StateCommitment `protobuf:"bytes,2,opt,name=commitment,proto3" json:"commitment,omitempty"`
+}
+
+func (m *PayloadKeyWithCommitment) Reset() { *m = PayloadKeyWithCommitment{} }
+func (m *PayloadKeyWithCommitment) String() string { return proto.CompactTextString(m) }
+func (*PayloadKeyWithCommitment) ProtoMessage() {}
+func (*PayloadKeyWithCommitment) Descriptor() ([]byte, []int) {
+ return fileDescriptor_cd20ea79758052c4, []int{10}
+}
+func (m *PayloadKeyWithCommitment) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *PayloadKeyWithCommitment) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_PayloadKeyWithCommitment.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *PayloadKeyWithCommitment) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_PayloadKeyWithCommitment.Merge(m, src)
+}
+func (m *PayloadKeyWithCommitment) XXX_Size() int {
+ return m.Size()
+}
+func (m *PayloadKeyWithCommitment) XXX_DiscardUnknown() {
+ xxx_messageInfo_PayloadKeyWithCommitment.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_PayloadKeyWithCommitment proto.InternalMessageInfo
+
+func (m *PayloadKeyWithCommitment) GetPayloadKey() *PayloadKey {
+ if m != nil {
+ return m.PayloadKey
+ }
+ return nil
+}
+
+func (m *PayloadKeyWithCommitment) GetCommitment() *v1alpha1.StateCommitment {
+ if m != nil {
+ return m.Commitment
+ }
+ return nil
+}
+
+type NullifierWithNote struct {
+ Nullifier *v1alpha1.Nullifier `protobuf:"bytes,1,opt,name=nullifier,proto3" json:"nullifier,omitempty"`
+ Note *v1alpha1.Note `protobuf:"bytes,2,opt,name=note,proto3" json:"note,omitempty"`
+}
+
+func (m *NullifierWithNote) Reset() { *m = NullifierWithNote{} }
+func (m *NullifierWithNote) String() string { return proto.CompactTextString(m) }
+func (*NullifierWithNote) ProtoMessage() {}
+func (*NullifierWithNote) Descriptor() ([]byte, []int) {
+ return fileDescriptor_cd20ea79758052c4, []int{11}
+}
+func (m *NullifierWithNote) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *NullifierWithNote) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_NullifierWithNote.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *NullifierWithNote) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_NullifierWithNote.Merge(m, src)
+}
+func (m *NullifierWithNote) XXX_Size() int {
+ return m.Size()
+}
+func (m *NullifierWithNote) XXX_DiscardUnknown() {
+ xxx_messageInfo_NullifierWithNote.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_NullifierWithNote proto.InternalMessageInfo
+
+func (m *NullifierWithNote) GetNullifier() *v1alpha1.Nullifier {
+ if m != nil {
+ return m.Nullifier
+ }
+ return nil
+}
+
+func (m *NullifierWithNote) GetNote() *v1alpha1.Note {
+ if m != nil {
+ return m.Note
+ }
+ return nil
+}
+
+// View of a Penumbra transaction.
+type TransactionView struct {
+ // View of the transaction body
+ BodyView *TransactionBodyView `protobuf:"bytes,1,opt,name=body_view,json=bodyView,proto3" json:"body_view,omitempty"`
+ // The binding signature is stored separately from the transaction body that it signs.
+ BindingSig []byte `protobuf:"bytes,2,opt,name=binding_sig,json=bindingSig,proto3" json:"binding_sig,omitempty"`
+ // The root of some previous state of the state commitment tree, used as an anchor for all
+ // ZK state transition proofs.
+ Anchor *v1alpha1.MerkleRoot `protobuf:"bytes,3,opt,name=anchor,proto3" json:"anchor,omitempty"`
+}
+
+func (m *TransactionView) Reset() { *m = TransactionView{} }
+func (m *TransactionView) String() string { return proto.CompactTextString(m) }
+func (*TransactionView) ProtoMessage() {}
+func (*TransactionView) Descriptor() ([]byte, []int) {
+ return fileDescriptor_cd20ea79758052c4, []int{12}
+}
+func (m *TransactionView) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *TransactionView) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_TransactionView.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *TransactionView) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_TransactionView.Merge(m, src)
+}
+func (m *TransactionView) XXX_Size() int {
+ return m.Size()
+}
+func (m *TransactionView) XXX_DiscardUnknown() {
+ xxx_messageInfo_TransactionView.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_TransactionView proto.InternalMessageInfo
+
+func (m *TransactionView) GetBodyView() *TransactionBodyView {
+ if m != nil {
+ return m.BodyView
+ }
+ return nil
+}
+
+func (m *TransactionView) GetBindingSig() []byte {
+ if m != nil {
+ return m.BindingSig
+ }
+ return nil
+}
+
+func (m *TransactionView) GetAnchor() *v1alpha1.MerkleRoot {
+ if m != nil {
+ return m.Anchor
+ }
+ return nil
+}
+
+type TransactionBodyView struct {
+ // A list views into of actions (state changes) performed by this transaction.
+ ActionViews []*ActionView `protobuf:"bytes,1,rep,name=action_views,json=actionViews,proto3" json:"action_views,omitempty"`
+ // Transaction parameters.
+ TransactionParameters *TransactionParameters `protobuf:"bytes,2,opt,name=transaction_parameters,json=transactionParameters,proto3" json:"transaction_parameters,omitempty"`
+ // The transaction fee.
+ Fee *v1alpha1.Fee `protobuf:"bytes,3,opt,name=fee,proto3" json:"fee,omitempty"`
+ // Types that are valid to be assigned to XDetectionData:
+ //
+ // *TransactionBodyView_DetectionData
+ XDetectionData isTransactionBodyView_XDetectionData `protobuf_oneof:"_detection_data"`
+ // Types that are valid to be assigned to XMemoView:
+ //
+ // *TransactionBodyView_MemoView
+ XMemoView isTransactionBodyView_XMemoView `protobuf_oneof:"_memo_view"`
+}
+
+func (m *TransactionBodyView) Reset() { *m = TransactionBodyView{} }
+func (m *TransactionBodyView) String() string { return proto.CompactTextString(m) }
+func (*TransactionBodyView) ProtoMessage() {}
+func (*TransactionBodyView) Descriptor() ([]byte, []int) {
+ return fileDescriptor_cd20ea79758052c4, []int{13}
+}
+func (m *TransactionBodyView) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *TransactionBodyView) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_TransactionBodyView.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *TransactionBodyView) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_TransactionBodyView.Merge(m, src)
+}
+func (m *TransactionBodyView) XXX_Size() int {
+ return m.Size()
+}
+func (m *TransactionBodyView) XXX_DiscardUnknown() {
+ xxx_messageInfo_TransactionBodyView.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_TransactionBodyView proto.InternalMessageInfo
+
+type isTransactionBodyView_XDetectionData interface {
+ isTransactionBodyView_XDetectionData()
+ MarshalTo([]byte) (int, error)
+ Size() int
+}
+type isTransactionBodyView_XMemoView interface {
+ isTransactionBodyView_XMemoView()
+ MarshalTo([]byte) (int, error)
+ Size() int
+}
+
+type TransactionBodyView_DetectionData struct {
+ DetectionData *DetectionData `protobuf:"bytes,4,opt,name=detection_data,json=detectionData,proto3,oneof" json:"detection_data,omitempty"`
+}
+type TransactionBodyView_MemoView struct {
+ MemoView *MemoView `protobuf:"bytes,5,opt,name=memo_view,json=memoView,proto3,oneof" json:"memo_view,omitempty"`
+}
+
+func (*TransactionBodyView_DetectionData) isTransactionBodyView_XDetectionData() {}
+func (*TransactionBodyView_MemoView) isTransactionBodyView_XMemoView() {}
+
+func (m *TransactionBodyView) GetXDetectionData() isTransactionBodyView_XDetectionData {
+ if m != nil {
+ return m.XDetectionData
+ }
+ return nil
+}
+func (m *TransactionBodyView) GetXMemoView() isTransactionBodyView_XMemoView {
+ if m != nil {
+ return m.XMemoView
+ }
+ return nil
+}
+
+func (m *TransactionBodyView) GetActionViews() []*ActionView {
+ if m != nil {
+ return m.ActionViews
+ }
+ return nil
+}
+
+func (m *TransactionBodyView) GetTransactionParameters() *TransactionParameters {
+ if m != nil {
+ return m.TransactionParameters
+ }
+ return nil
+}
+
+func (m *TransactionBodyView) GetFee() *v1alpha1.Fee {
+ if m != nil {
+ return m.Fee
+ }
+ return nil
+}
+
+func (m *TransactionBodyView) GetDetectionData() *DetectionData {
+ if x, ok := m.GetXDetectionData().(*TransactionBodyView_DetectionData); ok {
+ return x.DetectionData
+ }
+ return nil
+}
+
+func (m *TransactionBodyView) GetMemoView() *MemoView {
+ if x, ok := m.GetXMemoView().(*TransactionBodyView_MemoView); ok {
+ return x.MemoView
+ }
+ return nil
+}
+
+// XXX_OneofWrappers is for the internal use of the proto package.
+func (*TransactionBodyView) XXX_OneofWrappers() []interface{} {
+ return []interface{}{
+ (*TransactionBodyView_DetectionData)(nil),
+ (*TransactionBodyView_MemoView)(nil),
+ }
+}
+
+// A view of a specific state change action performed by a transaction.
+type ActionView struct {
+ // Types that are valid to be assigned to ActionView:
+ //
+ // *ActionView_Spend
+ // *ActionView_Output
+ // *ActionView_Swap
+ // *ActionView_SwapClaim
+ // *ActionView_ValidatorDefinition
+ // *ActionView_IbcAction
+ // *ActionView_ProposalSubmit
+ // *ActionView_ProposalWithdraw
+ // *ActionView_ValidatorVote
+ // *ActionView_DelegatorVote
+ // *ActionView_ProposalDepositClaim
+ // *ActionView_PositionOpen
+ // *ActionView_PositionClose
+ // *ActionView_PositionWithdraw
+ // *ActionView_PositionRewardClaim
+ // *ActionView_Delegate
+ // *ActionView_Undelegate
+ // *ActionView_DaoSpend
+ // *ActionView_DaoOutput
+ // *ActionView_DaoDeposit
+ // *ActionView_UndelegateClaim
+ // *ActionView_Ics20Withdrawal
+ ActionView isActionView_ActionView `protobuf_oneof:"action_view"`
+}
+
+func (m *ActionView) Reset() { *m = ActionView{} }
+func (m *ActionView) String() string { return proto.CompactTextString(m) }
+func (*ActionView) ProtoMessage() {}
+func (*ActionView) Descriptor() ([]byte, []int) {
+ return fileDescriptor_cd20ea79758052c4, []int{14}
+}
+func (m *ActionView) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *ActionView) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_ActionView.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *ActionView) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_ActionView.Merge(m, src)
+}
+func (m *ActionView) XXX_Size() int {
+ return m.Size()
+}
+func (m *ActionView) XXX_DiscardUnknown() {
+ xxx_messageInfo_ActionView.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_ActionView proto.InternalMessageInfo
+
+type isActionView_ActionView interface {
+ isActionView_ActionView()
+ MarshalTo([]byte) (int, error)
+ Size() int
+}
+
+type ActionView_Spend struct {
+ Spend *SpendView `protobuf:"bytes,1,opt,name=spend,proto3,oneof" json:"spend,omitempty"`
+}
+type ActionView_Output struct {
+ Output *OutputView `protobuf:"bytes,2,opt,name=output,proto3,oneof" json:"output,omitempty"`
+}
+type ActionView_Swap struct {
+ Swap *v1alpha11.SwapView `protobuf:"bytes,3,opt,name=swap,proto3,oneof" json:"swap,omitempty"`
+}
+type ActionView_SwapClaim struct {
+ SwapClaim *v1alpha11.SwapClaimView `protobuf:"bytes,4,opt,name=swap_claim,json=swapClaim,proto3,oneof" json:"swap_claim,omitempty"`
+}
+type ActionView_ValidatorDefinition struct {
+ ValidatorDefinition *v1alpha12.ValidatorDefinition `protobuf:"bytes,16,opt,name=validator_definition,json=validatorDefinition,proto3,oneof" json:"validator_definition,omitempty"`
+}
+type ActionView_IbcAction struct {
+ IbcAction *v1alpha13.IbcAction `protobuf:"bytes,17,opt,name=ibc_action,json=ibcAction,proto3,oneof" json:"ibc_action,omitempty"`
+}
+type ActionView_ProposalSubmit struct {
+ ProposalSubmit *v1alpha14.ProposalSubmit `protobuf:"bytes,18,opt,name=proposal_submit,json=proposalSubmit,proto3,oneof" json:"proposal_submit,omitempty"`
+}
+type ActionView_ProposalWithdraw struct {
+ ProposalWithdraw *v1alpha14.ProposalWithdraw `protobuf:"bytes,19,opt,name=proposal_withdraw,json=proposalWithdraw,proto3,oneof" json:"proposal_withdraw,omitempty"`
+}
+type ActionView_ValidatorVote struct {
+ ValidatorVote *v1alpha14.ValidatorVote `protobuf:"bytes,20,opt,name=validator_vote,json=validatorVote,proto3,oneof" json:"validator_vote,omitempty"`
+}
+type ActionView_DelegatorVote struct {
+ DelegatorVote *DelegatorVoteView `protobuf:"bytes,21,opt,name=delegator_vote,json=delegatorVote,proto3,oneof" json:"delegator_vote,omitempty"`
+}
+type ActionView_ProposalDepositClaim struct {
+ ProposalDepositClaim *v1alpha14.ProposalDepositClaim `protobuf:"bytes,22,opt,name=proposal_deposit_claim,json=proposalDepositClaim,proto3,oneof" json:"proposal_deposit_claim,omitempty"`
+}
+type ActionView_PositionOpen struct {
+ PositionOpen *v1alpha11.PositionOpen `protobuf:"bytes,30,opt,name=position_open,json=positionOpen,proto3,oneof" json:"position_open,omitempty"`
+}
+type ActionView_PositionClose struct {
+ PositionClose *v1alpha11.PositionClose `protobuf:"bytes,31,opt,name=position_close,json=positionClose,proto3,oneof" json:"position_close,omitempty"`
+}
+type ActionView_PositionWithdraw struct {
+ PositionWithdraw *v1alpha11.PositionWithdraw `protobuf:"bytes,32,opt,name=position_withdraw,json=positionWithdraw,proto3,oneof" json:"position_withdraw,omitempty"`
+}
+type ActionView_PositionRewardClaim struct {
+ PositionRewardClaim *v1alpha11.PositionRewardClaim `protobuf:"bytes,34,opt,name=position_reward_claim,json=positionRewardClaim,proto3,oneof" json:"position_reward_claim,omitempty"`
+}
+type ActionView_Delegate struct {
+ Delegate *v1alpha12.Delegate `protobuf:"bytes,41,opt,name=delegate,proto3,oneof" json:"delegate,omitempty"`
+}
+type ActionView_Undelegate struct {
+ Undelegate *v1alpha12.Undelegate `protobuf:"bytes,42,opt,name=undelegate,proto3,oneof" json:"undelegate,omitempty"`
+}
+type ActionView_DaoSpend struct {
+ DaoSpend *v1alpha14.DaoSpend `protobuf:"bytes,50,opt,name=dao_spend,json=daoSpend,proto3,oneof" json:"dao_spend,omitempty"`
+}
+type ActionView_DaoOutput struct {
+ DaoOutput *v1alpha14.DaoOutput `protobuf:"bytes,51,opt,name=dao_output,json=daoOutput,proto3,oneof" json:"dao_output,omitempty"`
+}
+type ActionView_DaoDeposit struct {
+ DaoDeposit *v1alpha14.DaoDeposit `protobuf:"bytes,52,opt,name=dao_deposit,json=daoDeposit,proto3,oneof" json:"dao_deposit,omitempty"`
+}
+type ActionView_UndelegateClaim struct {
+ UndelegateClaim *v1alpha12.UndelegateClaim `protobuf:"bytes,43,opt,name=undelegate_claim,json=undelegateClaim,proto3,oneof" json:"undelegate_claim,omitempty"`
+}
+type ActionView_Ics20Withdrawal struct {
+ Ics20Withdrawal *v1alpha13.Ics20Withdrawal `protobuf:"bytes,200,opt,name=ics20_withdrawal,json=ics20Withdrawal,proto3,oneof" json:"ics20_withdrawal,omitempty"`
+}
+
+func (*ActionView_Spend) isActionView_ActionView() {}
+func (*ActionView_Output) isActionView_ActionView() {}
+func (*ActionView_Swap) isActionView_ActionView() {}
+func (*ActionView_SwapClaim) isActionView_ActionView() {}
+func (*ActionView_ValidatorDefinition) isActionView_ActionView() {}
+func (*ActionView_IbcAction) isActionView_ActionView() {}
+func (*ActionView_ProposalSubmit) isActionView_ActionView() {}
+func (*ActionView_ProposalWithdraw) isActionView_ActionView() {}
+func (*ActionView_ValidatorVote) isActionView_ActionView() {}
+func (*ActionView_DelegatorVote) isActionView_ActionView() {}
+func (*ActionView_ProposalDepositClaim) isActionView_ActionView() {}
+func (*ActionView_PositionOpen) isActionView_ActionView() {}
+func (*ActionView_PositionClose) isActionView_ActionView() {}
+func (*ActionView_PositionWithdraw) isActionView_ActionView() {}
+func (*ActionView_PositionRewardClaim) isActionView_ActionView() {}
+func (*ActionView_Delegate) isActionView_ActionView() {}
+func (*ActionView_Undelegate) isActionView_ActionView() {}
+func (*ActionView_DaoSpend) isActionView_ActionView() {}
+func (*ActionView_DaoOutput) isActionView_ActionView() {}
+func (*ActionView_DaoDeposit) isActionView_ActionView() {}
+func (*ActionView_UndelegateClaim) isActionView_ActionView() {}
+func (*ActionView_Ics20Withdrawal) isActionView_ActionView() {}
+
+func (m *ActionView) GetActionView() isActionView_ActionView {
+ if m != nil {
+ return m.ActionView
+ }
+ return nil
+}
+
+func (m *ActionView) GetSpend() *SpendView {
+ if x, ok := m.GetActionView().(*ActionView_Spend); ok {
+ return x.Spend
+ }
+ return nil
+}
+
+func (m *ActionView) GetOutput() *OutputView {
+ if x, ok := m.GetActionView().(*ActionView_Output); ok {
+ return x.Output
+ }
+ return nil
+}
+
+func (m *ActionView) GetSwap() *v1alpha11.SwapView {
+ if x, ok := m.GetActionView().(*ActionView_Swap); ok {
+ return x.Swap
+ }
+ return nil
+}
+
+func (m *ActionView) GetSwapClaim() *v1alpha11.SwapClaimView {
+ if x, ok := m.GetActionView().(*ActionView_SwapClaim); ok {
+ return x.SwapClaim
+ }
+ return nil
+}
+
+func (m *ActionView) GetValidatorDefinition() *v1alpha12.ValidatorDefinition {
+ if x, ok := m.GetActionView().(*ActionView_ValidatorDefinition); ok {
+ return x.ValidatorDefinition
+ }
+ return nil
+}
+
+func (m *ActionView) GetIbcAction() *v1alpha13.IbcAction {
+ if x, ok := m.GetActionView().(*ActionView_IbcAction); ok {
+ return x.IbcAction
+ }
+ return nil
+}
+
+func (m *ActionView) GetProposalSubmit() *v1alpha14.ProposalSubmit {
+ if x, ok := m.GetActionView().(*ActionView_ProposalSubmit); ok {
+ return x.ProposalSubmit
+ }
+ return nil
+}
+
+func (m *ActionView) GetProposalWithdraw() *v1alpha14.ProposalWithdraw {
+ if x, ok := m.GetActionView().(*ActionView_ProposalWithdraw); ok {
+ return x.ProposalWithdraw
+ }
+ return nil
+}
+
+func (m *ActionView) GetValidatorVote() *v1alpha14.ValidatorVote {
+ if x, ok := m.GetActionView().(*ActionView_ValidatorVote); ok {
+ return x.ValidatorVote
+ }
+ return nil
+}
+
+func (m *ActionView) GetDelegatorVote() *DelegatorVoteView {
+ if x, ok := m.GetActionView().(*ActionView_DelegatorVote); ok {
+ return x.DelegatorVote
+ }
+ return nil
+}
+
+func (m *ActionView) GetProposalDepositClaim() *v1alpha14.ProposalDepositClaim {
+ if x, ok := m.GetActionView().(*ActionView_ProposalDepositClaim); ok {
+ return x.ProposalDepositClaim
+ }
+ return nil
+}
+
+func (m *ActionView) GetPositionOpen() *v1alpha11.PositionOpen {
+ if x, ok := m.GetActionView().(*ActionView_PositionOpen); ok {
+ return x.PositionOpen
+ }
+ return nil
+}
+
+func (m *ActionView) GetPositionClose() *v1alpha11.PositionClose {
+ if x, ok := m.GetActionView().(*ActionView_PositionClose); ok {
+ return x.PositionClose
+ }
+ return nil
+}
+
+func (m *ActionView) GetPositionWithdraw() *v1alpha11.PositionWithdraw {
+ if x, ok := m.GetActionView().(*ActionView_PositionWithdraw); ok {
+ return x.PositionWithdraw
+ }
+ return nil
+}
+
+func (m *ActionView) GetPositionRewardClaim() *v1alpha11.PositionRewardClaim {
+ if x, ok := m.GetActionView().(*ActionView_PositionRewardClaim); ok {
+ return x.PositionRewardClaim
+ }
+ return nil
+}
+
+func (m *ActionView) GetDelegate() *v1alpha12.Delegate {
+ if x, ok := m.GetActionView().(*ActionView_Delegate); ok {
+ return x.Delegate
+ }
+ return nil
+}
+
+func (m *ActionView) GetUndelegate() *v1alpha12.Undelegate {
+ if x, ok := m.GetActionView().(*ActionView_Undelegate); ok {
+ return x.Undelegate
+ }
+ return nil
+}
+
+func (m *ActionView) GetDaoSpend() *v1alpha14.DaoSpend {
+ if x, ok := m.GetActionView().(*ActionView_DaoSpend); ok {
+ return x.DaoSpend
+ }
+ return nil
+}
+
+func (m *ActionView) GetDaoOutput() *v1alpha14.DaoOutput {
+ if x, ok := m.GetActionView().(*ActionView_DaoOutput); ok {
+ return x.DaoOutput
+ }
+ return nil
+}
+
+func (m *ActionView) GetDaoDeposit() *v1alpha14.DaoDeposit {
+ if x, ok := m.GetActionView().(*ActionView_DaoDeposit); ok {
+ return x.DaoDeposit
+ }
+ return nil
+}
+
+func (m *ActionView) GetUndelegateClaim() *v1alpha12.UndelegateClaim {
+ if x, ok := m.GetActionView().(*ActionView_UndelegateClaim); ok {
+ return x.UndelegateClaim
+ }
+ return nil
+}
+
+func (m *ActionView) GetIcs20Withdrawal() *v1alpha13.Ics20Withdrawal {
+ if x, ok := m.GetActionView().(*ActionView_Ics20Withdrawal); ok {
+ return x.Ics20Withdrawal
+ }
+ return nil
+}
+
+// XXX_OneofWrappers is for the internal use of the proto package.
+func (*ActionView) XXX_OneofWrappers() []interface{} {
+ return []interface{}{
+ (*ActionView_Spend)(nil),
+ (*ActionView_Output)(nil),
+ (*ActionView_Swap)(nil),
+ (*ActionView_SwapClaim)(nil),
+ (*ActionView_ValidatorDefinition)(nil),
+ (*ActionView_IbcAction)(nil),
+ (*ActionView_ProposalSubmit)(nil),
+ (*ActionView_ProposalWithdraw)(nil),
+ (*ActionView_ValidatorVote)(nil),
+ (*ActionView_DelegatorVote)(nil),
+ (*ActionView_ProposalDepositClaim)(nil),
+ (*ActionView_PositionOpen)(nil),
+ (*ActionView_PositionClose)(nil),
+ (*ActionView_PositionWithdraw)(nil),
+ (*ActionView_PositionRewardClaim)(nil),
+ (*ActionView_Delegate)(nil),
+ (*ActionView_Undelegate)(nil),
+ (*ActionView_DaoSpend)(nil),
+ (*ActionView_DaoOutput)(nil),
+ (*ActionView_DaoDeposit)(nil),
+ (*ActionView_UndelegateClaim)(nil),
+ (*ActionView_Ics20Withdrawal)(nil),
+ }
+}
+
+type SpendView struct {
+ // Types that are valid to be assigned to SpendView:
+ //
+ // *SpendView_Visible_
+ // *SpendView_Opaque_
+ SpendView isSpendView_SpendView `protobuf_oneof:"spend_view"`
+}
+
+func (m *SpendView) Reset() { *m = SpendView{} }
+func (m *SpendView) String() string { return proto.CompactTextString(m) }
+func (*SpendView) ProtoMessage() {}
+func (*SpendView) Descriptor() ([]byte, []int) {
+ return fileDescriptor_cd20ea79758052c4, []int{15}
+}
+func (m *SpendView) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *SpendView) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_SpendView.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *SpendView) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_SpendView.Merge(m, src)
+}
+func (m *SpendView) XXX_Size() int {
+ return m.Size()
+}
+func (m *SpendView) XXX_DiscardUnknown() {
+ xxx_messageInfo_SpendView.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_SpendView proto.InternalMessageInfo
+
+type isSpendView_SpendView interface {
+ isSpendView_SpendView()
+ MarshalTo([]byte) (int, error)
+ Size() int
+}
+
+type SpendView_Visible_ struct {
+ Visible *SpendView_Visible `protobuf:"bytes,1,opt,name=visible,proto3,oneof" json:"visible,omitempty"`
+}
+type SpendView_Opaque_ struct {
+ Opaque *SpendView_Opaque `protobuf:"bytes,2,opt,name=opaque,proto3,oneof" json:"opaque,omitempty"`
+}
+
+func (*SpendView_Visible_) isSpendView_SpendView() {}
+func (*SpendView_Opaque_) isSpendView_SpendView() {}
+
+func (m *SpendView) GetSpendView() isSpendView_SpendView {
+ if m != nil {
+ return m.SpendView
+ }
+ return nil
+}
+
+func (m *SpendView) GetVisible() *SpendView_Visible {
+ if x, ok := m.GetSpendView().(*SpendView_Visible_); ok {
+ return x.Visible
+ }
+ return nil
+}
+
+func (m *SpendView) GetOpaque() *SpendView_Opaque {
+ if x, ok := m.GetSpendView().(*SpendView_Opaque_); ok {
+ return x.Opaque
+ }
+ return nil
+}
+
+// XXX_OneofWrappers is for the internal use of the proto package.
+func (*SpendView) XXX_OneofWrappers() []interface{} {
+ return []interface{}{
+ (*SpendView_Visible_)(nil),
+ (*SpendView_Opaque_)(nil),
+ }
+}
+
+type SpendView_Visible struct {
+ Spend *Spend `protobuf:"bytes,1,opt,name=spend,proto3" json:"spend,omitempty"`
+ Note *v1alpha1.NoteView `protobuf:"bytes,2,opt,name=note,proto3" json:"note,omitempty"`
+}
+
+func (m *SpendView_Visible) Reset() { *m = SpendView_Visible{} }
+func (m *SpendView_Visible) String() string { return proto.CompactTextString(m) }
+func (*SpendView_Visible) ProtoMessage() {}
+func (*SpendView_Visible) Descriptor() ([]byte, []int) {
+ return fileDescriptor_cd20ea79758052c4, []int{15, 0}
+}
+func (m *SpendView_Visible) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *SpendView_Visible) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_SpendView_Visible.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *SpendView_Visible) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_SpendView_Visible.Merge(m, src)
+}
+func (m *SpendView_Visible) XXX_Size() int {
+ return m.Size()
+}
+func (m *SpendView_Visible) XXX_DiscardUnknown() {
+ xxx_messageInfo_SpendView_Visible.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_SpendView_Visible proto.InternalMessageInfo
+
+func (m *SpendView_Visible) GetSpend() *Spend {
+ if m != nil {
+ return m.Spend
+ }
+ return nil
+}
+
+func (m *SpendView_Visible) GetNote() *v1alpha1.NoteView {
+ if m != nil {
+ return m.Note
+ }
+ return nil
+}
+
+type SpendView_Opaque struct {
+ Spend *Spend `protobuf:"bytes,1,opt,name=spend,proto3" json:"spend,omitempty"`
+}
+
+func (m *SpendView_Opaque) Reset() { *m = SpendView_Opaque{} }
+func (m *SpendView_Opaque) String() string { return proto.CompactTextString(m) }
+func (*SpendView_Opaque) ProtoMessage() {}
+func (*SpendView_Opaque) Descriptor() ([]byte, []int) {
+ return fileDescriptor_cd20ea79758052c4, []int{15, 1}
+}
+func (m *SpendView_Opaque) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *SpendView_Opaque) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_SpendView_Opaque.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *SpendView_Opaque) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_SpendView_Opaque.Merge(m, src)
+}
+func (m *SpendView_Opaque) XXX_Size() int {
+ return m.Size()
+}
+func (m *SpendView_Opaque) XXX_DiscardUnknown() {
+ xxx_messageInfo_SpendView_Opaque.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_SpendView_Opaque proto.InternalMessageInfo
+
+func (m *SpendView_Opaque) GetSpend() *Spend {
+ if m != nil {
+ return m.Spend
+ }
+ return nil
+}
+
+type DelegatorVoteView struct {
+ // Types that are valid to be assigned to DelegatorVote:
+ //
+ // *DelegatorVoteView_Visible_
+ // *DelegatorVoteView_Opaque_
+ DelegatorVote isDelegatorVoteView_DelegatorVote `protobuf_oneof:"delegator_vote"`
+}
+
+func (m *DelegatorVoteView) Reset() { *m = DelegatorVoteView{} }
+func (m *DelegatorVoteView) String() string { return proto.CompactTextString(m) }
+func (*DelegatorVoteView) ProtoMessage() {}
+func (*DelegatorVoteView) Descriptor() ([]byte, []int) {
+ return fileDescriptor_cd20ea79758052c4, []int{16}
+}
+func (m *DelegatorVoteView) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *DelegatorVoteView) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_DelegatorVoteView.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *DelegatorVoteView) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_DelegatorVoteView.Merge(m, src)
+}
+func (m *DelegatorVoteView) XXX_Size() int {
+ return m.Size()
+}
+func (m *DelegatorVoteView) XXX_DiscardUnknown() {
+ xxx_messageInfo_DelegatorVoteView.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_DelegatorVoteView proto.InternalMessageInfo
+
+type isDelegatorVoteView_DelegatorVote interface {
+ isDelegatorVoteView_DelegatorVote()
+ MarshalTo([]byte) (int, error)
+ Size() int
+}
+
+type DelegatorVoteView_Visible_ struct {
+ Visible *DelegatorVoteView_Visible `protobuf:"bytes,1,opt,name=visible,proto3,oneof" json:"visible,omitempty"`
+}
+type DelegatorVoteView_Opaque_ struct {
+ Opaque *DelegatorVoteView_Opaque `protobuf:"bytes,2,opt,name=opaque,proto3,oneof" json:"opaque,omitempty"`
+}
+
+func (*DelegatorVoteView_Visible_) isDelegatorVoteView_DelegatorVote() {}
+func (*DelegatorVoteView_Opaque_) isDelegatorVoteView_DelegatorVote() {}
+
+func (m *DelegatorVoteView) GetDelegatorVote() isDelegatorVoteView_DelegatorVote {
+ if m != nil {
+ return m.DelegatorVote
+ }
+ return nil
+}
+
+func (m *DelegatorVoteView) GetVisible() *DelegatorVoteView_Visible {
+ if x, ok := m.GetDelegatorVote().(*DelegatorVoteView_Visible_); ok {
+ return x.Visible
+ }
+ return nil
+}
+
+func (m *DelegatorVoteView) GetOpaque() *DelegatorVoteView_Opaque {
+ if x, ok := m.GetDelegatorVote().(*DelegatorVoteView_Opaque_); ok {
+ return x.Opaque
+ }
+ return nil
+}
+
+// XXX_OneofWrappers is for the internal use of the proto package.
+func (*DelegatorVoteView) XXX_OneofWrappers() []interface{} {
+ return []interface{}{
+ (*DelegatorVoteView_Visible_)(nil),
+ (*DelegatorVoteView_Opaque_)(nil),
+ }
+}
+
+type DelegatorVoteView_Visible struct {
+ DelegatorVote *v1alpha14.DelegatorVote `protobuf:"bytes,1,opt,name=delegator_vote,json=delegatorVote,proto3" json:"delegator_vote,omitempty"`
+ Note *v1alpha1.NoteView `protobuf:"bytes,2,opt,name=note,proto3" json:"note,omitempty"`
+}
+
+func (m *DelegatorVoteView_Visible) Reset() { *m = DelegatorVoteView_Visible{} }
+func (m *DelegatorVoteView_Visible) String() string { return proto.CompactTextString(m) }
+func (*DelegatorVoteView_Visible) ProtoMessage() {}
+func (*DelegatorVoteView_Visible) Descriptor() ([]byte, []int) {
+ return fileDescriptor_cd20ea79758052c4, []int{16, 0}
+}
+func (m *DelegatorVoteView_Visible) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *DelegatorVoteView_Visible) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_DelegatorVoteView_Visible.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *DelegatorVoteView_Visible) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_DelegatorVoteView_Visible.Merge(m, src)
+}
+func (m *DelegatorVoteView_Visible) XXX_Size() int {
+ return m.Size()
+}
+func (m *DelegatorVoteView_Visible) XXX_DiscardUnknown() {
+ xxx_messageInfo_DelegatorVoteView_Visible.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_DelegatorVoteView_Visible proto.InternalMessageInfo
+
+func (m *DelegatorVoteView_Visible) GetDelegatorVote() *v1alpha14.DelegatorVote {
+ if m != nil {
+ return m.DelegatorVote
+ }
+ return nil
+}
+
+func (m *DelegatorVoteView_Visible) GetNote() *v1alpha1.NoteView {
+ if m != nil {
+ return m.Note
+ }
+ return nil
+}
+
+type DelegatorVoteView_Opaque struct {
+ DelegatorVote *v1alpha14.DelegatorVote `protobuf:"bytes,1,opt,name=delegator_vote,json=delegatorVote,proto3" json:"delegator_vote,omitempty"`
+}
+
+func (m *DelegatorVoteView_Opaque) Reset() { *m = DelegatorVoteView_Opaque{} }
+func (m *DelegatorVoteView_Opaque) String() string { return proto.CompactTextString(m) }
+func (*DelegatorVoteView_Opaque) ProtoMessage() {}
+func (*DelegatorVoteView_Opaque) Descriptor() ([]byte, []int) {
+ return fileDescriptor_cd20ea79758052c4, []int{16, 1}
+}
+func (m *DelegatorVoteView_Opaque) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *DelegatorVoteView_Opaque) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_DelegatorVoteView_Opaque.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *DelegatorVoteView_Opaque) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_DelegatorVoteView_Opaque.Merge(m, src)
+}
+func (m *DelegatorVoteView_Opaque) XXX_Size() int {
+ return m.Size()
+}
+func (m *DelegatorVoteView_Opaque) XXX_DiscardUnknown() {
+ xxx_messageInfo_DelegatorVoteView_Opaque.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_DelegatorVoteView_Opaque proto.InternalMessageInfo
+
+func (m *DelegatorVoteView_Opaque) GetDelegatorVote() *v1alpha14.DelegatorVote {
+ if m != nil {
+ return m.DelegatorVote
+ }
+ return nil
+}
+
+type OutputView struct {
+ // Types that are valid to be assigned to OutputView:
+ //
+ // *OutputView_Visible_
+ // *OutputView_Opaque_
+ OutputView isOutputView_OutputView `protobuf_oneof:"output_view"`
+}
+
+func (m *OutputView) Reset() { *m = OutputView{} }
+func (m *OutputView) String() string { return proto.CompactTextString(m) }
+func (*OutputView) ProtoMessage() {}
+func (*OutputView) Descriptor() ([]byte, []int) {
+ return fileDescriptor_cd20ea79758052c4, []int{17}
+}
+func (m *OutputView) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *OutputView) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_OutputView.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *OutputView) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_OutputView.Merge(m, src)
+}
+func (m *OutputView) XXX_Size() int {
+ return m.Size()
+}
+func (m *OutputView) XXX_DiscardUnknown() {
+ xxx_messageInfo_OutputView.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_OutputView proto.InternalMessageInfo
+
+type isOutputView_OutputView interface {
+ isOutputView_OutputView()
+ MarshalTo([]byte) (int, error)
+ Size() int
+}
+
+type OutputView_Visible_ struct {
+ Visible *OutputView_Visible `protobuf:"bytes,1,opt,name=visible,proto3,oneof" json:"visible,omitempty"`
+}
+type OutputView_Opaque_ struct {
+ Opaque *OutputView_Opaque `protobuf:"bytes,2,opt,name=opaque,proto3,oneof" json:"opaque,omitempty"`
+}
+
+func (*OutputView_Visible_) isOutputView_OutputView() {}
+func (*OutputView_Opaque_) isOutputView_OutputView() {}
+
+func (m *OutputView) GetOutputView() isOutputView_OutputView {
+ if m != nil {
+ return m.OutputView
+ }
+ return nil
+}
+
+func (m *OutputView) GetVisible() *OutputView_Visible {
+ if x, ok := m.GetOutputView().(*OutputView_Visible_); ok {
+ return x.Visible
+ }
+ return nil
+}
+
+func (m *OutputView) GetOpaque() *OutputView_Opaque {
+ if x, ok := m.GetOutputView().(*OutputView_Opaque_); ok {
+ return x.Opaque
+ }
+ return nil
+}
+
+// XXX_OneofWrappers is for the internal use of the proto package.
+func (*OutputView) XXX_OneofWrappers() []interface{} {
+ return []interface{}{
+ (*OutputView_Visible_)(nil),
+ (*OutputView_Opaque_)(nil),
+ }
+}
+
+type OutputView_Visible struct {
+ Output *Output `protobuf:"bytes,1,opt,name=output,proto3" json:"output,omitempty"`
+ Note *v1alpha1.NoteView `protobuf:"bytes,2,opt,name=note,proto3" json:"note,omitempty"`
+ PayloadKey *PayloadKey `protobuf:"bytes,3,opt,name=payload_key,json=payloadKey,proto3" json:"payload_key,omitempty"`
+}
+
+func (m *OutputView_Visible) Reset() { *m = OutputView_Visible{} }
+func (m *OutputView_Visible) String() string { return proto.CompactTextString(m) }
+func (*OutputView_Visible) ProtoMessage() {}
+func (*OutputView_Visible) Descriptor() ([]byte, []int) {
+ return fileDescriptor_cd20ea79758052c4, []int{17, 0}
+}
+func (m *OutputView_Visible) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *OutputView_Visible) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_OutputView_Visible.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *OutputView_Visible) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_OutputView_Visible.Merge(m, src)
+}
+func (m *OutputView_Visible) XXX_Size() int {
+ return m.Size()
+}
+func (m *OutputView_Visible) XXX_DiscardUnknown() {
+ xxx_messageInfo_OutputView_Visible.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_OutputView_Visible proto.InternalMessageInfo
+
+func (m *OutputView_Visible) GetOutput() *Output {
+ if m != nil {
+ return m.Output
+ }
+ return nil
+}
+
+func (m *OutputView_Visible) GetNote() *v1alpha1.NoteView {
+ if m != nil {
+ return m.Note
+ }
+ return nil
+}
+
+func (m *OutputView_Visible) GetPayloadKey() *PayloadKey {
+ if m != nil {
+ return m.PayloadKey
+ }
+ return nil
+}
+
+type OutputView_Opaque struct {
+ Output *Output `protobuf:"bytes,1,opt,name=output,proto3" json:"output,omitempty"`
+}
+
+func (m *OutputView_Opaque) Reset() { *m = OutputView_Opaque{} }
+func (m *OutputView_Opaque) String() string { return proto.CompactTextString(m) }
+func (*OutputView_Opaque) ProtoMessage() {}
+func (*OutputView_Opaque) Descriptor() ([]byte, []int) {
+ return fileDescriptor_cd20ea79758052c4, []int{17, 1}
+}
+func (m *OutputView_Opaque) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *OutputView_Opaque) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_OutputView_Opaque.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *OutputView_Opaque) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_OutputView_Opaque.Merge(m, src)
+}
+func (m *OutputView_Opaque) XXX_Size() int {
+ return m.Size()
+}
+func (m *OutputView_Opaque) XXX_DiscardUnknown() {
+ xxx_messageInfo_OutputView_Opaque.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_OutputView_Opaque proto.InternalMessageInfo
+
+func (m *OutputView_Opaque) GetOutput() *Output {
+ if m != nil {
+ return m.Output
+ }
+ return nil
+}
+
+// Spends a shielded note.
+type Spend struct {
+ // The effecting data of the spend.
+ Body *SpendBody `protobuf:"bytes,1,opt,name=body,proto3" json:"body,omitempty"`
+ // The authorizing signature for the spend.
+ AuthSig *v1alpha1.SpendAuthSignature `protobuf:"bytes,2,opt,name=auth_sig,json=authSig,proto3" json:"auth_sig,omitempty"`
+ // The proof that the spend is well-formed is authorizing data.
+ Proof *v1alpha1.ZKSpendProof `protobuf:"bytes,3,opt,name=proof,proto3" json:"proof,omitempty"`
+}
+
+func (m *Spend) Reset() { *m = Spend{} }
+func (m *Spend) String() string { return proto.CompactTextString(m) }
+func (*Spend) ProtoMessage() {}
+func (*Spend) Descriptor() ([]byte, []int) {
+ return fileDescriptor_cd20ea79758052c4, []int{18}
+}
+func (m *Spend) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *Spend) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_Spend.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *Spend) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_Spend.Merge(m, src)
+}
+func (m *Spend) XXX_Size() int {
+ return m.Size()
+}
+func (m *Spend) XXX_DiscardUnknown() {
+ xxx_messageInfo_Spend.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_Spend proto.InternalMessageInfo
+
+func (m *Spend) GetBody() *SpendBody {
+ if m != nil {
+ return m.Body
+ }
+ return nil
+}
+
+func (m *Spend) GetAuthSig() *v1alpha1.SpendAuthSignature {
+ if m != nil {
+ return m.AuthSig
+ }
+ return nil
+}
+
+func (m *Spend) GetProof() *v1alpha1.ZKSpendProof {
+ if m != nil {
+ return m.Proof
+ }
+ return nil
+}
+
+// The body of a spend description, containing only the effecting data
+// describing changes to the ledger, and not the authorizing data that allows
+// those changes to be performed.
+type SpendBody struct {
+ // A commitment to the value of the input note.
+ BalanceCommitment *v1alpha1.BalanceCommitment `protobuf:"bytes,1,opt,name=balance_commitment,json=balanceCommitment,proto3" json:"balance_commitment,omitempty"`
+ // The nullifier of the input note.
+ Nullifier []byte `protobuf:"bytes,3,opt,name=nullifier,proto3" json:"nullifier,omitempty"`
+ // The randomized validating key for the spend authorization signature.
+ Rk []byte `protobuf:"bytes,4,opt,name=rk,proto3" json:"rk,omitempty"`
+}
+
+func (m *SpendBody) Reset() { *m = SpendBody{} }
+func (m *SpendBody) String() string { return proto.CompactTextString(m) }
+func (*SpendBody) ProtoMessage() {}
+func (*SpendBody) Descriptor() ([]byte, []int) {
+ return fileDescriptor_cd20ea79758052c4, []int{19}
+}
+func (m *SpendBody) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *SpendBody) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_SpendBody.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *SpendBody) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_SpendBody.Merge(m, src)
+}
+func (m *SpendBody) XXX_Size() int {
+ return m.Size()
+}
+func (m *SpendBody) XXX_DiscardUnknown() {
+ xxx_messageInfo_SpendBody.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_SpendBody proto.InternalMessageInfo
+
+func (m *SpendBody) GetBalanceCommitment() *v1alpha1.BalanceCommitment {
+ if m != nil {
+ return m.BalanceCommitment
+ }
+ return nil
+}
+
+func (m *SpendBody) GetNullifier() []byte {
+ if m != nil {
+ return m.Nullifier
+ }
+ return nil
+}
+
+func (m *SpendBody) GetRk() []byte {
+ if m != nil {
+ return m.Rk
+ }
+ return nil
+}
+
+// Creates a new shielded note.
+type Output struct {
+ // The effecting data for the output.
+ Body *OutputBody `protobuf:"bytes,1,opt,name=body,proto3" json:"body,omitempty"`
+ // The output proof is authorizing data.
+ Proof *v1alpha1.ZKOutputProof `protobuf:"bytes,2,opt,name=proof,proto3" json:"proof,omitempty"`
+}
+
+func (m *Output) Reset() { *m = Output{} }
+func (m *Output) String() string { return proto.CompactTextString(m) }
+func (*Output) ProtoMessage() {}
+func (*Output) Descriptor() ([]byte, []int) {
+ return fileDescriptor_cd20ea79758052c4, []int{20}
+}
+func (m *Output) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *Output) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_Output.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *Output) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_Output.Merge(m, src)
+}
+func (m *Output) XXX_Size() int {
+ return m.Size()
+}
+func (m *Output) XXX_DiscardUnknown() {
+ xxx_messageInfo_Output.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_Output proto.InternalMessageInfo
+
+func (m *Output) GetBody() *OutputBody {
+ if m != nil {
+ return m.Body
+ }
+ return nil
+}
+
+func (m *Output) GetProof() *v1alpha1.ZKOutputProof {
+ if m != nil {
+ return m.Proof
+ }
+ return nil
+}
+
+// The body of an output description, containing only the effecting data
+// describing changes to the ledger, and not the authorizing data that allows
+// those changes to be performed.
+type OutputBody struct {
+ // The minimal data required to scan and process the new output note.
+ NotePayload *v1alpha1.NotePayload `protobuf:"bytes,1,opt,name=note_payload,json=notePayload,proto3" json:"note_payload,omitempty"`
+ // A commitment to the value of the output note. 32 bytes.
+ BalanceCommitment *v1alpha1.BalanceCommitment `protobuf:"bytes,2,opt,name=balance_commitment,json=balanceCommitment,proto3" json:"balance_commitment,omitempty"`
+ // An encrypted key for decrypting the memo.
+ WrappedMemoKey []byte `protobuf:"bytes,3,opt,name=wrapped_memo_key,json=wrappedMemoKey,proto3" json:"wrapped_memo_key,omitempty"`
+ // The key material used for note encryption, wrapped in encryption to the
+ // sender's outgoing viewing key. 80 bytes.
+ OvkWrappedKey []byte `protobuf:"bytes,4,opt,name=ovk_wrapped_key,json=ovkWrappedKey,proto3" json:"ovk_wrapped_key,omitempty"`
+}
+
+func (m *OutputBody) Reset() { *m = OutputBody{} }
+func (m *OutputBody) String() string { return proto.CompactTextString(m) }
+func (*OutputBody) ProtoMessage() {}
+func (*OutputBody) Descriptor() ([]byte, []int) {
+ return fileDescriptor_cd20ea79758052c4, []int{21}
+}
+func (m *OutputBody) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *OutputBody) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_OutputBody.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *OutputBody) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_OutputBody.Merge(m, src)
+}
+func (m *OutputBody) XXX_Size() int {
+ return m.Size()
+}
+func (m *OutputBody) XXX_DiscardUnknown() {
+ xxx_messageInfo_OutputBody.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_OutputBody proto.InternalMessageInfo
+
+func (m *OutputBody) GetNotePayload() *v1alpha1.NotePayload {
+ if m != nil {
+ return m.NotePayload
+ }
+ return nil
+}
+
+func (m *OutputBody) GetBalanceCommitment() *v1alpha1.BalanceCommitment {
+ if m != nil {
+ return m.BalanceCommitment
+ }
+ return nil
+}
+
+func (m *OutputBody) GetWrappedMemoKey() []byte {
+ if m != nil {
+ return m.WrappedMemoKey
+ }
+ return nil
+}
+
+func (m *OutputBody) GetOvkWrappedKey() []byte {
+ if m != nil {
+ return m.OvkWrappedKey
+ }
+ return nil
+}
+
+// The data required to authorize a transaction plan.
+type AuthorizationData struct {
+ // The computed auth hash for the approved transaction plan.
+ EffectHash *v1alpha1.EffectHash `protobuf:"bytes,1,opt,name=effect_hash,json=effectHash,proto3" json:"effect_hash,omitempty"`
+ // The required spend authorizations, returned in the same order as the
+ // Spend actions in the original request.
+ SpendAuths []*v1alpha1.SpendAuthSignature `protobuf:"bytes,2,rep,name=spend_auths,json=spendAuths,proto3" json:"spend_auths,omitempty"`
+ // The required delegator vote authorizations, returned in the same order as the
+ // DelegatorVote actions in the original request.
+ DelegatorVoteAuths []*v1alpha1.SpendAuthSignature `protobuf:"bytes,3,rep,name=delegator_vote_auths,json=delegatorVoteAuths,proto3" json:"delegator_vote_auths,omitempty"`
+}
+
+func (m *AuthorizationData) Reset() { *m = AuthorizationData{} }
+func (m *AuthorizationData) String() string { return proto.CompactTextString(m) }
+func (*AuthorizationData) ProtoMessage() {}
+func (*AuthorizationData) Descriptor() ([]byte, []int) {
+ return fileDescriptor_cd20ea79758052c4, []int{22}
+}
+func (m *AuthorizationData) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *AuthorizationData) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_AuthorizationData.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *AuthorizationData) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_AuthorizationData.Merge(m, src)
+}
+func (m *AuthorizationData) XXX_Size() int {
+ return m.Size()
+}
+func (m *AuthorizationData) XXX_DiscardUnknown() {
+ xxx_messageInfo_AuthorizationData.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_AuthorizationData proto.InternalMessageInfo
+
+func (m *AuthorizationData) GetEffectHash() *v1alpha1.EffectHash {
+ if m != nil {
+ return m.EffectHash
+ }
+ return nil
+}
+
+func (m *AuthorizationData) GetSpendAuths() []*v1alpha1.SpendAuthSignature {
+ if m != nil {
+ return m.SpendAuths
+ }
+ return nil
+}
+
+func (m *AuthorizationData) GetDelegatorVoteAuths() []*v1alpha1.SpendAuthSignature {
+ if m != nil {
+ return m.DelegatorVoteAuths
+ }
+ return nil
+}
+
+// The data required for proving when building a transaction from a plan.
+type WitnessData struct {
+ // The anchor for the state transition proofs.
+ Anchor *v1alpha1.MerkleRoot `protobuf:"bytes,1,opt,name=anchor,proto3" json:"anchor,omitempty"`
+ // The auth paths for the notes the transaction spends, in the
+ // same order as the spends in the transaction plan.
+ StateCommitmentProofs []*v1alpha1.StateCommitmentProof `protobuf:"bytes,2,rep,name=state_commitment_proofs,json=stateCommitmentProofs,proto3" json:"state_commitment_proofs,omitempty"`
+}
+
+func (m *WitnessData) Reset() { *m = WitnessData{} }
+func (m *WitnessData) String() string { return proto.CompactTextString(m) }
+func (*WitnessData) ProtoMessage() {}
+func (*WitnessData) Descriptor() ([]byte, []int) {
+ return fileDescriptor_cd20ea79758052c4, []int{23}
+}
+func (m *WitnessData) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *WitnessData) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_WitnessData.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *WitnessData) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_WitnessData.Merge(m, src)
+}
+func (m *WitnessData) XXX_Size() int {
+ return m.Size()
+}
+func (m *WitnessData) XXX_DiscardUnknown() {
+ xxx_messageInfo_WitnessData.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_WitnessData proto.InternalMessageInfo
+
+func (m *WitnessData) GetAnchor() *v1alpha1.MerkleRoot {
+ if m != nil {
+ return m.Anchor
+ }
+ return nil
+}
+
+func (m *WitnessData) GetStateCommitmentProofs() []*v1alpha1.StateCommitmentProof {
+ if m != nil {
+ return m.StateCommitmentProofs
+ }
+ return nil
+}
+
+// Describes a planned transaction. Permits clients to prepare a transaction
+// prior submission, so that a user can review it prior to authorizing its execution.
+type TransactionPlan struct {
+ // The planner interface(s) for Actions to be performed, such as a Spend, Swap,
+ // or Delegation. See the ActionPlan docs for a full list of options.
+ Actions []*ActionPlan `protobuf:"bytes,1,rep,name=actions,proto3" json:"actions,omitempty"`
+ // Time, as block height, after which TransactionPlan should be considered invalid.
+ ExpiryHeight uint64 `protobuf:"varint,2,opt,name=expiry_height,json=expiryHeight,proto3" json:"expiry_height,omitempty"`
+ // The name of the network for which this TransactionPlan was built.
+ ChainId string `protobuf:"bytes,3,opt,name=chain_id,json=chainId,proto3" json:"chain_id,omitempty"`
+ Fee *v1alpha1.Fee `protobuf:"bytes,4,opt,name=fee,proto3" json:"fee,omitempty"`
+ CluePlans []*CluePlan `protobuf:"bytes,5,rep,name=clue_plans,json=cluePlans,proto3" json:"clue_plans,omitempty"`
+ // Planning interface for constructing an optional Memo for the Transaction.
+ MemoPlan *MemoPlan `protobuf:"bytes,6,opt,name=memo_plan,json=memoPlan,proto3" json:"memo_plan,omitempty"`
+}
+
+func (m *TransactionPlan) Reset() { *m = TransactionPlan{} }
+func (m *TransactionPlan) String() string { return proto.CompactTextString(m) }
+func (*TransactionPlan) ProtoMessage() {}
+func (*TransactionPlan) Descriptor() ([]byte, []int) {
+ return fileDescriptor_cd20ea79758052c4, []int{24}
+}
+func (m *TransactionPlan) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *TransactionPlan) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_TransactionPlan.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *TransactionPlan) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_TransactionPlan.Merge(m, src)
+}
+func (m *TransactionPlan) XXX_Size() int {
+ return m.Size()
+}
+func (m *TransactionPlan) XXX_DiscardUnknown() {
+ xxx_messageInfo_TransactionPlan.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_TransactionPlan proto.InternalMessageInfo
+
+func (m *TransactionPlan) GetActions() []*ActionPlan {
+ if m != nil {
+ return m.Actions
+ }
+ return nil
+}
+
+func (m *TransactionPlan) GetExpiryHeight() uint64 {
+ if m != nil {
+ return m.ExpiryHeight
+ }
+ return 0
+}
+
+func (m *TransactionPlan) GetChainId() string {
+ if m != nil {
+ return m.ChainId
+ }
+ return ""
+}
+
+func (m *TransactionPlan) GetFee() *v1alpha1.Fee {
+ if m != nil {
+ return m.Fee
+ }
+ return nil
+}
+
+func (m *TransactionPlan) GetCluePlans() []*CluePlan {
+ if m != nil {
+ return m.CluePlans
+ }
+ return nil
+}
+
+func (m *TransactionPlan) GetMemoPlan() *MemoPlan {
+ if m != nil {
+ return m.MemoPlan
+ }
+ return nil
+}
+
+// Describes a planned transaction action.
+//
+// Some transaction Actions don't have any private data and are treated as being plans
+// themselves.
+type ActionPlan struct {
+ // Types that are valid to be assigned to Action:
+ //
+ // *ActionPlan_Spend
+ // *ActionPlan_Output
+ // *ActionPlan_Swap
+ // *ActionPlan_SwapClaim
+ // *ActionPlan_ValidatorDefinition
+ // *ActionPlan_IbcAction
+ // *ActionPlan_ProposalSubmit
+ // *ActionPlan_ProposalWithdraw
+ // *ActionPlan_ValidatorVote
+ // *ActionPlan_DelegatorVote
+ // *ActionPlan_ProposalDepositClaim
+ // *ActionPlan_Withdrawal
+ // *ActionPlan_PositionOpen
+ // *ActionPlan_PositionClose
+ // *ActionPlan_PositionWithdraw
+ // *ActionPlan_PositionRewardClaim
+ // *ActionPlan_Delegate
+ // *ActionPlan_Undelegate
+ // *ActionPlan_UndelegateClaim
+ // *ActionPlan_DaoSpend
+ // *ActionPlan_DaoOutput
+ // *ActionPlan_DaoDeposit
+ Action isActionPlan_Action `protobuf_oneof:"action"`
+}
+
+func (m *ActionPlan) Reset() { *m = ActionPlan{} }
+func (m *ActionPlan) String() string { return proto.CompactTextString(m) }
+func (*ActionPlan) ProtoMessage() {}
+func (*ActionPlan) Descriptor() ([]byte, []int) {
+ return fileDescriptor_cd20ea79758052c4, []int{25}
+}
+func (m *ActionPlan) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *ActionPlan) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_ActionPlan.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *ActionPlan) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_ActionPlan.Merge(m, src)
+}
+func (m *ActionPlan) XXX_Size() int {
+ return m.Size()
+}
+func (m *ActionPlan) XXX_DiscardUnknown() {
+ xxx_messageInfo_ActionPlan.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_ActionPlan proto.InternalMessageInfo
+
+type isActionPlan_Action interface {
+ isActionPlan_Action()
+ MarshalTo([]byte) (int, error)
+ Size() int
+}
+
+type ActionPlan_Spend struct {
+ Spend *SpendPlan `protobuf:"bytes,1,opt,name=spend,proto3,oneof" json:"spend,omitempty"`
+}
+type ActionPlan_Output struct {
+ Output *OutputPlan `protobuf:"bytes,2,opt,name=output,proto3,oneof" json:"output,omitempty"`
+}
+type ActionPlan_Swap struct {
+ Swap *v1alpha11.SwapPlan `protobuf:"bytes,3,opt,name=swap,proto3,oneof" json:"swap,omitempty"`
+}
+type ActionPlan_SwapClaim struct {
+ SwapClaim *v1alpha11.SwapClaimPlan `protobuf:"bytes,4,opt,name=swap_claim,json=swapClaim,proto3,oneof" json:"swap_claim,omitempty"`
+}
+type ActionPlan_ValidatorDefinition struct {
+ ValidatorDefinition *v1alpha12.ValidatorDefinition `protobuf:"bytes,16,opt,name=validator_definition,json=validatorDefinition,proto3,oneof" json:"validator_definition,omitempty"`
+}
+type ActionPlan_IbcAction struct {
+ IbcAction *v1alpha13.IbcAction `protobuf:"bytes,17,opt,name=ibc_action,json=ibcAction,proto3,oneof" json:"ibc_action,omitempty"`
+}
+type ActionPlan_ProposalSubmit struct {
+ ProposalSubmit *v1alpha14.ProposalSubmit `protobuf:"bytes,18,opt,name=proposal_submit,json=proposalSubmit,proto3,oneof" json:"proposal_submit,omitempty"`
+}
+type ActionPlan_ProposalWithdraw struct {
+ ProposalWithdraw *v1alpha14.ProposalWithdraw `protobuf:"bytes,19,opt,name=proposal_withdraw,json=proposalWithdraw,proto3,oneof" json:"proposal_withdraw,omitempty"`
+}
+type ActionPlan_ValidatorVote struct {
+ ValidatorVote *v1alpha14.ValidatorVote `protobuf:"bytes,20,opt,name=validator_vote,json=validatorVote,proto3,oneof" json:"validator_vote,omitempty"`
+}
+type ActionPlan_DelegatorVote struct {
+ DelegatorVote *v1alpha14.DelegatorVotePlan `protobuf:"bytes,21,opt,name=delegator_vote,json=delegatorVote,proto3,oneof" json:"delegator_vote,omitempty"`
+}
+type ActionPlan_ProposalDepositClaim struct {
+ ProposalDepositClaim *v1alpha14.ProposalDepositClaim `protobuf:"bytes,22,opt,name=proposal_deposit_claim,json=proposalDepositClaim,proto3,oneof" json:"proposal_deposit_claim,omitempty"`
+}
+type ActionPlan_Withdrawal struct {
+ Withdrawal *v1alpha13.Ics20Withdrawal `protobuf:"bytes,23,opt,name=withdrawal,proto3,oneof" json:"withdrawal,omitempty"`
+}
+type ActionPlan_PositionOpen struct {
+ PositionOpen *v1alpha11.PositionOpen `protobuf:"bytes,30,opt,name=position_open,json=positionOpen,proto3,oneof" json:"position_open,omitempty"`
+}
+type ActionPlan_PositionClose struct {
+ PositionClose *v1alpha11.PositionClose `protobuf:"bytes,31,opt,name=position_close,json=positionClose,proto3,oneof" json:"position_close,omitempty"`
+}
+type ActionPlan_PositionWithdraw struct {
+ PositionWithdraw *v1alpha11.PositionWithdrawPlan `protobuf:"bytes,32,opt,name=position_withdraw,json=positionWithdraw,proto3,oneof" json:"position_withdraw,omitempty"`
+}
+type ActionPlan_PositionRewardClaim struct {
+ PositionRewardClaim *v1alpha11.PositionRewardClaimPlan `protobuf:"bytes,34,opt,name=position_reward_claim,json=positionRewardClaim,proto3,oneof" json:"position_reward_claim,omitempty"`
+}
+type ActionPlan_Delegate struct {
+ Delegate *v1alpha12.Delegate `protobuf:"bytes,40,opt,name=delegate,proto3,oneof" json:"delegate,omitempty"`
+}
+type ActionPlan_Undelegate struct {
+ Undelegate *v1alpha12.Undelegate `protobuf:"bytes,41,opt,name=undelegate,proto3,oneof" json:"undelegate,omitempty"`
+}
+type ActionPlan_UndelegateClaim struct {
+ UndelegateClaim *v1alpha12.UndelegateClaimPlan `protobuf:"bytes,42,opt,name=undelegate_claim,json=undelegateClaim,proto3,oneof" json:"undelegate_claim,omitempty"`
+}
+type ActionPlan_DaoSpend struct {
+ DaoSpend *v1alpha14.DaoSpend `protobuf:"bytes,50,opt,name=dao_spend,json=daoSpend,proto3,oneof" json:"dao_spend,omitempty"`
+}
+type ActionPlan_DaoOutput struct {
+ DaoOutput *v1alpha14.DaoOutput `protobuf:"bytes,51,opt,name=dao_output,json=daoOutput,proto3,oneof" json:"dao_output,omitempty"`
+}
+type ActionPlan_DaoDeposit struct {
+ DaoDeposit *v1alpha14.DaoDeposit `protobuf:"bytes,52,opt,name=dao_deposit,json=daoDeposit,proto3,oneof" json:"dao_deposit,omitempty"`
+}
+
+func (*ActionPlan_Spend) isActionPlan_Action() {}
+func (*ActionPlan_Output) isActionPlan_Action() {}
+func (*ActionPlan_Swap) isActionPlan_Action() {}
+func (*ActionPlan_SwapClaim) isActionPlan_Action() {}
+func (*ActionPlan_ValidatorDefinition) isActionPlan_Action() {}
+func (*ActionPlan_IbcAction) isActionPlan_Action() {}
+func (*ActionPlan_ProposalSubmit) isActionPlan_Action() {}
+func (*ActionPlan_ProposalWithdraw) isActionPlan_Action() {}
+func (*ActionPlan_ValidatorVote) isActionPlan_Action() {}
+func (*ActionPlan_DelegatorVote) isActionPlan_Action() {}
+func (*ActionPlan_ProposalDepositClaim) isActionPlan_Action() {}
+func (*ActionPlan_Withdrawal) isActionPlan_Action() {}
+func (*ActionPlan_PositionOpen) isActionPlan_Action() {}
+func (*ActionPlan_PositionClose) isActionPlan_Action() {}
+func (*ActionPlan_PositionWithdraw) isActionPlan_Action() {}
+func (*ActionPlan_PositionRewardClaim) isActionPlan_Action() {}
+func (*ActionPlan_Delegate) isActionPlan_Action() {}
+func (*ActionPlan_Undelegate) isActionPlan_Action() {}
+func (*ActionPlan_UndelegateClaim) isActionPlan_Action() {}
+func (*ActionPlan_DaoSpend) isActionPlan_Action() {}
+func (*ActionPlan_DaoOutput) isActionPlan_Action() {}
+func (*ActionPlan_DaoDeposit) isActionPlan_Action() {}
+
+func (m *ActionPlan) GetAction() isActionPlan_Action {
+ if m != nil {
+ return m.Action
+ }
+ return nil
+}
+
+func (m *ActionPlan) GetSpend() *SpendPlan {
+ if x, ok := m.GetAction().(*ActionPlan_Spend); ok {
+ return x.Spend
+ }
+ return nil
+}
+
+func (m *ActionPlan) GetOutput() *OutputPlan {
+ if x, ok := m.GetAction().(*ActionPlan_Output); ok {
+ return x.Output
+ }
+ return nil
+}
+
+func (m *ActionPlan) GetSwap() *v1alpha11.SwapPlan {
+ if x, ok := m.GetAction().(*ActionPlan_Swap); ok {
+ return x.Swap
+ }
+ return nil
+}
+
+func (m *ActionPlan) GetSwapClaim() *v1alpha11.SwapClaimPlan {
+ if x, ok := m.GetAction().(*ActionPlan_SwapClaim); ok {
+ return x.SwapClaim
+ }
+ return nil
+}
+
+func (m *ActionPlan) GetValidatorDefinition() *v1alpha12.ValidatorDefinition {
+ if x, ok := m.GetAction().(*ActionPlan_ValidatorDefinition); ok {
+ return x.ValidatorDefinition
+ }
+ return nil
+}
+
+func (m *ActionPlan) GetIbcAction() *v1alpha13.IbcAction {
+ if x, ok := m.GetAction().(*ActionPlan_IbcAction); ok {
+ return x.IbcAction
+ }
+ return nil
+}
+
+func (m *ActionPlan) GetProposalSubmit() *v1alpha14.ProposalSubmit {
+ if x, ok := m.GetAction().(*ActionPlan_ProposalSubmit); ok {
+ return x.ProposalSubmit
+ }
+ return nil
+}
+
+func (m *ActionPlan) GetProposalWithdraw() *v1alpha14.ProposalWithdraw {
+ if x, ok := m.GetAction().(*ActionPlan_ProposalWithdraw); ok {
+ return x.ProposalWithdraw
+ }
+ return nil
+}
+
+func (m *ActionPlan) GetValidatorVote() *v1alpha14.ValidatorVote {
+ if x, ok := m.GetAction().(*ActionPlan_ValidatorVote); ok {
+ return x.ValidatorVote
+ }
+ return nil
+}
+
+func (m *ActionPlan) GetDelegatorVote() *v1alpha14.DelegatorVotePlan {
+ if x, ok := m.GetAction().(*ActionPlan_DelegatorVote); ok {
+ return x.DelegatorVote
+ }
+ return nil
+}
+
+func (m *ActionPlan) GetProposalDepositClaim() *v1alpha14.ProposalDepositClaim {
+ if x, ok := m.GetAction().(*ActionPlan_ProposalDepositClaim); ok {
+ return x.ProposalDepositClaim
+ }
+ return nil
+}
+
+func (m *ActionPlan) GetWithdrawal() *v1alpha13.Ics20Withdrawal {
+ if x, ok := m.GetAction().(*ActionPlan_Withdrawal); ok {
+ return x.Withdrawal
+ }
+ return nil
+}
+
+func (m *ActionPlan) GetPositionOpen() *v1alpha11.PositionOpen {
+ if x, ok := m.GetAction().(*ActionPlan_PositionOpen); ok {
+ return x.PositionOpen
+ }
+ return nil
+}
+
+func (m *ActionPlan) GetPositionClose() *v1alpha11.PositionClose {
+ if x, ok := m.GetAction().(*ActionPlan_PositionClose); ok {
+ return x.PositionClose
+ }
+ return nil
+}
+
+func (m *ActionPlan) GetPositionWithdraw() *v1alpha11.PositionWithdrawPlan {
+ if x, ok := m.GetAction().(*ActionPlan_PositionWithdraw); ok {
+ return x.PositionWithdraw
+ }
+ return nil
+}
+
+func (m *ActionPlan) GetPositionRewardClaim() *v1alpha11.PositionRewardClaimPlan {
+ if x, ok := m.GetAction().(*ActionPlan_PositionRewardClaim); ok {
+ return x.PositionRewardClaim
+ }
+ return nil
+}
+
+func (m *ActionPlan) GetDelegate() *v1alpha12.Delegate {
+ if x, ok := m.GetAction().(*ActionPlan_Delegate); ok {
+ return x.Delegate
+ }
+ return nil
+}
+
+func (m *ActionPlan) GetUndelegate() *v1alpha12.Undelegate {
+ if x, ok := m.GetAction().(*ActionPlan_Undelegate); ok {
+ return x.Undelegate
+ }
+ return nil
+}
+
+func (m *ActionPlan) GetUndelegateClaim() *v1alpha12.UndelegateClaimPlan {
+ if x, ok := m.GetAction().(*ActionPlan_UndelegateClaim); ok {
+ return x.UndelegateClaim
+ }
+ return nil
+}
+
+func (m *ActionPlan) GetDaoSpend() *v1alpha14.DaoSpend {
+ if x, ok := m.GetAction().(*ActionPlan_DaoSpend); ok {
+ return x.DaoSpend
+ }
+ return nil
+}
+
+func (m *ActionPlan) GetDaoOutput() *v1alpha14.DaoOutput {
+ if x, ok := m.GetAction().(*ActionPlan_DaoOutput); ok {
+ return x.DaoOutput
+ }
+ return nil
+}
+
+func (m *ActionPlan) GetDaoDeposit() *v1alpha14.DaoDeposit {
+ if x, ok := m.GetAction().(*ActionPlan_DaoDeposit); ok {
+ return x.DaoDeposit
+ }
+ return nil
+}
+
+// XXX_OneofWrappers is for the internal use of the proto package.
+func (*ActionPlan) XXX_OneofWrappers() []interface{} {
+ return []interface{}{
+ (*ActionPlan_Spend)(nil),
+ (*ActionPlan_Output)(nil),
+ (*ActionPlan_Swap)(nil),
+ (*ActionPlan_SwapClaim)(nil),
+ (*ActionPlan_ValidatorDefinition)(nil),
+ (*ActionPlan_IbcAction)(nil),
+ (*ActionPlan_ProposalSubmit)(nil),
+ (*ActionPlan_ProposalWithdraw)(nil),
+ (*ActionPlan_ValidatorVote)(nil),
+ (*ActionPlan_DelegatorVote)(nil),
+ (*ActionPlan_ProposalDepositClaim)(nil),
+ (*ActionPlan_Withdrawal)(nil),
+ (*ActionPlan_PositionOpen)(nil),
+ (*ActionPlan_PositionClose)(nil),
+ (*ActionPlan_PositionWithdraw)(nil),
+ (*ActionPlan_PositionRewardClaim)(nil),
+ (*ActionPlan_Delegate)(nil),
+ (*ActionPlan_Undelegate)(nil),
+ (*ActionPlan_UndelegateClaim)(nil),
+ (*ActionPlan_DaoSpend)(nil),
+ (*ActionPlan_DaoOutput)(nil),
+ (*ActionPlan_DaoDeposit)(nil),
+ }
+}
+
+// Describes a plan for forming a `Clue`.
+type CluePlan struct {
+ // The address.
+ Address *v1alpha1.Address `protobuf:"bytes,1,opt,name=address,proto3" json:"address,omitempty"`
+ // The random seed to use for the clue plan.
+ Rseed []byte `protobuf:"bytes,2,opt,name=rseed,proto3" json:"rseed,omitempty"`
+ // The bits of precision.
+ PrecisionBits uint64 `protobuf:"varint,3,opt,name=precision_bits,json=precisionBits,proto3" json:"precision_bits,omitempty"`
+}
+
+func (m *CluePlan) Reset() { *m = CluePlan{} }
+func (m *CluePlan) String() string { return proto.CompactTextString(m) }
+func (*CluePlan) ProtoMessage() {}
+func (*CluePlan) Descriptor() ([]byte, []int) {
+ return fileDescriptor_cd20ea79758052c4, []int{26}
+}
+func (m *CluePlan) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *CluePlan) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_CluePlan.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *CluePlan) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_CluePlan.Merge(m, src)
+}
+func (m *CluePlan) XXX_Size() int {
+ return m.Size()
+}
+func (m *CluePlan) XXX_DiscardUnknown() {
+ xxx_messageInfo_CluePlan.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_CluePlan proto.InternalMessageInfo
+
+func (m *CluePlan) GetAddress() *v1alpha1.Address {
+ if m != nil {
+ return m.Address
+ }
+ return nil
+}
+
+func (m *CluePlan) GetRseed() []byte {
+ if m != nil {
+ return m.Rseed
+ }
+ return nil
+}
+
+func (m *CluePlan) GetPrecisionBits() uint64 {
+ if m != nil {
+ return m.PrecisionBits
+ }
+ return 0
+}
+
+// Describes a plan for forming a `Memo`.
+type MemoPlan struct {
+ // The plaintext.
+ Plaintext *MemoPlaintext `protobuf:"bytes,1,opt,name=plaintext,proto3" json:"plaintext,omitempty"`
+ // The key to use to encrypt the memo.
+ Key []byte `protobuf:"bytes,2,opt,name=key,proto3" json:"key,omitempty"`
+}
+
+func (m *MemoPlan) Reset() { *m = MemoPlan{} }
+func (m *MemoPlan) String() string { return proto.CompactTextString(m) }
+func (*MemoPlan) ProtoMessage() {}
+func (*MemoPlan) Descriptor() ([]byte, []int) {
+ return fileDescriptor_cd20ea79758052c4, []int{27}
+}
+func (m *MemoPlan) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *MemoPlan) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_MemoPlan.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *MemoPlan) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_MemoPlan.Merge(m, src)
+}
+func (m *MemoPlan) XXX_Size() int {
+ return m.Size()
+}
+func (m *MemoPlan) XXX_DiscardUnknown() {
+ xxx_messageInfo_MemoPlan.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_MemoPlan proto.InternalMessageInfo
+
+func (m *MemoPlan) GetPlaintext() *MemoPlaintext {
+ if m != nil {
+ return m.Plaintext
+ }
+ return nil
+}
+
+func (m *MemoPlan) GetKey() []byte {
+ if m != nil {
+ return m.Key
+ }
+ return nil
+}
+
+type MemoCiphertext struct {
+ Inner []byte `protobuf:"bytes,1,opt,name=inner,proto3" json:"inner,omitempty"`
+}
+
+func (m *MemoCiphertext) Reset() { *m = MemoCiphertext{} }
+func (m *MemoCiphertext) String() string { return proto.CompactTextString(m) }
+func (*MemoCiphertext) ProtoMessage() {}
+func (*MemoCiphertext) Descriptor() ([]byte, []int) {
+ return fileDescriptor_cd20ea79758052c4, []int{28}
+}
+func (m *MemoCiphertext) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *MemoCiphertext) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_MemoCiphertext.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *MemoCiphertext) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_MemoCiphertext.Merge(m, src)
+}
+func (m *MemoCiphertext) XXX_Size() int {
+ return m.Size()
+}
+func (m *MemoCiphertext) XXX_DiscardUnknown() {
+ xxx_messageInfo_MemoCiphertext.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_MemoCiphertext proto.InternalMessageInfo
+
+func (m *MemoCiphertext) GetInner() []byte {
+ if m != nil {
+ return m.Inner
+ }
+ return nil
+}
+
+type MemoPlaintext struct {
+ Sender *v1alpha1.Address `protobuf:"bytes,1,opt,name=sender,proto3" json:"sender,omitempty"`
+ Text string `protobuf:"bytes,2,opt,name=text,proto3" json:"text,omitempty"`
+}
+
+func (m *MemoPlaintext) Reset() { *m = MemoPlaintext{} }
+func (m *MemoPlaintext) String() string { return proto.CompactTextString(m) }
+func (*MemoPlaintext) ProtoMessage() {}
+func (*MemoPlaintext) Descriptor() ([]byte, []int) {
+ return fileDescriptor_cd20ea79758052c4, []int{29}
+}
+func (m *MemoPlaintext) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *MemoPlaintext) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_MemoPlaintext.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *MemoPlaintext) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_MemoPlaintext.Merge(m, src)
+}
+func (m *MemoPlaintext) XXX_Size() int {
+ return m.Size()
+}
+func (m *MemoPlaintext) XXX_DiscardUnknown() {
+ xxx_messageInfo_MemoPlaintext.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_MemoPlaintext proto.InternalMessageInfo
+
+func (m *MemoPlaintext) GetSender() *v1alpha1.Address {
+ if m != nil {
+ return m.Sender
+ }
+ return nil
+}
+
+func (m *MemoPlaintext) GetText() string {
+ if m != nil {
+ return m.Text
+ }
+ return ""
+}
+
+type MemoView struct {
+ // Types that are valid to be assigned to MemoView:
+ //
+ // *MemoView_Visible_
+ // *MemoView_Opaque_
+ MemoView isMemoView_MemoView `protobuf_oneof:"memo_view"`
+}
+
+func (m *MemoView) Reset() { *m = MemoView{} }
+func (m *MemoView) String() string { return proto.CompactTextString(m) }
+func (*MemoView) ProtoMessage() {}
+func (*MemoView) Descriptor() ([]byte, []int) {
+ return fileDescriptor_cd20ea79758052c4, []int{30}
+}
+func (m *MemoView) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *MemoView) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_MemoView.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *MemoView) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_MemoView.Merge(m, src)
+}
+func (m *MemoView) XXX_Size() int {
+ return m.Size()
+}
+func (m *MemoView) XXX_DiscardUnknown() {
+ xxx_messageInfo_MemoView.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_MemoView proto.InternalMessageInfo
+
+type isMemoView_MemoView interface {
+ isMemoView_MemoView()
+ MarshalTo([]byte) (int, error)
+ Size() int
+}
+
+type MemoView_Visible_ struct {
+ Visible *MemoView_Visible `protobuf:"bytes,1,opt,name=visible,proto3,oneof" json:"visible,omitempty"`
+}
+type MemoView_Opaque_ struct {
+ Opaque *MemoView_Opaque `protobuf:"bytes,2,opt,name=opaque,proto3,oneof" json:"opaque,omitempty"`
+}
+
+func (*MemoView_Visible_) isMemoView_MemoView() {}
+func (*MemoView_Opaque_) isMemoView_MemoView() {}
+
+func (m *MemoView) GetMemoView() isMemoView_MemoView {
+ if m != nil {
+ return m.MemoView
+ }
+ return nil
+}
+
+func (m *MemoView) GetVisible() *MemoView_Visible {
+ if x, ok := m.GetMemoView().(*MemoView_Visible_); ok {
+ return x.Visible
+ }
+ return nil
+}
+
+func (m *MemoView) GetOpaque() *MemoView_Opaque {
+ if x, ok := m.GetMemoView().(*MemoView_Opaque_); ok {
+ return x.Opaque
+ }
+ return nil
+}
+
+// XXX_OneofWrappers is for the internal use of the proto package.
+func (*MemoView) XXX_OneofWrappers() []interface{} {
+ return []interface{}{
+ (*MemoView_Visible_)(nil),
+ (*MemoView_Opaque_)(nil),
+ }
+}
+
+type MemoView_Visible struct {
+ Ciphertext *MemoCiphertext `protobuf:"bytes,1,opt,name=ciphertext,proto3" json:"ciphertext,omitempty"`
+ Plaintext *MemoPlaintext `protobuf:"bytes,2,opt,name=plaintext,proto3" json:"plaintext,omitempty"`
+}
+
+func (m *MemoView_Visible) Reset() { *m = MemoView_Visible{} }
+func (m *MemoView_Visible) String() string { return proto.CompactTextString(m) }
+func (*MemoView_Visible) ProtoMessage() {}
+func (*MemoView_Visible) Descriptor() ([]byte, []int) {
+ return fileDescriptor_cd20ea79758052c4, []int{30, 0}
+}
+func (m *MemoView_Visible) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *MemoView_Visible) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_MemoView_Visible.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *MemoView_Visible) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_MemoView_Visible.Merge(m, src)
+}
+func (m *MemoView_Visible) XXX_Size() int {
+ return m.Size()
+}
+func (m *MemoView_Visible) XXX_DiscardUnknown() {
+ xxx_messageInfo_MemoView_Visible.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_MemoView_Visible proto.InternalMessageInfo
+
+func (m *MemoView_Visible) GetCiphertext() *MemoCiphertext {
+ if m != nil {
+ return m.Ciphertext
+ }
+ return nil
+}
+
+func (m *MemoView_Visible) GetPlaintext() *MemoPlaintext {
+ if m != nil {
+ return m.Plaintext
+ }
+ return nil
+}
+
+type MemoView_Opaque struct {
+ Ciphertext *MemoCiphertext `protobuf:"bytes,1,opt,name=ciphertext,proto3" json:"ciphertext,omitempty"`
+}
+
+func (m *MemoView_Opaque) Reset() { *m = MemoView_Opaque{} }
+func (m *MemoView_Opaque) String() string { return proto.CompactTextString(m) }
+func (*MemoView_Opaque) ProtoMessage() {}
+func (*MemoView_Opaque) Descriptor() ([]byte, []int) {
+ return fileDescriptor_cd20ea79758052c4, []int{30, 1}
+}
+func (m *MemoView_Opaque) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *MemoView_Opaque) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_MemoView_Opaque.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *MemoView_Opaque) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_MemoView_Opaque.Merge(m, src)
+}
+func (m *MemoView_Opaque) XXX_Size() int {
+ return m.Size()
+}
+func (m *MemoView_Opaque) XXX_DiscardUnknown() {
+ xxx_messageInfo_MemoView_Opaque.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_MemoView_Opaque proto.InternalMessageInfo
+
+func (m *MemoView_Opaque) GetCiphertext() *MemoCiphertext {
+ if m != nil {
+ return m.Ciphertext
+ }
+ return nil
+}
+
+type SpendPlan struct {
+ // The plaintext note we plan to spend.
+ Note *v1alpha1.Note `protobuf:"bytes,1,opt,name=note,proto3" json:"note,omitempty"`
+ // The position of the note we plan to spend.
+ Position uint64 `protobuf:"varint,2,opt,name=position,proto3" json:"position,omitempty"`
+ // The randomizer to use for the spend.
+ Randomizer []byte `protobuf:"bytes,3,opt,name=randomizer,proto3" json:"randomizer,omitempty"`
+ // The blinding factor to use for the value commitment.
+ ValueBlinding []byte `protobuf:"bytes,4,opt,name=value_blinding,json=valueBlinding,proto3" json:"value_blinding,omitempty"`
+ // The first blinding factor to use for the ZK spend proof.
+ ProofBlindingR []byte `protobuf:"bytes,5,opt,name=proof_blinding_r,json=proofBlindingR,proto3" json:"proof_blinding_r,omitempty"`
+ // The second blinding factor to use for the ZK spend proof.
+ ProofBlindingS []byte `protobuf:"bytes,6,opt,name=proof_blinding_s,json=proofBlindingS,proto3" json:"proof_blinding_s,omitempty"`
+}
+
+func (m *SpendPlan) Reset() { *m = SpendPlan{} }
+func (m *SpendPlan) String() string { return proto.CompactTextString(m) }
+func (*SpendPlan) ProtoMessage() {}
+func (*SpendPlan) Descriptor() ([]byte, []int) {
+ return fileDescriptor_cd20ea79758052c4, []int{31}
+}
+func (m *SpendPlan) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *SpendPlan) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_SpendPlan.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *SpendPlan) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_SpendPlan.Merge(m, src)
+}
+func (m *SpendPlan) XXX_Size() int {
+ return m.Size()
+}
+func (m *SpendPlan) XXX_DiscardUnknown() {
+ xxx_messageInfo_SpendPlan.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_SpendPlan proto.InternalMessageInfo
+
+func (m *SpendPlan) GetNote() *v1alpha1.Note {
+ if m != nil {
+ return m.Note
+ }
+ return nil
+}
+
+func (m *SpendPlan) GetPosition() uint64 {
+ if m != nil {
+ return m.Position
+ }
+ return 0
+}
+
+func (m *SpendPlan) GetRandomizer() []byte {
+ if m != nil {
+ return m.Randomizer
+ }
+ return nil
+}
+
+func (m *SpendPlan) GetValueBlinding() []byte {
+ if m != nil {
+ return m.ValueBlinding
+ }
+ return nil
+}
+
+func (m *SpendPlan) GetProofBlindingR() []byte {
+ if m != nil {
+ return m.ProofBlindingR
+ }
+ return nil
+}
+
+func (m *SpendPlan) GetProofBlindingS() []byte {
+ if m != nil {
+ return m.ProofBlindingS
+ }
+ return nil
+}
+
+type OutputPlan struct {
+ // The value to send to this output.
+ Value *v1alpha1.Value `protobuf:"bytes,1,opt,name=value,proto3" json:"value,omitempty"`
+ // The destination address to send it to.
+ DestAddress *v1alpha1.Address `protobuf:"bytes,2,opt,name=dest_address,json=destAddress,proto3" json:"dest_address,omitempty"`
+ // The rseed to use for the new note.
+ Rseed []byte `protobuf:"bytes,3,opt,name=rseed,proto3" json:"rseed,omitempty"`
+ // The blinding factor to use for the value commitment.
+ ValueBlinding []byte `protobuf:"bytes,4,opt,name=value_blinding,json=valueBlinding,proto3" json:"value_blinding,omitempty"`
+ // The first blinding factor to use for the ZK output proof.
+ ProofBlindingR []byte `protobuf:"bytes,5,opt,name=proof_blinding_r,json=proofBlindingR,proto3" json:"proof_blinding_r,omitempty"`
+ // The second blinding factor to use for the ZK output proof.
+ ProofBlindingS []byte `protobuf:"bytes,6,opt,name=proof_blinding_s,json=proofBlindingS,proto3" json:"proof_blinding_s,omitempty"`
+}
+
+func (m *OutputPlan) Reset() { *m = OutputPlan{} }
+func (m *OutputPlan) String() string { return proto.CompactTextString(m) }
+func (*OutputPlan) ProtoMessage() {}
+func (*OutputPlan) Descriptor() ([]byte, []int) {
+ return fileDescriptor_cd20ea79758052c4, []int{32}
+}
+func (m *OutputPlan) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *OutputPlan) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_OutputPlan.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *OutputPlan) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_OutputPlan.Merge(m, src)
+}
+func (m *OutputPlan) XXX_Size() int {
+ return m.Size()
+}
+func (m *OutputPlan) XXX_DiscardUnknown() {
+ xxx_messageInfo_OutputPlan.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_OutputPlan proto.InternalMessageInfo
+
+func (m *OutputPlan) GetValue() *v1alpha1.Value {
+ if m != nil {
+ return m.Value
+ }
+ return nil
+}
+
+func (m *OutputPlan) GetDestAddress() *v1alpha1.Address {
+ if m != nil {
+ return m.DestAddress
+ }
+ return nil
+}
+
+func (m *OutputPlan) GetRseed() []byte {
+ if m != nil {
+ return m.Rseed
+ }
+ return nil
+}
+
+func (m *OutputPlan) GetValueBlinding() []byte {
+ if m != nil {
+ return m.ValueBlinding
+ }
+ return nil
+}
+
+func (m *OutputPlan) GetProofBlindingR() []byte {
+ if m != nil {
+ return m.ProofBlindingR
+ }
+ return nil
+}
+
+func (m *OutputPlan) GetProofBlindingS() []byte {
+ if m != nil {
+ return m.ProofBlindingS
+ }
+ return nil
+}
+
+func init() {
+ proto.RegisterType((*Transaction)(nil), "penumbra.core.transaction.v1alpha1.Transaction")
+ proto.RegisterType((*Id)(nil), "penumbra.core.transaction.v1alpha1.Id")
+ proto.RegisterType((*EffectHash)(nil), "penumbra.core.transaction.v1alpha1.EffectHash")
+ proto.RegisterType((*TransactionBody)(nil), "penumbra.core.transaction.v1alpha1.TransactionBody")
+ proto.RegisterType((*MemoData)(nil), "penumbra.core.transaction.v1alpha1.MemoData")
+ proto.RegisterType((*TransactionParameters)(nil), "penumbra.core.transaction.v1alpha1.TransactionParameters")
+ proto.RegisterType((*DetectionData)(nil), "penumbra.core.transaction.v1alpha1.DetectionData")
+ proto.RegisterType((*Action)(nil), "penumbra.core.transaction.v1alpha1.Action")
+ proto.RegisterType((*TransactionPerspective)(nil), "penumbra.core.transaction.v1alpha1.TransactionPerspective")
+ proto.RegisterType((*PayloadKey)(nil), "penumbra.core.transaction.v1alpha1.PayloadKey")
+ proto.RegisterType((*PayloadKeyWithCommitment)(nil), "penumbra.core.transaction.v1alpha1.PayloadKeyWithCommitment")
+ proto.RegisterType((*NullifierWithNote)(nil), "penumbra.core.transaction.v1alpha1.NullifierWithNote")
+ proto.RegisterType((*TransactionView)(nil), "penumbra.core.transaction.v1alpha1.TransactionView")
+ proto.RegisterType((*TransactionBodyView)(nil), "penumbra.core.transaction.v1alpha1.TransactionBodyView")
+ proto.RegisterType((*ActionView)(nil), "penumbra.core.transaction.v1alpha1.ActionView")
+ proto.RegisterType((*SpendView)(nil), "penumbra.core.transaction.v1alpha1.SpendView")
+ proto.RegisterType((*SpendView_Visible)(nil), "penumbra.core.transaction.v1alpha1.SpendView.Visible")
+ proto.RegisterType((*SpendView_Opaque)(nil), "penumbra.core.transaction.v1alpha1.SpendView.Opaque")
+ proto.RegisterType((*DelegatorVoteView)(nil), "penumbra.core.transaction.v1alpha1.DelegatorVoteView")
+ proto.RegisterType((*DelegatorVoteView_Visible)(nil), "penumbra.core.transaction.v1alpha1.DelegatorVoteView.Visible")
+ proto.RegisterType((*DelegatorVoteView_Opaque)(nil), "penumbra.core.transaction.v1alpha1.DelegatorVoteView.Opaque")
+ proto.RegisterType((*OutputView)(nil), "penumbra.core.transaction.v1alpha1.OutputView")
+ proto.RegisterType((*OutputView_Visible)(nil), "penumbra.core.transaction.v1alpha1.OutputView.Visible")
+ proto.RegisterType((*OutputView_Opaque)(nil), "penumbra.core.transaction.v1alpha1.OutputView.Opaque")
+ proto.RegisterType((*Spend)(nil), "penumbra.core.transaction.v1alpha1.Spend")
+ proto.RegisterType((*SpendBody)(nil), "penumbra.core.transaction.v1alpha1.SpendBody")
+ proto.RegisterType((*Output)(nil), "penumbra.core.transaction.v1alpha1.Output")
+ proto.RegisterType((*OutputBody)(nil), "penumbra.core.transaction.v1alpha1.OutputBody")
+ proto.RegisterType((*AuthorizationData)(nil), "penumbra.core.transaction.v1alpha1.AuthorizationData")
+ proto.RegisterType((*WitnessData)(nil), "penumbra.core.transaction.v1alpha1.WitnessData")
+ proto.RegisterType((*TransactionPlan)(nil), "penumbra.core.transaction.v1alpha1.TransactionPlan")
+ proto.RegisterType((*ActionPlan)(nil), "penumbra.core.transaction.v1alpha1.ActionPlan")
+ proto.RegisterType((*CluePlan)(nil), "penumbra.core.transaction.v1alpha1.CluePlan")
+ proto.RegisterType((*MemoPlan)(nil), "penumbra.core.transaction.v1alpha1.MemoPlan")
+ proto.RegisterType((*MemoCiphertext)(nil), "penumbra.core.transaction.v1alpha1.MemoCiphertext")
+ proto.RegisterType((*MemoPlaintext)(nil), "penumbra.core.transaction.v1alpha1.MemoPlaintext")
+ proto.RegisterType((*MemoView)(nil), "penumbra.core.transaction.v1alpha1.MemoView")
+ proto.RegisterType((*MemoView_Visible)(nil), "penumbra.core.transaction.v1alpha1.MemoView.Visible")
+ proto.RegisterType((*MemoView_Opaque)(nil), "penumbra.core.transaction.v1alpha1.MemoView.Opaque")
+ proto.RegisterType((*SpendPlan)(nil), "penumbra.core.transaction.v1alpha1.SpendPlan")
+ proto.RegisterType((*OutputPlan)(nil), "penumbra.core.transaction.v1alpha1.OutputPlan")
+}
+
+func init() {
+ proto.RegisterFile("penumbra/core/transaction/v1alpha1/transaction.proto", fileDescriptor_cd20ea79758052c4)
+}
+
+var fileDescriptor_cd20ea79758052c4 = []byte{
+ // 2795 bytes of a gzipped FileDescriptorProto
+ 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xec, 0x5b, 0xcf, 0x6f, 0xe3, 0xc6,
+ 0xf5, 0x17, 0x25, 0xdb, 0x6b, 0x3f, 0xc9, 0x5a, 0x7b, 0xf6, 0x47, 0xf4, 0x35, 0xbe, 0x70, 0x16,
+ 0x4c, 0xb2, 0xf5, 0x6e, 0x12, 0x39, 0xeb, 0xdd, 0x4d, 0x50, 0x27, 0x6d, 0x63, 0xd9, 0xd9, 0xc8,
+ 0xbb, 0xf1, 0x5a, 0xa1, 0x53, 0xbb, 0x49, 0x9d, 0xb0, 0x23, 0x72, 0x6c, 0x11, 0x96, 0x48, 0x96,
+ 0xa4, 0xe4, 0x75, 0xfe, 0x81, 0xa6, 0x97, 0x22, 0x05, 0x7a, 0x28, 0x7a, 0x29, 0x50, 0xe4, 0xd4,
+ 0x43, 0xff, 0x80, 0x16, 0x3d, 0x37, 0x68, 0x2f, 0x01, 0x7a, 0x29, 0x10, 0x14, 0x48, 0x37, 0xa7,
+ 0xfe, 0xb8, 0xf4, 0xdc, 0x4b, 0x31, 0x3f, 0x38, 0x24, 0x25, 0x7a, 0x45, 0xd9, 0x4e, 0x83, 0xfc,
+ 0x38, 0x99, 0xf3, 0xfc, 0xde, 0x67, 0x66, 0xde, 0x7b, 0x33, 0xf3, 0xde, 0x9b, 0x11, 0xdc, 0x72,
+ 0x89, 0xdd, 0xed, 0x34, 0x3d, 0xbc, 0x68, 0x38, 0x1e, 0x59, 0x0c, 0x3c, 0x6c, 0xfb, 0xd8, 0x08,
+ 0x2c, 0xc7, 0x5e, 0xec, 0xdd, 0xc0, 0x6d, 0xb7, 0x85, 0x6f, 0xc4, 0x89, 0x55, 0xd7, 0x73, 0x02,
+ 0x07, 0xa9, 0xa1, 0x54, 0x95, 0x4a, 0x55, 0xe3, 0x0c, 0xa1, 0xd4, 0xdc, 0xf5, 0x24, 0xb2, 0xe1,
+ 0x1d, 0xb9, 0x81, 0x13, 0x81, 0xf2, 0x36, 0xc7, 0x9b, 0x5b, 0x48, 0xf2, 0xfa, 0x01, 0x3e, 0x20,
+ 0x11, 0x2b, 0x6b, 0x0a, 0xce, 0x27, 0x93, 0x9c, 0x56, 0xd3, 0x88, 0xf8, 0xac, 0xa6, 0x91, 0xce,
+ 0x65, 0x92, 0x07, 0x11, 0x97, 0x49, 0x1e, 0x08, 0xae, 0xa5, 0x24, 0xd7, 0xbe, 0xd3, 0x23, 0x9e,
+ 0x8d, 0x6d, 0x23, 0xd6, 0x75, 0x44, 0xe3, 0x32, 0xea, 0x6f, 0x15, 0x28, 0xbe, 0x11, 0x4d, 0x17,
+ 0xbd, 0x0a, 0x63, 0x4d, 0xc7, 0x3c, 0xaa, 0x28, 0x57, 0x94, 0x85, 0xe2, 0xd2, 0xcd, 0xea, 0x70,
+ 0xc5, 0x54, 0x63, 0xe2, 0x35, 0xc7, 0x3c, 0xd2, 0x18, 0x00, 0x7a, 0x1c, 0x8a, 0x4d, 0xcb, 0x36,
+ 0x2d, 0x7b, 0x5f, 0xf7, 0xad, 0xfd, 0x4a, 0xfe, 0x8a, 0xb2, 0x50, 0xd2, 0x40, 0x90, 0xb6, 0xac,
+ 0x7d, 0xb4, 0x02, 0x13, 0xd8, 0x36, 0x5a, 0x8e, 0x57, 0x29, 0xb0, 0xbe, 0xae, 0xf5, 0xf5, 0x25,
+ 0x14, 0x2a, 0xbb, 0xd9, 0x20, 0xde, 0x41, 0x9b, 0x68, 0x8e, 0x13, 0x68, 0x42, 0x50, 0xad, 0x40,
+ 0x7e, 0xdd, 0x44, 0x08, 0xc6, 0x5a, 0xd8, 0x6f, 0xb1, 0x21, 0x97, 0x34, 0xf6, 0xad, 0xaa, 0x00,
+ 0xaf, 0xec, 0xed, 0x11, 0x23, 0xa8, 0x63, 0xbf, 0x85, 0x2e, 0xc2, 0xb8, 0x65, 0xdb, 0xc4, 0x13,
+ 0x2c, 0xbc, 0xa1, 0x7e, 0x50, 0x80, 0xf3, 0x7d, 0x63, 0x47, 0x6b, 0x70, 0x8e, 0xb7, 0xfc, 0x8a,
+ 0x72, 0xa5, 0xb0, 0x50, 0x5c, 0xba, 0x9e, 0x45, 0x03, 0x2b, 0xac, 0xad, 0x85, 0xa2, 0xc8, 0x85,
+ 0xcb, 0x31, 0x3e, 0xdd, 0xc5, 0x1e, 0xee, 0x90, 0x80, 0x78, 0x3e, 0x53, 0x43, 0x71, 0xe9, 0x9b,
+ 0x23, 0xaa, 0xb5, 0x21, 0x01, 0xb4, 0x4b, 0x41, 0x1a, 0x19, 0xdd, 0x82, 0xc2, 0x1e, 0x21, 0x42,
+ 0x93, 0xea, 0x10, 0x4d, 0xde, 0x21, 0x44, 0xa3, 0xec, 0xe8, 0x7b, 0x50, 0x36, 0x49, 0x40, 0xf8,
+ 0x28, 0x4d, 0x1c, 0xe0, 0xca, 0x18, 0x03, 0xb8, 0x91, 0x65, 0x7c, 0x6b, 0xa1, 0xe4, 0x1a, 0x0e,
+ 0xb0, 0x36, 0x6d, 0xc6, 0x9b, 0x68, 0x1d, 0xa6, 0x3a, 0xa4, 0xe3, 0x70, 0xd0, 0x71, 0x06, 0xfa,
+ 0x4c, 0x16, 0xd0, 0x0d, 0xd2, 0x71, 0x18, 0xde, 0x64, 0x47, 0x7c, 0xa9, 0xeb, 0x30, 0x19, 0x52,
+ 0xd1, 0x75, 0x28, 0x13, 0x9b, 0x4d, 0x87, 0x98, 0x3a, 0xe5, 0xe0, 0x16, 0xad, 0xe7, 0xb4, 0x69,
+ 0x49, 0xa7, 0xcc, 0xef, 0x29, 0x4a, 0x6d, 0x16, 0xce, 0xeb, 0x49, 0x66, 0x75, 0x07, 0x2e, 0xa5,
+ 0x6a, 0x15, 0x3d, 0x01, 0xd3, 0xe4, 0x81, 0x6b, 0x79, 0x47, 0x7a, 0x8b, 0x58, 0xfb, 0xad, 0x80,
+ 0xc1, 0x8e, 0x69, 0x25, 0x4e, 0xac, 0x33, 0x1a, 0xfa, 0x3f, 0x98, 0x34, 0x5a, 0xd8, 0xb2, 0x75,
+ 0xcb, 0x64, 0x76, 0x9c, 0xd2, 0xce, 0xb1, 0xf6, 0xba, 0xa9, 0xbe, 0x0e, 0xd3, 0x09, 0x75, 0xa0,
+ 0x97, 0x61, 0x6a, 0xaf, 0x63, 0xea, 0x46, 0xbb, 0x4b, 0xfc, 0xca, 0x18, 0xf3, 0xa4, 0x27, 0x86,
+ 0x58, 0x65, 0xb5, 0xdd, 0x25, 0xda, 0xe4, 0x5e, 0xc7, 0xa4, 0x1f, 0xbe, 0xfa, 0xe7, 0x32, 0x4c,
+ 0x70, 0xbf, 0x42, 0x2b, 0x30, 0xee, 0xbb, 0xc4, 0x36, 0xc5, 0xa2, 0xbc, 0x96, 0x45, 0x91, 0x5b,
+ 0x54, 0xa0, 0x9e, 0xd3, 0xb8, 0x24, 0x5a, 0x83, 0x09, 0xa7, 0x1b, 0xb8, 0xdd, 0x40, 0x78, 0x60,
+ 0x26, 0xb7, 0xde, 0x64, 0x12, 0xf5, 0x9c, 0x26, 0x64, 0xd1, 0xf3, 0x30, 0xe6, 0x1f, 0x62, 0x57,
+ 0xb8, 0xd9, 0x95, 0x3e, 0x0c, 0xba, 0x11, 0x45, 0xfd, 0x1f, 0x62, 0xb7, 0x9e, 0xd3, 0x18, 0x3f,
+ 0xba, 0x03, 0x40, 0xff, 0xea, 0x46, 0x1b, 0x5b, 0x1d, 0xe1, 0x63, 0x4f, 0x0d, 0x93, 0x5e, 0xa5,
+ 0xcc, 0xf5, 0x9c, 0x36, 0xe5, 0x87, 0x0d, 0xb4, 0x07, 0x17, 0x7b, 0xb8, 0x6d, 0x99, 0x38, 0x70,
+ 0x3c, 0xdd, 0x24, 0x7b, 0x96, 0x6d, 0xd1, 0x11, 0x57, 0x66, 0x52, 0xbd, 0x96, 0x6f, 0xb3, 0x12,
+ 0x73, 0x3b, 0x94, 0x5c, 0x93, 0x82, 0xf5, 0x9c, 0x76, 0xa1, 0x37, 0x48, 0xa6, 0xe3, 0xb5, 0x9a,
+ 0x86, 0xce, 0xf5, 0x51, 0x99, 0x4d, 0x1d, 0x2f, 0xdd, 0x9c, 0x25, 0xf6, 0x7a, 0xd3, 0xe0, 0xb6,
+ 0xa2, 0xe3, 0xb5, 0xc2, 0x06, 0xda, 0x85, 0xf3, 0xae, 0xe7, 0xb8, 0x8e, 0x8f, 0xdb, 0xba, 0xdf,
+ 0x6d, 0x76, 0xac, 0xa0, 0x82, 0x52, 0x87, 0x1a, 0xdb, 0x96, 0x25, 0x66, 0x43, 0x48, 0x6e, 0x31,
+ 0xc1, 0x7a, 0x4e, 0x2b, 0xbb, 0x09, 0x0a, 0x6a, 0xc2, 0xac, 0x44, 0x3f, 0xb4, 0x82, 0x96, 0xe9,
+ 0xe1, 0xc3, 0xca, 0x85, 0xd4, 0x7d, 0xfb, 0x51, 0xf8, 0x3b, 0x42, 0xb4, 0x9e, 0xd3, 0x66, 0xdc,
+ 0x3e, 0x1a, 0x7a, 0x13, 0xca, 0x91, 0xc6, 0x7b, 0x4e, 0x40, 0x2a, 0x17, 0x59, 0x07, 0xcf, 0x65,
+ 0xe8, 0x40, 0x2a, 0x7c, 0xdb, 0x09, 0x08, 0x5d, 0xa2, 0xbd, 0x38, 0x81, 0x42, 0x9b, 0xa4, 0x4d,
+ 0xf6, 0x23, 0xe8, 0x4b, 0x99, 0xa1, 0xd7, 0x42, 0xc1, 0x10, 0xda, 0x8c, 0x13, 0x90, 0x03, 0x97,
+ 0xa5, 0x66, 0x4c, 0xe2, 0x3a, 0xbe, 0x15, 0x08, 0xdf, 0xbb, 0xcc, 0xba, 0x78, 0x61, 0x04, 0xf5,
+ 0xac, 0x71, 0xf9, 0xd0, 0x1b, 0x2f, 0xba, 0x29, 0x74, 0xb4, 0x09, 0xd3, 0xac, 0x45, 0xf7, 0x51,
+ 0xc7, 0x25, 0x76, 0x65, 0x9e, 0xf5, 0xb3, 0xf0, 0x28, 0x1f, 0x6f, 0x08, 0x81, 0x4d, 0x97, 0x50,
+ 0xb7, 0x29, 0xb9, 0xb1, 0x36, 0xd2, 0xa0, 0x2c, 0x01, 0x8d, 0xb6, 0xe3, 0x93, 0xca, 0xe3, 0xa9,
+ 0x6b, 0x3f, 0x15, 0x71, 0x95, 0x0a, 0x50, 0xad, 0xb8, 0x71, 0x02, 0xfa, 0x3e, 0xcc, 0x4a, 0x4c,
+ 0xe9, 0x2f, 0x57, 0x52, 0xf7, 0xe6, 0x54, 0xd8, 0x84, 0xa3, 0xf4, 0xd1, 0x10, 0x81, 0x4b, 0x12,
+ 0xdc, 0x23, 0x87, 0xd8, 0x33, 0x85, 0xc6, 0x55, 0xd6, 0xc1, 0x62, 0x96, 0x0e, 0x34, 0x26, 0x17,
+ 0x6a, 0xfa, 0x82, 0x3b, 0x48, 0x46, 0x6b, 0x30, 0x29, 0x4c, 0x4d, 0x2a, 0x0b, 0x0c, 0xf9, 0xea,
+ 0xa3, 0x57, 0xbd, 0xf0, 0x14, 0xaa, 0x0e, 0x29, 0x89, 0xee, 0x02, 0x74, 0x6d, 0x89, 0x73, 0x2d,
+ 0xd5, 0x56, 0x7d, 0x38, 0xdf, 0x95, 0xfc, 0xf5, 0x9c, 0x16, 0x93, 0x46, 0x6f, 0xc1, 0x4c, 0xd4,
+ 0x12, 0x73, 0xbe, 0xce, 0x10, 0x9f, 0xcd, 0x8a, 0x18, 0xce, 0xf8, 0x7c, 0x37, 0x49, 0x42, 0x77,
+ 0x61, 0xca, 0xc4, 0x8e, 0xce, 0x37, 0xff, 0x25, 0x06, 0xfa, 0x74, 0x96, 0xd5, 0x81, 0x9d, 0x70,
+ 0xfb, 0x9f, 0x34, 0xc5, 0x37, 0xda, 0x00, 0xa0, 0x58, 0xe2, 0x14, 0xb8, 0x99, 0x6a, 0xf6, 0x63,
+ 0xc0, 0xe4, 0x39, 0x40, 0x47, 0xc3, 0x1b, 0xa8, 0x01, 0x45, 0x0a, 0x27, 0x56, 0x57, 0xe5, 0x56,
+ 0xea, 0x8c, 0x8f, 0xc1, 0x13, 0x4b, 0x87, 0x2a, 0xd2, 0x94, 0x2d, 0xf4, 0x26, 0xcc, 0x58, 0x86,
+ 0xbf, 0xf4, 0x9c, 0xf4, 0x4d, 0xdc, 0xae, 0x7c, 0xa8, 0xa4, 0x4e, 0x3a, 0xb9, 0xf7, 0x52, 0xa1,
+ 0x1d, 0x29, 0x43, 0xf5, 0x68, 0x25, 0x49, 0xb5, 0x49, 0x98, 0xe0, 0x7b, 0xb9, 0xfa, 0xe3, 0x31,
+ 0xb8, 0x1c, 0x0f, 0x01, 0x88, 0xe7, 0xbb, 0xf4, 0xd8, 0xee, 0x11, 0xa4, 0x43, 0xc9, 0xc5, 0x47,
+ 0x6d, 0x07, 0x9b, 0xfa, 0x01, 0x39, 0x0a, 0xe3, 0xbf, 0x97, 0xb2, 0x1c, 0x94, 0x0d, 0x2e, 0x77,
+ 0x8f, 0x1c, 0xd1, 0x4e, 0x57, 0x9d, 0x4e, 0xc7, 0x0a, 0x3a, 0xc4, 0x0e, 0xb4, 0xa2, 0x2b, 0xff,
+ 0xe3, 0xa3, 0x1f, 0xc0, 0x0c, 0xb3, 0xa4, 0x6e, 0x77, 0xdb, 0x6d, 0x6b, 0xcf, 0xe2, 0xf1, 0x20,
+ 0xed, 0xe4, 0x76, 0x96, 0x4e, 0xee, 0x87, 0x52, 0xb4, 0x8f, 0xfb, 0x4e, 0x40, 0xb4, 0xf3, 0x0c,
+ 0x4e, 0xd2, 0x7d, 0x74, 0x07, 0x4a, 0xd8, 0xec, 0x59, 0x06, 0xd1, 0x6d, 0x27, 0x20, 0x7e, 0xa5,
+ 0x90, 0x29, 0xf0, 0x60, 0x58, 0x45, 0x2e, 0x48, 0xbf, 0x7d, 0xba, 0x9d, 0x61, 0xd3, 0xf4, 0x88,
+ 0xef, 0xeb, 0x3d, 0x8b, 0x1c, 0x86, 0x11, 0xcc, 0xf5, 0x21, 0x40, 0x2b, 0x5c, 0x66, 0xdb, 0x22,
+ 0x87, 0x5a, 0x09, 0x47, 0x0d, 0x9f, 0x86, 0x1f, 0x26, 0xb1, 0x9d, 0x8e, 0x5f, 0x19, 0x67, 0x48,
+ 0xcf, 0x0c, 0x41, 0x5a, 0xa3, 0xcc, 0x1b, 0x24, 0xc0, 0x34, 0x7e, 0xd4, 0x84, 0x2c, 0xda, 0x80,
+ 0x72, 0x3c, 0xac, 0xb6, 0xcc, 0xca, 0x44, 0xea, 0x16, 0x90, 0xaa, 0xbe, 0x75, 0x53, 0x9b, 0x8e,
+ 0xfd, 0x63, 0xdd, 0xa4, 0x39, 0x42, 0x64, 0xb8, 0x63, 0x72, 0x84, 0xdf, 0x29, 0x50, 0x39, 0xce,
+ 0xba, 0x68, 0x13, 0x8a, 0x31, 0x8f, 0x11, 0xd1, 0x59, 0x75, 0x34, 0x87, 0xd1, 0x20, 0x72, 0x11,
+ 0x74, 0x1f, 0xc0, 0x90, 0xf0, 0x22, 0x52, 0xab, 0x0e, 0x51, 0xd5, 0x56, 0x40, 0xb7, 0x8b, 0xc8,
+ 0xe5, 0x62, 0x08, 0xea, 0xcf, 0x14, 0x98, 0x1d, 0x70, 0x1b, 0x74, 0x07, 0xa6, 0xa4, 0x07, 0x8a,
+ 0x41, 0x2f, 0x0c, 0x73, 0x91, 0x90, 0x5f, 0x8b, 0x44, 0xd1, 0x0b, 0x30, 0x46, 0xdd, 0x4c, 0x8c,
+ 0x33, 0x93, 0x97, 0x31, 0x01, 0xf5, 0x4f, 0x4a, 0x22, 0xf1, 0xa2, 0x2e, 0x82, 0xde, 0x80, 0x29,
+ 0x9a, 0x36, 0x32, 0x7f, 0x13, 0x83, 0x7a, 0xe1, 0x04, 0xc9, 0x27, 0xf3, 0xbd, 0xc9, 0xa6, 0xf8,
+ 0xfa, 0x9f, 0x24, 0xa1, 0x9f, 0x14, 0xe0, 0x42, 0xca, 0x28, 0xd0, 0xeb, 0x50, 0x12, 0x8e, 0xca,
+ 0xd7, 0x10, 0xdf, 0x4f, 0xaa, 0xd9, 0xf3, 0x49, 0x36, 0x97, 0x62, 0xa4, 0xa3, 0x2f, 0x4e, 0x5e,
+ 0xf9, 0xf6, 0x99, 0xe5, 0x95, 0x3c, 0xb6, 0x8b, 0x11, 0xde, 0x53, 0x14, 0x74, 0x5f, 0x24, 0x97,
+ 0xcc, 0x57, 0x46, 0x4c, 0x2e, 0xa9, 0x22, 0xeb, 0x0a, 0x4f, 0x2f, 0xe9, 0x77, 0x98, 0x29, 0x26,
+ 0xc7, 0x5b, 0x2b, 0x01, 0xe8, 0xb2, 0x0f, 0xf5, 0xdf, 0x65, 0x80, 0xc8, 0x26, 0xe8, 0x95, 0x64,
+ 0x3e, 0xf6, 0x6c, 0xe6, 0x7c, 0x8c, 0x75, 0x2e, 0x73, 0xb2, 0x7a, 0x5f, 0x4e, 0x56, 0xcd, 0x9e,
+ 0x93, 0x09, 0xa0, 0x30, 0x2f, 0x5b, 0x4e, 0xe4, 0x65, 0x4f, 0x0e, 0xcb, 0xac, 0x84, 0x34, 0xcf,
+ 0xcd, 0xee, 0xa6, 0xe4, 0x66, 0xd7, 0x32, 0xe5, 0x66, 0x02, 0xe6, 0xeb, 0xfc, 0xec, 0xcb, 0x99,
+ 0x9f, 0xbd, 0x73, 0x4c, 0x7e, 0x76, 0x3b, 0xdb, 0x22, 0x8e, 0xe5, 0x63, 0xc2, 0x51, 0xbe, 0x4e,
+ 0xd2, 0xbe, 0x82, 0x49, 0xda, 0xb5, 0x33, 0x4a, 0xd2, 0xae, 0x9f, 0x2a, 0x49, 0xfb, 0x4a, 0x25,
+ 0x52, 0x69, 0x19, 0xe9, 0xd3, 0x67, 0x94, 0x91, 0x7e, 0x86, 0x49, 0xda, 0x34, 0x14, 0x63, 0xf1,
+ 0x92, 0xfa, 0xd3, 0x02, 0x4c, 0xc9, 0x43, 0x13, 0xbd, 0x0e, 0xe7, 0x7a, 0x96, 0x6f, 0x35, 0xdb,
+ 0x44, 0x1c, 0xba, 0xb7, 0x47, 0x3a, 0x74, 0xab, 0xdb, 0x5c, 0xb8, 0x9e, 0xd3, 0x42, 0x1c, 0x74,
+ 0x1f, 0x26, 0x1c, 0x17, 0xff, 0xb0, 0x1b, 0x06, 0xb0, 0xb7, 0x46, 0x43, 0xdc, 0x64, 0xb2, 0xec,
+ 0x10, 0x66, 0x5f, 0x73, 0x3f, 0x52, 0xe0, 0x9c, 0xe8, 0x06, 0x7d, 0xe7, 0xa4, 0x15, 0xdb, 0x30,
+ 0x36, 0x78, 0x31, 0x11, 0x5b, 0x7f, 0x23, 0x43, 0x6c, 0xcd, 0xa2, 0x45, 0x26, 0x34, 0xb7, 0x0e,
+ 0x13, 0x7c, 0x74, 0xa7, 0x1e, 0x07, 0x8d, 0x83, 0x78, 0xce, 0xca, 0x6c, 0xf2, 0xd7, 0x02, 0xcc,
+ 0x0e, 0xec, 0xec, 0xe8, 0xcd, 0x7e, 0xdb, 0x7c, 0xeb, 0x44, 0x27, 0x44, 0x9a, 0x8d, 0xb6, 0xfb,
+ 0x6c, 0xf4, 0xd2, 0xc9, 0x90, 0x07, 0x6c, 0xf5, 0xcb, 0x98, 0xad, 0x76, 0x06, 0xce, 0x39, 0xe5,
+ 0x64, 0x75, 0xc8, 0xfe, 0x03, 0xee, 0x54, 0x36, 0xc4, 0xd2, 0x86, 0x9f, 0xd5, 0xf8, 0x6a, 0x33,
+ 0xfd, 0xc0, 0xea, 0xbf, 0x0a, 0x00, 0x51, 0x80, 0x89, 0xb4, 0x7e, 0xc3, 0x3e, 0x3f, 0x5a, 0x84,
+ 0x9a, 0x66, 0xd1, 0xcd, 0x3e, 0x8b, 0xde, 0x1e, 0x11, 0x72, 0xc0, 0x94, 0x1f, 0xc7, 0x4c, 0x59,
+ 0x93, 0x11, 0xb5, 0x32, 0xea, 0x2d, 0x87, 0x8c, 0xa5, 0x4f, 0x63, 0xb5, 0xfe, 0x8a, 0x40, 0xe1,
+ 0xb4, 0x15, 0x81, 0xb9, 0xd7, 0xa4, 0x1b, 0x9c, 0xc1, 0xdc, 0xe8, 0x16, 0xcb, 0xbf, 0xf8, 0x72,
+ 0xfe, 0x58, 0x81, 0x71, 0x7e, 0xa6, 0xad, 0x24, 0x6e, 0x7d, 0xb3, 0x27, 0x34, 0xb1, 0xfb, 0xde,
+ 0xd7, 0x60, 0x12, 0x77, 0x83, 0x96, 0xcc, 0xb3, 0x07, 0x83, 0xe8, 0x81, 0xca, 0x05, 0x45, 0x58,
+ 0xe9, 0x06, 0xad, 0x2d, 0x6b, 0xdf, 0xc6, 0x41, 0xd7, 0x23, 0xda, 0x39, 0xcc, 0x9b, 0x68, 0x05,
+ 0xc6, 0x5d, 0xcf, 0x71, 0xf6, 0x84, 0x0a, 0x9f, 0x1e, 0x02, 0xf5, 0xd6, 0x3d, 0x06, 0xd6, 0xa0,
+ 0x22, 0x1a, 0x97, 0x54, 0x7f, 0xa1, 0x88, 0x03, 0x84, 0x5d, 0xec, 0xea, 0x80, 0x9a, 0xb8, 0x4d,
+ 0x57, 0x87, 0x1e, 0x2b, 0xb1, 0xa4, 0xaf, 0xa4, 0x7e, 0xf4, 0x1a, 0x17, 0x8c, 0x15, 0x59, 0x66,
+ 0x9b, 0xfd, 0x24, 0xf4, 0xff, 0xf1, 0xaa, 0x4a, 0x81, 0x15, 0x1a, 0x62, 0xb5, 0x92, 0x32, 0xe4,
+ 0xbd, 0x03, 0x96, 0x5d, 0x95, 0xb4, 0xbc, 0x77, 0xa0, 0xbe, 0xaf, 0xc0, 0x84, 0x08, 0x00, 0x6a,
+ 0x09, 0xdd, 0x8f, 0x90, 0x04, 0xc6, 0x94, 0x5f, 0x0b, 0xd5, 0x95, 0x4f, 0x0d, 0x47, 0x06, 0xd5,
+ 0xc5, 0x11, 0x12, 0xfa, 0xfa, 0x49, 0x3e, 0x5c, 0xfc, 0x4c, 0x61, 0x1b, 0x50, 0xa2, 0x2e, 0xad,
+ 0x0b, 0x67, 0x3c, 0xc6, 0xeb, 0xd2, 0xd6, 0x83, 0x70, 0x65, 0xad, 0x68, 0x47, 0x8d, 0x63, 0xf4,
+ 0x9f, 0x3f, 0x3b, 0xfd, 0x2f, 0xc0, 0xcc, 0xa1, 0x87, 0x5d, 0x57, 0xdc, 0xf5, 0xca, 0xf5, 0x57,
+ 0xd2, 0xca, 0x82, 0x4e, 0xd3, 0xff, 0x7b, 0xe4, 0x08, 0x5d, 0x85, 0xf3, 0x4e, 0xef, 0x40, 0x0f,
+ 0xb9, 0x29, 0x23, 0x37, 0xcc, 0xb4, 0xd3, 0x3b, 0xd8, 0xe1, 0xd4, 0x7b, 0xe4, 0x48, 0xfd, 0x79,
+ 0x1e, 0x66, 0xa9, 0x7b, 0x3a, 0x9e, 0xf5, 0x2e, 0x96, 0x37, 0xbb, 0x77, 0xa1, 0x48, 0xd8, 0xcb,
+ 0x02, 0x5d, 0x3e, 0x3a, 0x18, 0x5e, 0x36, 0x8a, 0xde, 0x22, 0x68, 0x40, 0xa2, 0x77, 0x09, 0x1a,
+ 0x14, 0xf9, 0xe9, 0x4a, 0xdd, 0x3e, 0x2c, 0x06, 0x9f, 0x60, 0xd9, 0xf0, 0x33, 0x9a, 0xd2, 0x7c,
+ 0x64, 0xc0, 0xc5, 0xe4, 0xae, 0x2e, 0xc0, 0x0b, 0x27, 0x05, 0x47, 0x89, 0x53, 0x83, 0x75, 0xa2,
+ 0xfe, 0x5e, 0x81, 0xe2, 0x8e, 0x15, 0xd8, 0xc4, 0xf7, 0x99, 0x52, 0xa2, 0x32, 0x9a, 0x72, 0xc2,
+ 0x32, 0x1a, 0x3a, 0x80, 0xc7, 0xfc, 0x80, 0x05, 0xac, 0xd2, 0xa6, 0x3a, 0x73, 0xcc, 0x50, 0x2f,
+ 0x37, 0x47, 0x2b, 0x84, 0x72, 0xdf, 0xbe, 0xe4, 0xa7, 0x50, 0x7d, 0xf5, 0xef, 0xf9, 0x44, 0x05,
+ 0xb2, 0xd1, 0xc6, 0x36, 0xaa, 0xf7, 0x3f, 0xfd, 0x18, 0xa1, 0x54, 0x47, 0x01, 0xa2, 0xe7, 0x1f,
+ 0x03, 0xaf, 0x09, 0xf2, 0x43, 0x5e, 0x13, 0x14, 0x12, 0xaf, 0x09, 0xc2, 0xa2, 0xdb, 0xd8, 0x68,
+ 0x45, 0xb7, 0x7b, 0x00, 0x46, 0xbb, 0x4b, 0x74, 0xb7, 0x8d, 0xed, 0xe3, 0xea, 0xec, 0xa9, 0x53,
+ 0x58, 0x6d, 0x77, 0x09, 0x9b, 0xc0, 0x94, 0x21, 0xbe, 0x7c, 0xf9, 0x7e, 0x83, 0x82, 0x89, 0x2a,
+ 0x7b, 0xe6, 0x12, 0x1b, 0xc3, 0x62, 0x05, 0x36, 0xfa, 0xa5, 0xfe, 0x53, 0x16, 0xcf, 0x98, 0x9a,
+ 0x4f, 0x5c, 0x3c, 0xa3, 0xd2, 0x67, 0x52, 0x3c, 0x13, 0x40, 0x27, 0x2c, 0x9e, 0x09, 0xe9, 0xd3,
+ 0x16, 0xcf, 0x04, 0xcc, 0xd7, 0xc5, 0xb3, 0x2f, 0x67, 0xf1, 0xec, 0xed, 0x63, 0x8a, 0x67, 0xb7,
+ 0x46, 0x0d, 0xda, 0x85, 0x9f, 0x7c, 0xde, 0xb5, 0xb3, 0x0d, 0x80, 0x58, 0xc6, 0xff, 0xd8, 0x49,
+ 0x12, 0xfe, 0x18, 0xc0, 0x17, 0xa3, 0x14, 0xa7, 0x1f, 0x5f, 0x8a, 0x7b, 0x6e, 0x94, 0x52, 0x9c,
+ 0x30, 0xe1, 0x60, 0x39, 0xce, 0x7a, 0x74, 0x39, 0xee, 0xe6, 0x88, 0xe5, 0x38, 0xd1, 0xcf, 0x17,
+ 0xe4, 0xdd, 0xc4, 0x3b, 0xc7, 0xbe, 0x9b, 0xb8, 0x31, 0x52, 0x95, 0x4a, 0xcc, 0xfa, 0x2b, 0xfd,
+ 0x76, 0x22, 0xfe, 0xc0, 0x41, 0x81, 0xc9, 0xf0, 0x40, 0x47, 0x2f, 0xc3, 0x39, 0x71, 0x0d, 0x2f,
+ 0x4e, 0xdb, 0xab, 0xd9, 0x6e, 0xf0, 0xb5, 0x50, 0x0c, 0x5d, 0x84, 0x71, 0xcf, 0x27, 0xc4, 0x14,
+ 0x57, 0xa7, 0xbc, 0x81, 0x9e, 0x82, 0xb2, 0xeb, 0x11, 0xc3, 0xf2, 0xa9, 0xe7, 0x36, 0xad, 0xc0,
+ 0x67, 0x87, 0xe7, 0x98, 0x36, 0x2d, 0xa9, 0x35, 0x2b, 0xf0, 0xd5, 0x0e, 0x7f, 0xb9, 0xc9, 0x86,
+ 0xb2, 0x09, 0x53, 0x6e, 0x1b, 0x5b, 0x76, 0x40, 0x1e, 0x84, 0x69, 0xd7, 0x8d, 0x11, 0x02, 0x0a,
+ 0x2e, 0xa8, 0x45, 0x18, 0x68, 0x06, 0x0a, 0x34, 0x72, 0xe7, 0xe3, 0xa2, 0x9f, 0xea, 0x55, 0x28,
+ 0x53, 0xee, 0x55, 0xcb, 0x6d, 0x11, 0x8f, 0xf1, 0xa4, 0xdf, 0xe9, 0x1b, 0x30, 0x9d, 0x40, 0x45,
+ 0xdf, 0x86, 0x09, 0x9f, 0xd8, 0xa6, 0xbc, 0x0d, 0xcf, 0xaa, 0x25, 0x21, 0x85, 0x10, 0x8c, 0xb1,
+ 0x69, 0xf1, 0x47, 0xa1, 0xec, 0x5b, 0xfd, 0x43, 0x81, 0x4f, 0x9e, 0x15, 0x52, 0x1a, 0xfd, 0x85,
+ 0x94, 0x5b, 0xa3, 0x5c, 0x57, 0xa6, 0x95, 0x51, 0x36, 0xfa, 0xca, 0x28, 0x37, 0x47, 0x02, 0x1c,
+ 0x28, 0xa2, 0xfc, 0x26, 0x56, 0x44, 0xd1, 0x00, 0x0c, 0xa9, 0x42, 0x31, 0xde, 0xa5, 0xac, 0xf0,
+ 0x91, 0xf2, 0xb5, 0x18, 0x4a, 0xd2, 0xfa, 0xf9, 0xd3, 0x5b, 0x7f, 0x6e, 0x57, 0xd6, 0x45, 0x3e,
+ 0x83, 0xe1, 0xd6, 0x8a, 0xb1, 0x0b, 0x66, 0xf5, 0x3f, 0x61, 0x1d, 0x81, 0xf9, 0x71, 0xf8, 0xe8,
+ 0x41, 0x19, 0xf1, 0xd1, 0x03, 0x9a, 0x83, 0xc9, 0x70, 0x63, 0x16, 0xf9, 0x80, 0x6c, 0xa3, 0x79,
+ 0x00, 0x0f, 0xdb, 0xa6, 0xd3, 0xb1, 0xde, 0x95, 0xc5, 0x83, 0x18, 0x85, 0xae, 0xb7, 0x1e, 0xa6,
+ 0xb1, 0x7d, 0xb3, 0xcd, 0x9f, 0x2e, 0x84, 0x09, 0x2b, 0xa3, 0xd6, 0x04, 0x91, 0xa6, 0xc0, 0x2c,
+ 0x63, 0x92, 0x6c, 0xba, 0xc7, 0xae, 0xc7, 0x4b, 0x2c, 0xba, 0x72, 0xf6, 0x42, 0x46, 0x2d, 0x85,
+ 0xd3, 0x67, 0x51, 0x7e, 0x3f, 0xe7, 0x96, 0xfa, 0x81, 0xac, 0x0a, 0xb0, 0xe9, 0x2f, 0xc3, 0x38,
+ 0xeb, 0x53, 0xcc, 0xff, 0xc9, 0x21, 0xf3, 0xdf, 0xa6, 0xbc, 0x1a, 0x17, 0x41, 0xeb, 0x50, 0x32,
+ 0x89, 0x1f, 0xe8, 0xe1, 0x96, 0x94, 0x1f, 0x69, 0xb1, 0x15, 0xa9, 0xec, 0x4a, 0xff, 0xb6, 0x54,
+ 0xe8, 0xdb, 0x96, 0x3e, 0x27, 0x35, 0xd5, 0xfe, 0x96, 0xff, 0xf0, 0xe1, 0xbc, 0xf2, 0xd1, 0xc3,
+ 0x79, 0xe5, 0x93, 0x87, 0xf3, 0xca, 0xfb, 0x9f, 0xce, 0xe7, 0x3e, 0xfa, 0x74, 0x3e, 0xf7, 0x97,
+ 0x4f, 0xe7, 0x73, 0x70, 0xd5, 0x70, 0x3a, 0x19, 0xfc, 0xb1, 0x36, 0x13, 0x4f, 0x48, 0x3d, 0x27,
+ 0x70, 0x1a, 0xca, 0x5b, 0xcd, 0x7d, 0x2b, 0x68, 0x75, 0x9b, 0x55, 0xc3, 0xe9, 0x2c, 0x1a, 0x8e,
+ 0xdf, 0x71, 0xfc, 0x45, 0x8f, 0xb4, 0xf1, 0x11, 0xf1, 0x16, 0x7b, 0x4b, 0xf2, 0x93, 0xe5, 0x8d,
+ 0xfe, 0xe2, 0xf0, 0x5f, 0xbe, 0xbc, 0x18, 0x23, 0x86, 0xb4, 0x5f, 0xe5, 0x0b, 0x8d, 0xd5, 0x37,
+ 0x7e, 0x9d, 0x57, 0x1b, 0xe1, 0x10, 0x57, 0xe9, 0x10, 0x63, 0x83, 0xa9, 0x6e, 0x0b, 0xd6, 0x3f,
+ 0x46, 0x4c, 0xbb, 0x94, 0x69, 0x37, 0xc6, 0xb4, 0x1b, 0x32, 0x3d, 0xcc, 0x57, 0x87, 0x33, 0xed,
+ 0xbe, 0xda, 0xa8, 0x85, 0xcf, 0xbb, 0xfe, 0x91, 0x7f, 0x2a, 0x14, 0x58, 0x5e, 0xa6, 0x12, 0xcb,
+ 0xcb, 0x31, 0x91, 0xe5, 0xe5, 0x50, 0xa6, 0x39, 0xc1, 0x7e, 0xb1, 0x72, 0xf3, 0xbf, 0x01, 0x00,
+ 0x00, 0xff, 0xff, 0x96, 0xcf, 0xfa, 0xae, 0xe3, 0x33, 0x00, 0x00,
+}
+
+func (m *Transaction) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *Transaction) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *Transaction) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Anchor != nil {
+ {
+ size, err := m.Anchor.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1a
+ }
+ if len(m.BindingSig) > 0 {
+ i -= len(m.BindingSig)
+ copy(dAtA[i:], m.BindingSig)
+ i = encodeVarintTransaction(dAtA, i, uint64(len(m.BindingSig)))
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.Body != nil {
+ {
+ size, err := m.Body.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *Id) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *Id) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *Id) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.Hash) > 0 {
+ i -= len(m.Hash)
+ copy(dAtA[i:], m.Hash)
+ i = encodeVarintTransaction(dAtA, i, uint64(len(m.Hash)))
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *EffectHash) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *EffectHash) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *EffectHash) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.Inner) > 0 {
+ i -= len(m.Inner)
+ copy(dAtA[i:], m.Inner)
+ i = encodeVarintTransaction(dAtA, i, uint64(len(m.Inner)))
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *TransactionBody) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *TransactionBody) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *TransactionBody) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.MemoData != nil {
+ {
+ size, err := m.MemoData.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x2a
+ }
+ if m.DetectionData != nil {
+ {
+ size, err := m.DetectionData.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x22
+ }
+ if m.Fee != nil {
+ {
+ size, err := m.Fee.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1a
+ }
+ if m.TransactionParameters != nil {
+ {
+ size, err := m.TransactionParameters.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if len(m.Actions) > 0 {
+ for iNdEx := len(m.Actions) - 1; iNdEx >= 0; iNdEx-- {
+ {
+ size, err := m.Actions[iNdEx].MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *MemoData) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *MemoData) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *MemoData) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.XEncryptedMemo != nil {
+ {
+ size := m.XEncryptedMemo.Size()
+ i -= size
+ if _, err := m.XEncryptedMemo.MarshalTo(dAtA[i:]); err != nil {
+ return 0, err
+ }
+ }
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *MemoData_EncryptedMemo) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *MemoData_EncryptedMemo) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.EncryptedMemo != nil {
+ i -= len(m.EncryptedMemo)
+ copy(dAtA[i:], m.EncryptedMemo)
+ i = encodeVarintTransaction(dAtA, i, uint64(len(m.EncryptedMemo)))
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+func (m *TransactionParameters) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *TransactionParameters) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *TransactionParameters) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.ChainId) > 0 {
+ i -= len(m.ChainId)
+ copy(dAtA[i:], m.ChainId)
+ i = encodeVarintTransaction(dAtA, i, uint64(len(m.ChainId)))
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.ExpiryHeight != 0 {
+ i = encodeVarintTransaction(dAtA, i, uint64(m.ExpiryHeight))
+ i--
+ dAtA[i] = 0x8
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *DetectionData) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *DetectionData) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *DetectionData) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.FmdClues) > 0 {
+ for iNdEx := len(m.FmdClues) - 1; iNdEx >= 0; iNdEx-- {
+ {
+ size, err := m.FmdClues[iNdEx].MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x22
+ }
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *Action) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *Action) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *Action) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Action != nil {
+ {
+ size := m.Action.Size()
+ i -= size
+ if _, err := m.Action.MarshalTo(dAtA[i:]); err != nil {
+ return 0, err
+ }
+ }
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *Action_Spend) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *Action_Spend) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.Spend != nil {
+ {
+ size, err := m.Spend.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+func (m *Action_Output) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *Action_Output) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.Output != nil {
+ {
+ size, err := m.Output.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ return len(dAtA) - i, nil
+}
+func (m *Action_Swap) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *Action_Swap) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.Swap != nil {
+ {
+ size, err := m.Swap.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1a
+ }
+ return len(dAtA) - i, nil
+}
+func (m *Action_SwapClaim) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *Action_SwapClaim) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.SwapClaim != nil {
+ {
+ size, err := m.SwapClaim.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x22
+ }
+ return len(dAtA) - i, nil
+}
+func (m *Action_ValidatorDefinition) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *Action_ValidatorDefinition) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.ValidatorDefinition != nil {
+ {
+ size, err := m.ValidatorDefinition.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1
+ i--
+ dAtA[i] = 0x82
+ }
+ return len(dAtA) - i, nil
+}
+func (m *Action_IbcAction) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *Action_IbcAction) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.IbcAction != nil {
+ {
+ size, err := m.IbcAction.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1
+ i--
+ dAtA[i] = 0x8a
+ }
+ return len(dAtA) - i, nil
+}
+func (m *Action_ProposalSubmit) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *Action_ProposalSubmit) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.ProposalSubmit != nil {
+ {
+ size, err := m.ProposalSubmit.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1
+ i--
+ dAtA[i] = 0x92
+ }
+ return len(dAtA) - i, nil
+}
+func (m *Action_ProposalWithdraw) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *Action_ProposalWithdraw) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.ProposalWithdraw != nil {
+ {
+ size, err := m.ProposalWithdraw.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1
+ i--
+ dAtA[i] = 0x9a
+ }
+ return len(dAtA) - i, nil
+}
+func (m *Action_ValidatorVote) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *Action_ValidatorVote) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.ValidatorVote != nil {
+ {
+ size, err := m.ValidatorVote.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1
+ i--
+ dAtA[i] = 0xa2
+ }
+ return len(dAtA) - i, nil
+}
+func (m *Action_DelegatorVote) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *Action_DelegatorVote) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.DelegatorVote != nil {
+ {
+ size, err := m.DelegatorVote.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1
+ i--
+ dAtA[i] = 0xaa
+ }
+ return len(dAtA) - i, nil
+}
+func (m *Action_ProposalDepositClaim) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *Action_ProposalDepositClaim) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.ProposalDepositClaim != nil {
+ {
+ size, err := m.ProposalDepositClaim.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1
+ i--
+ dAtA[i] = 0xb2
+ }
+ return len(dAtA) - i, nil
+}
+func (m *Action_PositionOpen) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *Action_PositionOpen) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.PositionOpen != nil {
+ {
+ size, err := m.PositionOpen.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1
+ i--
+ dAtA[i] = 0xf2
+ }
+ return len(dAtA) - i, nil
+}
+func (m *Action_PositionClose) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *Action_PositionClose) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.PositionClose != nil {
+ {
+ size, err := m.PositionClose.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1
+ i--
+ dAtA[i] = 0xfa
+ }
+ return len(dAtA) - i, nil
+}
+func (m *Action_PositionWithdraw) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *Action_PositionWithdraw) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.PositionWithdraw != nil {
+ {
+ size, err := m.PositionWithdraw.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x2
+ i--
+ dAtA[i] = 0x82
+ }
+ return len(dAtA) - i, nil
+}
+func (m *Action_PositionRewardClaim) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *Action_PositionRewardClaim) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.PositionRewardClaim != nil {
+ {
+ size, err := m.PositionRewardClaim.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x2
+ i--
+ dAtA[i] = 0x92
+ }
+ return len(dAtA) - i, nil
+}
+func (m *Action_Delegate) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *Action_Delegate) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.Delegate != nil {
+ {
+ size, err := m.Delegate.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x2
+ i--
+ dAtA[i] = 0xc2
+ }
+ return len(dAtA) - i, nil
+}
+func (m *Action_Undelegate) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *Action_Undelegate) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.Undelegate != nil {
+ {
+ size, err := m.Undelegate.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x2
+ i--
+ dAtA[i] = 0xca
+ }
+ return len(dAtA) - i, nil
+}
+func (m *Action_UndelegateClaim) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *Action_UndelegateClaim) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.UndelegateClaim != nil {
+ {
+ size, err := m.UndelegateClaim.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x2
+ i--
+ dAtA[i] = 0xd2
+ }
+ return len(dAtA) - i, nil
+}
+func (m *Action_DaoSpend) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *Action_DaoSpend) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.DaoSpend != nil {
+ {
+ size, err := m.DaoSpend.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x3
+ i--
+ dAtA[i] = 0x92
+ }
+ return len(dAtA) - i, nil
+}
+func (m *Action_DaoOutput) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *Action_DaoOutput) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.DaoOutput != nil {
+ {
+ size, err := m.DaoOutput.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x3
+ i--
+ dAtA[i] = 0x9a
+ }
+ return len(dAtA) - i, nil
+}
+func (m *Action_DaoDeposit) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *Action_DaoDeposit) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.DaoDeposit != nil {
+ {
+ size, err := m.DaoDeposit.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x3
+ i--
+ dAtA[i] = 0xa2
+ }
+ return len(dAtA) - i, nil
+}
+func (m *Action_Ics20Withdrawal) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *Action_Ics20Withdrawal) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.Ics20Withdrawal != nil {
+ {
+ size, err := m.Ics20Withdrawal.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xc
+ i--
+ dAtA[i] = 0xc2
+ }
+ return len(dAtA) - i, nil
+}
+func (m *TransactionPerspective) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *TransactionPerspective) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *TransactionPerspective) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.TransactionId != nil {
+ {
+ size, err := m.TransactionId.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x32
+ }
+ if len(m.Denoms) > 0 {
+ for iNdEx := len(m.Denoms) - 1; iNdEx >= 0; iNdEx-- {
+ {
+ size, err := m.Denoms[iNdEx].MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x2a
+ }
+ }
+ if len(m.AddressViews) > 0 {
+ for iNdEx := len(m.AddressViews) - 1; iNdEx >= 0; iNdEx-- {
+ {
+ size, err := m.AddressViews[iNdEx].MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x22
+ }
+ }
+ if len(m.AdviceNotes) > 0 {
+ for iNdEx := len(m.AdviceNotes) - 1; iNdEx >= 0; iNdEx-- {
+ {
+ size, err := m.AdviceNotes[iNdEx].MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1a
+ }
+ }
+ if len(m.SpendNullifiers) > 0 {
+ for iNdEx := len(m.SpendNullifiers) - 1; iNdEx >= 0; iNdEx-- {
+ {
+ size, err := m.SpendNullifiers[iNdEx].MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ }
+ if len(m.PayloadKeys) > 0 {
+ for iNdEx := len(m.PayloadKeys) - 1; iNdEx >= 0; iNdEx-- {
+ {
+ size, err := m.PayloadKeys[iNdEx].MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *PayloadKey) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *PayloadKey) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *PayloadKey) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.Inner) > 0 {
+ i -= len(m.Inner)
+ copy(dAtA[i:], m.Inner)
+ i = encodeVarintTransaction(dAtA, i, uint64(len(m.Inner)))
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *PayloadKeyWithCommitment) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *PayloadKeyWithCommitment) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *PayloadKeyWithCommitment) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Commitment != nil {
+ {
+ size, err := m.Commitment.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.PayloadKey != nil {
+ {
+ size, err := m.PayloadKey.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *NullifierWithNote) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *NullifierWithNote) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *NullifierWithNote) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Note != nil {
+ {
+ size, err := m.Note.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.Nullifier != nil {
+ {
+ size, err := m.Nullifier.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *TransactionView) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *TransactionView) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *TransactionView) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Anchor != nil {
+ {
+ size, err := m.Anchor.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1a
+ }
+ if len(m.BindingSig) > 0 {
+ i -= len(m.BindingSig)
+ copy(dAtA[i:], m.BindingSig)
+ i = encodeVarintTransaction(dAtA, i, uint64(len(m.BindingSig)))
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.BodyView != nil {
+ {
+ size, err := m.BodyView.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *TransactionBodyView) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *TransactionBodyView) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *TransactionBodyView) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.XMemoView != nil {
+ {
+ size := m.XMemoView.Size()
+ i -= size
+ if _, err := m.XMemoView.MarshalTo(dAtA[i:]); err != nil {
+ return 0, err
+ }
+ }
+ }
+ if m.XDetectionData != nil {
+ {
+ size := m.XDetectionData.Size()
+ i -= size
+ if _, err := m.XDetectionData.MarshalTo(dAtA[i:]); err != nil {
+ return 0, err
+ }
+ }
+ }
+ if m.Fee != nil {
+ {
+ size, err := m.Fee.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1a
+ }
+ if m.TransactionParameters != nil {
+ {
+ size, err := m.TransactionParameters.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if len(m.ActionViews) > 0 {
+ for iNdEx := len(m.ActionViews) - 1; iNdEx >= 0; iNdEx-- {
+ {
+ size, err := m.ActionViews[iNdEx].MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *TransactionBodyView_DetectionData) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *TransactionBodyView_DetectionData) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.DetectionData != nil {
+ {
+ size, err := m.DetectionData.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x22
+ }
+ return len(dAtA) - i, nil
+}
+func (m *TransactionBodyView_MemoView) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *TransactionBodyView_MemoView) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.MemoView != nil {
+ {
+ size, err := m.MemoView.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x2a
+ }
+ return len(dAtA) - i, nil
+}
+func (m *ActionView) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *ActionView) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ActionView) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.ActionView != nil {
+ {
+ size := m.ActionView.Size()
+ i -= size
+ if _, err := m.ActionView.MarshalTo(dAtA[i:]); err != nil {
+ return 0, err
+ }
+ }
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *ActionView_Spend) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ActionView_Spend) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.Spend != nil {
+ {
+ size, err := m.Spend.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+func (m *ActionView_Output) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ActionView_Output) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.Output != nil {
+ {
+ size, err := m.Output.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ return len(dAtA) - i, nil
+}
+func (m *ActionView_Swap) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ActionView_Swap) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.Swap != nil {
+ {
+ size, err := m.Swap.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1a
+ }
+ return len(dAtA) - i, nil
+}
+func (m *ActionView_SwapClaim) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ActionView_SwapClaim) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.SwapClaim != nil {
+ {
+ size, err := m.SwapClaim.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x22
+ }
+ return len(dAtA) - i, nil
+}
+func (m *ActionView_ValidatorDefinition) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ActionView_ValidatorDefinition) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.ValidatorDefinition != nil {
+ {
+ size, err := m.ValidatorDefinition.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1
+ i--
+ dAtA[i] = 0x82
+ }
+ return len(dAtA) - i, nil
+}
+func (m *ActionView_IbcAction) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ActionView_IbcAction) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.IbcAction != nil {
+ {
+ size, err := m.IbcAction.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1
+ i--
+ dAtA[i] = 0x8a
+ }
+ return len(dAtA) - i, nil
+}
+func (m *ActionView_ProposalSubmit) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ActionView_ProposalSubmit) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.ProposalSubmit != nil {
+ {
+ size, err := m.ProposalSubmit.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1
+ i--
+ dAtA[i] = 0x92
+ }
+ return len(dAtA) - i, nil
+}
+func (m *ActionView_ProposalWithdraw) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ActionView_ProposalWithdraw) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.ProposalWithdraw != nil {
+ {
+ size, err := m.ProposalWithdraw.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1
+ i--
+ dAtA[i] = 0x9a
+ }
+ return len(dAtA) - i, nil
+}
+func (m *ActionView_ValidatorVote) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ActionView_ValidatorVote) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.ValidatorVote != nil {
+ {
+ size, err := m.ValidatorVote.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1
+ i--
+ dAtA[i] = 0xa2
+ }
+ return len(dAtA) - i, nil
+}
+func (m *ActionView_DelegatorVote) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ActionView_DelegatorVote) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.DelegatorVote != nil {
+ {
+ size, err := m.DelegatorVote.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1
+ i--
+ dAtA[i] = 0xaa
+ }
+ return len(dAtA) - i, nil
+}
+func (m *ActionView_ProposalDepositClaim) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ActionView_ProposalDepositClaim) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.ProposalDepositClaim != nil {
+ {
+ size, err := m.ProposalDepositClaim.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1
+ i--
+ dAtA[i] = 0xb2
+ }
+ return len(dAtA) - i, nil
+}
+func (m *ActionView_PositionOpen) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ActionView_PositionOpen) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.PositionOpen != nil {
+ {
+ size, err := m.PositionOpen.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1
+ i--
+ dAtA[i] = 0xf2
+ }
+ return len(dAtA) - i, nil
+}
+func (m *ActionView_PositionClose) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ActionView_PositionClose) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.PositionClose != nil {
+ {
+ size, err := m.PositionClose.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1
+ i--
+ dAtA[i] = 0xfa
+ }
+ return len(dAtA) - i, nil
+}
+func (m *ActionView_PositionWithdraw) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ActionView_PositionWithdraw) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.PositionWithdraw != nil {
+ {
+ size, err := m.PositionWithdraw.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x2
+ i--
+ dAtA[i] = 0x82
+ }
+ return len(dAtA) - i, nil
+}
+func (m *ActionView_PositionRewardClaim) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ActionView_PositionRewardClaim) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.PositionRewardClaim != nil {
+ {
+ size, err := m.PositionRewardClaim.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x2
+ i--
+ dAtA[i] = 0x92
+ }
+ return len(dAtA) - i, nil
+}
+func (m *ActionView_Delegate) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ActionView_Delegate) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.Delegate != nil {
+ {
+ size, err := m.Delegate.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x2
+ i--
+ dAtA[i] = 0xca
+ }
+ return len(dAtA) - i, nil
+}
+func (m *ActionView_Undelegate) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ActionView_Undelegate) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.Undelegate != nil {
+ {
+ size, err := m.Undelegate.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x2
+ i--
+ dAtA[i] = 0xd2
+ }
+ return len(dAtA) - i, nil
+}
+func (m *ActionView_UndelegateClaim) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ActionView_UndelegateClaim) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.UndelegateClaim != nil {
+ {
+ size, err := m.UndelegateClaim.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x2
+ i--
+ dAtA[i] = 0xda
+ }
+ return len(dAtA) - i, nil
+}
+func (m *ActionView_DaoSpend) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ActionView_DaoSpend) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.DaoSpend != nil {
+ {
+ size, err := m.DaoSpend.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x3
+ i--
+ dAtA[i] = 0x92
+ }
+ return len(dAtA) - i, nil
+}
+func (m *ActionView_DaoOutput) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ActionView_DaoOutput) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.DaoOutput != nil {
+ {
+ size, err := m.DaoOutput.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x3
+ i--
+ dAtA[i] = 0x9a
+ }
+ return len(dAtA) - i, nil
+}
+func (m *ActionView_DaoDeposit) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ActionView_DaoDeposit) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.DaoDeposit != nil {
+ {
+ size, err := m.DaoDeposit.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x3
+ i--
+ dAtA[i] = 0xa2
+ }
+ return len(dAtA) - i, nil
+}
+func (m *ActionView_Ics20Withdrawal) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ActionView_Ics20Withdrawal) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.Ics20Withdrawal != nil {
+ {
+ size, err := m.Ics20Withdrawal.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xc
+ i--
+ dAtA[i] = 0xc2
+ }
+ return len(dAtA) - i, nil
+}
+func (m *SpendView) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *SpendView) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *SpendView) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.SpendView != nil {
+ {
+ size := m.SpendView.Size()
+ i -= size
+ if _, err := m.SpendView.MarshalTo(dAtA[i:]); err != nil {
+ return 0, err
+ }
+ }
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *SpendView_Visible_) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *SpendView_Visible_) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.Visible != nil {
+ {
+ size, err := m.Visible.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+func (m *SpendView_Opaque_) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *SpendView_Opaque_) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.Opaque != nil {
+ {
+ size, err := m.Opaque.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ return len(dAtA) - i, nil
+}
+func (m *SpendView_Visible) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *SpendView_Visible) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *SpendView_Visible) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Note != nil {
+ {
+ size, err := m.Note.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.Spend != nil {
+ {
+ size, err := m.Spend.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *SpendView_Opaque) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *SpendView_Opaque) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *SpendView_Opaque) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Spend != nil {
+ {
+ size, err := m.Spend.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *DelegatorVoteView) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *DelegatorVoteView) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *DelegatorVoteView) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.DelegatorVote != nil {
+ {
+ size := m.DelegatorVote.Size()
+ i -= size
+ if _, err := m.DelegatorVote.MarshalTo(dAtA[i:]); err != nil {
+ return 0, err
+ }
+ }
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *DelegatorVoteView_Visible_) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *DelegatorVoteView_Visible_) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.Visible != nil {
+ {
+ size, err := m.Visible.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+func (m *DelegatorVoteView_Opaque_) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *DelegatorVoteView_Opaque_) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.Opaque != nil {
+ {
+ size, err := m.Opaque.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ return len(dAtA) - i, nil
+}
+func (m *DelegatorVoteView_Visible) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *DelegatorVoteView_Visible) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *DelegatorVoteView_Visible) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Note != nil {
+ {
+ size, err := m.Note.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.DelegatorVote != nil {
+ {
+ size, err := m.DelegatorVote.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *DelegatorVoteView_Opaque) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *DelegatorVoteView_Opaque) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *DelegatorVoteView_Opaque) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.DelegatorVote != nil {
+ {
+ size, err := m.DelegatorVote.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *OutputView) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *OutputView) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *OutputView) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.OutputView != nil {
+ {
+ size := m.OutputView.Size()
+ i -= size
+ if _, err := m.OutputView.MarshalTo(dAtA[i:]); err != nil {
+ return 0, err
+ }
+ }
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *OutputView_Visible_) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *OutputView_Visible_) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.Visible != nil {
+ {
+ size, err := m.Visible.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+func (m *OutputView_Opaque_) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *OutputView_Opaque_) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.Opaque != nil {
+ {
+ size, err := m.Opaque.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ return len(dAtA) - i, nil
+}
+func (m *OutputView_Visible) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *OutputView_Visible) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *OutputView_Visible) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.PayloadKey != nil {
+ {
+ size, err := m.PayloadKey.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1a
+ }
+ if m.Note != nil {
+ {
+ size, err := m.Note.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.Output != nil {
+ {
+ size, err := m.Output.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *OutputView_Opaque) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *OutputView_Opaque) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *OutputView_Opaque) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Output != nil {
+ {
+ size, err := m.Output.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *Spend) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *Spend) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *Spend) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Proof != nil {
+ {
+ size, err := m.Proof.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1a
+ }
+ if m.AuthSig != nil {
+ {
+ size, err := m.AuthSig.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.Body != nil {
+ {
+ size, err := m.Body.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *SpendBody) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *SpendBody) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *SpendBody) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.Rk) > 0 {
+ i -= len(m.Rk)
+ copy(dAtA[i:], m.Rk)
+ i = encodeVarintTransaction(dAtA, i, uint64(len(m.Rk)))
+ i--
+ dAtA[i] = 0x22
+ }
+ if len(m.Nullifier) > 0 {
+ i -= len(m.Nullifier)
+ copy(dAtA[i:], m.Nullifier)
+ i = encodeVarintTransaction(dAtA, i, uint64(len(m.Nullifier)))
+ i--
+ dAtA[i] = 0x1a
+ }
+ if m.BalanceCommitment != nil {
+ {
+ size, err := m.BalanceCommitment.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *Output) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *Output) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *Output) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Proof != nil {
+ {
+ size, err := m.Proof.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.Body != nil {
+ {
+ size, err := m.Body.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *OutputBody) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *OutputBody) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *OutputBody) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.OvkWrappedKey) > 0 {
+ i -= len(m.OvkWrappedKey)
+ copy(dAtA[i:], m.OvkWrappedKey)
+ i = encodeVarintTransaction(dAtA, i, uint64(len(m.OvkWrappedKey)))
+ i--
+ dAtA[i] = 0x22
+ }
+ if len(m.WrappedMemoKey) > 0 {
+ i -= len(m.WrappedMemoKey)
+ copy(dAtA[i:], m.WrappedMemoKey)
+ i = encodeVarintTransaction(dAtA, i, uint64(len(m.WrappedMemoKey)))
+ i--
+ dAtA[i] = 0x1a
+ }
+ if m.BalanceCommitment != nil {
+ {
+ size, err := m.BalanceCommitment.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.NotePayload != nil {
+ {
+ size, err := m.NotePayload.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *AuthorizationData) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *AuthorizationData) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *AuthorizationData) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.DelegatorVoteAuths) > 0 {
+ for iNdEx := len(m.DelegatorVoteAuths) - 1; iNdEx >= 0; iNdEx-- {
+ {
+ size, err := m.DelegatorVoteAuths[iNdEx].MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1a
+ }
+ }
+ if len(m.SpendAuths) > 0 {
+ for iNdEx := len(m.SpendAuths) - 1; iNdEx >= 0; iNdEx-- {
+ {
+ size, err := m.SpendAuths[iNdEx].MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ }
+ if m.EffectHash != nil {
+ {
+ size, err := m.EffectHash.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *WitnessData) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *WitnessData) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *WitnessData) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.StateCommitmentProofs) > 0 {
+ for iNdEx := len(m.StateCommitmentProofs) - 1; iNdEx >= 0; iNdEx-- {
+ {
+ size, err := m.StateCommitmentProofs[iNdEx].MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ }
+ if m.Anchor != nil {
+ {
+ size, err := m.Anchor.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *TransactionPlan) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *TransactionPlan) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *TransactionPlan) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.MemoPlan != nil {
+ {
+ size, err := m.MemoPlan.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x32
+ }
+ if len(m.CluePlans) > 0 {
+ for iNdEx := len(m.CluePlans) - 1; iNdEx >= 0; iNdEx-- {
+ {
+ size, err := m.CluePlans[iNdEx].MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x2a
+ }
+ }
+ if m.Fee != nil {
+ {
+ size, err := m.Fee.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x22
+ }
+ if len(m.ChainId) > 0 {
+ i -= len(m.ChainId)
+ copy(dAtA[i:], m.ChainId)
+ i = encodeVarintTransaction(dAtA, i, uint64(len(m.ChainId)))
+ i--
+ dAtA[i] = 0x1a
+ }
+ if m.ExpiryHeight != 0 {
+ i = encodeVarintTransaction(dAtA, i, uint64(m.ExpiryHeight))
+ i--
+ dAtA[i] = 0x10
+ }
+ if len(m.Actions) > 0 {
+ for iNdEx := len(m.Actions) - 1; iNdEx >= 0; iNdEx-- {
+ {
+ size, err := m.Actions[iNdEx].MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *ActionPlan) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *ActionPlan) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ActionPlan) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Action != nil {
+ {
+ size := m.Action.Size()
+ i -= size
+ if _, err := m.Action.MarshalTo(dAtA[i:]); err != nil {
+ return 0, err
+ }
+ }
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *ActionPlan_Spend) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ActionPlan_Spend) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.Spend != nil {
+ {
+ size, err := m.Spend.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+func (m *ActionPlan_Output) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ActionPlan_Output) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.Output != nil {
+ {
+ size, err := m.Output.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ return len(dAtA) - i, nil
+}
+func (m *ActionPlan_Swap) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ActionPlan_Swap) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.Swap != nil {
+ {
+ size, err := m.Swap.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1a
+ }
+ return len(dAtA) - i, nil
+}
+func (m *ActionPlan_SwapClaim) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ActionPlan_SwapClaim) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.SwapClaim != nil {
+ {
+ size, err := m.SwapClaim.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x22
+ }
+ return len(dAtA) - i, nil
+}
+func (m *ActionPlan_ValidatorDefinition) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ActionPlan_ValidatorDefinition) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.ValidatorDefinition != nil {
+ {
+ size, err := m.ValidatorDefinition.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1
+ i--
+ dAtA[i] = 0x82
+ }
+ return len(dAtA) - i, nil
+}
+func (m *ActionPlan_IbcAction) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ActionPlan_IbcAction) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.IbcAction != nil {
+ {
+ size, err := m.IbcAction.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1
+ i--
+ dAtA[i] = 0x8a
+ }
+ return len(dAtA) - i, nil
+}
+func (m *ActionPlan_ProposalSubmit) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ActionPlan_ProposalSubmit) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.ProposalSubmit != nil {
+ {
+ size, err := m.ProposalSubmit.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1
+ i--
+ dAtA[i] = 0x92
+ }
+ return len(dAtA) - i, nil
+}
+func (m *ActionPlan_ProposalWithdraw) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ActionPlan_ProposalWithdraw) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.ProposalWithdraw != nil {
+ {
+ size, err := m.ProposalWithdraw.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1
+ i--
+ dAtA[i] = 0x9a
+ }
+ return len(dAtA) - i, nil
+}
+func (m *ActionPlan_ValidatorVote) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ActionPlan_ValidatorVote) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.ValidatorVote != nil {
+ {
+ size, err := m.ValidatorVote.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1
+ i--
+ dAtA[i] = 0xa2
+ }
+ return len(dAtA) - i, nil
+}
+func (m *ActionPlan_DelegatorVote) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ActionPlan_DelegatorVote) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.DelegatorVote != nil {
+ {
+ size, err := m.DelegatorVote.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1
+ i--
+ dAtA[i] = 0xaa
+ }
+ return len(dAtA) - i, nil
+}
+func (m *ActionPlan_ProposalDepositClaim) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ActionPlan_ProposalDepositClaim) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.ProposalDepositClaim != nil {
+ {
+ size, err := m.ProposalDepositClaim.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1
+ i--
+ dAtA[i] = 0xb2
+ }
+ return len(dAtA) - i, nil
+}
+func (m *ActionPlan_Withdrawal) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ActionPlan_Withdrawal) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.Withdrawal != nil {
+ {
+ size, err := m.Withdrawal.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1
+ i--
+ dAtA[i] = 0xba
+ }
+ return len(dAtA) - i, nil
+}
+func (m *ActionPlan_PositionOpen) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ActionPlan_PositionOpen) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.PositionOpen != nil {
+ {
+ size, err := m.PositionOpen.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1
+ i--
+ dAtA[i] = 0xf2
+ }
+ return len(dAtA) - i, nil
+}
+func (m *ActionPlan_PositionClose) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ActionPlan_PositionClose) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.PositionClose != nil {
+ {
+ size, err := m.PositionClose.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1
+ i--
+ dAtA[i] = 0xfa
+ }
+ return len(dAtA) - i, nil
+}
+func (m *ActionPlan_PositionWithdraw) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ActionPlan_PositionWithdraw) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.PositionWithdraw != nil {
+ {
+ size, err := m.PositionWithdraw.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x2
+ i--
+ dAtA[i] = 0x82
+ }
+ return len(dAtA) - i, nil
+}
+func (m *ActionPlan_PositionRewardClaim) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ActionPlan_PositionRewardClaim) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.PositionRewardClaim != nil {
+ {
+ size, err := m.PositionRewardClaim.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x2
+ i--
+ dAtA[i] = 0x92
+ }
+ return len(dAtA) - i, nil
+}
+func (m *ActionPlan_Delegate) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ActionPlan_Delegate) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.Delegate != nil {
+ {
+ size, err := m.Delegate.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x2
+ i--
+ dAtA[i] = 0xc2
+ }
+ return len(dAtA) - i, nil
+}
+func (m *ActionPlan_Undelegate) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ActionPlan_Undelegate) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.Undelegate != nil {
+ {
+ size, err := m.Undelegate.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x2
+ i--
+ dAtA[i] = 0xca
+ }
+ return len(dAtA) - i, nil
+}
+func (m *ActionPlan_UndelegateClaim) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ActionPlan_UndelegateClaim) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.UndelegateClaim != nil {
+ {
+ size, err := m.UndelegateClaim.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x2
+ i--
+ dAtA[i] = 0xd2
+ }
+ return len(dAtA) - i, nil
+}
+func (m *ActionPlan_DaoSpend) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ActionPlan_DaoSpend) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.DaoSpend != nil {
+ {
+ size, err := m.DaoSpend.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x3
+ i--
+ dAtA[i] = 0x92
+ }
+ return len(dAtA) - i, nil
+}
+func (m *ActionPlan_DaoOutput) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ActionPlan_DaoOutput) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.DaoOutput != nil {
+ {
+ size, err := m.DaoOutput.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x3
+ i--
+ dAtA[i] = 0x9a
+ }
+ return len(dAtA) - i, nil
+}
+func (m *ActionPlan_DaoDeposit) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ActionPlan_DaoDeposit) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.DaoDeposit != nil {
+ {
+ size, err := m.DaoDeposit.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x3
+ i--
+ dAtA[i] = 0xa2
+ }
+ return len(dAtA) - i, nil
+}
+func (m *CluePlan) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *CluePlan) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *CluePlan) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.PrecisionBits != 0 {
+ i = encodeVarintTransaction(dAtA, i, uint64(m.PrecisionBits))
+ i--
+ dAtA[i] = 0x18
+ }
+ if len(m.Rseed) > 0 {
+ i -= len(m.Rseed)
+ copy(dAtA[i:], m.Rseed)
+ i = encodeVarintTransaction(dAtA, i, uint64(len(m.Rseed)))
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.Address != nil {
+ {
+ size, err := m.Address.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *MemoPlan) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *MemoPlan) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *MemoPlan) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.Key) > 0 {
+ i -= len(m.Key)
+ copy(dAtA[i:], m.Key)
+ i = encodeVarintTransaction(dAtA, i, uint64(len(m.Key)))
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.Plaintext != nil {
+ {
+ size, err := m.Plaintext.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *MemoCiphertext) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *MemoCiphertext) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *MemoCiphertext) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.Inner) > 0 {
+ i -= len(m.Inner)
+ copy(dAtA[i:], m.Inner)
+ i = encodeVarintTransaction(dAtA, i, uint64(len(m.Inner)))
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *MemoPlaintext) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *MemoPlaintext) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *MemoPlaintext) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.Text) > 0 {
+ i -= len(m.Text)
+ copy(dAtA[i:], m.Text)
+ i = encodeVarintTransaction(dAtA, i, uint64(len(m.Text)))
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.Sender != nil {
+ {
+ size, err := m.Sender.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *MemoView) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *MemoView) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *MemoView) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.MemoView != nil {
+ {
+ size := m.MemoView.Size()
+ i -= size
+ if _, err := m.MemoView.MarshalTo(dAtA[i:]); err != nil {
+ return 0, err
+ }
+ }
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *MemoView_Visible_) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *MemoView_Visible_) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.Visible != nil {
+ {
+ size, err := m.Visible.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+func (m *MemoView_Opaque_) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *MemoView_Opaque_) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.Opaque != nil {
+ {
+ size, err := m.Opaque.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ return len(dAtA) - i, nil
+}
+func (m *MemoView_Visible) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *MemoView_Visible) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *MemoView_Visible) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Plaintext != nil {
+ {
+ size, err := m.Plaintext.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.Ciphertext != nil {
+ {
+ size, err := m.Ciphertext.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *MemoView_Opaque) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *MemoView_Opaque) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *MemoView_Opaque) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Ciphertext != nil {
+ {
+ size, err := m.Ciphertext.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *SpendPlan) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *SpendPlan) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *SpendPlan) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.ProofBlindingS) > 0 {
+ i -= len(m.ProofBlindingS)
+ copy(dAtA[i:], m.ProofBlindingS)
+ i = encodeVarintTransaction(dAtA, i, uint64(len(m.ProofBlindingS)))
+ i--
+ dAtA[i] = 0x32
+ }
+ if len(m.ProofBlindingR) > 0 {
+ i -= len(m.ProofBlindingR)
+ copy(dAtA[i:], m.ProofBlindingR)
+ i = encodeVarintTransaction(dAtA, i, uint64(len(m.ProofBlindingR)))
+ i--
+ dAtA[i] = 0x2a
+ }
+ if len(m.ValueBlinding) > 0 {
+ i -= len(m.ValueBlinding)
+ copy(dAtA[i:], m.ValueBlinding)
+ i = encodeVarintTransaction(dAtA, i, uint64(len(m.ValueBlinding)))
+ i--
+ dAtA[i] = 0x22
+ }
+ if len(m.Randomizer) > 0 {
+ i -= len(m.Randomizer)
+ copy(dAtA[i:], m.Randomizer)
+ i = encodeVarintTransaction(dAtA, i, uint64(len(m.Randomizer)))
+ i--
+ dAtA[i] = 0x1a
+ }
+ if m.Position != 0 {
+ i = encodeVarintTransaction(dAtA, i, uint64(m.Position))
+ i--
+ dAtA[i] = 0x10
+ }
+ if m.Note != nil {
+ {
+ size, err := m.Note.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *OutputPlan) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *OutputPlan) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *OutputPlan) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.ProofBlindingS) > 0 {
+ i -= len(m.ProofBlindingS)
+ copy(dAtA[i:], m.ProofBlindingS)
+ i = encodeVarintTransaction(dAtA, i, uint64(len(m.ProofBlindingS)))
+ i--
+ dAtA[i] = 0x32
+ }
+ if len(m.ProofBlindingR) > 0 {
+ i -= len(m.ProofBlindingR)
+ copy(dAtA[i:], m.ProofBlindingR)
+ i = encodeVarintTransaction(dAtA, i, uint64(len(m.ProofBlindingR)))
+ i--
+ dAtA[i] = 0x2a
+ }
+ if len(m.ValueBlinding) > 0 {
+ i -= len(m.ValueBlinding)
+ copy(dAtA[i:], m.ValueBlinding)
+ i = encodeVarintTransaction(dAtA, i, uint64(len(m.ValueBlinding)))
+ i--
+ dAtA[i] = 0x22
+ }
+ if len(m.Rseed) > 0 {
+ i -= len(m.Rseed)
+ copy(dAtA[i:], m.Rseed)
+ i = encodeVarintTransaction(dAtA, i, uint64(len(m.Rseed)))
+ i--
+ dAtA[i] = 0x1a
+ }
+ if m.DestAddress != nil {
+ {
+ size, err := m.DestAddress.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.Value != nil {
+ {
+ size, err := m.Value.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransaction(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func encodeVarintTransaction(dAtA []byte, offset int, v uint64) int {
+ offset -= sovTransaction(v)
+ base := offset
+ for v >= 1<<7 {
+ dAtA[offset] = uint8(v&0x7f | 0x80)
+ v >>= 7
+ offset++
+ }
+ dAtA[offset] = uint8(v)
+ return base
+}
+func (m *Transaction) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Body != nil {
+ l = m.Body.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ l = len(m.BindingSig)
+ if l > 0 {
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ if m.Anchor != nil {
+ l = m.Anchor.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+
+func (m *Id) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ l = len(m.Hash)
+ if l > 0 {
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+
+func (m *EffectHash) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ l = len(m.Inner)
+ if l > 0 {
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+
+func (m *TransactionBody) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if len(m.Actions) > 0 {
+ for _, e := range m.Actions {
+ l = e.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ }
+ if m.TransactionParameters != nil {
+ l = m.TransactionParameters.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ if m.Fee != nil {
+ l = m.Fee.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ if m.DetectionData != nil {
+ l = m.DetectionData.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ if m.MemoData != nil {
+ l = m.MemoData.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+
+func (m *MemoData) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.XEncryptedMemo != nil {
+ n += m.XEncryptedMemo.Size()
+ }
+ return n
+}
+
+func (m *MemoData_EncryptedMemo) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.EncryptedMemo != nil {
+ l = len(m.EncryptedMemo)
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *TransactionParameters) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.ExpiryHeight != 0 {
+ n += 1 + sovTransaction(uint64(m.ExpiryHeight))
+ }
+ l = len(m.ChainId)
+ if l > 0 {
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+
+func (m *DetectionData) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if len(m.FmdClues) > 0 {
+ for _, e := range m.FmdClues {
+ l = e.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ }
+ return n
+}
+
+func (m *Action) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Action != nil {
+ n += m.Action.Size()
+ }
+ return n
+}
+
+func (m *Action_Spend) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Spend != nil {
+ l = m.Spend.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *Action_Output) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Output != nil {
+ l = m.Output.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *Action_Swap) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Swap != nil {
+ l = m.Swap.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *Action_SwapClaim) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.SwapClaim != nil {
+ l = m.SwapClaim.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *Action_ValidatorDefinition) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.ValidatorDefinition != nil {
+ l = m.ValidatorDefinition.Size()
+ n += 2 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *Action_IbcAction) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.IbcAction != nil {
+ l = m.IbcAction.Size()
+ n += 2 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *Action_ProposalSubmit) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.ProposalSubmit != nil {
+ l = m.ProposalSubmit.Size()
+ n += 2 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *Action_ProposalWithdraw) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.ProposalWithdraw != nil {
+ l = m.ProposalWithdraw.Size()
+ n += 2 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *Action_ValidatorVote) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.ValidatorVote != nil {
+ l = m.ValidatorVote.Size()
+ n += 2 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *Action_DelegatorVote) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.DelegatorVote != nil {
+ l = m.DelegatorVote.Size()
+ n += 2 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *Action_ProposalDepositClaim) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.ProposalDepositClaim != nil {
+ l = m.ProposalDepositClaim.Size()
+ n += 2 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *Action_PositionOpen) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.PositionOpen != nil {
+ l = m.PositionOpen.Size()
+ n += 2 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *Action_PositionClose) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.PositionClose != nil {
+ l = m.PositionClose.Size()
+ n += 2 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *Action_PositionWithdraw) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.PositionWithdraw != nil {
+ l = m.PositionWithdraw.Size()
+ n += 2 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *Action_PositionRewardClaim) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.PositionRewardClaim != nil {
+ l = m.PositionRewardClaim.Size()
+ n += 2 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *Action_Delegate) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Delegate != nil {
+ l = m.Delegate.Size()
+ n += 2 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *Action_Undelegate) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Undelegate != nil {
+ l = m.Undelegate.Size()
+ n += 2 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *Action_UndelegateClaim) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.UndelegateClaim != nil {
+ l = m.UndelegateClaim.Size()
+ n += 2 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *Action_DaoSpend) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.DaoSpend != nil {
+ l = m.DaoSpend.Size()
+ n += 2 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *Action_DaoOutput) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.DaoOutput != nil {
+ l = m.DaoOutput.Size()
+ n += 2 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *Action_DaoDeposit) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.DaoDeposit != nil {
+ l = m.DaoDeposit.Size()
+ n += 2 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *Action_Ics20Withdrawal) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Ics20Withdrawal != nil {
+ l = m.Ics20Withdrawal.Size()
+ n += 2 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *TransactionPerspective) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if len(m.PayloadKeys) > 0 {
+ for _, e := range m.PayloadKeys {
+ l = e.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ }
+ if len(m.SpendNullifiers) > 0 {
+ for _, e := range m.SpendNullifiers {
+ l = e.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ }
+ if len(m.AdviceNotes) > 0 {
+ for _, e := range m.AdviceNotes {
+ l = e.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ }
+ if len(m.AddressViews) > 0 {
+ for _, e := range m.AddressViews {
+ l = e.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ }
+ if len(m.Denoms) > 0 {
+ for _, e := range m.Denoms {
+ l = e.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ }
+ if m.TransactionId != nil {
+ l = m.TransactionId.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+
+func (m *PayloadKey) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ l = len(m.Inner)
+ if l > 0 {
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+
+func (m *PayloadKeyWithCommitment) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.PayloadKey != nil {
+ l = m.PayloadKey.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ if m.Commitment != nil {
+ l = m.Commitment.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+
+func (m *NullifierWithNote) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Nullifier != nil {
+ l = m.Nullifier.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ if m.Note != nil {
+ l = m.Note.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+
+func (m *TransactionView) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.BodyView != nil {
+ l = m.BodyView.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ l = len(m.BindingSig)
+ if l > 0 {
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ if m.Anchor != nil {
+ l = m.Anchor.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+
+func (m *TransactionBodyView) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if len(m.ActionViews) > 0 {
+ for _, e := range m.ActionViews {
+ l = e.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ }
+ if m.TransactionParameters != nil {
+ l = m.TransactionParameters.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ if m.Fee != nil {
+ l = m.Fee.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ if m.XDetectionData != nil {
+ n += m.XDetectionData.Size()
+ }
+ if m.XMemoView != nil {
+ n += m.XMemoView.Size()
+ }
+ return n
+}
+
+func (m *TransactionBodyView_DetectionData) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.DetectionData != nil {
+ l = m.DetectionData.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *TransactionBodyView_MemoView) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.MemoView != nil {
+ l = m.MemoView.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *ActionView) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.ActionView != nil {
+ n += m.ActionView.Size()
+ }
+ return n
+}
+
+func (m *ActionView_Spend) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Spend != nil {
+ l = m.Spend.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *ActionView_Output) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Output != nil {
+ l = m.Output.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *ActionView_Swap) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Swap != nil {
+ l = m.Swap.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *ActionView_SwapClaim) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.SwapClaim != nil {
+ l = m.SwapClaim.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *ActionView_ValidatorDefinition) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.ValidatorDefinition != nil {
+ l = m.ValidatorDefinition.Size()
+ n += 2 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *ActionView_IbcAction) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.IbcAction != nil {
+ l = m.IbcAction.Size()
+ n += 2 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *ActionView_ProposalSubmit) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.ProposalSubmit != nil {
+ l = m.ProposalSubmit.Size()
+ n += 2 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *ActionView_ProposalWithdraw) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.ProposalWithdraw != nil {
+ l = m.ProposalWithdraw.Size()
+ n += 2 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *ActionView_ValidatorVote) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.ValidatorVote != nil {
+ l = m.ValidatorVote.Size()
+ n += 2 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *ActionView_DelegatorVote) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.DelegatorVote != nil {
+ l = m.DelegatorVote.Size()
+ n += 2 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *ActionView_ProposalDepositClaim) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.ProposalDepositClaim != nil {
+ l = m.ProposalDepositClaim.Size()
+ n += 2 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *ActionView_PositionOpen) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.PositionOpen != nil {
+ l = m.PositionOpen.Size()
+ n += 2 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *ActionView_PositionClose) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.PositionClose != nil {
+ l = m.PositionClose.Size()
+ n += 2 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *ActionView_PositionWithdraw) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.PositionWithdraw != nil {
+ l = m.PositionWithdraw.Size()
+ n += 2 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *ActionView_PositionRewardClaim) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.PositionRewardClaim != nil {
+ l = m.PositionRewardClaim.Size()
+ n += 2 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *ActionView_Delegate) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Delegate != nil {
+ l = m.Delegate.Size()
+ n += 2 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *ActionView_Undelegate) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Undelegate != nil {
+ l = m.Undelegate.Size()
+ n += 2 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *ActionView_UndelegateClaim) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.UndelegateClaim != nil {
+ l = m.UndelegateClaim.Size()
+ n += 2 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *ActionView_DaoSpend) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.DaoSpend != nil {
+ l = m.DaoSpend.Size()
+ n += 2 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *ActionView_DaoOutput) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.DaoOutput != nil {
+ l = m.DaoOutput.Size()
+ n += 2 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *ActionView_DaoDeposit) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.DaoDeposit != nil {
+ l = m.DaoDeposit.Size()
+ n += 2 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *ActionView_Ics20Withdrawal) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Ics20Withdrawal != nil {
+ l = m.Ics20Withdrawal.Size()
+ n += 2 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *SpendView) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.SpendView != nil {
+ n += m.SpendView.Size()
+ }
+ return n
+}
+
+func (m *SpendView_Visible_) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Visible != nil {
+ l = m.Visible.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *SpendView_Opaque_) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Opaque != nil {
+ l = m.Opaque.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *SpendView_Visible) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Spend != nil {
+ l = m.Spend.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ if m.Note != nil {
+ l = m.Note.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+
+func (m *SpendView_Opaque) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Spend != nil {
+ l = m.Spend.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+
+func (m *DelegatorVoteView) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.DelegatorVote != nil {
+ n += m.DelegatorVote.Size()
+ }
+ return n
+}
+
+func (m *DelegatorVoteView_Visible_) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Visible != nil {
+ l = m.Visible.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *DelegatorVoteView_Opaque_) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Opaque != nil {
+ l = m.Opaque.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *DelegatorVoteView_Visible) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.DelegatorVote != nil {
+ l = m.DelegatorVote.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ if m.Note != nil {
+ l = m.Note.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+
+func (m *DelegatorVoteView_Opaque) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.DelegatorVote != nil {
+ l = m.DelegatorVote.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+
+func (m *OutputView) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.OutputView != nil {
+ n += m.OutputView.Size()
+ }
+ return n
+}
+
+func (m *OutputView_Visible_) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Visible != nil {
+ l = m.Visible.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *OutputView_Opaque_) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Opaque != nil {
+ l = m.Opaque.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *OutputView_Visible) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Output != nil {
+ l = m.Output.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ if m.Note != nil {
+ l = m.Note.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ if m.PayloadKey != nil {
+ l = m.PayloadKey.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+
+func (m *OutputView_Opaque) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Output != nil {
+ l = m.Output.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+
+func (m *Spend) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Body != nil {
+ l = m.Body.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ if m.AuthSig != nil {
+ l = m.AuthSig.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ if m.Proof != nil {
+ l = m.Proof.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+
+func (m *SpendBody) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.BalanceCommitment != nil {
+ l = m.BalanceCommitment.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ l = len(m.Nullifier)
+ if l > 0 {
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ l = len(m.Rk)
+ if l > 0 {
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+
+func (m *Output) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Body != nil {
+ l = m.Body.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ if m.Proof != nil {
+ l = m.Proof.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+
+func (m *OutputBody) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.NotePayload != nil {
+ l = m.NotePayload.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ if m.BalanceCommitment != nil {
+ l = m.BalanceCommitment.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ l = len(m.WrappedMemoKey)
+ if l > 0 {
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ l = len(m.OvkWrappedKey)
+ if l > 0 {
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+
+func (m *AuthorizationData) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.EffectHash != nil {
+ l = m.EffectHash.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ if len(m.SpendAuths) > 0 {
+ for _, e := range m.SpendAuths {
+ l = e.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ }
+ if len(m.DelegatorVoteAuths) > 0 {
+ for _, e := range m.DelegatorVoteAuths {
+ l = e.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ }
+ return n
+}
+
+func (m *WitnessData) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Anchor != nil {
+ l = m.Anchor.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ if len(m.StateCommitmentProofs) > 0 {
+ for _, e := range m.StateCommitmentProofs {
+ l = e.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ }
+ return n
+}
+
+func (m *TransactionPlan) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if len(m.Actions) > 0 {
+ for _, e := range m.Actions {
+ l = e.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ }
+ if m.ExpiryHeight != 0 {
+ n += 1 + sovTransaction(uint64(m.ExpiryHeight))
+ }
+ l = len(m.ChainId)
+ if l > 0 {
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ if m.Fee != nil {
+ l = m.Fee.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ if len(m.CluePlans) > 0 {
+ for _, e := range m.CluePlans {
+ l = e.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ }
+ if m.MemoPlan != nil {
+ l = m.MemoPlan.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+
+func (m *ActionPlan) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Action != nil {
+ n += m.Action.Size()
+ }
+ return n
+}
+
+func (m *ActionPlan_Spend) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Spend != nil {
+ l = m.Spend.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *ActionPlan_Output) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Output != nil {
+ l = m.Output.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *ActionPlan_Swap) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Swap != nil {
+ l = m.Swap.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *ActionPlan_SwapClaim) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.SwapClaim != nil {
+ l = m.SwapClaim.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *ActionPlan_ValidatorDefinition) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.ValidatorDefinition != nil {
+ l = m.ValidatorDefinition.Size()
+ n += 2 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *ActionPlan_IbcAction) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.IbcAction != nil {
+ l = m.IbcAction.Size()
+ n += 2 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *ActionPlan_ProposalSubmit) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.ProposalSubmit != nil {
+ l = m.ProposalSubmit.Size()
+ n += 2 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *ActionPlan_ProposalWithdraw) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.ProposalWithdraw != nil {
+ l = m.ProposalWithdraw.Size()
+ n += 2 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *ActionPlan_ValidatorVote) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.ValidatorVote != nil {
+ l = m.ValidatorVote.Size()
+ n += 2 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *ActionPlan_DelegatorVote) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.DelegatorVote != nil {
+ l = m.DelegatorVote.Size()
+ n += 2 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *ActionPlan_ProposalDepositClaim) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.ProposalDepositClaim != nil {
+ l = m.ProposalDepositClaim.Size()
+ n += 2 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *ActionPlan_Withdrawal) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Withdrawal != nil {
+ l = m.Withdrawal.Size()
+ n += 2 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *ActionPlan_PositionOpen) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.PositionOpen != nil {
+ l = m.PositionOpen.Size()
+ n += 2 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *ActionPlan_PositionClose) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.PositionClose != nil {
+ l = m.PositionClose.Size()
+ n += 2 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *ActionPlan_PositionWithdraw) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.PositionWithdraw != nil {
+ l = m.PositionWithdraw.Size()
+ n += 2 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *ActionPlan_PositionRewardClaim) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.PositionRewardClaim != nil {
+ l = m.PositionRewardClaim.Size()
+ n += 2 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *ActionPlan_Delegate) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Delegate != nil {
+ l = m.Delegate.Size()
+ n += 2 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *ActionPlan_Undelegate) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Undelegate != nil {
+ l = m.Undelegate.Size()
+ n += 2 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *ActionPlan_UndelegateClaim) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.UndelegateClaim != nil {
+ l = m.UndelegateClaim.Size()
+ n += 2 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *ActionPlan_DaoSpend) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.DaoSpend != nil {
+ l = m.DaoSpend.Size()
+ n += 2 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *ActionPlan_DaoOutput) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.DaoOutput != nil {
+ l = m.DaoOutput.Size()
+ n += 2 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *ActionPlan_DaoDeposit) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.DaoDeposit != nil {
+ l = m.DaoDeposit.Size()
+ n += 2 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *CluePlan) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Address != nil {
+ l = m.Address.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ l = len(m.Rseed)
+ if l > 0 {
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ if m.PrecisionBits != 0 {
+ n += 1 + sovTransaction(uint64(m.PrecisionBits))
+ }
+ return n
+}
+
+func (m *MemoPlan) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Plaintext != nil {
+ l = m.Plaintext.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ l = len(m.Key)
+ if l > 0 {
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+
+func (m *MemoCiphertext) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ l = len(m.Inner)
+ if l > 0 {
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+
+func (m *MemoPlaintext) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Sender != nil {
+ l = m.Sender.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ l = len(m.Text)
+ if l > 0 {
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+
+func (m *MemoView) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.MemoView != nil {
+ n += m.MemoView.Size()
+ }
+ return n
+}
+
+func (m *MemoView_Visible_) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Visible != nil {
+ l = m.Visible.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *MemoView_Opaque_) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Opaque != nil {
+ l = m.Opaque.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+func (m *MemoView_Visible) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Ciphertext != nil {
+ l = m.Ciphertext.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ if m.Plaintext != nil {
+ l = m.Plaintext.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+
+func (m *MemoView_Opaque) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Ciphertext != nil {
+ l = m.Ciphertext.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+
+func (m *SpendPlan) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Note != nil {
+ l = m.Note.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ if m.Position != 0 {
+ n += 1 + sovTransaction(uint64(m.Position))
+ }
+ l = len(m.Randomizer)
+ if l > 0 {
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ l = len(m.ValueBlinding)
+ if l > 0 {
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ l = len(m.ProofBlindingR)
+ if l > 0 {
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ l = len(m.ProofBlindingS)
+ if l > 0 {
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+
+func (m *OutputPlan) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Value != nil {
+ l = m.Value.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ if m.DestAddress != nil {
+ l = m.DestAddress.Size()
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ l = len(m.Rseed)
+ if l > 0 {
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ l = len(m.ValueBlinding)
+ if l > 0 {
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ l = len(m.ProofBlindingR)
+ if l > 0 {
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ l = len(m.ProofBlindingS)
+ if l > 0 {
+ n += 1 + l + sovTransaction(uint64(l))
+ }
+ return n
+}
+
+func sovTransaction(x uint64) (n int) {
+ return (math_bits.Len64(x|1) + 6) / 7
+}
+func sozTransaction(x uint64) (n int) {
+ return sovTransaction(uint64((x << 1) ^ uint64((int64(x) >> 63))))
+}
+func (m *Transaction) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Transaction: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Transaction: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Body", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Body == nil {
+ m.Body = &TransactionBody{}
+ }
+ if err := m.Body.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field BindingSig", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.BindingSig = append(m.BindingSig[:0], dAtA[iNdEx:postIndex]...)
+ if m.BindingSig == nil {
+ m.BindingSig = []byte{}
+ }
+ iNdEx = postIndex
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Anchor", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Anchor == nil {
+ m.Anchor = &v1alpha1.MerkleRoot{}
+ }
+ if err := m.Anchor.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipTransaction(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *Id) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Id: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Id: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Hash", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Hash = append(m.Hash[:0], dAtA[iNdEx:postIndex]...)
+ if m.Hash == nil {
+ m.Hash = []byte{}
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipTransaction(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *EffectHash) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: EffectHash: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: EffectHash: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Inner", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Inner = append(m.Inner[:0], dAtA[iNdEx:postIndex]...)
+ if m.Inner == nil {
+ m.Inner = []byte{}
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipTransaction(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *TransactionBody) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: TransactionBody: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: TransactionBody: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Actions", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Actions = append(m.Actions, &Action{})
+ if err := m.Actions[len(m.Actions)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field TransactionParameters", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.TransactionParameters == nil {
+ m.TransactionParameters = &TransactionParameters{}
+ }
+ if err := m.TransactionParameters.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Fee", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Fee == nil {
+ m.Fee = &v1alpha1.Fee{}
+ }
+ if err := m.Fee.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 4:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field DetectionData", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.DetectionData == nil {
+ m.DetectionData = &DetectionData{}
+ }
+ if err := m.DetectionData.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 5:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field MemoData", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.MemoData == nil {
+ m.MemoData = &MemoData{}
+ }
+ if err := m.MemoData.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipTransaction(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *MemoData) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: MemoData: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: MemoData: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field EncryptedMemo", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := make([]byte, postIndex-iNdEx)
+ copy(v, dAtA[iNdEx:postIndex])
+ m.XEncryptedMemo = &MemoData_EncryptedMemo{v}
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipTransaction(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *TransactionParameters) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: TransactionParameters: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: TransactionParameters: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ExpiryHeight", wireType)
+ }
+ m.ExpiryHeight = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.ExpiryHeight |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ChainId", wireType)
+ }
+ var stringLen uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ stringLen |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ intStringLen := int(stringLen)
+ if intStringLen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + intStringLen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.ChainId = string(dAtA[iNdEx:postIndex])
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipTransaction(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *DetectionData) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: DetectionData: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: DetectionData: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 4:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field FmdClues", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.FmdClues = append(m.FmdClues, &v1alpha1.Clue{})
+ if err := m.FmdClues[len(m.FmdClues)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipTransaction(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *Action) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Action: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Action: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Spend", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &Spend{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.Action = &Action_Spend{v}
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Output", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &Output{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.Action = &Action_Output{v}
+ iNdEx = postIndex
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Swap", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha11.Swap{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.Action = &Action_Swap{v}
+ iNdEx = postIndex
+ case 4:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field SwapClaim", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha11.SwapClaim{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.Action = &Action_SwapClaim{v}
+ iNdEx = postIndex
+ case 16:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ValidatorDefinition", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha12.ValidatorDefinition{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.Action = &Action_ValidatorDefinition{v}
+ iNdEx = postIndex
+ case 17:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field IbcAction", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha13.IbcAction{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.Action = &Action_IbcAction{v}
+ iNdEx = postIndex
+ case 18:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ProposalSubmit", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha14.ProposalSubmit{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.Action = &Action_ProposalSubmit{v}
+ iNdEx = postIndex
+ case 19:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ProposalWithdraw", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha14.ProposalWithdraw{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.Action = &Action_ProposalWithdraw{v}
+ iNdEx = postIndex
+ case 20:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ValidatorVote", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha14.ValidatorVote{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.Action = &Action_ValidatorVote{v}
+ iNdEx = postIndex
+ case 21:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field DelegatorVote", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha14.DelegatorVote{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.Action = &Action_DelegatorVote{v}
+ iNdEx = postIndex
+ case 22:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ProposalDepositClaim", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha14.ProposalDepositClaim{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.Action = &Action_ProposalDepositClaim{v}
+ iNdEx = postIndex
+ case 30:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field PositionOpen", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha11.PositionOpen{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.Action = &Action_PositionOpen{v}
+ iNdEx = postIndex
+ case 31:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field PositionClose", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha11.PositionClose{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.Action = &Action_PositionClose{v}
+ iNdEx = postIndex
+ case 32:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field PositionWithdraw", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha11.PositionWithdraw{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.Action = &Action_PositionWithdraw{v}
+ iNdEx = postIndex
+ case 34:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field PositionRewardClaim", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha11.PositionRewardClaim{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.Action = &Action_PositionRewardClaim{v}
+ iNdEx = postIndex
+ case 40:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Delegate", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha12.Delegate{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.Action = &Action_Delegate{v}
+ iNdEx = postIndex
+ case 41:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Undelegate", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha12.Undelegate{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.Action = &Action_Undelegate{v}
+ iNdEx = postIndex
+ case 42:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field UndelegateClaim", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha12.UndelegateClaim{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.Action = &Action_UndelegateClaim{v}
+ iNdEx = postIndex
+ case 50:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field DaoSpend", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha14.DaoSpend{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.Action = &Action_DaoSpend{v}
+ iNdEx = postIndex
+ case 51:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field DaoOutput", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha14.DaoOutput{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.Action = &Action_DaoOutput{v}
+ iNdEx = postIndex
+ case 52:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field DaoDeposit", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha14.DaoDeposit{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.Action = &Action_DaoDeposit{v}
+ iNdEx = postIndex
+ case 200:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Ics20Withdrawal", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha13.Ics20Withdrawal{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.Action = &Action_Ics20Withdrawal{v}
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipTransaction(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *TransactionPerspective) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: TransactionPerspective: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: TransactionPerspective: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field PayloadKeys", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.PayloadKeys = append(m.PayloadKeys, &PayloadKeyWithCommitment{})
+ if err := m.PayloadKeys[len(m.PayloadKeys)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field SpendNullifiers", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.SpendNullifiers = append(m.SpendNullifiers, &NullifierWithNote{})
+ if err := m.SpendNullifiers[len(m.SpendNullifiers)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field AdviceNotes", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.AdviceNotes = append(m.AdviceNotes, &v1alpha1.Note{})
+ if err := m.AdviceNotes[len(m.AdviceNotes)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 4:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field AddressViews", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.AddressViews = append(m.AddressViews, &v1alpha1.AddressView{})
+ if err := m.AddressViews[len(m.AddressViews)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 5:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Denoms", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Denoms = append(m.Denoms, &v1alpha1.DenomMetadata{})
+ if err := m.Denoms[len(m.Denoms)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 6:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field TransactionId", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.TransactionId == nil {
+ m.TransactionId = &Id{}
+ }
+ if err := m.TransactionId.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipTransaction(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *PayloadKey) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: PayloadKey: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: PayloadKey: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Inner", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Inner = append(m.Inner[:0], dAtA[iNdEx:postIndex]...)
+ if m.Inner == nil {
+ m.Inner = []byte{}
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipTransaction(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *PayloadKeyWithCommitment) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: PayloadKeyWithCommitment: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: PayloadKeyWithCommitment: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field PayloadKey", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.PayloadKey == nil {
+ m.PayloadKey = &PayloadKey{}
+ }
+ if err := m.PayloadKey.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Commitment", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Commitment == nil {
+ m.Commitment = &v1alpha1.StateCommitment{}
+ }
+ if err := m.Commitment.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipTransaction(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *NullifierWithNote) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: NullifierWithNote: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: NullifierWithNote: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Nullifier", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Nullifier == nil {
+ m.Nullifier = &v1alpha1.Nullifier{}
+ }
+ if err := m.Nullifier.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Note", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Note == nil {
+ m.Note = &v1alpha1.Note{}
+ }
+ if err := m.Note.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipTransaction(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *TransactionView) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: TransactionView: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: TransactionView: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field BodyView", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.BodyView == nil {
+ m.BodyView = &TransactionBodyView{}
+ }
+ if err := m.BodyView.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field BindingSig", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.BindingSig = append(m.BindingSig[:0], dAtA[iNdEx:postIndex]...)
+ if m.BindingSig == nil {
+ m.BindingSig = []byte{}
+ }
+ iNdEx = postIndex
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Anchor", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Anchor == nil {
+ m.Anchor = &v1alpha1.MerkleRoot{}
+ }
+ if err := m.Anchor.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipTransaction(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *TransactionBodyView) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: TransactionBodyView: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: TransactionBodyView: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ActionViews", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.ActionViews = append(m.ActionViews, &ActionView{})
+ if err := m.ActionViews[len(m.ActionViews)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field TransactionParameters", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.TransactionParameters == nil {
+ m.TransactionParameters = &TransactionParameters{}
+ }
+ if err := m.TransactionParameters.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Fee", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Fee == nil {
+ m.Fee = &v1alpha1.Fee{}
+ }
+ if err := m.Fee.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 4:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field DetectionData", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &DetectionData{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.XDetectionData = &TransactionBodyView_DetectionData{v}
+ iNdEx = postIndex
+ case 5:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field MemoView", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &MemoView{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.XMemoView = &TransactionBodyView_MemoView{v}
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipTransaction(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *ActionView) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: ActionView: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: ActionView: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Spend", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &SpendView{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.ActionView = &ActionView_Spend{v}
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Output", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &OutputView{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.ActionView = &ActionView_Output{v}
+ iNdEx = postIndex
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Swap", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha11.SwapView{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.ActionView = &ActionView_Swap{v}
+ iNdEx = postIndex
+ case 4:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field SwapClaim", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha11.SwapClaimView{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.ActionView = &ActionView_SwapClaim{v}
+ iNdEx = postIndex
+ case 16:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ValidatorDefinition", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha12.ValidatorDefinition{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.ActionView = &ActionView_ValidatorDefinition{v}
+ iNdEx = postIndex
+ case 17:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field IbcAction", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha13.IbcAction{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.ActionView = &ActionView_IbcAction{v}
+ iNdEx = postIndex
+ case 18:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ProposalSubmit", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha14.ProposalSubmit{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.ActionView = &ActionView_ProposalSubmit{v}
+ iNdEx = postIndex
+ case 19:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ProposalWithdraw", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha14.ProposalWithdraw{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.ActionView = &ActionView_ProposalWithdraw{v}
+ iNdEx = postIndex
+ case 20:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ValidatorVote", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha14.ValidatorVote{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.ActionView = &ActionView_ValidatorVote{v}
+ iNdEx = postIndex
+ case 21:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field DelegatorVote", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &DelegatorVoteView{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.ActionView = &ActionView_DelegatorVote{v}
+ iNdEx = postIndex
+ case 22:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ProposalDepositClaim", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha14.ProposalDepositClaim{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.ActionView = &ActionView_ProposalDepositClaim{v}
+ iNdEx = postIndex
+ case 30:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field PositionOpen", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha11.PositionOpen{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.ActionView = &ActionView_PositionOpen{v}
+ iNdEx = postIndex
+ case 31:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field PositionClose", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha11.PositionClose{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.ActionView = &ActionView_PositionClose{v}
+ iNdEx = postIndex
+ case 32:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field PositionWithdraw", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha11.PositionWithdraw{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.ActionView = &ActionView_PositionWithdraw{v}
+ iNdEx = postIndex
+ case 34:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field PositionRewardClaim", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha11.PositionRewardClaim{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.ActionView = &ActionView_PositionRewardClaim{v}
+ iNdEx = postIndex
+ case 41:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Delegate", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha12.Delegate{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.ActionView = &ActionView_Delegate{v}
+ iNdEx = postIndex
+ case 42:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Undelegate", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha12.Undelegate{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.ActionView = &ActionView_Undelegate{v}
+ iNdEx = postIndex
+ case 43:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field UndelegateClaim", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha12.UndelegateClaim{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.ActionView = &ActionView_UndelegateClaim{v}
+ iNdEx = postIndex
+ case 50:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field DaoSpend", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha14.DaoSpend{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.ActionView = &ActionView_DaoSpend{v}
+ iNdEx = postIndex
+ case 51:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field DaoOutput", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha14.DaoOutput{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.ActionView = &ActionView_DaoOutput{v}
+ iNdEx = postIndex
+ case 52:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field DaoDeposit", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha14.DaoDeposit{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.ActionView = &ActionView_DaoDeposit{v}
+ iNdEx = postIndex
+ case 200:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Ics20Withdrawal", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha13.Ics20Withdrawal{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.ActionView = &ActionView_Ics20Withdrawal{v}
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipTransaction(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *SpendView) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: SpendView: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: SpendView: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Visible", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &SpendView_Visible{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.SpendView = &SpendView_Visible_{v}
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Opaque", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &SpendView_Opaque{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.SpendView = &SpendView_Opaque_{v}
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipTransaction(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *SpendView_Visible) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Visible: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Visible: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Spend", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Spend == nil {
+ m.Spend = &Spend{}
+ }
+ if err := m.Spend.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Note", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Note == nil {
+ m.Note = &v1alpha1.NoteView{}
+ }
+ if err := m.Note.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipTransaction(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *SpendView_Opaque) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Opaque: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Opaque: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Spend", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Spend == nil {
+ m.Spend = &Spend{}
+ }
+ if err := m.Spend.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipTransaction(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *DelegatorVoteView) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: DelegatorVoteView: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: DelegatorVoteView: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Visible", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &DelegatorVoteView_Visible{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.DelegatorVote = &DelegatorVoteView_Visible_{v}
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Opaque", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &DelegatorVoteView_Opaque{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.DelegatorVote = &DelegatorVoteView_Opaque_{v}
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipTransaction(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *DelegatorVoteView_Visible) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Visible: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Visible: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field DelegatorVote", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.DelegatorVote == nil {
+ m.DelegatorVote = &v1alpha14.DelegatorVote{}
+ }
+ if err := m.DelegatorVote.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Note", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Note == nil {
+ m.Note = &v1alpha1.NoteView{}
+ }
+ if err := m.Note.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipTransaction(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *DelegatorVoteView_Opaque) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Opaque: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Opaque: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field DelegatorVote", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.DelegatorVote == nil {
+ m.DelegatorVote = &v1alpha14.DelegatorVote{}
+ }
+ if err := m.DelegatorVote.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipTransaction(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *OutputView) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: OutputView: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: OutputView: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Visible", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &OutputView_Visible{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.OutputView = &OutputView_Visible_{v}
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Opaque", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &OutputView_Opaque{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.OutputView = &OutputView_Opaque_{v}
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipTransaction(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *OutputView_Visible) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Visible: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Visible: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Output", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Output == nil {
+ m.Output = &Output{}
+ }
+ if err := m.Output.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Note", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Note == nil {
+ m.Note = &v1alpha1.NoteView{}
+ }
+ if err := m.Note.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field PayloadKey", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.PayloadKey == nil {
+ m.PayloadKey = &PayloadKey{}
+ }
+ if err := m.PayloadKey.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipTransaction(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *OutputView_Opaque) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Opaque: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Opaque: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Output", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Output == nil {
+ m.Output = &Output{}
+ }
+ if err := m.Output.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipTransaction(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *Spend) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Spend: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Spend: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Body", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Body == nil {
+ m.Body = &SpendBody{}
+ }
+ if err := m.Body.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field AuthSig", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.AuthSig == nil {
+ m.AuthSig = &v1alpha1.SpendAuthSignature{}
+ }
+ if err := m.AuthSig.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Proof", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Proof == nil {
+ m.Proof = &v1alpha1.ZKSpendProof{}
+ }
+ if err := m.Proof.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipTransaction(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *SpendBody) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: SpendBody: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: SpendBody: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field BalanceCommitment", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.BalanceCommitment == nil {
+ m.BalanceCommitment = &v1alpha1.BalanceCommitment{}
+ }
+ if err := m.BalanceCommitment.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Nullifier", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Nullifier = append(m.Nullifier[:0], dAtA[iNdEx:postIndex]...)
+ if m.Nullifier == nil {
+ m.Nullifier = []byte{}
+ }
+ iNdEx = postIndex
+ case 4:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Rk", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Rk = append(m.Rk[:0], dAtA[iNdEx:postIndex]...)
+ if m.Rk == nil {
+ m.Rk = []byte{}
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipTransaction(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *Output) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Output: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Output: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Body", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Body == nil {
+ m.Body = &OutputBody{}
+ }
+ if err := m.Body.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Proof", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Proof == nil {
+ m.Proof = &v1alpha1.ZKOutputProof{}
+ }
+ if err := m.Proof.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipTransaction(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *OutputBody) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: OutputBody: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: OutputBody: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field NotePayload", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.NotePayload == nil {
+ m.NotePayload = &v1alpha1.NotePayload{}
+ }
+ if err := m.NotePayload.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field BalanceCommitment", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.BalanceCommitment == nil {
+ m.BalanceCommitment = &v1alpha1.BalanceCommitment{}
+ }
+ if err := m.BalanceCommitment.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field WrappedMemoKey", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.WrappedMemoKey = append(m.WrappedMemoKey[:0], dAtA[iNdEx:postIndex]...)
+ if m.WrappedMemoKey == nil {
+ m.WrappedMemoKey = []byte{}
+ }
+ iNdEx = postIndex
+ case 4:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field OvkWrappedKey", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.OvkWrappedKey = append(m.OvkWrappedKey[:0], dAtA[iNdEx:postIndex]...)
+ if m.OvkWrappedKey == nil {
+ m.OvkWrappedKey = []byte{}
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipTransaction(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *AuthorizationData) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: AuthorizationData: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: AuthorizationData: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field EffectHash", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.EffectHash == nil {
+ m.EffectHash = &v1alpha1.EffectHash{}
+ }
+ if err := m.EffectHash.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field SpendAuths", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.SpendAuths = append(m.SpendAuths, &v1alpha1.SpendAuthSignature{})
+ if err := m.SpendAuths[len(m.SpendAuths)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field DelegatorVoteAuths", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.DelegatorVoteAuths = append(m.DelegatorVoteAuths, &v1alpha1.SpendAuthSignature{})
+ if err := m.DelegatorVoteAuths[len(m.DelegatorVoteAuths)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipTransaction(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *WitnessData) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: WitnessData: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: WitnessData: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Anchor", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Anchor == nil {
+ m.Anchor = &v1alpha1.MerkleRoot{}
+ }
+ if err := m.Anchor.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field StateCommitmentProofs", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.StateCommitmentProofs = append(m.StateCommitmentProofs, &v1alpha1.StateCommitmentProof{})
+ if err := m.StateCommitmentProofs[len(m.StateCommitmentProofs)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipTransaction(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *TransactionPlan) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: TransactionPlan: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: TransactionPlan: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Actions", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Actions = append(m.Actions, &ActionPlan{})
+ if err := m.Actions[len(m.Actions)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ExpiryHeight", wireType)
+ }
+ m.ExpiryHeight = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.ExpiryHeight |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ChainId", wireType)
+ }
+ var stringLen uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ stringLen |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ intStringLen := int(stringLen)
+ if intStringLen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + intStringLen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.ChainId = string(dAtA[iNdEx:postIndex])
+ iNdEx = postIndex
+ case 4:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Fee", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Fee == nil {
+ m.Fee = &v1alpha1.Fee{}
+ }
+ if err := m.Fee.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 5:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field CluePlans", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.CluePlans = append(m.CluePlans, &CluePlan{})
+ if err := m.CluePlans[len(m.CluePlans)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 6:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field MemoPlan", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.MemoPlan == nil {
+ m.MemoPlan = &MemoPlan{}
+ }
+ if err := m.MemoPlan.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipTransaction(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *ActionPlan) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: ActionPlan: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: ActionPlan: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Spend", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &SpendPlan{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.Action = &ActionPlan_Spend{v}
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Output", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &OutputPlan{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.Action = &ActionPlan_Output{v}
+ iNdEx = postIndex
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Swap", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha11.SwapPlan{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.Action = &ActionPlan_Swap{v}
+ iNdEx = postIndex
+ case 4:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field SwapClaim", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha11.SwapClaimPlan{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.Action = &ActionPlan_SwapClaim{v}
+ iNdEx = postIndex
+ case 16:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ValidatorDefinition", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha12.ValidatorDefinition{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.Action = &ActionPlan_ValidatorDefinition{v}
+ iNdEx = postIndex
+ case 17:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field IbcAction", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha13.IbcAction{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.Action = &ActionPlan_IbcAction{v}
+ iNdEx = postIndex
+ case 18:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ProposalSubmit", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha14.ProposalSubmit{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.Action = &ActionPlan_ProposalSubmit{v}
+ iNdEx = postIndex
+ case 19:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ProposalWithdraw", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha14.ProposalWithdraw{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.Action = &ActionPlan_ProposalWithdraw{v}
+ iNdEx = postIndex
+ case 20:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ValidatorVote", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha14.ValidatorVote{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.Action = &ActionPlan_ValidatorVote{v}
+ iNdEx = postIndex
+ case 21:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field DelegatorVote", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha14.DelegatorVotePlan{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.Action = &ActionPlan_DelegatorVote{v}
+ iNdEx = postIndex
+ case 22:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ProposalDepositClaim", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha14.ProposalDepositClaim{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.Action = &ActionPlan_ProposalDepositClaim{v}
+ iNdEx = postIndex
+ case 23:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Withdrawal", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha13.Ics20Withdrawal{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.Action = &ActionPlan_Withdrawal{v}
+ iNdEx = postIndex
+ case 30:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field PositionOpen", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha11.PositionOpen{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.Action = &ActionPlan_PositionOpen{v}
+ iNdEx = postIndex
+ case 31:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field PositionClose", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha11.PositionClose{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.Action = &ActionPlan_PositionClose{v}
+ iNdEx = postIndex
+ case 32:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field PositionWithdraw", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha11.PositionWithdrawPlan{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.Action = &ActionPlan_PositionWithdraw{v}
+ iNdEx = postIndex
+ case 34:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field PositionRewardClaim", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha11.PositionRewardClaimPlan{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.Action = &ActionPlan_PositionRewardClaim{v}
+ iNdEx = postIndex
+ case 40:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Delegate", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha12.Delegate{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.Action = &ActionPlan_Delegate{v}
+ iNdEx = postIndex
+ case 41:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Undelegate", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha12.Undelegate{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.Action = &ActionPlan_Undelegate{v}
+ iNdEx = postIndex
+ case 42:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field UndelegateClaim", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha12.UndelegateClaimPlan{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.Action = &ActionPlan_UndelegateClaim{v}
+ iNdEx = postIndex
+ case 50:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field DaoSpend", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha14.DaoSpend{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.Action = &ActionPlan_DaoSpend{v}
+ iNdEx = postIndex
+ case 51:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field DaoOutput", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha14.DaoOutput{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.Action = &ActionPlan_DaoOutput{v}
+ iNdEx = postIndex
+ case 52:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field DaoDeposit", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha14.DaoDeposit{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.Action = &ActionPlan_DaoDeposit{v}
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipTransaction(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *CluePlan) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: CluePlan: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: CluePlan: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Address", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Address == nil {
+ m.Address = &v1alpha1.Address{}
+ }
+ if err := m.Address.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Rseed", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Rseed = append(m.Rseed[:0], dAtA[iNdEx:postIndex]...)
+ if m.Rseed == nil {
+ m.Rseed = []byte{}
+ }
+ iNdEx = postIndex
+ case 3:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field PrecisionBits", wireType)
+ }
+ m.PrecisionBits = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.PrecisionBits |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ default:
+ iNdEx = preIndex
+ skippy, err := skipTransaction(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *MemoPlan) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: MemoPlan: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: MemoPlan: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Plaintext", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Plaintext == nil {
+ m.Plaintext = &MemoPlaintext{}
+ }
+ if err := m.Plaintext.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Key", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Key = append(m.Key[:0], dAtA[iNdEx:postIndex]...)
+ if m.Key == nil {
+ m.Key = []byte{}
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipTransaction(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *MemoCiphertext) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: MemoCiphertext: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: MemoCiphertext: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Inner", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Inner = append(m.Inner[:0], dAtA[iNdEx:postIndex]...)
+ if m.Inner == nil {
+ m.Inner = []byte{}
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipTransaction(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *MemoPlaintext) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: MemoPlaintext: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: MemoPlaintext: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Sender", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Sender == nil {
+ m.Sender = &v1alpha1.Address{}
+ }
+ if err := m.Sender.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Text", wireType)
+ }
+ var stringLen uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ stringLen |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ intStringLen := int(stringLen)
+ if intStringLen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + intStringLen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Text = string(dAtA[iNdEx:postIndex])
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipTransaction(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *MemoView) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: MemoView: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: MemoView: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Visible", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &MemoView_Visible{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.MemoView = &MemoView_Visible_{v}
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Opaque", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &MemoView_Opaque{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.MemoView = &MemoView_Opaque_{v}
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipTransaction(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *MemoView_Visible) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Visible: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Visible: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Ciphertext", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Ciphertext == nil {
+ m.Ciphertext = &MemoCiphertext{}
+ }
+ if err := m.Ciphertext.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Plaintext", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Plaintext == nil {
+ m.Plaintext = &MemoPlaintext{}
+ }
+ if err := m.Plaintext.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipTransaction(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *MemoView_Opaque) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Opaque: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Opaque: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Ciphertext", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Ciphertext == nil {
+ m.Ciphertext = &MemoCiphertext{}
+ }
+ if err := m.Ciphertext.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipTransaction(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *SpendPlan) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: SpendPlan: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: SpendPlan: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Note", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Note == nil {
+ m.Note = &v1alpha1.Note{}
+ }
+ if err := m.Note.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Position", wireType)
+ }
+ m.Position = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.Position |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Randomizer", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Randomizer = append(m.Randomizer[:0], dAtA[iNdEx:postIndex]...)
+ if m.Randomizer == nil {
+ m.Randomizer = []byte{}
+ }
+ iNdEx = postIndex
+ case 4:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ValueBlinding", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.ValueBlinding = append(m.ValueBlinding[:0], dAtA[iNdEx:postIndex]...)
+ if m.ValueBlinding == nil {
+ m.ValueBlinding = []byte{}
+ }
+ iNdEx = postIndex
+ case 5:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ProofBlindingR", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.ProofBlindingR = append(m.ProofBlindingR[:0], dAtA[iNdEx:postIndex]...)
+ if m.ProofBlindingR == nil {
+ m.ProofBlindingR = []byte{}
+ }
+ iNdEx = postIndex
+ case 6:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ProofBlindingS", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.ProofBlindingS = append(m.ProofBlindingS[:0], dAtA[iNdEx:postIndex]...)
+ if m.ProofBlindingS == nil {
+ m.ProofBlindingS = []byte{}
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipTransaction(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *OutputPlan) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: OutputPlan: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: OutputPlan: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Value", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Value == nil {
+ m.Value = &v1alpha1.Value{}
+ }
+ if err := m.Value.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field DestAddress", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.DestAddress == nil {
+ m.DestAddress = &v1alpha1.Address{}
+ }
+ if err := m.DestAddress.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Rseed", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Rseed = append(m.Rseed[:0], dAtA[iNdEx:postIndex]...)
+ if m.Rseed == nil {
+ m.Rseed = []byte{}
+ }
+ iNdEx = postIndex
+ case 4:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ValueBlinding", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.ValueBlinding = append(m.ValueBlinding[:0], dAtA[iNdEx:postIndex]...)
+ if m.ValueBlinding == nil {
+ m.ValueBlinding = []byte{}
+ }
+ iNdEx = postIndex
+ case 5:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ProofBlindingR", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.ProofBlindingR = append(m.ProofBlindingR[:0], dAtA[iNdEx:postIndex]...)
+ if m.ProofBlindingR == nil {
+ m.ProofBlindingR = []byte{}
+ }
+ iNdEx = postIndex
+ case 6:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ProofBlindingS", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.ProofBlindingS = append(m.ProofBlindingS[:0], dAtA[iNdEx:postIndex]...)
+ if m.ProofBlindingS == nil {
+ m.ProofBlindingS = []byte{}
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipTransaction(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthTransaction
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func skipTransaction(dAtA []byte) (n int, err error) {
+ l := len(dAtA)
+ iNdEx := 0
+ depth := 0
+ for iNdEx < l {
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return 0, ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return 0, io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= (uint64(b) & 0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ wireType := int(wire & 0x7)
+ switch wireType {
+ case 0:
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return 0, ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return 0, io.ErrUnexpectedEOF
+ }
+ iNdEx++
+ if dAtA[iNdEx-1] < 0x80 {
+ break
+ }
+ }
+ case 1:
+ iNdEx += 8
+ case 2:
+ var length int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return 0, ErrIntOverflowTransaction
+ }
+ if iNdEx >= l {
+ return 0, io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ length |= (int(b) & 0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if length < 0 {
+ return 0, ErrInvalidLengthTransaction
+ }
+ iNdEx += length
+ case 3:
+ depth++
+ case 4:
+ if depth == 0 {
+ return 0, ErrUnexpectedEndOfGroupTransaction
+ }
+ depth--
+ case 5:
+ iNdEx += 4
+ default:
+ return 0, fmt.Errorf("proto: illegal wireType %d", wireType)
+ }
+ if iNdEx < 0 {
+ return 0, ErrInvalidLengthTransaction
+ }
+ if depth == 0 {
+ return iNdEx, nil
+ }
+ }
+ return 0, io.ErrUnexpectedEOF
+}
+
+var (
+ ErrInvalidLengthTransaction = fmt.Errorf("proto: negative length found during unmarshaling")
+ ErrIntOverflowTransaction = fmt.Errorf("proto: integer overflow")
+ ErrUnexpectedEndOfGroupTransaction = fmt.Errorf("proto: unexpected end of group")
+)
diff --git a/relayer/chains/penumbra/core/transparent_proofs/v1alpha1/transparent_proofs.pb.go b/relayer/chains/penumbra/core/transparent_proofs/v1alpha1/transparent_proofs.pb.go
new file mode 100644
index 000000000..61dc0d957
--- /dev/null
+++ b/relayer/chains/penumbra/core/transparent_proofs/v1alpha1/transparent_proofs.pb.go
@@ -0,0 +1,589 @@
+// Code generated by protoc-gen-gogo. DO NOT EDIT.
+// source: penumbra/core/transparent_proofs/v1alpha1/transparent_proofs.proto
+
+package transparent_proofsv1alpha1
+
+import (
+ fmt "fmt"
+ proto "github.com/cosmos/gogoproto/proto"
+ v1alpha11 "github.com/cosmos/relayer/v2/relayer/chains/penumbra/core/crypto/v1alpha1"
+ v1alpha1 "github.com/cosmos/relayer/v2/relayer/chains/penumbra/core/dex/v1alpha1"
+ io "io"
+ math "math"
+ math_bits "math/bits"
+)
+
+// Reference imports to suppress errors if they are not otherwise used.
+var _ = proto.Marshal
+var _ = fmt.Errorf
+var _ = math.Inf
+
+// This is a compile-time assertion to ensure that this generated file
+// is compatible with the proto package it is being compiled against.
+// A compilation error at this line likely means your copy of the
+// proto package needs to be updated.
+const _ = proto.GoGoProtoPackageIsVersion3 // please upgrade the proto package
+
+// A Penumbra transparent SwapClaimProof.
+type SwapClaimProof struct {
+ // The swap being claimed
+ SwapPlaintext *v1alpha1.SwapPlaintext `protobuf:"bytes,1,opt,name=swap_plaintext,json=swapPlaintext,proto3" json:"swap_plaintext,omitempty"`
+ // Inclusion proof for the swap commitment
+ SwapCommitmentProof *v1alpha11.StateCommitmentProof `protobuf:"bytes,4,opt,name=swap_commitment_proof,json=swapCommitmentProof,proto3" json:"swap_commitment_proof,omitempty"`
+ // The nullifier key used to derive the swap nullifier
+ Nk []byte `protobuf:"bytes,6,opt,name=nk,proto3" json:"nk,omitempty"`
+ //
+ // @exclude
+ // Describes output amounts
+ Lambda_1I *v1alpha11.Amount `protobuf:"bytes,20,opt,name=lambda_1_i,json=lambda1I,proto3" json:"lambda_1_i,omitempty"`
+ Lambda_2I *v1alpha11.Amount `protobuf:"bytes,21,opt,name=lambda_2_i,json=lambda2I,proto3" json:"lambda_2_i,omitempty"`
+}
+
+func (m *SwapClaimProof) Reset() { *m = SwapClaimProof{} }
+func (m *SwapClaimProof) String() string { return proto.CompactTextString(m) }
+func (*SwapClaimProof) ProtoMessage() {}
+func (*SwapClaimProof) Descriptor() ([]byte, []int) {
+ return fileDescriptor_1536b20e10cd99e5, []int{0}
+}
+func (m *SwapClaimProof) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *SwapClaimProof) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_SwapClaimProof.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *SwapClaimProof) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_SwapClaimProof.Merge(m, src)
+}
+func (m *SwapClaimProof) XXX_Size() int {
+ return m.Size()
+}
+func (m *SwapClaimProof) XXX_DiscardUnknown() {
+ xxx_messageInfo_SwapClaimProof.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_SwapClaimProof proto.InternalMessageInfo
+
+func (m *SwapClaimProof) GetSwapPlaintext() *v1alpha1.SwapPlaintext {
+ if m != nil {
+ return m.SwapPlaintext
+ }
+ return nil
+}
+
+func (m *SwapClaimProof) GetSwapCommitmentProof() *v1alpha11.StateCommitmentProof {
+ if m != nil {
+ return m.SwapCommitmentProof
+ }
+ return nil
+}
+
+func (m *SwapClaimProof) GetNk() []byte {
+ if m != nil {
+ return m.Nk
+ }
+ return nil
+}
+
+func (m *SwapClaimProof) GetLambda_1I() *v1alpha11.Amount {
+ if m != nil {
+ return m.Lambda_1I
+ }
+ return nil
+}
+
+func (m *SwapClaimProof) GetLambda_2I() *v1alpha11.Amount {
+ if m != nil {
+ return m.Lambda_2I
+ }
+ return nil
+}
+
+func init() {
+ proto.RegisterType((*SwapClaimProof)(nil), "penumbra.core.transparent_proofs.v1alpha1.SwapClaimProof")
+}
+
+func init() {
+ proto.RegisterFile("penumbra/core/transparent_proofs/v1alpha1/transparent_proofs.proto", fileDescriptor_1536b20e10cd99e5)
+}
+
+var fileDescriptor_1536b20e10cd99e5 = []byte{
+ // 448 bytes of a gzipped FileDescriptorProto
+ 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x9c, 0x93, 0x3f, 0x6f, 0xd3, 0x40,
+ 0x18, 0xc6, 0x63, 0x17, 0x55, 0xe8, 0x80, 0x0c, 0x86, 0x22, 0xab, 0x83, 0x55, 0x21, 0x90, 0x52,
+ 0x10, 0x67, 0x25, 0x65, 0x32, 0x13, 0xf1, 0x80, 0x3a, 0x20, 0x9d, 0x42, 0xc5, 0x80, 0x22, 0x59,
+ 0x6f, 0x9c, 0xa3, 0xb1, 0xea, 0xfb, 0xa3, 0xbb, 0x4b, 0x9b, 0x7e, 0x0b, 0x06, 0x3e, 0x01, 0x23,
+ 0x9f, 0x04, 0x31, 0x75, 0x64, 0x44, 0x89, 0x58, 0xf8, 0x14, 0xe8, 0x9c, 0x5e, 0xdc, 0xd4, 0x91,
+ 0x88, 0xd8, 0x7c, 0x7e, 0x9f, 0xe7, 0xf7, 0x3c, 0xaf, 0x7c, 0x46, 0x7d, 0x49, 0xf9, 0x94, 0x8d,
+ 0x14, 0xc4, 0xb9, 0x50, 0x34, 0x36, 0x0a, 0xb8, 0x96, 0xa0, 0x28, 0x37, 0x99, 0x54, 0x42, 0x7c,
+ 0xd2, 0xf1, 0x79, 0x17, 0x4a, 0x39, 0x81, 0xee, 0x86, 0x19, 0x96, 0x4a, 0x18, 0x11, 0x1c, 0x3a,
+ 0x06, 0xb6, 0x0c, 0xbc, 0x41, 0xe7, 0x18, 0xfb, 0xcf, 0xd7, 0xe3, 0x72, 0x75, 0x29, 0x8d, 0xa8,
+ 0x23, 0x96, 0xe7, 0x25, 0x76, 0xff, 0xe9, 0xba, 0x76, 0x4c, 0x67, 0xb5, 0x70, 0x4c, 0x67, 0x4b,
+ 0xd5, 0x93, 0xdf, 0x3e, 0x6a, 0xbf, 0xbf, 0x00, 0x99, 0x96, 0x50, 0x30, 0x62, 0xe3, 0x02, 0x82,
+ 0xda, 0xfa, 0x02, 0x64, 0x26, 0x4b, 0x28, 0xb8, 0xa1, 0x33, 0x13, 0x7a, 0x07, 0x5e, 0xe7, 0x5e,
+ 0xef, 0x10, 0xaf, 0x17, 0xb5, 0x10, 0x47, 0xc4, 0x96, 0x41, 0x9c, 0x61, 0xf0, 0x40, 0xdf, 0x3c,
+ 0x06, 0xa7, 0x68, 0xaf, 0x22, 0xe6, 0x82, 0xb1, 0xc2, 0xb0, 0xd5, 0x66, 0xe1, 0x9d, 0x0a, 0x7c,
+ 0x74, 0x0b, 0x7c, 0xbd, 0x46, 0xcd, 0x36, 0x60, 0x68, 0xba, 0xf2, 0x56, 0x2d, 0x07, 0x0f, 0x2d,
+ 0xf1, 0xd6, 0xcb, 0xa0, 0x8d, 0x7c, 0x7e, 0x16, 0xee, 0x1e, 0x78, 0x9d, 0xfb, 0x03, 0x9f, 0x9f,
+ 0x05, 0x29, 0x42, 0x25, 0xb0, 0xd1, 0x18, 0xb2, 0x6e, 0x56, 0x84, 0x8f, 0xaa, 0xb4, 0x67, 0xff,
+ 0x48, 0x7b, 0xc3, 0xc4, 0x94, 0x9b, 0xc1, 0xdd, 0xa5, 0xb1, 0x7b, 0x7c, 0x03, 0xd2, 0xcb, 0x8a,
+ 0x70, 0xef, 0x3f, 0x20, 0xbd, 0xe3, 0xfe, 0x97, 0x9d, 0xef, 0xf3, 0xc8, 0xbb, 0x9a, 0x47, 0xde,
+ 0xaf, 0x79, 0xe4, 0x7d, 0x5e, 0x44, 0xad, 0xab, 0x45, 0xd4, 0xfa, 0xb9, 0x88, 0x5a, 0xe8, 0x65,
+ 0x2e, 0x18, 0xde, 0xfa, 0x0e, 0xf4, 0x1f, 0x9f, 0xd4, 0xc3, 0x6a, 0x6b, 0x4d, 0xec, 0x97, 0x24,
+ 0xde, 0x47, 0x79, 0x5a, 0x98, 0xc9, 0x74, 0x84, 0x73, 0xc1, 0xe2, 0x5c, 0x68, 0x26, 0x74, 0xac,
+ 0x68, 0x09, 0x97, 0x54, 0xc5, 0xe7, 0xbd, 0xd5, 0x63, 0x3e, 0x81, 0x82, 0xeb, 0x78, 0xeb, 0x8b,
+ 0xfb, 0xba, 0x39, 0x73, 0xa3, 0xaf, 0xfe, 0x0e, 0x49, 0x4f, 0xbe, 0xf9, 0x1d, 0xe2, 0xda, 0xa7,
+ 0xb6, 0x7d, 0xa3, 0x20, 0xfe, 0x70, 0x6d, 0xf8, 0x51, 0x4b, 0x87, 0x56, 0x3a, 0x6c, 0x48, 0x87,
+ 0x4e, 0x3a, 0xf7, 0x5f, 0x6d, 0x2b, 0x1d, 0xbe, 0x25, 0xfd, 0x77, 0xd4, 0xc0, 0x18, 0x0c, 0xfc,
+ 0xf1, 0x5f, 0x38, 0x5b, 0x92, 0x58, 0x5f, 0x92, 0x34, 0x8c, 0x49, 0xe2, 0x9c, 0xa3, 0xdd, 0xea,
+ 0x2f, 0x38, 0xfa, 0x1b, 0x00, 0x00, 0xff, 0xff, 0x7e, 0xa6, 0x57, 0xdf, 0xc8, 0x03, 0x00, 0x00,
+}
+
+func (m *SwapClaimProof) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *SwapClaimProof) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *SwapClaimProof) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Lambda_2I != nil {
+ {
+ size, err := m.Lambda_2I.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransparentProofs(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1
+ i--
+ dAtA[i] = 0xaa
+ }
+ if m.Lambda_1I != nil {
+ {
+ size, err := m.Lambda_1I.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransparentProofs(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1
+ i--
+ dAtA[i] = 0xa2
+ }
+ if len(m.Nk) > 0 {
+ i -= len(m.Nk)
+ copy(dAtA[i:], m.Nk)
+ i = encodeVarintTransparentProofs(dAtA, i, uint64(len(m.Nk)))
+ i--
+ dAtA[i] = 0x32
+ }
+ if m.SwapCommitmentProof != nil {
+ {
+ size, err := m.SwapCommitmentProof.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransparentProofs(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x22
+ }
+ if m.SwapPlaintext != nil {
+ {
+ size, err := m.SwapPlaintext.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintTransparentProofs(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func encodeVarintTransparentProofs(dAtA []byte, offset int, v uint64) int {
+ offset -= sovTransparentProofs(v)
+ base := offset
+ for v >= 1<<7 {
+ dAtA[offset] = uint8(v&0x7f | 0x80)
+ v >>= 7
+ offset++
+ }
+ dAtA[offset] = uint8(v)
+ return base
+}
+func (m *SwapClaimProof) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.SwapPlaintext != nil {
+ l = m.SwapPlaintext.Size()
+ n += 1 + l + sovTransparentProofs(uint64(l))
+ }
+ if m.SwapCommitmentProof != nil {
+ l = m.SwapCommitmentProof.Size()
+ n += 1 + l + sovTransparentProofs(uint64(l))
+ }
+ l = len(m.Nk)
+ if l > 0 {
+ n += 1 + l + sovTransparentProofs(uint64(l))
+ }
+ if m.Lambda_1I != nil {
+ l = m.Lambda_1I.Size()
+ n += 2 + l + sovTransparentProofs(uint64(l))
+ }
+ if m.Lambda_2I != nil {
+ l = m.Lambda_2I.Size()
+ n += 2 + l + sovTransparentProofs(uint64(l))
+ }
+ return n
+}
+
+func sovTransparentProofs(x uint64) (n int) {
+ return (math_bits.Len64(x|1) + 6) / 7
+}
+func sozTransparentProofs(x uint64) (n int) {
+ return sovTransparentProofs(uint64((x << 1) ^ uint64((int64(x) >> 63))))
+}
+func (m *SwapClaimProof) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransparentProofs
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: SwapClaimProof: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: SwapClaimProof: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field SwapPlaintext", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransparentProofs
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransparentProofs
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransparentProofs
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.SwapPlaintext == nil {
+ m.SwapPlaintext = &v1alpha1.SwapPlaintext{}
+ }
+ if err := m.SwapPlaintext.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 4:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field SwapCommitmentProof", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransparentProofs
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransparentProofs
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransparentProofs
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.SwapCommitmentProof == nil {
+ m.SwapCommitmentProof = &v1alpha11.StateCommitmentProof{}
+ }
+ if err := m.SwapCommitmentProof.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 6:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Nk", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransparentProofs
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthTransparentProofs
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransparentProofs
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Nk = append(m.Nk[:0], dAtA[iNdEx:postIndex]...)
+ if m.Nk == nil {
+ m.Nk = []byte{}
+ }
+ iNdEx = postIndex
+ case 20:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Lambda_1I", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransparentProofs
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransparentProofs
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransparentProofs
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Lambda_1I == nil {
+ m.Lambda_1I = &v1alpha11.Amount{}
+ }
+ if err := m.Lambda_1I.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 21:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Lambda_2I", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowTransparentProofs
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthTransparentProofs
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthTransparentProofs
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Lambda_2I == nil {
+ m.Lambda_2I = &v1alpha11.Amount{}
+ }
+ if err := m.Lambda_2I.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipTransparentProofs(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthTransparentProofs
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func skipTransparentProofs(dAtA []byte) (n int, err error) {
+ l := len(dAtA)
+ iNdEx := 0
+ depth := 0
+ for iNdEx < l {
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return 0, ErrIntOverflowTransparentProofs
+ }
+ if iNdEx >= l {
+ return 0, io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= (uint64(b) & 0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ wireType := int(wire & 0x7)
+ switch wireType {
+ case 0:
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return 0, ErrIntOverflowTransparentProofs
+ }
+ if iNdEx >= l {
+ return 0, io.ErrUnexpectedEOF
+ }
+ iNdEx++
+ if dAtA[iNdEx-1] < 0x80 {
+ break
+ }
+ }
+ case 1:
+ iNdEx += 8
+ case 2:
+ var length int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return 0, ErrIntOverflowTransparentProofs
+ }
+ if iNdEx >= l {
+ return 0, io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ length |= (int(b) & 0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if length < 0 {
+ return 0, ErrInvalidLengthTransparentProofs
+ }
+ iNdEx += length
+ case 3:
+ depth++
+ case 4:
+ if depth == 0 {
+ return 0, ErrUnexpectedEndOfGroupTransparentProofs
+ }
+ depth--
+ case 5:
+ iNdEx += 4
+ default:
+ return 0, fmt.Errorf("proto: illegal wireType %d", wireType)
+ }
+ if iNdEx < 0 {
+ return 0, ErrInvalidLengthTransparentProofs
+ }
+ if depth == 0 {
+ return iNdEx, nil
+ }
+ }
+ return 0, io.ErrUnexpectedEOF
+}
+
+var (
+ ErrInvalidLengthTransparentProofs = fmt.Errorf("proto: negative length found during unmarshaling")
+ ErrIntOverflowTransparentProofs = fmt.Errorf("proto: integer overflow")
+ ErrUnexpectedEndOfGroupTransparentProofs = fmt.Errorf("proto: unexpected end of group")
+)
diff --git a/relayer/chains/penumbra/custody/v1alpha1/custody.pb.go b/relayer/chains/penumbra/custody/v1alpha1/custody.pb.go
new file mode 100644
index 000000000..d30aa8c26
--- /dev/null
+++ b/relayer/chains/penumbra/custody/v1alpha1/custody.pb.go
@@ -0,0 +1,1213 @@
+// Code generated by protoc-gen-gogo. DO NOT EDIT.
+// source: penumbra/custody/v1alpha1/custody.proto
+
+package custodyv1alpha1
+
+import (
+ context "context"
+ fmt "fmt"
+ grpc1 "github.com/cosmos/gogoproto/grpc"
+ proto "github.com/cosmos/gogoproto/proto"
+ v1alpha11 "github.com/cosmos/relayer/v2/relayer/chains/penumbra/core/crypto/v1alpha1"
+ v1alpha1 "github.com/cosmos/relayer/v2/relayer/chains/penumbra/core/transaction/v1alpha1"
+ grpc "google.golang.org/grpc"
+ codes "google.golang.org/grpc/codes"
+ status "google.golang.org/grpc/status"
+ io "io"
+ math "math"
+ math_bits "math/bits"
+)
+
+// Reference imports to suppress errors if they are not otherwise used.
+var _ = proto.Marshal
+var _ = fmt.Errorf
+var _ = math.Inf
+
+// This is a compile-time assertion to ensure that this generated file
+// is compatible with the proto package it is being compiled against.
+// A compilation error at this line likely means your copy of the
+// proto package needs to be updated.
+const _ = proto.GoGoProtoPackageIsVersion3 // please upgrade the proto package
+
+type AuthorizeRequest struct {
+ // The transaction plan to authorize.
+ Plan *v1alpha1.TransactionPlan `protobuf:"bytes,1,opt,name=plan,proto3" json:"plan,omitempty"`
+ // Identifies the FVK (and hence the spend authorization key) to use for signing.
+ AccountGroupId *v1alpha11.AccountGroupId `protobuf:"bytes,2,opt,name=account_group_id,json=accountGroupId,proto3" json:"account_group_id,omitempty"`
+ // Optionally, pre-authorization data, if required by the custodian.
+ //
+ // Multiple `PreAuthorization` packets can be included in a single request,
+ // to support multi-party pre-authorizations.
+ PreAuthorizations []*PreAuthorization `protobuf:"bytes,3,rep,name=pre_authorizations,json=preAuthorizations,proto3" json:"pre_authorizations,omitempty"`
+}
+
+func (m *AuthorizeRequest) Reset() { *m = AuthorizeRequest{} }
+func (m *AuthorizeRequest) String() string { return proto.CompactTextString(m) }
+func (*AuthorizeRequest) ProtoMessage() {}
+func (*AuthorizeRequest) Descriptor() ([]byte, []int) {
+ return fileDescriptor_8c8c99775232419d, []int{0}
+}
+func (m *AuthorizeRequest) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *AuthorizeRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_AuthorizeRequest.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *AuthorizeRequest) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_AuthorizeRequest.Merge(m, src)
+}
+func (m *AuthorizeRequest) XXX_Size() int {
+ return m.Size()
+}
+func (m *AuthorizeRequest) XXX_DiscardUnknown() {
+ xxx_messageInfo_AuthorizeRequest.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_AuthorizeRequest proto.InternalMessageInfo
+
+func (m *AuthorizeRequest) GetPlan() *v1alpha1.TransactionPlan {
+ if m != nil {
+ return m.Plan
+ }
+ return nil
+}
+
+func (m *AuthorizeRequest) GetAccountGroupId() *v1alpha11.AccountGroupId {
+ if m != nil {
+ return m.AccountGroupId
+ }
+ return nil
+}
+
+func (m *AuthorizeRequest) GetPreAuthorizations() []*PreAuthorization {
+ if m != nil {
+ return m.PreAuthorizations
+ }
+ return nil
+}
+
+type AuthorizeResponse struct {
+ Data *v1alpha1.AuthorizationData `protobuf:"bytes,1,opt,name=data,proto3" json:"data,omitempty"`
+}
+
+func (m *AuthorizeResponse) Reset() { *m = AuthorizeResponse{} }
+func (m *AuthorizeResponse) String() string { return proto.CompactTextString(m) }
+func (*AuthorizeResponse) ProtoMessage() {}
+func (*AuthorizeResponse) Descriptor() ([]byte, []int) {
+ return fileDescriptor_8c8c99775232419d, []int{1}
+}
+func (m *AuthorizeResponse) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *AuthorizeResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_AuthorizeResponse.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *AuthorizeResponse) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_AuthorizeResponse.Merge(m, src)
+}
+func (m *AuthorizeResponse) XXX_Size() int {
+ return m.Size()
+}
+func (m *AuthorizeResponse) XXX_DiscardUnknown() {
+ xxx_messageInfo_AuthorizeResponse.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_AuthorizeResponse proto.InternalMessageInfo
+
+func (m *AuthorizeResponse) GetData() *v1alpha1.AuthorizationData {
+ if m != nil {
+ return m.Data
+ }
+ return nil
+}
+
+// A pre-authorization packet. This allows a custodian to delegate (partial)
+// signing authority to other authorization mechanisms. Details of how a
+// custodian manages those keys are out-of-scope for the custody protocol and
+// are custodian-specific.
+type PreAuthorization struct {
+ // Types that are valid to be assigned to PreAuthorization:
+ // *PreAuthorization_Ed25519_
+ PreAuthorization isPreAuthorization_PreAuthorization `protobuf_oneof:"pre_authorization"`
+}
+
+func (m *PreAuthorization) Reset() { *m = PreAuthorization{} }
+func (m *PreAuthorization) String() string { return proto.CompactTextString(m) }
+func (*PreAuthorization) ProtoMessage() {}
+func (*PreAuthorization) Descriptor() ([]byte, []int) {
+ return fileDescriptor_8c8c99775232419d, []int{2}
+}
+func (m *PreAuthorization) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *PreAuthorization) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_PreAuthorization.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *PreAuthorization) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_PreAuthorization.Merge(m, src)
+}
+func (m *PreAuthorization) XXX_Size() int {
+ return m.Size()
+}
+func (m *PreAuthorization) XXX_DiscardUnknown() {
+ xxx_messageInfo_PreAuthorization.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_PreAuthorization proto.InternalMessageInfo
+
+type isPreAuthorization_PreAuthorization interface {
+ isPreAuthorization_PreAuthorization()
+ MarshalTo([]byte) (int, error)
+ Size() int
+}
+
+type PreAuthorization_Ed25519_ struct {
+ Ed25519 *PreAuthorization_Ed25519 `protobuf:"bytes,1,opt,name=ed25519,proto3,oneof" json:"ed25519,omitempty"`
+}
+
+func (*PreAuthorization_Ed25519_) isPreAuthorization_PreAuthorization() {}
+
+func (m *PreAuthorization) GetPreAuthorization() isPreAuthorization_PreAuthorization {
+ if m != nil {
+ return m.PreAuthorization
+ }
+ return nil
+}
+
+func (m *PreAuthorization) GetEd25519() *PreAuthorization_Ed25519 {
+ if x, ok := m.GetPreAuthorization().(*PreAuthorization_Ed25519_); ok {
+ return x.Ed25519
+ }
+ return nil
+}
+
+// XXX_OneofWrappers is for the internal use of the proto package.
+func (*PreAuthorization) XXX_OneofWrappers() []interface{} {
+ return []interface{}{
+ (*PreAuthorization_Ed25519_)(nil),
+ }
+}
+
+// An Ed25519-based preauthorization, containing an Ed25519 signature over the
+// `TransactionPlan`.
+type PreAuthorization_Ed25519 struct {
+ // The Ed25519 verification key used to verify the signature.
+ Vk []byte `protobuf:"bytes,1,opt,name=vk,proto3" json:"vk,omitempty"`
+ // The Ed25519 signature over the `TransactionPlan`.
+ Sig []byte `protobuf:"bytes,2,opt,name=sig,proto3" json:"sig,omitempty"`
+}
+
+func (m *PreAuthorization_Ed25519) Reset() { *m = PreAuthorization_Ed25519{} }
+func (m *PreAuthorization_Ed25519) String() string { return proto.CompactTextString(m) }
+func (*PreAuthorization_Ed25519) ProtoMessage() {}
+func (*PreAuthorization_Ed25519) Descriptor() ([]byte, []int) {
+ return fileDescriptor_8c8c99775232419d, []int{2, 0}
+}
+func (m *PreAuthorization_Ed25519) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *PreAuthorization_Ed25519) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_PreAuthorization_Ed25519.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *PreAuthorization_Ed25519) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_PreAuthorization_Ed25519.Merge(m, src)
+}
+func (m *PreAuthorization_Ed25519) XXX_Size() int {
+ return m.Size()
+}
+func (m *PreAuthorization_Ed25519) XXX_DiscardUnknown() {
+ xxx_messageInfo_PreAuthorization_Ed25519.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_PreAuthorization_Ed25519 proto.InternalMessageInfo
+
+func (m *PreAuthorization_Ed25519) GetVk() []byte {
+ if m != nil {
+ return m.Vk
+ }
+ return nil
+}
+
+func (m *PreAuthorization_Ed25519) GetSig() []byte {
+ if m != nil {
+ return m.Sig
+ }
+ return nil
+}
+
+func init() {
+ proto.RegisterType((*AuthorizeRequest)(nil), "penumbra.custody.v1alpha1.AuthorizeRequest")
+ proto.RegisterType((*AuthorizeResponse)(nil), "penumbra.custody.v1alpha1.AuthorizeResponse")
+ proto.RegisterType((*PreAuthorization)(nil), "penumbra.custody.v1alpha1.PreAuthorization")
+ proto.RegisterType((*PreAuthorization_Ed25519)(nil), "penumbra.custody.v1alpha1.PreAuthorization.Ed25519")
+}
+
+func init() {
+ proto.RegisterFile("penumbra/custody/v1alpha1/custody.proto", fileDescriptor_8c8c99775232419d)
+}
+
+var fileDescriptor_8c8c99775232419d = []byte{
+ // 534 bytes of a gzipped FileDescriptorProto
+ 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x8c, 0x93, 0x4f, 0x6f, 0xd3, 0x30,
+ 0x18, 0xc6, 0x9b, 0x74, 0x62, 0xc2, 0xab, 0xa6, 0xd6, 0x48, 0xa8, 0x2b, 0x22, 0x9a, 0x2a, 0x21,
+ 0x26, 0x06, 0x8e, 0xda, 0xd1, 0x03, 0xe5, 0xd4, 0x0e, 0x54, 0x76, 0x40, 0x44, 0xe1, 0xaf, 0xa6,
+ 0x8a, 0xca, 0x75, 0x4d, 0x1b, 0x2d, 0x8d, 0x83, 0xed, 0x44, 0x2a, 0x27, 0x3e, 0xc2, 0x3e, 0xc3,
+ 0x24, 0x2e, 0x7c, 0x12, 0xc4, 0x69, 0x47, 0x8e, 0xa8, 0xbd, 0xf1, 0x29, 0x50, 0xfe, 0xb8, 0x49,
+ 0x0b, 0x85, 0xdd, 0xe2, 0xe7, 0x7d, 0xde, 0x9f, 0x5f, 0x3f, 0xb1, 0xc1, 0x5d, 0x9f, 0x7a, 0xc1,
+ 0x74, 0xc8, 0xb1, 0x49, 0x02, 0x21, 0xd9, 0x68, 0x66, 0x86, 0x0d, 0xec, 0xfa, 0x13, 0xdc, 0x50,
+ 0x02, 0xf2, 0x39, 0x93, 0x0c, 0xee, 0x29, 0x23, 0x52, 0xba, 0x32, 0xd6, 0xee, 0x65, 0x0c, 0xc6,
+ 0xa9, 0x49, 0xf8, 0xcc, 0x97, 0x2c, 0xc7, 0x89, 0xd7, 0x09, 0xa6, 0xf6, 0x70, 0xd5, 0x2b, 0x39,
+ 0xf6, 0x04, 0x26, 0xd2, 0x61, 0x5e, 0xd6, 0x90, 0x13, 0x93, 0xae, 0xfa, 0xb9, 0x0e, 0xca, 0x9d,
+ 0x40, 0x4e, 0x18, 0x77, 0x3e, 0x51, 0x9b, 0x7e, 0x0c, 0xa8, 0x90, 0xb0, 0x07, 0xb6, 0x7c, 0x17,
+ 0x7b, 0x55, 0x6d, 0x5f, 0x3b, 0xd8, 0x69, 0x1e, 0xa1, 0x6c, 0x40, 0xc6, 0x29, 0xca, 0x43, 0x14,
+ 0x19, 0xbd, 0xca, 0x44, 0xcb, 0xc5, 0x9e, 0x1d, 0x03, 0xe0, 0x5b, 0x50, 0xc6, 0x84, 0xb0, 0xc0,
+ 0x93, 0x83, 0x31, 0x67, 0x81, 0x3f, 0x70, 0x46, 0x55, 0x3d, 0x86, 0x3e, 0x58, 0x83, 0xa6, 0x47,
+ 0x59, 0xf2, 0x3a, 0x49, 0x5b, 0x2f, 0xea, 0x3a, 0x19, 0xd9, 0xbb, 0x78, 0x65, 0x0d, 0x4f, 0x01,
+ 0xf4, 0x39, 0x1d, 0xe0, 0x74, 0x72, 0x1c, 0xed, 0x2b, 0xaa, 0xc5, 0xfd, 0xe2, 0xc1, 0x4e, 0xf3,
+ 0x10, 0x6d, 0x0c, 0x14, 0x59, 0x9c, 0x76, 0xf2, 0x3d, 0x76, 0xc5, 0x5f, 0x53, 0x44, 0xfd, 0x3d,
+ 0xa8, 0xe4, 0x12, 0x11, 0x3e, 0xf3, 0x04, 0x85, 0x27, 0x60, 0x6b, 0x84, 0x25, 0x4e, 0x23, 0x69,
+ 0x5d, 0x25, 0x92, 0x15, 0xec, 0x13, 0x2c, 0xb1, 0x1d, 0x23, 0xea, 0x5f, 0x34, 0x50, 0x5e, 0x9f,
+ 0x03, 0xbe, 0x00, 0xdb, 0x74, 0xd4, 0x6c, 0xb5, 0x1a, 0x8f, 0xfe, 0x92, 0xfa, 0xff, 0x4e, 0x81,
+ 0x9e, 0x26, 0xad, 0xcf, 0x0a, 0xb6, 0xa2, 0xd4, 0x0e, 0xc1, 0x76, 0xaa, 0xc2, 0x5d, 0xa0, 0x87,
+ 0x67, 0x31, 0xb6, 0x64, 0xeb, 0xe1, 0x19, 0x2c, 0x83, 0xa2, 0x70, 0xc6, 0xf1, 0x8f, 0x28, 0xd9,
+ 0xd1, 0x67, 0xf7, 0x06, 0xa8, 0xfc, 0x11, 0x67, 0xf3, 0xb3, 0x06, 0x6e, 0x1e, 0x27, 0x5b, 0x5b,
+ 0xd1, 0x5d, 0x21, 0xcc, 0x7d, 0x49, 0x79, 0xe8, 0x10, 0x0a, 0x3f, 0x80, 0xeb, 0xcb, 0x88, 0xe0,
+ 0xbf, 0xf2, 0x5e, 0xbf, 0x5a, 0xb5, 0xfb, 0x57, 0x33, 0x27, 0xa9, 0x77, 0x2f, 0xf4, 0x6f, 0x73,
+ 0x43, 0xbb, 0x9c, 0x1b, 0xda, 0xcf, 0xb9, 0xa1, 0x9d, 0x2f, 0x8c, 0xc2, 0xe5, 0xc2, 0x28, 0xfc,
+ 0x58, 0x18, 0x05, 0x70, 0x9b, 0xb0, 0xe9, 0x66, 0x56, 0xb7, 0x94, 0x9f, 0xdc, 0xd2, 0x4e, 0x5f,
+ 0x8f, 0x1d, 0x39, 0x09, 0x86, 0x88, 0xb0, 0xa9, 0x49, 0x98, 0x98, 0x32, 0x61, 0x72, 0xea, 0xe2,
+ 0x19, 0xe5, 0x66, 0xd8, 0x5c, 0x7e, 0x92, 0x09, 0x76, 0x3c, 0x61, 0x6e, 0x7c, 0xb9, 0x8f, 0x53,
+ 0x41, 0xad, 0x2f, 0xf4, 0xa2, 0x75, 0xfc, 0xee, 0xab, 0xbe, 0x67, 0xa9, 0x41, 0xd2, 0x6d, 0xd1,
+ 0x9b, 0xd4, 0xf1, 0x3d, 0xab, 0xf5, 0xd3, 0x5a, 0x5f, 0xd5, 0xe6, 0xfa, 0x9d, 0x8d, 0xb5, 0x7e,
+ 0xcf, 0xea, 0x3e, 0xa7, 0x12, 0x47, 0x37, 0xe6, 0x97, 0x7e, 0x4b, 0xf9, 0xda, 0xed, 0xd4, 0xd8,
+ 0x6e, 0x2b, 0xe7, 0xf0, 0x5a, 0xfc, 0x92, 0x8f, 0x7e, 0x07, 0x00, 0x00, 0xff, 0xff, 0x40, 0xae,
+ 0xeb, 0xca, 0x71, 0x04, 0x00, 0x00,
+}
+
+// Reference imports to suppress errors if they are not otherwise used.
+var _ context.Context
+var _ grpc.ClientConn
+
+// This is a compile-time assertion to ensure that this generated file
+// is compatible with the grpc package it is being compiled against.
+const _ = grpc.SupportPackageIsVersion4
+
+// CustodyProtocolServiceClient is the client API for CustodyProtocolService service.
+//
+// For semantics around ctx use and closing/ending streaming RPCs, please refer to https://godoc.org/google.golang.org/grpc#ClientConn.NewStream.
+type CustodyProtocolServiceClient interface {
+ // Requests authorization of the transaction with the given description.
+ Authorize(ctx context.Context, in *AuthorizeRequest, opts ...grpc.CallOption) (*AuthorizeResponse, error)
+}
+
+type custodyProtocolServiceClient struct {
+ cc grpc1.ClientConn
+}
+
+func NewCustodyProtocolServiceClient(cc grpc1.ClientConn) CustodyProtocolServiceClient {
+ return &custodyProtocolServiceClient{cc}
+}
+
+func (c *custodyProtocolServiceClient) Authorize(ctx context.Context, in *AuthorizeRequest, opts ...grpc.CallOption) (*AuthorizeResponse, error) {
+ out := new(AuthorizeResponse)
+ err := c.cc.Invoke(ctx, "/penumbra.custody.v1alpha1.CustodyProtocolService/Authorize", in, out, opts...)
+ if err != nil {
+ return nil, err
+ }
+ return out, nil
+}
+
+// CustodyProtocolServiceServer is the server API for CustodyProtocolService service.
+type CustodyProtocolServiceServer interface {
+ // Requests authorization of the transaction with the given description.
+ Authorize(context.Context, *AuthorizeRequest) (*AuthorizeResponse, error)
+}
+
+// UnimplementedCustodyProtocolServiceServer can be embedded to have forward compatible implementations.
+type UnimplementedCustodyProtocolServiceServer struct {
+}
+
+func (*UnimplementedCustodyProtocolServiceServer) Authorize(ctx context.Context, req *AuthorizeRequest) (*AuthorizeResponse, error) {
+ return nil, status.Errorf(codes.Unimplemented, "method Authorize not implemented")
+}
+
+func RegisterCustodyProtocolServiceServer(s grpc1.Server, srv CustodyProtocolServiceServer) {
+ s.RegisterService(&_CustodyProtocolService_serviceDesc, srv)
+}
+
+func _CustodyProtocolService_Authorize_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) {
+ in := new(AuthorizeRequest)
+ if err := dec(in); err != nil {
+ return nil, err
+ }
+ if interceptor == nil {
+ return srv.(CustodyProtocolServiceServer).Authorize(ctx, in)
+ }
+ info := &grpc.UnaryServerInfo{
+ Server: srv,
+ FullMethod: "/penumbra.custody.v1alpha1.CustodyProtocolService/Authorize",
+ }
+ handler := func(ctx context.Context, req interface{}) (interface{}, error) {
+ return srv.(CustodyProtocolServiceServer).Authorize(ctx, req.(*AuthorizeRequest))
+ }
+ return interceptor(ctx, in, info, handler)
+}
+
+var _CustodyProtocolService_serviceDesc = grpc.ServiceDesc{
+ ServiceName: "penumbra.custody.v1alpha1.CustodyProtocolService",
+ HandlerType: (*CustodyProtocolServiceServer)(nil),
+ Methods: []grpc.MethodDesc{
+ {
+ MethodName: "Authorize",
+ Handler: _CustodyProtocolService_Authorize_Handler,
+ },
+ },
+ Streams: []grpc.StreamDesc{},
+ Metadata: "penumbra/custody/v1alpha1/custody.proto",
+}
+
+func (m *AuthorizeRequest) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *AuthorizeRequest) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *AuthorizeRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.PreAuthorizations) > 0 {
+ for iNdEx := len(m.PreAuthorizations) - 1; iNdEx >= 0; iNdEx-- {
+ {
+ size, err := m.PreAuthorizations[iNdEx].MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintCustody(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1a
+ }
+ }
+ if m.AccountGroupId != nil {
+ {
+ size, err := m.AccountGroupId.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintCustody(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.Plan != nil {
+ {
+ size, err := m.Plan.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintCustody(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *AuthorizeResponse) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *AuthorizeResponse) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *AuthorizeResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Data != nil {
+ {
+ size, err := m.Data.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintCustody(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *PreAuthorization) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *PreAuthorization) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *PreAuthorization) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.PreAuthorization != nil {
+ {
+ size := m.PreAuthorization.Size()
+ i -= size
+ if _, err := m.PreAuthorization.MarshalTo(dAtA[i:]); err != nil {
+ return 0, err
+ }
+ }
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *PreAuthorization_Ed25519_) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *PreAuthorization_Ed25519_) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.Ed25519 != nil {
+ {
+ size, err := m.Ed25519.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintCustody(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+func (m *PreAuthorization_Ed25519) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *PreAuthorization_Ed25519) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *PreAuthorization_Ed25519) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.Sig) > 0 {
+ i -= len(m.Sig)
+ copy(dAtA[i:], m.Sig)
+ i = encodeVarintCustody(dAtA, i, uint64(len(m.Sig)))
+ i--
+ dAtA[i] = 0x12
+ }
+ if len(m.Vk) > 0 {
+ i -= len(m.Vk)
+ copy(dAtA[i:], m.Vk)
+ i = encodeVarintCustody(dAtA, i, uint64(len(m.Vk)))
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func encodeVarintCustody(dAtA []byte, offset int, v uint64) int {
+ offset -= sovCustody(v)
+ base := offset
+ for v >= 1<<7 {
+ dAtA[offset] = uint8(v&0x7f | 0x80)
+ v >>= 7
+ offset++
+ }
+ dAtA[offset] = uint8(v)
+ return base
+}
+func (m *AuthorizeRequest) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Plan != nil {
+ l = m.Plan.Size()
+ n += 1 + l + sovCustody(uint64(l))
+ }
+ if m.AccountGroupId != nil {
+ l = m.AccountGroupId.Size()
+ n += 1 + l + sovCustody(uint64(l))
+ }
+ if len(m.PreAuthorizations) > 0 {
+ for _, e := range m.PreAuthorizations {
+ l = e.Size()
+ n += 1 + l + sovCustody(uint64(l))
+ }
+ }
+ return n
+}
+
+func (m *AuthorizeResponse) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Data != nil {
+ l = m.Data.Size()
+ n += 1 + l + sovCustody(uint64(l))
+ }
+ return n
+}
+
+func (m *PreAuthorization) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.PreAuthorization != nil {
+ n += m.PreAuthorization.Size()
+ }
+ return n
+}
+
+func (m *PreAuthorization_Ed25519_) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Ed25519 != nil {
+ l = m.Ed25519.Size()
+ n += 1 + l + sovCustody(uint64(l))
+ }
+ return n
+}
+func (m *PreAuthorization_Ed25519) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ l = len(m.Vk)
+ if l > 0 {
+ n += 1 + l + sovCustody(uint64(l))
+ }
+ l = len(m.Sig)
+ if l > 0 {
+ n += 1 + l + sovCustody(uint64(l))
+ }
+ return n
+}
+
+func sovCustody(x uint64) (n int) {
+ return (math_bits.Len64(x|1) + 6) / 7
+}
+func sozCustody(x uint64) (n int) {
+ return sovCustody(uint64((x << 1) ^ uint64((int64(x) >> 63))))
+}
+func (m *AuthorizeRequest) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCustody
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: AuthorizeRequest: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: AuthorizeRequest: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Plan", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCustody
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthCustody
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthCustody
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Plan == nil {
+ m.Plan = &v1alpha1.TransactionPlan{}
+ }
+ if err := m.Plan.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field AccountGroupId", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCustody
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthCustody
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthCustody
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.AccountGroupId == nil {
+ m.AccountGroupId = &v1alpha11.AccountGroupId{}
+ }
+ if err := m.AccountGroupId.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field PreAuthorizations", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCustody
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthCustody
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthCustody
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.PreAuthorizations = append(m.PreAuthorizations, &PreAuthorization{})
+ if err := m.PreAuthorizations[len(m.PreAuthorizations)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipCustody(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthCustody
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *AuthorizeResponse) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCustody
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: AuthorizeResponse: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: AuthorizeResponse: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Data", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCustody
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthCustody
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthCustody
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Data == nil {
+ m.Data = &v1alpha1.AuthorizationData{}
+ }
+ if err := m.Data.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipCustody(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthCustody
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *PreAuthorization) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCustody
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: PreAuthorization: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: PreAuthorization: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Ed25519", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCustody
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthCustody
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthCustody
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &PreAuthorization_Ed25519{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.PreAuthorization = &PreAuthorization_Ed25519_{v}
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipCustody(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthCustody
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *PreAuthorization_Ed25519) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCustody
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Ed25519: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Ed25519: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Vk", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCustody
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthCustody
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthCustody
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Vk = append(m.Vk[:0], dAtA[iNdEx:postIndex]...)
+ if m.Vk == nil {
+ m.Vk = []byte{}
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Sig", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowCustody
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthCustody
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthCustody
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Sig = append(m.Sig[:0], dAtA[iNdEx:postIndex]...)
+ if m.Sig == nil {
+ m.Sig = []byte{}
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipCustody(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthCustody
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func skipCustody(dAtA []byte) (n int, err error) {
+ l := len(dAtA)
+ iNdEx := 0
+ depth := 0
+ for iNdEx < l {
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return 0, ErrIntOverflowCustody
+ }
+ if iNdEx >= l {
+ return 0, io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= (uint64(b) & 0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ wireType := int(wire & 0x7)
+ switch wireType {
+ case 0:
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return 0, ErrIntOverflowCustody
+ }
+ if iNdEx >= l {
+ return 0, io.ErrUnexpectedEOF
+ }
+ iNdEx++
+ if dAtA[iNdEx-1] < 0x80 {
+ break
+ }
+ }
+ case 1:
+ iNdEx += 8
+ case 2:
+ var length int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return 0, ErrIntOverflowCustody
+ }
+ if iNdEx >= l {
+ return 0, io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ length |= (int(b) & 0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if length < 0 {
+ return 0, ErrInvalidLengthCustody
+ }
+ iNdEx += length
+ case 3:
+ depth++
+ case 4:
+ if depth == 0 {
+ return 0, ErrUnexpectedEndOfGroupCustody
+ }
+ depth--
+ case 5:
+ iNdEx += 4
+ default:
+ return 0, fmt.Errorf("proto: illegal wireType %d", wireType)
+ }
+ if iNdEx < 0 {
+ return 0, ErrInvalidLengthCustody
+ }
+ if depth == 0 {
+ return iNdEx, nil
+ }
+ }
+ return 0, io.ErrUnexpectedEOF
+}
+
+var (
+ ErrInvalidLengthCustody = fmt.Errorf("proto: negative length found during unmarshaling")
+ ErrIntOverflowCustody = fmt.Errorf("proto: integer overflow")
+ ErrUnexpectedEndOfGroupCustody = fmt.Errorf("proto: unexpected end of group")
+)
diff --git a/relayer/chains/penumbra/event_parser.go b/relayer/chains/penumbra/event_parser.go
new file mode 100644
index 000000000..319a8157b
--- /dev/null
+++ b/relayer/chains/penumbra/event_parser.go
@@ -0,0 +1,472 @@
+package penumbra
+
+import (
+ "encoding/base64"
+ "encoding/hex"
+ "fmt"
+ "strconv"
+ "strings"
+ "time"
+
+ abci "github.com/cometbft/cometbft/abci/types"
+ sdk "github.com/cosmos/cosmos-sdk/types"
+ clienttypes "github.com/cosmos/ibc-go/v7/modules/core/02-client/types"
+ conntypes "github.com/cosmos/ibc-go/v7/modules/core/03-connection/types"
+ chantypes "github.com/cosmos/ibc-go/v7/modules/core/04-channel/types"
+ "github.com/cosmos/relayer/v2/relayer/processor"
+ "github.com/cosmos/relayer/v2/relayer/provider"
+ "go.uber.org/zap"
+ "go.uber.org/zap/zapcore"
+)
+
+// ibcMessage is the type used for parsing all possible properties of IBC messages
+type ibcMessage struct {
+ eventType string
+ info ibcMessageInfo
+}
+
+type ibcMessageInfo interface {
+ parseAttrs(log *zap.Logger, attrs []sdk.Attribute)
+ MarshalLogObject(enc zapcore.ObjectEncoder) error
+}
+
+func (ccp *PenumbraChainProcessor) ibcMessagesFromBlockEvents(
+ beginBlockEvents, endBlockEvents []abci.Event,
+ height uint64, base64Encoded bool,
+) (res []ibcMessage) {
+ chainID := ccp.chainProvider.ChainId()
+ res = append(res, ibcMessagesFromEvents(ccp.log, beginBlockEvents, chainID, height, base64Encoded)...)
+ res = append(res, ibcMessagesFromEvents(ccp.log, endBlockEvents, chainID, height, base64Encoded)...)
+ return res
+}
+
+func parseBase64Event(log *zap.Logger, event abci.Event) sdk.StringEvent {
+ evt := sdk.StringEvent{Type: event.Type}
+ for _, attr := range event.Attributes {
+ key, err := base64.StdEncoding.DecodeString(attr.Key)
+ if err != nil {
+ log.Error("Failed to decode legacy key as base64", zap.String("base64", attr.Key), zap.Error(err))
+ continue
+ }
+ value, err := base64.StdEncoding.DecodeString(attr.Value)
+ if err != nil {
+ log.Error("Failed to decode legacy value as base64", zap.String("base64", attr.Value), zap.Error(err))
+ continue
+ }
+ evt.Attributes = append(evt.Attributes, sdk.Attribute{
+ Key: string(key),
+ Value: string(value),
+ })
+ }
+ return evt
+}
+
+// ibcMessagesFromTransaction parses all events within a transaction to find IBC messages
+func ibcMessagesFromEvents(
+ log *zap.Logger,
+ events []abci.Event,
+ chainID string,
+ height uint64,
+ base64Encoded bool,
+) (messages []ibcMessage) {
+ for _, event := range events {
+ var evt sdk.StringEvent
+ if base64Encoded {
+ evt = parseBase64Event(log, event)
+ } else {
+ evt = sdk.StringifyEvent(event)
+ }
+ m := parseIBCMessageFromEvent(log, evt, chainID, height)
+ if m == nil || m.info == nil {
+ // Not an IBC message, don't need to log here
+ continue
+ }
+ messages = append(messages, *m)
+ }
+ return messages
+}
+
+func parseIBCMessageFromEvent(
+ log *zap.Logger,
+ event sdk.StringEvent,
+ chainID string,
+ height uint64,
+) *ibcMessage {
+ switch event.Type {
+ case chantypes.EventTypeSendPacket, chantypes.EventTypeRecvPacket, chantypes.EventTypeWriteAck,
+ chantypes.EventTypeAcknowledgePacket, chantypes.EventTypeTimeoutPacket,
+ chantypes.EventTypeTimeoutPacketOnClose:
+ pi := &packetInfo{Height: height}
+ pi.parseAttrs(log, event.Attributes)
+ return &ibcMessage{
+ eventType: event.Type,
+ info: pi,
+ }
+ case chantypes.EventTypeChannelOpenInit, chantypes.EventTypeChannelOpenTry,
+ chantypes.EventTypeChannelOpenAck, chantypes.EventTypeChannelOpenConfirm,
+ chantypes.EventTypeChannelCloseInit, chantypes.EventTypeChannelCloseConfirm:
+ ci := &channelInfo{Height: height}
+ ci.parseAttrs(log, event.Attributes)
+ return &ibcMessage{
+ eventType: event.Type,
+ info: ci,
+ }
+ case conntypes.EventTypeConnectionOpenInit, conntypes.EventTypeConnectionOpenTry,
+ conntypes.EventTypeConnectionOpenAck, conntypes.EventTypeConnectionOpenConfirm:
+ ci := &connectionInfo{Height: height}
+ ci.parseAttrs(log, event.Attributes)
+ return &ibcMessage{
+ eventType: event.Type,
+ info: ci,
+ }
+ case clienttypes.EventTypeCreateClient, clienttypes.EventTypeUpdateClient,
+ clienttypes.EventTypeUpgradeClient, clienttypes.EventTypeSubmitMisbehaviour,
+ clienttypes.EventTypeUpdateClientProposal:
+ ci := new(clientInfo)
+ ci.parseAttrs(log, event.Attributes)
+ return &ibcMessage{
+ eventType: event.Type,
+ info: ci,
+ }
+
+ case string(processor.ClientICQTypeRequest), string(processor.ClientICQTypeResponse):
+ ci := &clientICQInfo{
+ Height: height,
+ Source: chainID,
+ }
+ ci.parseAttrs(log, event.Attributes)
+ return &ibcMessage{
+ eventType: event.Type,
+ info: ci,
+ }
+ }
+ return nil
+}
+
+func (msg *ibcMessage) parseIBCPacketReceiveMessageFromEvent(
+ log *zap.Logger,
+ event sdk.StringEvent,
+ chainID string,
+ height uint64,
+) *ibcMessage {
+ var pi *packetInfo
+ if msg.info == nil {
+ pi = &packetInfo{Height: height}
+ msg.info = pi
+ } else {
+ pi = msg.info.(*packetInfo)
+ }
+ pi.parseAttrs(log, event.Attributes)
+ if event.Type != chantypes.EventTypeWriteAck {
+ msg.eventType = event.Type
+ }
+ return msg
+}
+
+// clientInfo contains the consensus height of the counterparty chain for a client.
+type clientInfo struct {
+ clientID string
+ consensusHeight clienttypes.Height
+ header []byte
+}
+
+func (c clientInfo) ClientState(trustingPeriod time.Duration) provider.ClientState {
+ return provider.ClientState{
+ ClientID: c.clientID,
+ ConsensusHeight: c.consensusHeight,
+ TrustingPeriod: trustingPeriod,
+ Header: c.header,
+ }
+}
+
+func (res *clientInfo) MarshalLogObject(enc zapcore.ObjectEncoder) error {
+ enc.AddString("client_id", res.clientID)
+ enc.AddUint64("consensus_height", res.consensusHeight.RevisionHeight)
+ enc.AddUint64("consensus_height_revision", res.consensusHeight.RevisionNumber)
+ return nil
+}
+
+func (res *clientInfo) parseAttrs(log *zap.Logger, attributes []sdk.Attribute) {
+ for _, attr := range attributes {
+ res.parseClientAttribute(log, attr)
+ }
+}
+
+func (res *clientInfo) parseClientAttribute(log *zap.Logger, attr sdk.Attribute) {
+ switch attr.Key {
+ case clienttypes.AttributeKeyClientID:
+ res.clientID = attr.Value
+ case clienttypes.AttributeKeyConsensusHeight:
+ revisionSplit := strings.Split(attr.Value, "-")
+ if len(revisionSplit) != 2 {
+ log.Error("Error parsing client consensus height",
+ zap.String("client_id", res.clientID),
+ zap.String("value", attr.Value),
+ )
+ return
+ }
+ revisionNumberString := revisionSplit[0]
+ revisionNumber, err := strconv.ParseUint(revisionNumberString, 10, 64)
+ if err != nil {
+ log.Error("Error parsing client consensus height revision number",
+ zap.Error(err),
+ )
+ return
+ }
+ revisionHeightString := revisionSplit[1]
+ revisionHeight, err := strconv.ParseUint(revisionHeightString, 10, 64)
+ if err != nil {
+ log.Error("Error parsing client consensus height revision height",
+ zap.Error(err),
+ )
+ return
+ }
+ res.consensusHeight = clienttypes.Height{
+ RevisionNumber: revisionNumber,
+ RevisionHeight: revisionHeight,
+ }
+ case clienttypes.AttributeKeyHeader:
+ data, err := hex.DecodeString(attr.Value)
+ if err != nil {
+ log.Error("Error parsing client header",
+ zap.String("header", attr.Value),
+ zap.Error(err),
+ )
+ return
+ }
+ res.header = data
+ }
+}
+
+// alias type to the provider types, used for adding parser methods
+type packetInfo provider.PacketInfo
+
+func (res *packetInfo) MarshalLogObject(enc zapcore.ObjectEncoder) error {
+ enc.AddUint64("sequence", res.Sequence)
+ enc.AddString("src_channel", res.SourceChannel)
+ enc.AddString("src_port", res.SourcePort)
+ enc.AddString("dst_channel", res.DestChannel)
+ enc.AddString("dst_port", res.DestPort)
+ return nil
+}
+
+// parsePacketInfo is treated differently from the others since it can be constructed from the accumulation of multiple events
+func (res *packetInfo) parseAttrs(log *zap.Logger, attrs []sdk.Attribute) {
+ for _, attr := range attrs {
+ res.parsePacketAttribute(log, attr)
+ }
+}
+
+func (res *packetInfo) parsePacketAttribute(log *zap.Logger, attr sdk.Attribute) {
+ var err error
+ switch attr.Key {
+ case chantypes.AttributeKeySequence:
+ res.Sequence, err = strconv.ParseUint(attr.Value, 10, 64)
+ if err != nil {
+ log.Error("Error parsing packet sequence",
+ zap.String("value", attr.Value),
+ zap.Error(err),
+ )
+ return
+ }
+ case chantypes.AttributeKeyTimeoutTimestamp:
+ res.TimeoutTimestamp, err = strconv.ParseUint(attr.Value, 10, 64)
+ if err != nil {
+ log.Error("Error parsing packet timestamp",
+ zap.Uint64("sequence", res.Sequence),
+ zap.String("value", attr.Value),
+ zap.Error(err),
+ )
+ return
+ }
+ // NOTE: deprecated per IBC spec
+ case chantypes.AttributeKeyData:
+ res.Data = []byte(attr.Value)
+ case chantypes.AttributeKeyDataHex:
+ data, err := hex.DecodeString(attr.Value)
+ if err != nil {
+ log.Error("Error parsing packet data",
+ zap.Uint64("sequence", res.Sequence),
+ zap.Error(err),
+ )
+ return
+ }
+ res.Data = data
+ // NOTE: deprecated per IBC spec
+ case chantypes.AttributeKeyAck:
+ res.Ack = []byte(attr.Value)
+ case chantypes.AttributeKeyAckHex:
+ data, err := hex.DecodeString(attr.Value)
+ if err != nil {
+ log.Error("Error parsing packet ack",
+ zap.Uint64("sequence", res.Sequence),
+ zap.String("value", attr.Value),
+ zap.Error(err),
+ )
+ return
+ }
+ res.Ack = data
+ case chantypes.AttributeKeyTimeoutHeight:
+ timeoutSplit := strings.Split(attr.Value, "-")
+ if len(timeoutSplit) != 2 {
+ log.Error("Error parsing packet height timeout",
+ zap.Uint64("sequence", res.Sequence),
+ zap.String("value", attr.Value),
+ )
+ return
+ }
+ revisionNumber, err := strconv.ParseUint(timeoutSplit[0], 10, 64)
+ if err != nil {
+ log.Error("Error parsing packet timeout height revision number",
+ zap.Uint64("sequence", res.Sequence),
+ zap.String("value", timeoutSplit[0]),
+ zap.Error(err),
+ )
+ return
+ }
+ revisionHeight, err := strconv.ParseUint(timeoutSplit[1], 10, 64)
+ if err != nil {
+ log.Error("Error parsing packet timeout height revision height",
+ zap.Uint64("sequence", res.Sequence),
+ zap.String("value", timeoutSplit[1]),
+ zap.Error(err),
+ )
+ return
+ }
+ res.TimeoutHeight = clienttypes.Height{
+ RevisionNumber: revisionNumber,
+ RevisionHeight: revisionHeight,
+ }
+ case chantypes.AttributeKeySrcPort:
+ res.SourcePort = attr.Value
+ case chantypes.AttributeKeySrcChannel:
+ res.SourceChannel = attr.Value
+ case chantypes.AttributeKeyDstPort:
+ res.DestPort = attr.Value
+ case chantypes.AttributeKeyDstChannel:
+ res.DestChannel = attr.Value
+ case chantypes.AttributeKeyChannelOrdering:
+ res.ChannelOrder = attr.Value
+ }
+}
+
+// alias type to the provider types, used for adding parser methods
+type channelInfo provider.ChannelInfo
+
+func (res *channelInfo) MarshalLogObject(enc zapcore.ObjectEncoder) error {
+ enc.AddString("channel_id", res.ChannelID)
+ enc.AddString("port_id", res.PortID)
+ enc.AddString("counterparty_channel_id", res.CounterpartyChannelID)
+ enc.AddString("counterparty_port_id", res.CounterpartyPortID)
+ return nil
+}
+
+func (res *channelInfo) parseAttrs(log *zap.Logger, attrs []sdk.Attribute) {
+ for _, attr := range attrs {
+ res.parseChannelAttribute(attr)
+ }
+}
+
+// parseChannelAttribute parses channel attributes from an event.
+// If the attribute has already been parsed into the channelInfo,
+// it will not overwrite, and return true to inform the caller that
+// the attribute already exists.
+func (res *channelInfo) parseChannelAttribute(attr sdk.Attribute) {
+ switch attr.Key {
+ case chantypes.AttributeKeyPortID:
+ res.PortID = attr.Value
+ case chantypes.AttributeKeyChannelID:
+ res.ChannelID = attr.Value
+ case chantypes.AttributeCounterpartyPortID:
+ res.CounterpartyPortID = attr.Value
+ case chantypes.AttributeCounterpartyChannelID:
+ res.CounterpartyChannelID = attr.Value
+ case chantypes.AttributeKeyConnectionID:
+ res.ConnID = attr.Value
+ case chantypes.AttributeVersion:
+ res.Version = attr.Value
+ }
+}
+
+// alias type to the provider types, used for adding parser methods
+type connectionInfo provider.ConnectionInfo
+
+func (res *connectionInfo) MarshalLogObject(enc zapcore.ObjectEncoder) error {
+ enc.AddString("connection_id", res.ConnID)
+ enc.AddString("client_id", res.ClientID)
+ enc.AddString("counterparty_connection_id", res.CounterpartyConnID)
+ enc.AddString("counterparty_client_id", res.CounterpartyClientID)
+ return nil
+}
+
+func (res *connectionInfo) parseAttrs(log *zap.Logger, attrs []sdk.Attribute) {
+ for _, attr := range attrs {
+ res.parseConnectionAttribute(attr)
+ }
+}
+
+func (res *connectionInfo) parseConnectionAttribute(attr sdk.Attribute) {
+ switch attr.Key {
+ case conntypes.AttributeKeyConnectionID:
+ res.ConnID = attr.Value
+ case conntypes.AttributeKeyClientID:
+ res.ClientID = attr.Value
+ case conntypes.AttributeKeyCounterpartyConnectionID:
+ res.CounterpartyConnID = attr.Value
+ case conntypes.AttributeKeyCounterpartyClientID:
+ res.CounterpartyClientID = attr.Value
+ }
+}
+
+type clientICQInfo struct {
+ Source string
+ Connection string
+ Chain string
+ QueryID provider.ClientICQQueryID
+ Type string
+ Request []byte
+ Height uint64
+}
+
+func (res *clientICQInfo) MarshalLogObject(enc zapcore.ObjectEncoder) error {
+ enc.AddString("connection_id", res.Connection)
+ enc.AddString("chain_id", res.Chain)
+ enc.AddString("query_id", string(res.QueryID))
+ enc.AddString("type", res.Type)
+ enc.AddString("request", hex.EncodeToString(res.Request))
+ enc.AddUint64("height", res.Height)
+
+ return nil
+}
+
+func (res *clientICQInfo) parseAttrs(log *zap.Logger, attrs []sdk.Attribute) {
+ for _, attr := range attrs {
+ if err := res.parseAttribute(attr); err != nil {
+ panic(fmt.Errorf("failed to parse attributes from client ICQ message: %w", err))
+ }
+ }
+}
+
+func (res *clientICQInfo) parseAttribute(attr sdk.Attribute) (err error) {
+ switch attr.Key {
+ case "connection_id":
+ res.Connection = attr.Value
+ case "chain_id":
+ res.Chain = attr.Value
+ case "query_id":
+ res.QueryID = provider.ClientICQQueryID(attr.Value)
+ case "type":
+ res.Type = attr.Value
+ case "request":
+ res.Request, err = hex.DecodeString(attr.Value)
+ if err != nil {
+ return err
+ }
+ case "height":
+ res.Height, err = strconv.ParseUint(attr.Value, 10, 64)
+ if err != nil {
+ return err
+ }
+ }
+ return nil
+}
diff --git a/relayer/chains/penumbra/grpc_query.go b/relayer/chains/penumbra/grpc_query.go
new file mode 100644
index 000000000..70c375c81
--- /dev/null
+++ b/relayer/chains/penumbra/grpc_query.go
@@ -0,0 +1,215 @@
+package penumbra
+
+import (
+ "context"
+ "fmt"
+ "reflect"
+ "strconv"
+ "sync"
+ "time"
+
+ abci "github.com/cometbft/cometbft/abci/types"
+ gogogrpc "github.com/cosmos/gogoproto/grpc"
+ "github.com/cosmos/relayer/v2/relayer/provider"
+ "google.golang.org/grpc"
+ "google.golang.org/grpc/codes"
+ "google.golang.org/grpc/encoding"
+ "google.golang.org/grpc/encoding/proto"
+ "google.golang.org/grpc/metadata"
+ "google.golang.org/grpc/status"
+
+ "github.com/cosmos/cosmos-sdk/codec/types"
+ sdk "github.com/cosmos/cosmos-sdk/types"
+ sdkerrors "github.com/cosmos/cosmos-sdk/types/errors"
+ grpctypes "github.com/cosmos/cosmos-sdk/types/grpc"
+ "github.com/cosmos/cosmos-sdk/types/tx"
+)
+
+var _ gogogrpc.ClientConn = &PenumbraProvider{}
+
+var protoCodec = encoding.GetCodec(proto.Name)
+
+// Invoke implements the grpc ClientConn.Invoke method
+func (cc *PenumbraProvider) Invoke(ctx context.Context, method string, req, reply interface{}, opts ...grpc.CallOption) (err error) {
+ // Two things can happen here:
+ // 1. either we're broadcasting a Tx, in which call we call Tendermint's broadcast endpoint directly,
+ // 2. or we are querying for state, in which case we call ABCI's Querier.
+
+ // In both cases, we don't allow empty request req (it will panic unexpectedly).
+ if reflect.ValueOf(req).IsNil() {
+ return sdkerrors.Wrap(sdkerrors.ErrInvalidRequest, "request cannot be nil")
+ }
+
+ // Case 1. Broadcasting a Tx.
+ if reqProto, ok := req.(*tx.BroadcastTxRequest); ok {
+ if !ok {
+ return sdkerrors.Wrapf(sdkerrors.ErrInvalidRequest, "expected %T, got %T", (*tx.BroadcastTxRequest)(nil), req)
+ }
+ resProto, ok := reply.(*tx.BroadcastTxResponse)
+ if !ok {
+ return sdkerrors.Wrapf(sdkerrors.ErrInvalidRequest, "expected %T, got %T", (*tx.BroadcastTxResponse)(nil), req)
+ }
+
+ broadcastRes, err := cc.TxServiceBroadcast(ctx, reqProto)
+ if err != nil {
+ return err
+ }
+ *resProto = *broadcastRes
+ return err
+ }
+
+ // Case 2. Querying state.
+ inMd, _ := metadata.FromOutgoingContext(ctx)
+ abciRes, outMd, err := cc.RunGRPCQuery(ctx, method, req, inMd)
+ if err != nil {
+ return err
+ }
+
+ if err = protoCodec.Unmarshal(abciRes.Value, reply); err != nil {
+ return err
+ }
+
+ for _, callOpt := range opts {
+ header, ok := callOpt.(grpc.HeaderCallOption)
+ if !ok {
+ continue
+ }
+
+ *header.HeaderAddr = outMd
+ }
+
+ if cc.Codec.InterfaceRegistry != nil {
+ return types.UnpackInterfaces(reply, cc.Codec.Marshaler)
+ }
+
+ return nil
+}
+
+// NewStream implements the grpc ClientConn.NewStream method
+func (cc *PenumbraProvider) NewStream(context.Context, *grpc.StreamDesc, string, ...grpc.CallOption) (grpc.ClientStream, error) {
+ return nil, fmt.Errorf("streaming rpc not supported")
+}
+
+// RunGRPCQuery runs a gRPC query from the clientCtx, given all necessary
+// arguments for the gRPC method, and returns the ABCI response. It is used
+// to factorize code between client (Invoke) and server (RegisterGRPCServer)
+// gRPC handlers.
+func (cc *PenumbraProvider) RunGRPCQuery(ctx context.Context, method string, req interface{}, md metadata.MD) (abci.ResponseQuery, metadata.MD, error) {
+ reqBz, err := protoCodec.Marshal(req)
+ if err != nil {
+ return abci.ResponseQuery{}, nil, err
+ }
+
+ // parse height header
+ if heights := md.Get(grpctypes.GRPCBlockHeightHeader); len(heights) > 0 {
+ height, err := strconv.ParseInt(heights[0], 10, 64)
+ if err != nil {
+ return abci.ResponseQuery{}, nil, err
+ }
+ if height < 0 {
+ return abci.ResponseQuery{}, nil, sdkerrors.Wrapf(
+ sdkerrors.ErrInvalidRequest,
+ "client.Context.Invoke: height (%d) from %q must be >= 0", height, grpctypes.GRPCBlockHeightHeader)
+ }
+
+ }
+
+ height, err := GetHeightFromMetadata(md)
+ if err != nil {
+ return abci.ResponseQuery{}, nil, err
+ }
+
+ prove, err := GetProveFromMetadata(md)
+ if err != nil {
+ return abci.ResponseQuery{}, nil, err
+ }
+
+ abciReq := abci.RequestQuery{
+ Path: method,
+ Data: reqBz,
+ Height: height,
+ Prove: prove,
+ }
+
+ abciRes, err := cc.QueryABCI(ctx, abciReq)
+ if err != nil {
+ return abci.ResponseQuery{}, nil, err
+ }
+
+ // Create header metadata. For now the headers contain:
+ // - block height
+ // We then parse all the call options, if the call option is a
+ // HeaderCallOption, then we manually set the value of that header to the
+ // metadata.
+ md = metadata.Pairs(grpctypes.GRPCBlockHeightHeader, strconv.FormatInt(abciRes.Height, 10))
+ return abciRes, md, nil
+}
+
+// TxServiceBroadcast is a helper function to broadcast a Tx with the correct gRPC types
+// from the tx service. Calls `clientCtx.BroadcastTx` under the hood.
+func (cc *PenumbraProvider) TxServiceBroadcast(ctx context.Context, req *tx.BroadcastTxRequest) (*tx.BroadcastTxResponse, error) {
+ if req == nil || req.TxBytes == nil {
+ return nil, status.Error(codes.InvalidArgument, "invalid empty tx")
+ }
+
+ var (
+ blockTimeout = defaultBroadcastWaitTimeout
+ err error
+ rlyResp *provider.RelayerTxResponse
+ callbackErr error
+ wg sync.WaitGroup
+ )
+
+ if cc.PCfg.BlockTimeout != "" {
+ blockTimeout, err = time.ParseDuration(cc.PCfg.BlockTimeout)
+ if err != nil {
+ // Did you call Validate() method on CosmosProviderConfig struct
+ // before coming here?
+ return nil, err
+ }
+ }
+
+ callback := func(rtr *provider.RelayerTxResponse, err error) {
+ rlyResp = rtr
+ callbackErr = err
+ wg.Done()
+ }
+
+ wg.Add(1)
+
+ if err := cc.broadcastTx(ctx, req.TxBytes, nil, nil, ctx, blockTimeout, callback); err != nil {
+ return nil, err
+ }
+
+ wg.Wait()
+
+ if callbackErr != nil {
+ return nil, callbackErr
+ }
+
+ return &tx.BroadcastTxResponse{
+ TxResponse: &sdk.TxResponse{
+ Height: rlyResp.Height,
+ TxHash: rlyResp.TxHash,
+ Codespace: rlyResp.Codespace,
+ Code: rlyResp.Code,
+ Data: rlyResp.Data,
+ },
+ }, nil
+}
+
+func GetHeightFromMetadata(md metadata.MD) (int64, error) {
+ height := md.Get(grpctypes.GRPCBlockHeightHeader)
+ if len(height) == 1 {
+ return strconv.ParseInt(height[0], 10, 64)
+ }
+ return 0, nil
+}
+
+func GetProveFromMetadata(md metadata.MD) (bool, error) {
+ prove := md.Get("x-cosmos-query-prove")
+ if len(prove) == 1 {
+ return strconv.ParseBool(prove[0])
+ }
+ return false, nil
+}
diff --git a/relayer/chains/penumbra/keys.go b/relayer/chains/penumbra/keys.go
new file mode 100644
index 000000000..d08efe96d
--- /dev/null
+++ b/relayer/chains/penumbra/keys.go
@@ -0,0 +1,211 @@
+package penumbra
+
+import (
+ "errors"
+ "os"
+
+ ckeys "github.com/cosmos/cosmos-sdk/client/keys"
+ "github.com/cosmos/cosmos-sdk/crypto/hd"
+ "github.com/cosmos/cosmos-sdk/crypto/keyring"
+ sdk "github.com/cosmos/cosmos-sdk/types"
+ "github.com/cosmos/go-bip39"
+ "github.com/cosmos/relayer/v2/relayer/codecs/ethermint"
+ "github.com/cosmos/relayer/v2/relayer/codecs/injective"
+ "github.com/cosmos/relayer/v2/relayer/provider"
+)
+
+const ethereumCoinType = uint32(60)
+
+var (
+ // SupportedAlgorithms defines the list of signing algorithms used on Evmos:
+ // - secp256k1 (Cosmos)
+ // - eth_secp256k1 (Ethereum)
+ SupportedAlgorithms = keyring.SigningAlgoList{hd.Secp256k1, ethermint.EthSecp256k1, injective.EthSecp256k1}
+ // SupportedAlgorithmsLedger defines the list of signing algorithms used on Evmos for the Ledger device:
+ // - secp256k1 (Cosmos)
+ // - eth_secp256k1 (Ethereum)
+ SupportedAlgorithmsLedger = keyring.SigningAlgoList{hd.Secp256k1, ethermint.EthSecp256k1, injective.EthSecp256k1}
+)
+
+// KeyringAlgoOptions defines a function keys options for the ethereum Secp256k1 curve.
+// It supports secp256k1 and eth_secp256k1 keys for accounts.
+func KeyringAlgoOptions() keyring.Option {
+ return func(options *keyring.Options) {
+ options.SupportedAlgos = SupportedAlgorithms
+ options.SupportedAlgosLedger = SupportedAlgorithmsLedger
+ }
+}
+
+// CreateKeystore initializes a new instance of a keyring at the specified path in the local filesystem.
+func (cc *PenumbraProvider) CreateKeystore(path string) error {
+ keybase, err := keyring.New(cc.PCfg.ChainID, cc.PCfg.KeyringBackend, cc.PCfg.KeyDirectory, cc.Input, cc.Codec.Marshaler, KeyringAlgoOptions())
+ if err != nil {
+ return err
+ }
+ cc.Keybase = keybase
+ return nil
+}
+
+// KeystoreCreated returns true if there is an existing keystore instance at the specified path, it returns false otherwise.
+func (cc *PenumbraProvider) KeystoreCreated(path string) bool {
+ if _, err := os.Stat(cc.PCfg.KeyDirectory); errors.Is(err, os.ErrNotExist) {
+ return false
+ } else if cc.Keybase == nil {
+ return false
+ }
+ return true
+}
+
+// AddKey generates a new mnemonic which is then converted to a private key and BIP-39 HD Path and persists it to the keystore.
+// It fails if there is an existing key with the same address.
+func (cc *PenumbraProvider) AddKey(name string, coinType uint32, signingAlgorithm string, password string) (output *provider.KeyOutput, err error) {
+ ko, err := cc.KeyAddOrRestore(name, coinType)
+ if err != nil {
+ return nil, err
+ }
+ return ko, nil
+}
+
+// RestoreKey converts a mnemonic to a private key and BIP-39 HD Path and persists it to the keystore.
+// It fails if there is an existing key with the same address.
+func (cc *PenumbraProvider) RestoreKey(name, mnemonic string, coinType uint32, signingAlgorithm string) (address string, err error) {
+ ko, err := cc.KeyAddOrRestore(name, coinType, mnemonic)
+ if err != nil {
+ return "", err
+ }
+ return ko.Address, nil
+}
+
+// KeyAddOrRestore either generates a new mnemonic or uses the specified mnemonic and converts it to a private key
+// and BIP-39 HD Path which is then persisted to the keystore. It fails if there is an existing key with the same address.
+func (cc *PenumbraProvider) KeyAddOrRestore(keyName string, coinType uint32, mnemonic ...string) (*provider.KeyOutput, error) {
+ var mnemonicStr string
+ var err error
+ algo := keyring.SignatureAlgo(hd.Secp256k1)
+
+ if len(mnemonic) > 0 {
+ mnemonicStr = mnemonic[0]
+ } else {
+ mnemonicStr, err = CreateMnemonic()
+ if err != nil {
+ return nil, err
+ }
+ }
+
+ if coinType == ethereumCoinType {
+ algo = keyring.SignatureAlgo(ethermint.EthSecp256k1)
+ for _, codec := range cc.PCfg.ExtraCodecs {
+ if codec == "injective" {
+ algo = keyring.SignatureAlgo(injective.EthSecp256k1)
+ }
+ }
+ }
+
+ info, err := cc.Keybase.NewAccount(keyName, mnemonicStr, "", hd.CreateHDPath(coinType, 0, 0).String(), algo)
+ if err != nil {
+ return nil, err
+ }
+
+ acc, err := info.GetAddress()
+ if err != nil {
+ return nil, err
+ }
+
+ out, err := cc.EncodeBech32AccAddr(acc)
+ if err != nil {
+ return nil, err
+ }
+ return &provider.KeyOutput{Mnemonic: mnemonicStr, Address: out}, nil
+}
+
+// ShowAddress retrieves a key by name from the keystore and returns the bech32 encoded string representation of that key.
+func (cc *PenumbraProvider) ShowAddress(name string) (address string, err error) {
+ info, err := cc.Keybase.Key(name)
+ if err != nil {
+ return "", err
+ }
+ acc, err := info.GetAddress()
+ if err != nil {
+ return "", nil
+ }
+ out, err := cc.EncodeBech32AccAddr(acc)
+ if err != nil {
+ return "", err
+ }
+ return out, nil
+}
+
+// ListAddresses returns a map of bech32 encoded strings representing all keys currently in the keystore.
+func (cc *PenumbraProvider) ListAddresses() (map[string]string, error) {
+ out := map[string]string{}
+ info, err := cc.Keybase.List()
+ if err != nil {
+ return nil, err
+ }
+ for _, k := range info {
+ acc, err := k.GetAddress()
+ if err != nil {
+ return nil, err
+ }
+ addr, err := cc.EncodeBech32AccAddr(acc)
+ if err != nil {
+ return nil, err
+ }
+ out[k.Name] = addr
+ }
+ return out, nil
+}
+
+// DeleteKey removes a key from the keystore for the specified name.
+func (cc *PenumbraProvider) DeleteKey(name string) error {
+ if err := cc.Keybase.Delete(name); err != nil {
+ return err
+ }
+ return nil
+}
+
+// KeyExists returns true if a key with the specified name exists in the keystore, it returns false otherwise.
+func (cc *PenumbraProvider) KeyExists(name string) bool {
+ k, err := cc.Keybase.Key(name)
+ if err != nil {
+ return false
+ }
+
+ return k.Name == name
+
+}
+
+// ExportPrivKeyArmor returns a private key in ASCII armored format.
+// It returns an error if the key does not exist or a wrong encryption passphrase is supplied.
+func (cc *PenumbraProvider) ExportPrivKeyArmor(keyName string) (armor string, err error) {
+ return cc.Keybase.ExportPrivKeyArmor(keyName, ckeys.DefaultKeyPass)
+}
+
+// GetKeyAddress returns the account address representation for the currently configured key.
+func (cc *PenumbraProvider) GetKeyAddress() (sdk.AccAddress, error) {
+ info, err := cc.Keybase.Key(cc.PCfg.Key)
+ if err != nil {
+ return nil, err
+ }
+ return info.GetAddress()
+}
+
+// CreateMnemonic generates a new mnemonic.
+func CreateMnemonic() (string, error) {
+ entropySeed, err := bip39.NewEntropy(256)
+ if err != nil {
+ return "", err
+ }
+ mnemonic, err := bip39.NewMnemonic(entropySeed)
+ if err != nil {
+ return "", err
+ }
+ return mnemonic, nil
+}
+
+// EncodeBech32AccAddr returns the string bech32 representation for the specified account address.
+// It returns an empty sting if the byte slice is 0-length.
+// It returns an error if the bech32 conversion fails or the prefix is empty.
+func (cc *PenumbraProvider) EncodeBech32AccAddr(addr sdk.AccAddress) (string, error) {
+ return sdk.Bech32ifyAddressBytes(cc.PCfg.AccountPrefix, addr)
+}
diff --git a/relayer/chains/penumbra/log.go b/relayer/chains/penumbra/log.go
new file mode 100644
index 000000000..b1f110cf0
--- /dev/null
+++ b/relayer/chains/penumbra/log.go
@@ -0,0 +1,170 @@
+package penumbra
+
+import (
+ "reflect"
+
+ "github.com/cosmos/cosmos-sdk/codec/types"
+ sdk "github.com/cosmos/cosmos-sdk/types"
+ typestx "github.com/cosmos/cosmos-sdk/types/tx"
+ feetypes "github.com/cosmos/ibc-go/v7/modules/apps/29-fee/types"
+ transfertypes "github.com/cosmos/ibc-go/v7/modules/apps/transfer/types"
+ clienttypes "github.com/cosmos/ibc-go/v7/modules/core/02-client/types"
+ "github.com/cosmos/relayer/v2/relayer/provider"
+ "go.uber.org/zap"
+ "go.uber.org/zap/zapcore"
+)
+
+// getChannelsIfPresent scans the events for channel tags
+func getChannelsIfPresent(events []provider.RelayerEvent) []zapcore.Field {
+ channelTags := []string{srcChanTag, dstChanTag}
+ fields := []zap.Field{}
+
+ // While a transaction may have multiple messages, we just need to first
+ // pair of channels
+ foundTag := map[string]struct{}{}
+
+ for _, event := range events {
+ for _, tag := range channelTags {
+ for attributeKey, attributeValue := range event.Attributes {
+ if attributeKey == tag {
+ // Only append the tag once
+ // TODO: what if they are different?
+ if _, ok := foundTag[tag]; !ok {
+ fields = append(fields, zap.String(tag, attributeValue))
+ foundTag[tag] = struct{}{}
+ }
+ }
+ }
+ }
+ }
+ return fields
+}
+
+// LogFailedTx takes the transaction and the messages to create it and logs the appropriate data
+func (cc *PenumbraProvider) LogFailedTx(res *provider.RelayerTxResponse, err error, msgs []provider.RelayerMessage) {
+ // Include the chain_id
+ fields := []zapcore.Field{zap.String("chain_id", cc.ChainId())}
+
+ // Extract the channels from the events, if present
+ if res != nil {
+ channels := getChannelsIfPresent(res.Events)
+ fields = append(fields, channels...)
+ }
+ fields = append(fields, msgTypesField(msgs))
+
+ if err != nil {
+ // Make a copy since we may continue to the warning
+ errorFields := append(fields, zap.Error(err))
+ cc.log.Error(
+ "Failed sending cosmos transaction",
+ errorFields...,
+ )
+
+ if res == nil {
+ return
+ }
+ }
+
+ if res.Code != 0 && res.Data != "" {
+ fields = append(fields, zap.Object("response", res))
+ cc.log.Warn(
+ "Sent transaction but received failure response",
+ fields...,
+ )
+ }
+}
+
+// LogSuccessTx take the transaction and the messages to create it and logs the appropriate data
+func (cc *PenumbraProvider) LogSuccessTx(res *sdk.TxResponse, msgs []provider.RelayerMessage) {
+ // Include the chain_id
+ fields := []zapcore.Field{zap.String("chain_id", cc.ChainId())}
+
+ // Extract the channels from the events, if present
+ if res != nil {
+ events := parseEventsFromTxResponse(res)
+ fields = append(fields, getChannelsIfPresent(events)...)
+ }
+
+ // Include the gas used
+ fields = append(fields, zap.Int64("gas_used", res.GasUsed))
+
+ // Extract fees and fee_payer if present
+ ir := types.NewInterfaceRegistry()
+ var m sdk.Msg
+ if err := ir.UnpackAny(res.Tx, &m); err == nil {
+ if tx, ok := m.(*typestx.Tx); ok {
+ fields = append(fields, zap.Stringer("fees", tx.GetFee()))
+ if feePayer := getFeePayer(tx); feePayer != "" {
+ fields = append(fields, zap.String("fee_payer", feePayer))
+ }
+ } else {
+ cc.log.Debug(
+ "Failed to convert message to Tx type",
+ zap.Stringer("type", reflect.TypeOf(m)),
+ )
+ }
+ } else {
+ cc.log.Debug("Failed to unpack response Tx into sdk.Msg", zap.Error(err))
+ }
+
+ // Include the height, msgType, and tx_hash
+ fields = append(fields,
+ zap.Int64("height", res.Height),
+ msgTypesField(msgs),
+ zap.String("tx_hash", res.TxHash),
+ )
+
+ // Log the succesful transaction with fields
+ cc.log.Info(
+ "Successful transaction",
+ fields...,
+ )
+}
+
+func msgTypesField(msgs []provider.RelayerMessage) zap.Field {
+ msgTypes := make([]string, len(msgs))
+ for i, m := range msgs {
+ msgTypes[i] = m.Type()
+ }
+ return zap.Strings("msg_types", msgTypes)
+}
+
+// getFeePayer returns the bech32 address of the fee payer of a transaction.
+// This uses the fee payer field if set,
+// otherwise falls back to the address of whoever signed the first message.
+func getFeePayer(tx *typestx.Tx) string {
+ payer := tx.AuthInfo.Fee.Payer
+ if payer != "" {
+ return payer
+ }
+
+ switch firstMsg := tx.GetMsgs()[0].(type) {
+ case *transfertypes.MsgTransfer:
+ // There is a possible data race around concurrent map access
+ // in the cosmos sdk when it converts the address from bech32.
+ // We don't need the address conversion; just the sender is all that
+ // GetSigners is doing under the hood anyway.
+ return firstMsg.Sender
+ case *clienttypes.MsgCreateClient:
+ // Without this particular special case, there is a panic in ibc-go
+ // due to the sdk config singleton expecting one bech32 prefix but seeing another.
+ return firstMsg.Signer
+ case *clienttypes.MsgUpdateClient:
+ // Same failure mode as MsgCreateClient.
+ return firstMsg.Signer
+ case *clienttypes.MsgUpgradeClient:
+ return firstMsg.Signer
+ case *clienttypes.MsgSubmitMisbehaviour:
+ return firstMsg.Signer
+ case *feetypes.MsgRegisterPayee:
+ return firstMsg.Relayer
+ case *feetypes.MsgRegisterCounterpartyPayee:
+ return firstMsg.Relayer
+ case *feetypes.MsgPayPacketFee:
+ return firstMsg.Signer
+ case *feetypes.MsgPayPacketFeeAsync:
+ return firstMsg.PacketFee.RefundAddress
+ default:
+ return firstMsg.GetSigners()[0].String()
+ }
+}
diff --git a/relayer/chains/penumbra/message_handlers.go b/relayer/chains/penumbra/message_handlers.go
new file mode 100644
index 000000000..22b570eb6
--- /dev/null
+++ b/relayer/chains/penumbra/message_handlers.go
@@ -0,0 +1,168 @@
+package penumbra
+
+import (
+ conntypes "github.com/cosmos/ibc-go/v7/modules/core/03-connection/types"
+ chantypes "github.com/cosmos/ibc-go/v7/modules/core/04-channel/types"
+ "github.com/cosmos/relayer/v2/relayer/processor"
+ "github.com/cosmos/relayer/v2/relayer/provider"
+ "go.uber.org/zap"
+ "go.uber.org/zap/zapcore"
+)
+
+func (pcp *PenumbraChainProcessor) handleMessage(m ibcMessage, c processor.IBCMessagesCache) {
+ switch t := m.info.(type) {
+ case *packetInfo:
+ pcp.handlePacketMessage(m.eventType, provider.PacketInfo(*t), c)
+ case *channelInfo:
+ pcp.handleChannelMessage(m.eventType, provider.ChannelInfo(*t), c)
+ case *connectionInfo:
+ pcp.handleConnectionMessage(m.eventType, provider.ConnectionInfo(*t), c)
+ case *clientInfo:
+ pcp.handleClientMessage(m.eventType, *t)
+ }
+}
+
+func (pcp *PenumbraChainProcessor) handlePacketMessage(action string, pi provider.PacketInfo, c processor.IBCMessagesCache) {
+ channelKey, err := processor.PacketInfoChannelKey(action, pi)
+ if err != nil {
+ pcp.log.Error("Unexpected error handling packet message",
+ zap.String("action", action),
+ zap.Uint64("sequence", pi.Sequence),
+ zap.Any("channel", channelKey),
+ zap.Error(err),
+ )
+ return
+ }
+
+ if !c.PacketFlow.ShouldRetainSequence(pcp.pathProcessors, channelKey, pcp.chainProvider.ChainId(), action, pi.Sequence) {
+ pcp.log.Warn("Not retaining packet message",
+ zap.String("action", action),
+ zap.Uint64("sequence", pi.Sequence),
+ zap.Any("channel", channelKey),
+ )
+ return
+ }
+
+ c.PacketFlow.Retain(channelKey, action, pi)
+ pcp.logPacketMessage(action, pi)
+}
+
+func (pcp *PenumbraChainProcessor) handleChannelMessage(eventType string, ci provider.ChannelInfo, ibcMessagesCache processor.IBCMessagesCache) {
+ pcp.channelConnections[ci.ChannelID] = ci.ConnID
+ channelKey := processor.ChannelInfoChannelKey(ci)
+
+ if eventType == chantypes.EventTypeChannelOpenInit {
+ found := false
+ for k := range pcp.channelStateCache {
+ // Don't add a channelKey to the channelStateCache without counterparty channel ID
+ // since we already have the channelKey in the channelStateCache which includes the
+ // counterparty channel ID.
+ if k.MsgInitKey() == channelKey {
+ found = true
+ break
+ }
+ }
+ if !found {
+ pcp.channelStateCache.SetOpen(channelKey, false, ci.Order)
+ }
+ } else {
+ switch eventType {
+ case chantypes.EventTypeChannelOpenTry:
+ pcp.channelStateCache.SetOpen(channelKey, false, ci.Order)
+ case chantypes.EventTypeChannelOpenAck, chantypes.EventTypeChannelOpenConfirm:
+ pcp.channelStateCache.SetOpen(channelKey, true, ci.Order)
+ case chantypes.EventTypeChannelCloseConfirm:
+ for k := range pcp.channelStateCache {
+ if k.PortID == ci.PortID && k.ChannelID == ci.ChannelID {
+ pcp.channelStateCache.SetOpen(channelKey, false, ci.Order)
+ break
+ }
+ }
+ }
+ // Clear out MsgInitKeys once we have the counterparty channel ID
+ delete(pcp.channelStateCache, channelKey.MsgInitKey())
+ }
+
+ ibcMessagesCache.ChannelHandshake.Retain(channelKey, eventType, ci)
+
+ pcp.logChannelMessage(eventType, ci)
+}
+
+func (pcp *PenumbraChainProcessor) handleConnectionMessage(eventType string, ci provider.ConnectionInfo, ibcMessagesCache processor.IBCMessagesCache) {
+ pcp.connectionClients[ci.ConnID] = ci.ClientID
+ connectionKey := processor.ConnectionInfoConnectionKey(ci)
+ if eventType == conntypes.EventTypeConnectionOpenInit {
+ found := false
+ for k := range pcp.connectionStateCache {
+ // Don't add a connectionKey to the connectionStateCache without counterparty connection ID
+ // since we already have the connectionKey in the connectionStateCache which includes the
+ // counterparty connection ID.
+ if k.MsgInitKey() == connectionKey {
+ found = true
+ break
+ }
+ }
+ if !found {
+ pcp.connectionStateCache[connectionKey] = false
+ }
+ } else {
+ // Clear out MsgInitKeys once we have the counterparty connection ID
+ delete(pcp.connectionStateCache, connectionKey.MsgInitKey())
+ open := (eventType == conntypes.EventTypeConnectionOpenAck || eventType == conntypes.EventTypeConnectionOpenConfirm)
+ pcp.connectionStateCache[connectionKey] = open
+ }
+ ibcMessagesCache.ConnectionHandshake.Retain(connectionKey, eventType, ci)
+
+ pcp.logConnectionMessage(eventType, ci)
+}
+
+func (pcp *PenumbraChainProcessor) handleClientMessage(eventType string, ci clientInfo) {
+ pcp.latestClientState.update(ci)
+ pcp.logObservedIBCMessage(eventType, zap.String("client_id", ci.clientID))
+}
+
+func (pcp *PenumbraChainProcessor) logObservedIBCMessage(m string, fields ...zap.Field) {
+ pcp.log.With(zap.String("event_type", m)).Debug("Observed IBC message", fields...)
+}
+
+func (pcp *PenumbraChainProcessor) logPacketMessage(message string, pi provider.PacketInfo) {
+ if !pcp.log.Core().Enabled(zapcore.DebugLevel) {
+ return
+ }
+ fields := []zap.Field{
+ zap.Uint64("sequence", pi.Sequence),
+ zap.String("src_channel", pi.SourceChannel),
+ zap.String("src_port", pi.SourcePort),
+ zap.String("dst_channel", pi.DestChannel),
+ zap.String("dst_port", pi.DestPort),
+ }
+ if pi.TimeoutHeight.RevisionHeight > 0 {
+ fields = append(fields, zap.Uint64("timeout_height", pi.TimeoutHeight.RevisionHeight))
+ }
+ if pi.TimeoutHeight.RevisionNumber > 0 {
+ fields = append(fields, zap.Uint64("timeout_height_revision", pi.TimeoutHeight.RevisionNumber))
+ }
+ if pi.TimeoutTimestamp > 0 {
+ fields = append(fields, zap.Uint64("timeout_timestamp", pi.TimeoutTimestamp))
+ }
+ pcp.logObservedIBCMessage(message, fields...)
+}
+
+func (pcp *PenumbraChainProcessor) logChannelMessage(message string, ci provider.ChannelInfo) {
+ pcp.logObservedIBCMessage(message,
+ zap.String("channel_id", ci.ChannelID),
+ zap.String("port_id", ci.PortID),
+ zap.String("counterparty_channel_id", ci.CounterpartyChannelID),
+ zap.String("counterparty_port_id", ci.CounterpartyPortID),
+ zap.String("connection_id", ci.ConnID),
+ )
+}
+
+func (pcp *PenumbraChainProcessor) logConnectionMessage(message string, ci provider.ConnectionInfo) {
+ pcp.logObservedIBCMessage(message,
+ zap.String("client_id", ci.ClientID),
+ zap.String("connection_id", ci.ConnID),
+ zap.String("counterparty_client_id", ci.CounterpartyClientID),
+ zap.String("counterparty_connection_id", ci.CounterpartyConnID),
+ )
+}
diff --git a/relayer/chains/penumbra/msg.go b/relayer/chains/penumbra/msg.go
new file mode 100644
index 000000000..951529b0a
--- /dev/null
+++ b/relayer/chains/penumbra/msg.go
@@ -0,0 +1,80 @@
+package penumbra
+
+import (
+ "fmt"
+
+ "github.com/cosmos/cosmos-sdk/codec"
+ sdk "github.com/cosmos/cosmos-sdk/types"
+ "github.com/cosmos/gogoproto/proto"
+ chantypes "github.com/cosmos/ibc-go/v7/modules/core/04-channel/types"
+ "github.com/cosmos/relayer/v2/relayer/chains/cosmos"
+ "github.com/cosmos/relayer/v2/relayer/provider"
+ "go.uber.org/zap/zapcore"
+)
+
+type PenumbraMessage struct {
+ Msg sdk.Msg
+}
+
+func NewPenumbraMessage(msg sdk.Msg) provider.RelayerMessage {
+ return PenumbraMessage{
+ Msg: msg,
+ }
+}
+
+func PenumbraMsg(rm provider.RelayerMessage) sdk.Msg {
+ if val, ok := rm.(PenumbraMessage); !ok {
+ fmt.Printf("got data of type %T but wanted PenumbraMessage \n", val)
+ return nil
+ } else {
+ return val.Msg
+ }
+}
+
+// typedPenumbraMsg does not accept nil. IBC Message must be of the requested type.
+func typedPenumbraMsg[T *chantypes.MsgRecvPacket | *chantypes.MsgAcknowledgement](msg provider.RelayerMessage) T {
+ if msg == nil {
+ panic("msg is nil")
+ }
+ cosmosMsg := PenumbraMsg(msg)
+ if cosmosMsg == nil {
+ panic("cosmosMsg is nil")
+ }
+ return cosmosMsg.(T)
+}
+
+func PenumbraMsgs(rm ...provider.RelayerMessage) []sdk.Msg {
+ sdkMsgs := make([]sdk.Msg, 0)
+ for _, rMsg := range rm {
+ switch rMsg.(type) {
+ case PenumbraMessage:
+ sdkMsgs = append(sdkMsgs, rMsg.(PenumbraMessage).Msg)
+ case cosmos.CosmosMessage:
+ sdkMsgs = append(sdkMsgs, rMsg.(cosmos.CosmosMessage).Msg)
+ default:
+ fmt.Printf("got data of type %T but wanted PenumbraMessage \n", rMsg)
+ return nil
+ }
+ }
+ return sdkMsgs
+}
+
+func (cm PenumbraMessage) Type() string {
+ return sdk.MsgTypeURL(cm.Msg)
+}
+
+func (cm PenumbraMessage) MsgBytes() ([]byte, error) {
+ return proto.Marshal(cm.Msg)
+}
+
+// MarshalLogObject is used to encode cm to a zap logger with the zap.Object field type.
+func (cm PenumbraMessage) MarshalLogObject(enc zapcore.ObjectEncoder) error {
+ // Using plain json.Marshal or calling cm.Msg.String() both fail miserably here.
+ // There is probably a better way to encode the message than this.
+ j, err := codec.NewLegacyAmino().MarshalJSON(cm.Msg)
+ if err != nil {
+ return err
+ }
+ enc.AddByteString("msg_json", j)
+ return nil
+}
diff --git a/relayer/chains/penumbra/penumbra_chain_processor.go b/relayer/chains/penumbra/penumbra_chain_processor.go
new file mode 100644
index 000000000..f3e470ac3
--- /dev/null
+++ b/relayer/chains/penumbra/penumbra_chain_processor.go
@@ -0,0 +1,429 @@
+package penumbra
+
+import (
+ "context"
+ "errors"
+ "fmt"
+ "time"
+
+ "github.com/avast/retry-go/v4"
+ tmproto "github.com/cometbft/cometbft/proto/tendermint/types"
+ ctypes "github.com/cometbft/cometbft/rpc/core/types"
+ clienttypes "github.com/cosmos/ibc-go/v7/modules/core/02-client/types"
+ conntypes "github.com/cosmos/ibc-go/v7/modules/core/03-connection/types"
+ chantypes "github.com/cosmos/ibc-go/v7/modules/core/04-channel/types"
+ "github.com/cosmos/relayer/v2/relayer/processor"
+ "github.com/cosmos/relayer/v2/relayer/provider"
+
+ "go.uber.org/zap"
+ "golang.org/x/sync/errgroup"
+)
+
+const blockResultsQueryTimeout = 2 * time.Minute
+
+type PenumbraChainProcessor struct {
+ log *zap.Logger
+
+ chainProvider *PenumbraProvider
+
+ pathProcessors processor.PathProcessors
+
+ // indicates whether queries are in sync with latest height of the chain
+ inSync bool
+
+ // highest block
+ latestBlock provider.LatestBlock
+
+ // holds highest consensus height and header for all clients
+ latestClientState
+
+ // holds open state for known connections
+ connectionStateCache processor.ConnectionStateCache
+
+ // holds open state for known channels
+ channelStateCache processor.ChannelStateCache
+
+ // map of connection ID to client ID
+ connectionClients map[string]string
+
+ // map of channel ID to connection ID
+ channelConnections map[string]string
+}
+
+func NewPenumbraChainProcessor(log *zap.Logger, provider *PenumbraProvider) *PenumbraChainProcessor {
+ return &PenumbraChainProcessor{
+ log: log.With(zap.String("chain_name", provider.ChainName()), zap.String("chain_id", provider.ChainId())),
+ chainProvider: provider,
+ latestClientState: make(latestClientState),
+ connectionStateCache: make(processor.ConnectionStateCache),
+ channelStateCache: make(processor.ChannelStateCache),
+ connectionClients: make(map[string]string),
+ channelConnections: make(map[string]string),
+ }
+}
+
+const (
+ queryTimeout = 5 * time.Second
+ latestHeightQueryRetryDelay = 1 * time.Second
+ latestHeightQueryRetries = 5
+
+ defaultMinQueryLoopDuration = 1 * time.Second
+ inSyncNumBlocksThreshold = 2
+)
+
+type msgHandlerParams struct {
+ // incoming IBC message
+ messageInfo any
+
+ // reference to the caches that will be assembled by the handlers in this file
+ ibcMessagesCache processor.IBCMessagesCache
+}
+
+// latestClientState is a map of clientID to the latest clientInfo for that client.
+type latestClientState map[string]provider.ClientState
+
+func (l latestClientState) update(clientInfo clientInfo) {
+ existingClientInfo, ok := l[clientInfo.clientID]
+ if ok && clientInfo.consensusHeight.LT(existingClientInfo.ConsensusHeight) {
+ // height is less than latest, so no-op
+ return
+ }
+ // TODO: don't hardcode
+ tp := time.Hour * 2
+
+ // update latest if no existing state or provided consensus height is newer
+ l[clientInfo.clientID] = clientInfo.ClientState(tp)
+}
+
+// Provider returns the ChainProvider, which provides the methods for querying, assembling IBC messages, and sending transactions.
+func (pcp *PenumbraChainProcessor) Provider() provider.ChainProvider {
+ return pcp.chainProvider
+}
+
+// Set the PathProcessors that this ChainProcessor should publish relevant IBC events to.
+// ChainProcessors need reference to their PathProcessors and vice-versa, handled by EventProcessorBuilder.Build().
+func (pcp *PenumbraChainProcessor) SetPathProcessors(pathProcessors processor.PathProcessors) {
+ pcp.pathProcessors = pathProcessors
+}
+
+// latestHeightWithRetry will query for the latest height, retrying in case of failure.
+// It will delay by latestHeightQueryRetryDelay between attempts, up to latestHeightQueryRetries.
+func (pcp *PenumbraChainProcessor) latestHeightWithRetry(ctx context.Context) (latestHeight int64, err error) {
+ return latestHeight, retry.Do(func() error {
+ latestHeightQueryCtx, cancelLatestHeightQueryCtx := context.WithTimeout(ctx, queryTimeout)
+ defer cancelLatestHeightQueryCtx()
+ var err error
+ latestHeight, err = pcp.chainProvider.QueryLatestHeight(latestHeightQueryCtx)
+ return err
+ }, retry.Context(ctx), retry.Attempts(latestHeightQueryRetries), retry.Delay(latestHeightQueryRetryDelay), retry.LastErrorOnly(true), retry.OnRetry(func(n uint, err error) {
+ pcp.log.Info(
+ "Failed to query latest height",
+ zap.Uint("attempt", n+1),
+ zap.Uint("max_attempts", latestHeightQueryRetries),
+ zap.Error(err),
+ )
+ }))
+}
+
+// clientState will return the most recent client state if client messages
+// have already been observed for the clientID, otherwise it will query for it.
+func (pcp *PenumbraChainProcessor) clientState(ctx context.Context, clientID string) (provider.ClientState, error) {
+ if state, ok := pcp.latestClientState[clientID]; ok {
+ return state, nil
+ }
+ cs, err := pcp.chainProvider.QueryClientState(ctx, int64(pcp.latestBlock.Height), clientID)
+ if err != nil {
+ return provider.ClientState{}, err
+ }
+ clientState := provider.ClientState{
+ ClientID: clientID,
+ ConsensusHeight: cs.GetLatestHeight().(clienttypes.Height),
+ }
+ pcp.latestClientState[clientID] = clientState
+ return clientState, nil
+}
+
+// queryCyclePersistence hold the variables that should be retained across queryCycles.
+type queryCyclePersistence struct {
+ latestHeight int64
+ latestQueriedBlock int64
+ minQueryLoopDuration time.Duration
+}
+
+// Run starts the query loop for the chain which will gather applicable ibc messages and push events out to the relevant PathProcessors.
+// The initialBlockHistory parameter determines how many historical blocks should be fetched and processed before continuing with current blocks.
+// ChainProcessors should obey the context and return upon context cancellation.
+func (pcp *PenumbraChainProcessor) Run(ctx context.Context, initialBlockHistory uint64) error {
+ minQueryLoopDuration := pcp.chainProvider.PCfg.MinLoopDuration
+ if minQueryLoopDuration == 0 {
+ minQueryLoopDuration = defaultMinQueryLoopDuration
+ }
+
+ // this will be used for persistence across query cycle loop executions
+ persistence := queryCyclePersistence{
+ minQueryLoopDuration: minQueryLoopDuration,
+ }
+
+ // Infinite retry to get initial latest height
+ for {
+ latestHeight, err := pcp.latestHeightWithRetry(ctx)
+ if err != nil {
+ pcp.log.Error(
+ "Failed to query latest height after max attempts",
+ zap.Uint("attempts", latestHeightQueryRetries),
+ zap.Error(err),
+ )
+ if errors.Is(err, context.Canceled) || errors.Is(err, context.DeadlineExceeded) {
+ return nil
+ }
+ continue
+ }
+ persistence.latestHeight = latestHeight
+ break
+ }
+
+ // this will make initial QueryLoop iteration look back initialBlockHistory blocks in history
+ latestQueriedBlock := persistence.latestHeight - int64(initialBlockHistory)
+
+ if latestQueriedBlock < 0 {
+ latestQueriedBlock = 0
+ }
+
+ persistence.latestQueriedBlock = latestQueriedBlock
+
+ var eg errgroup.Group
+ eg.Go(func() error {
+ return pcp.initializeConnectionState(ctx)
+ })
+ eg.Go(func() error {
+ return pcp.initializeChannelState(ctx)
+ })
+ if err := eg.Wait(); err != nil {
+ return err
+ }
+
+ pcp.log.Debug("Entering main query loop")
+
+ ticker := time.NewTicker(persistence.minQueryLoopDuration)
+
+ for {
+ if err := pcp.queryCycle(ctx, &persistence); err != nil {
+ return err
+ }
+ select {
+ case <-ctx.Done():
+ return nil
+ case <-ticker.C:
+ ticker.Reset(persistence.minQueryLoopDuration)
+ }
+ }
+}
+
+// initializeConnectionState will bootstrap the connectionStateCache with the open connection state.
+func (pcp *PenumbraChainProcessor) initializeConnectionState(ctx context.Context) error {
+ ctx, cancel := context.WithTimeout(ctx, queryTimeout)
+ defer cancel()
+ connections, err := pcp.chainProvider.QueryConnections(ctx)
+ if err != nil {
+ return fmt.Errorf("error querying connections: %w", err)
+ }
+ for _, c := range connections {
+ pcp.connectionClients[c.Id] = c.ClientId
+ pcp.connectionStateCache[processor.ConnectionKey{
+ ConnectionID: c.Id,
+ ClientID: c.ClientId,
+ CounterpartyConnID: c.Counterparty.ConnectionId,
+ CounterpartyClientID: c.Counterparty.ClientId,
+ }] = c.State == conntypes.OPEN
+ }
+ return nil
+}
+
+// initializeChannelState will bootstrap the channelStateCache with the open channel state.
+func (pcp *PenumbraChainProcessor) initializeChannelState(ctx context.Context) error {
+ ctx, cancel := context.WithTimeout(ctx, queryTimeout)
+ defer cancel()
+ channels, err := pcp.chainProvider.QueryChannels(ctx)
+ if err != nil {
+ return fmt.Errorf("error querying channels: %w", err)
+ }
+ for _, ch := range channels {
+ if len(ch.ConnectionHops) != 1 {
+ pcp.log.Error("Found channel using multiple connection hops. Not currently supported, ignoring.",
+ zap.String("channel_id", ch.ChannelId),
+ zap.String("port_id", ch.PortId),
+ zap.Any("connection_hops", ch.ConnectionHops),
+ )
+ continue
+ }
+ pcp.channelConnections[ch.ChannelId] = ch.ConnectionHops[0]
+ k := processor.ChannelKey{
+ ChannelID: ch.ChannelId,
+ PortID: ch.PortId,
+ CounterpartyChannelID: ch.Counterparty.ChannelId,
+ CounterpartyPortID: ch.Counterparty.PortId,
+ }
+ pcp.channelStateCache.SetOpen(k, ch.State == chantypes.OPEN, ch.Ordering)
+ }
+ return nil
+}
+
+func (ccp *PenumbraChainProcessor) SnapshotHeight(height int64) {
+ panic("Not implemented for Penumbra")
+}
+
+func (ccp *PenumbraChainProcessor) StartFromHeight(ctx context.Context) int64 {
+ panic("Not implemented for Penumbra")
+}
+
+// ABCI results from a block
+type ResultBlockResults struct {
+ Height int64 `json:"height,string"`
+ TxsResults []*ExecTxResult `json:"txs_results"`
+ TotalGasUsed int64 `json:"total_gas_used,string"`
+ FinalizeBlockEvents []Event `json:"finalize_block_events"`
+ ValidatorUpdates []ValidatorUpdate `json:"validator_updates"`
+ ConsensusParamUpdates *tmproto.ConsensusParams `json:"consensus_param_updates"`
+}
+
+func (pcp *PenumbraChainProcessor) queryCycle(ctx context.Context, persistence *queryCyclePersistence) error {
+ var err error
+ persistence.latestHeight, err = pcp.latestHeightWithRetry(ctx)
+
+ // don't want to cause CosmosChainProcessor to quit here, can retry again next cycle.
+ if err != nil {
+ pcp.log.Error(
+ "Failed to query latest height after max attempts",
+ zap.Uint("attempts", latestHeightQueryRetries),
+ zap.Error(err),
+ )
+ return nil
+ }
+
+ pcp.log.Debug("Queried latest height",
+ zap.Int64("latest_height", persistence.latestHeight),
+ )
+
+ // used at the end of the cycle to send signal to path processors to start processing if both chains are in sync and no new messages came in this cycle
+ firstTimeInSync := false
+
+ if !pcp.inSync {
+ if (persistence.latestHeight - persistence.latestQueriedBlock) < inSyncNumBlocksThreshold {
+ pcp.inSync = true
+ firstTimeInSync = true
+ pcp.log.Info("Chain is in sync")
+ } else {
+ pcp.log.Info("Chain is not yet in sync",
+ zap.Int64("latest_queried_block", persistence.latestQueriedBlock),
+ zap.Int64("latest_height", persistence.latestHeight),
+ )
+ }
+ }
+
+ ibcMessagesCache := processor.NewIBCMessagesCache()
+
+ ibcHeaderCache := make(processor.IBCHeaderCache)
+
+ ppChanged := false
+
+ var latestHeader PenumbraIBCHeader
+
+ newLatestQueriedBlock := persistence.latestQueriedBlock
+
+ chainID := pcp.chainProvider.ChainId()
+
+ for i := persistence.latestQueriedBlock + 1; i <= persistence.latestHeight; i++ {
+ var eg errgroup.Group
+ var blockRes *ctypes.ResultBlockResults
+ var ibcHeader provider.IBCHeader
+ i := i
+ eg.Go(func() (err error) {
+ queryCtx, cancelQueryCtx := context.WithTimeout(ctx, blockResultsQueryTimeout)
+ defer cancelQueryCtx()
+ blockRes, err = pcp.chainProvider.RPCClient.BlockResults(queryCtx, &i)
+ return err
+ })
+ eg.Go(func() (err error) {
+ queryCtx, cancelQueryCtx := context.WithTimeout(ctx, queryTimeout)
+ defer cancelQueryCtx()
+ ibcHeader, err = pcp.chainProvider.QueryIBCHeader(queryCtx, i)
+ return err
+ })
+
+ if err := eg.Wait(); err != nil {
+ pcp.log.Warn("Error querying block data", zap.Error(err))
+ break
+ }
+
+ latestHeader = ibcHeader.(PenumbraIBCHeader)
+
+ heightUint64 := uint64(i)
+
+ pcp.latestBlock = provider.LatestBlock{
+ Height: heightUint64,
+ Time: latestHeader.SignedHeader.Time,
+ }
+
+ ibcHeaderCache[heightUint64] = latestHeader
+ ppChanged = true
+
+ blockMsgs := pcp.ibcMessagesFromBlockEvents(blockRes.BeginBlockEvents, blockRes.EndBlockEvents, heightUint64, true)
+ for _, m := range blockMsgs {
+ pcp.handleMessage(m, ibcMessagesCache)
+ }
+
+ for _, tx := range blockRes.TxsResults {
+ if tx.Code != 0 {
+ // tx was not successful
+ continue
+ }
+ messages := ibcMessagesFromEvents(pcp.log, tx.Events, chainID, heightUint64, true)
+
+ for _, m := range messages {
+ pcp.handleMessage(m, ibcMessagesCache)
+ }
+ }
+ newLatestQueriedBlock = i
+ }
+
+ if newLatestQueriedBlock == persistence.latestQueriedBlock {
+ return nil
+ }
+
+ if !ppChanged {
+ if firstTimeInSync {
+ for _, pp := range pcp.pathProcessors {
+ pp.ProcessBacklogIfReady()
+ }
+ }
+
+ return nil
+ }
+
+ for _, pp := range pcp.pathProcessors {
+ clientID := pp.RelevantClientID(chainID)
+ clientState, err := pcp.clientState(ctx, clientID)
+ if err != nil {
+ pcp.log.Error("Error fetching client state",
+ zap.String("client_id", clientID),
+ zap.Error(err),
+ )
+ continue
+ }
+
+ pp.HandleNewData(chainID, processor.ChainProcessorCacheData{
+ LatestBlock: pcp.latestBlock,
+ LatestHeader: latestHeader,
+ IBCMessagesCache: ibcMessagesCache.Clone(),
+ InSync: pcp.inSync,
+ ClientState: clientState,
+ ConnectionStateCache: pcp.connectionStateCache.FilterForClient(clientID),
+ ChannelStateCache: pcp.channelStateCache.FilterForClient(clientID, pcp.channelConnections, pcp.connectionClients),
+ IBCHeaderCache: ibcHeaderCache.Clone(),
+ })
+ }
+
+ persistence.latestQueriedBlock = newLatestQueriedBlock
+
+ return nil
+}
diff --git a/relayer/chains/penumbra/provider.go b/relayer/chains/penumbra/provider.go
new file mode 100644
index 000000000..d0f5ccf83
--- /dev/null
+++ b/relayer/chains/penumbra/provider.go
@@ -0,0 +1,364 @@
+package penumbra
+
+import (
+ "context"
+ "fmt"
+ "io"
+ "os"
+ "path"
+ "time"
+
+ provtypes "github.com/cometbft/cometbft/light/provider"
+ prov "github.com/cometbft/cometbft/light/provider/http"
+ rpcclient "github.com/cometbft/cometbft/rpc/client"
+ rpchttp "github.com/cometbft/cometbft/rpc/client/http"
+ jsonrpcclient "github.com/cometbft/cometbft/rpc/jsonrpc/client"
+ libclient "github.com/cometbft/cometbft/rpc/jsonrpc/client"
+ tmtypes "github.com/cometbft/cometbft/types"
+ "github.com/cosmos/cosmos-sdk/crypto/keyring"
+ "github.com/cosmos/cosmos-sdk/types/module"
+ "github.com/cosmos/gogoproto/proto"
+ chantypes "github.com/cosmos/ibc-go/v7/modules/core/04-channel/types"
+ commitmenttypes "github.com/cosmos/ibc-go/v7/modules/core/23-commitment/types"
+ ibcexported "github.com/cosmos/ibc-go/v7/modules/core/exported"
+ tmclient "github.com/cosmos/ibc-go/v7/modules/light-clients/07-tendermint"
+ "github.com/cosmos/relayer/v2/relayer/codecs/ethermint"
+ "github.com/cosmos/relayer/v2/relayer/provider"
+ "go.uber.org/zap"
+ "golang.org/x/mod/semver"
+)
+
+var (
+ _ provider.ChainProvider = &PenumbraProvider{}
+ _ provider.KeyProvider = &PenumbraProvider{}
+ _ provider.ProviderConfig = &PenumbraProviderConfig{}
+)
+
+const cometEncodingThreshold = "v0.37.0-alpha"
+
+type PenumbraProviderConfig struct {
+ KeyDirectory string `json:"key-directory" yaml:"key-directory"`
+ Key string `json:"key" yaml:"key"`
+ ChainName string `json:"-" yaml:"-"`
+ ChainID string `json:"chain-id" yaml:"chain-id"`
+ RPCAddr string `json:"rpc-addr" yaml:"rpc-addr"`
+ AccountPrefix string `json:"account-prefix" yaml:"account-prefix"`
+ KeyringBackend string `json:"keyring-backend" yaml:"keyring-backend"`
+ GasAdjustment float64 `json:"gas-adjustment" yaml:"gas-adjustment"`
+ GasPrices string `json:"gas-prices" yaml:"gas-prices"`
+ MinGasAmount uint64 `json:"min-gas-amount" yaml:"min-gas-amount"`
+ MaxGasAmount uint64 `json:"max-gas-amount" yaml:"max-gas-amount"`
+ Debug bool `json:"debug" yaml:"debug"`
+ Timeout string `json:"timeout" yaml:"timeout"`
+ BlockTimeout string `json:"block-timeout" yaml:"block-timeout"`
+ OutputFormat string `json:"output-format" yaml:"output-format"`
+ SignModeStr string `json:"sign-mode" yaml:"sign-mode"`
+ ExtraCodecs []string `json:"extra-codecs" yaml:"extra-codecs"`
+ Modules []module.AppModuleBasic `json:"-" yaml:"-"`
+ Slip44 int `json:"coin-type" yaml:"coin-type"`
+ Broadcast provider.BroadcastMode `json:"broadcast-mode" yaml:"broadcast-mode"`
+ MinLoopDuration time.Duration `json:"min-loop-duration" yaml:"min-loop-duration"`
+ ExtensionOptions []provider.ExtensionOption `json:"extension-options" yaml:"extension-options"`
+}
+
+func (pc PenumbraProviderConfig) Validate() error {
+ if _, err := time.ParseDuration(pc.Timeout); err != nil {
+ return fmt.Errorf("invalid Timeout: %w", err)
+ }
+ return nil
+}
+
+func (pc PenumbraProviderConfig) GetBlockInterval() uint64 {
+ panic("Not implemented for Penumbra")
+}
+
+func (pc PenumbraProviderConfig) GetFirstRetryBlockAfter() uint64 {
+ return 1
+}
+
+func (pc PenumbraProviderConfig) BroadcastMode() provider.BroadcastMode {
+ return pc.Broadcast
+}
+
+// NewProvider validates the PenumbraProviderConfig, instantiates a ChainClient and then instantiates a CosmosProvider
+func (pc PenumbraProviderConfig) NewProvider(log *zap.Logger, homepath string, debug bool, chainName string) (provider.ChainProvider, error) {
+ if err := pc.Validate(); err != nil {
+ return nil, err
+ }
+
+ pc.KeyDirectory = keysDir(homepath, pc.ChainID)
+
+ pc.ChainName = chainName
+ pc.Modules = append([]module.AppModuleBasic{}, moduleBasics...)
+
+ if pc.Broadcast == "" {
+ pc.Broadcast = provider.BroadcastModeBatch
+ }
+
+ httpClient, err := jsonrpcclient.DefaultHTTPClient(pc.RPCAddr)
+ if err != nil {
+ return nil, err
+ }
+
+ rc, err := jsonrpcclient.NewWithHTTPClient(pc.RPCAddr, httpClient)
+ if err != nil {
+ return nil, err
+ }
+
+ return &PenumbraProvider{
+ log: log,
+ PCfg: pc,
+ KeyringOptions: []keyring.Option{ethermint.EthSecp256k1Option()},
+ Input: os.Stdin,
+ Output: os.Stdout,
+
+ // TODO: this is a bit of a hack, we should probably have a better way to inject modules
+ Codec: makeCodec(pc.Modules, pc.ExtraCodecs),
+ RPCCaller: rc,
+ }, nil
+}
+
+type PenumbraIBCHeader struct {
+ SignedHeader *tmtypes.SignedHeader
+ ValidatorSet *tmtypes.ValidatorSet
+}
+
+func (h PenumbraIBCHeader) Height() uint64 {
+ return uint64(h.SignedHeader.Height)
+}
+
+func (h PenumbraIBCHeader) ConsensusState() ibcexported.ConsensusState {
+ return &tmclient.ConsensusState{
+ Timestamp: h.SignedHeader.Time,
+ Root: commitmenttypes.NewMerkleRoot(h.SignedHeader.AppHash),
+ NextValidatorsHash: h.ValidatorSet.Hash(),
+ }
+}
+
+func (h PenumbraIBCHeader) NextValidatorsHash() []byte {
+ return h.SignedHeader.NextValidatorsHash
+}
+
+func (h PenumbraIBCHeader) IsCompleteBlock() bool {
+ return true
+}
+
+func (h PenumbraIBCHeader) ShouldUpdateWithZeroMessage() bool {
+ return false
+}
+
+type PenumbraProvider struct {
+ log *zap.Logger
+
+ PCfg PenumbraProviderConfig
+ Keybase keyring.Keyring
+ KeyringOptions []keyring.Option
+ RPCClient rpcclient.Client
+ LightProvider provtypes.Provider
+ Input io.Reader
+ Output io.Writer
+ Codec Codec
+ RPCCaller jsonrpcclient.Caller
+
+ // for comet < v0.37, decode tm events as base64
+ cometLegacyEncoding bool
+}
+
+func (cc *PenumbraProvider) ProviderConfig() provider.ProviderConfig {
+ return cc.PCfg
+}
+
+func (cc *PenumbraProvider) ChainId() string {
+ return cc.PCfg.ChainID
+}
+
+func (cc *PenumbraProvider) ChainName() string {
+ return cc.PCfg.ChainName
+}
+
+func (cc *PenumbraProvider) Type() string {
+ return "penumbra"
+}
+
+func (cc *PenumbraProvider) Key() string {
+ return cc.PCfg.Key
+}
+
+func (cc *PenumbraProvider) Timeout() string {
+ return cc.PCfg.Timeout
+}
+
+func (cc *PenumbraProvider) CommitmentPrefix() commitmenttypes.MerklePrefix {
+ return commitmenttypes.NewMerklePrefix([]byte("PenumbraAppHash"))
+}
+
+// Address returns the chains configured address as a string
+func (cc *PenumbraProvider) Address() (string, error) {
+ info, err := cc.Keybase.Key(cc.PCfg.Key)
+ if err != nil {
+ return "", err
+ }
+
+ acc, err := info.GetAddress()
+ if err != nil {
+ return "", err
+ }
+
+ out, err := cc.EncodeBech32AccAddr(acc)
+ if err != nil {
+ return "", err
+ }
+
+ return out, err
+}
+
+func (cc *PenumbraProvider) TrustingPeriod(ctx context.Context) (time.Duration, error) {
+ // TODO
+ return time.Hour * 2, nil
+ /*
+ res, err := cc.QueryStakingParams(ctx)
+ if err != nil {
+ return 0, err
+ }
+
+ // We want the trusting period to be 85% of the unbonding time.
+ // Go mentions that the time.Duration type can track approximately 290 years.
+ // We don't want to lose precision if the duration is a very long duration
+ // by converting int64 to float64.
+ // Use integer math the whole time, first reducing by a factor of 100
+ // and then re-growing by 85x.
+ tp := res.UnbondingTime / 100 * 85
+
+ // And we only want the trusting period to be whole hours.
+ return tp.Truncate(time.Hour), nil
+ */
+}
+
+// Sprint returns the json representation of the specified proto message.
+func (cc *PenumbraProvider) Sprint(toPrint proto.Message) (string, error) {
+ out, err := cc.Codec.Marshaler.MarshalJSON(toPrint)
+ if err != nil {
+ return "", err
+ }
+ return string(out), nil
+}
+
+// Init initializes the keystore, RPC client, amd light client provider.
+// Once initialization is complete an attempt to query the underlying node's tendermint version is performed.
+// NOTE: Init must be called after creating a new instance of CosmosProvider.
+func (cc *PenumbraProvider) Init(ctx context.Context) error {
+ keybase, err := keyring.New(cc.PCfg.ChainID, cc.PCfg.KeyringBackend, cc.PCfg.KeyDirectory, cc.Input, cc.Codec.Marshaler, cc.KeyringOptions...)
+ if err != nil {
+ return err
+ }
+ // TODO: figure out how to deal with input or maybe just make all keyring backends test?
+
+ timeout, err := time.ParseDuration(cc.PCfg.Timeout)
+ if err != nil {
+ return err
+ }
+
+ rpcClient, err := newRPCClient(cc.PCfg.RPCAddr, timeout)
+ if err != nil {
+ return err
+ }
+
+ lightprovider, err := prov.New(cc.PCfg.ChainID, cc.PCfg.RPCAddr)
+ if err != nil {
+ return err
+ }
+
+ cc.RPCClient = rpcClient
+ cc.LightProvider = lightprovider
+ cc.Keybase = keybase
+
+ status, err := cc.QueryStatus(ctx)
+ if err != nil {
+ // Operations can occur before the node URL is added to the config, so noop here.
+ return nil
+ }
+
+ cc.setCometVersion(cc.log, status.NodeInfo.Version)
+
+ return nil
+}
+
+// WaitForNBlocks blocks until the next block on a given chain
+func (cc *PenumbraProvider) WaitForNBlocks(ctx context.Context, n int64) error {
+ var initial int64
+ h, err := cc.RPCClient.Status(ctx)
+ if err != nil {
+ return err
+ }
+ if h.SyncInfo.CatchingUp {
+ return fmt.Errorf("chain catching up")
+ }
+ initial = h.SyncInfo.LatestBlockHeight
+ for {
+ h, err = cc.RPCClient.Status(ctx)
+ if err != nil {
+ return err
+ }
+ if h.SyncInfo.LatestBlockHeight > initial+n {
+ return nil
+ }
+ select {
+ case <-time.After(10 * time.Millisecond):
+ // Nothing to do.
+ case <-ctx.Done():
+ return ctx.Err()
+ }
+ }
+}
+
+func (cc *PenumbraProvider) BlockTime(ctx context.Context, height int64) (time.Time, error) {
+ resultBlock, err := cc.RPCClient.Block(ctx, &height)
+ if err != nil {
+ return time.Time{}, err
+ }
+ return resultBlock.Block.Time, nil
+}
+
+func toPenumbraPacket(pi provider.PacketInfo) chantypes.Packet {
+ return chantypes.Packet{
+ Sequence: pi.Sequence,
+ SourcePort: pi.SourcePort,
+ SourceChannel: pi.SourceChannel,
+ DestinationPort: pi.DestPort,
+ DestinationChannel: pi.DestChannel,
+ Data: pi.Data,
+ TimeoutHeight: pi.TimeoutHeight,
+ TimeoutTimestamp: pi.TimeoutTimestamp,
+ }
+}
+
+func (cc *PenumbraProvider) setCometVersion(log *zap.Logger, version string) {
+ cc.cometLegacyEncoding = cc.legacyEncodedEvents(log, version)
+}
+
+func (cc *PenumbraProvider) legacyEncodedEvents(log *zap.Logger, version string) bool {
+ return semver.Compare("v"+version, cometEncodingThreshold) < 0
+}
+
+func (cc *PenumbraProvider) FirstRetryBlockAfter() uint64 {
+ return 1
+}
+
+// keysDir returns a string representing the path on the local filesystem where the keystore will be initialized.
+func keysDir(home, chainID string) string {
+ return path.Join(home, "keys", chainID)
+}
+
+// newRPCClient initializes a new tendermint RPC client connected to the specified address.
+func newRPCClient(addr string, timeout time.Duration) (*rpchttp.HTTP, error) {
+ httpClient, err := libclient.DefaultHTTPClient(addr)
+ if err != nil {
+ return nil, err
+ }
+ httpClient.Timeout = timeout
+ rpcClient, err := rpchttp.NewWithClient(addr, "/websocket", httpClient)
+ if err != nil {
+ return nil, err
+ }
+ return rpcClient, nil
+}
diff --git a/relayer/chains/penumbra/query.go b/relayer/chains/penumbra/query.go
new file mode 100644
index 000000000..3e6c69192
--- /dev/null
+++ b/relayer/chains/penumbra/query.go
@@ -0,0 +1,1013 @@
+package penumbra
+
+import (
+ "context"
+ "encoding/binary"
+ "encoding/hex"
+ "errors"
+ "fmt"
+ "strings"
+ "time"
+
+ abci "github.com/cometbft/cometbft/abci/types"
+ coretypes "github.com/cometbft/cometbft/rpc/core/types"
+ tmtypes "github.com/cometbft/cometbft/types"
+ "github.com/cosmos/cosmos-sdk/codec"
+ sdk "github.com/cosmos/cosmos-sdk/types"
+ sdkerrors "github.com/cosmos/cosmos-sdk/types/errors"
+ querytypes "github.com/cosmos/cosmos-sdk/types/query"
+ bankTypes "github.com/cosmos/cosmos-sdk/x/bank/types"
+ stakingtypes "github.com/cosmos/cosmos-sdk/x/staking/types"
+ upgradetypes "github.com/cosmos/cosmos-sdk/x/upgrade/types"
+ transfertypes "github.com/cosmos/ibc-go/v7/modules/apps/transfer/types"
+ clienttypes "github.com/cosmos/ibc-go/v7/modules/core/02-client/types"
+ conntypes "github.com/cosmos/ibc-go/v7/modules/core/03-connection/types"
+ chantypes "github.com/cosmos/ibc-go/v7/modules/core/04-channel/types"
+ commitmenttypes "github.com/cosmos/ibc-go/v7/modules/core/23-commitment/types"
+ host "github.com/cosmos/ibc-go/v7/modules/core/24-host"
+ "github.com/cosmos/ibc-go/v7/modules/core/exported"
+ ibcexported "github.com/cosmos/ibc-go/v7/modules/core/exported"
+ tmclient "github.com/cosmos/ibc-go/v7/modules/light-clients/07-tendermint"
+ "github.com/cosmos/relayer/v2/relayer/provider"
+ "go.uber.org/zap"
+ "golang.org/x/sync/errgroup"
+)
+
+var _ provider.QueryProvider = &PenumbraProvider{}
+
+// QueryTx takes a transaction hash and returns the transaction
+func (cc *PenumbraProvider) QueryTx(ctx context.Context, hashHex string) (*provider.RelayerTxResponse, error) {
+ hash, err := hex.DecodeString(hashHex)
+ if err != nil {
+ return nil, err
+ }
+
+ resp, err := cc.RPCClient.Tx(ctx, hash, true)
+ if err != nil {
+ return nil, err
+ }
+
+ events := parseEventsFromResponseDeliverTx(resp.TxResult)
+
+ return &provider.RelayerTxResponse{
+ Height: resp.Height,
+ TxHash: string(hash),
+ Code: resp.TxResult.Code,
+ Data: string(resp.TxResult.Data),
+ Events: events,
+ }, nil
+}
+
+// QueryTxs returns an array of transactions given a tag
+func (cc *PenumbraProvider) QueryTxs(ctx context.Context, page, limit int, events []string) ([]*provider.RelayerTxResponse, error) {
+ if len(events) == 0 {
+ return nil, errors.New("must declare at least one event to search")
+ }
+
+ if page <= 0 {
+ return nil, errors.New("page must greater than 0")
+ }
+
+ if limit <= 0 {
+ return nil, errors.New("limit must greater than 0")
+ }
+
+ res, err := cc.RPCClient.TxSearch(ctx, strings.Join(events, " AND "), true, &page, &limit, "")
+ if err != nil {
+ return nil, err
+ }
+
+ // Currently, we only call QueryTxs() in two spots and in both of them we are expecting there to only be,
+ // at most, one tx in the response. Because of this we don't want to initialize the slice with an initial size.
+ var txResps []*provider.RelayerTxResponse
+ for _, tx := range res.Txs {
+ relayerEvents := parseEventsFromResponseDeliverTx(tx.TxResult)
+ txResps = append(txResps, &provider.RelayerTxResponse{
+ Height: tx.Height,
+ TxHash: string(tx.Hash),
+ Code: tx.TxResult.Code,
+ Data: string(tx.TxResult.Data),
+ Events: relayerEvents,
+ })
+ }
+ return txResps, nil
+}
+
+// parseEventsFromResponseDeliverTx parses the events from a ResponseDeliverTx and builds a slice
+// of provider.RelayerEvent's.
+func parseEventsFromResponseDeliverTx(resp abci.ResponseDeliverTx) []provider.RelayerEvent {
+ var events []provider.RelayerEvent
+
+ for _, event := range resp.Events {
+ attributes := make(map[string]string)
+ for _, attribute := range event.Attributes {
+ attributes[string(attribute.Key)] = string(attribute.Value)
+ }
+ events = append(events, provider.RelayerEvent{
+ EventType: event.Type,
+ Attributes: attributes,
+ })
+ }
+ return events
+}
+
+// QueryBalance returns the amount of coins in the relayer account
+func (cc *PenumbraProvider) QueryBalance(ctx context.Context, keyName string) (sdk.Coins, error) {
+ addr, err := cc.ShowAddress(keyName)
+ if err != nil {
+ return nil, err
+ }
+
+ return cc.QueryBalanceWithAddress(ctx, addr)
+}
+
+// QueryBalanceWithAddress returns the amount of coins in the relayer account with address as input
+// TODO add pagination support
+func (cc *PenumbraProvider) QueryBalanceWithAddress(ctx context.Context, address string) (sdk.Coins, error) {
+ p := &bankTypes.QueryAllBalancesRequest{Address: address, Pagination: DefaultPageRequest()}
+ queryClient := bankTypes.NewQueryClient(cc)
+
+ res, err := queryClient.AllBalances(ctx, p)
+ if err != nil {
+ return nil, err
+ }
+
+ return res.Balances, nil
+}
+
+// QueryUnbondingPeriod returns the unbonding period of the chain
+func (cc *PenumbraProvider) QueryUnbondingPeriod(ctx context.Context) (time.Duration, error) {
+ // TODO:
+ return time.Hour * 4, nil
+ /*
+ req := stakingtypes.QueryParamsRequest{}
+ queryClient := stakingtypes.NewQueryClient(cc)
+
+ res, err := queryClient.Params(ctx, &req)
+ if err != nil {
+ return 0, err
+ }
+
+ return res.Params.UnbondingTime, nil
+ */
+}
+
+// QueryTendermintProof performs an ABCI query with the given key and returns
+// the value of the query, the proto encoded merkle proof, and the height of
+// the Tendermint block containing the state root. The desired tendermint height
+// to perform the query should be set in the client context. The query will be
+// performed at one below this height (at the IAVL version) in order to obtain
+// the correct merkle proof. Proof queries at height less than or equal to 2 are
+// not supported. Queries with a client context height of 0 will perform a query
+// at the latest state available.
+// Issue: https://github.com/cosmos/cosmos-sdk/issues/6567
+func (cc *PenumbraProvider) QueryTendermintProof(ctx context.Context, height int64, key []byte) ([]byte, []byte, clienttypes.Height, error) {
+ // ABCI queries at heights 1, 2 or less than or equal to 0 are not supported.
+ // Base app does not support queries for height less than or equal to 1.
+ // Therefore, a query at height 2 would be equivalent to a query at height 3.
+ // A height of 0 will query with the lastest state.
+ if height != 0 && height <= 2 {
+ return nil, nil, clienttypes.Height{}, fmt.Errorf("proof queries at height <= 2 are not supported")
+ }
+
+ if height != 0 {
+ height--
+ }
+
+ cc.log.Debug("Querying K/V", zap.String("ChainId", cc.ChainId()), zap.Int64("Height", height), zap.String("Key", string(key)))
+ req := abci.RequestQuery{
+ Path: "state/key",
+ Height: height,
+ Data: key,
+ Prove: true,
+ }
+
+ res, err := cc.QueryABCI(ctx, req)
+ if err != nil {
+ return nil, nil, clienttypes.Height{}, err
+ }
+
+ merkleProof, err := commitmenttypes.ConvertProofs(res.ProofOps)
+ if err != nil {
+ return nil, nil, clienttypes.Height{}, err
+ }
+
+ cdc := codec.NewProtoCodec(cc.Codec.InterfaceRegistry)
+
+ proofBz, err := cdc.Marshal(&merkleProof)
+ if err != nil {
+ return nil, nil, clienttypes.Height{}, err
+ }
+
+ revision := clienttypes.ParseChainID(cc.PCfg.ChainID)
+ return res.Value, proofBz, clienttypes.NewHeight(revision, uint64(res.Height)+1), nil
+}
+
+// QueryClientStateResponse retrieves the latest consensus state for a client in state at a given height
+func (cc *PenumbraProvider) QueryClientStateResponse(ctx context.Context, height int64, srcClientId string) (*clienttypes.QueryClientStateResponse, error) {
+ key := host.FullClientStateKey(srcClientId)
+
+ value, proofBz, proofHeight, err := cc.QueryTendermintProof(ctx, height, key)
+ if err != nil {
+ return nil, err
+ }
+
+ // check if client exists
+ if len(value) == 0 {
+ return nil, sdkerrors.Wrap(clienttypes.ErrClientNotFound, srcClientId)
+ }
+
+ cdc := codec.NewProtoCodec(cc.Codec.InterfaceRegistry)
+
+ clientState, err := clienttypes.UnmarshalClientState(cdc, value)
+ if err != nil {
+ return nil, err
+ }
+ cc.log.Debug("QueryClientStateResponse", zap.Int64("Height", height), zap.Any("proofHeight", proofHeight), zap.String("Key", string(key)), zap.Any("ClientState", clientState))
+
+ anyClientState, err := clienttypes.PackClientState(clientState)
+ if err != nil {
+ return nil, err
+ }
+
+ return &clienttypes.QueryClientStateResponse{
+ ClientState: anyClientState,
+ Proof: proofBz,
+ ProofHeight: proofHeight,
+ }, nil
+}
+
+// QueryClientState retrieves the latest consensus state for a client in state at a given height
+// and unpacks it to exported client state interface
+func (cc *PenumbraProvider) QueryClientState(ctx context.Context, height int64, clientid string) (ibcexported.ClientState, error) {
+ clientStateRes, err := cc.QueryClientStateResponse(ctx, height, clientid)
+ if err != nil {
+ return nil, err
+ }
+
+ clientStateExported, err := clienttypes.UnpackClientState(clientStateRes.ClientState)
+ if err != nil {
+ return nil, err
+ }
+
+ return clientStateExported, nil
+}
+
+// QueryClientConsensusState retrieves the latest consensus state for a client in state at a given height
+func (cc *PenumbraProvider) QueryClientConsensusState(ctx context.Context, chainHeight int64, clientid string, clientHeight ibcexported.Height) (*clienttypes.QueryConsensusStateResponse, error) {
+ key := host.FullConsensusStateKey(clientid, clientHeight)
+
+ value, proofBz, proofHeight, err := cc.QueryTendermintProof(ctx, chainHeight, key)
+ if err != nil {
+ return nil, err
+ }
+
+ // check if consensus state exists
+ if len(value) == 0 {
+ return nil, sdkerrors.Wrap(clienttypes.ErrConsensusStateNotFound, clientid)
+ }
+
+ cdc := codec.NewProtoCodec(cc.Codec.InterfaceRegistry)
+
+ cs, err := clienttypes.UnmarshalConsensusState(cdc, value)
+ if err != nil {
+ return nil, err
+ }
+
+ anyConsensusState, err := clienttypes.PackConsensusState(cs)
+ if err != nil {
+ return nil, err
+ }
+
+ return &clienttypes.QueryConsensusStateResponse{
+ ConsensusState: anyConsensusState,
+ Proof: proofBz,
+ ProofHeight: proofHeight,
+ }, nil
+}
+
+// QueryUpgradeProof performs an abci query with the given key and returns the proto encoded merkle proof
+// for the query and the height at which the proof will succeed on a tendermint verifier.
+func (cc *PenumbraProvider) QueryUpgradeProof(ctx context.Context, key []byte, height uint64) ([]byte, clienttypes.Height, error) {
+ res, err := cc.QueryABCI(ctx, abci.RequestQuery{
+ Path: "state/key",
+ Height: int64(height - 1),
+ Data: key,
+ Prove: true,
+ })
+ if err != nil {
+ return nil, clienttypes.Height{}, err
+ }
+
+ merkleProof, err := commitmenttypes.ConvertProofs(res.ProofOps)
+ if err != nil {
+ return nil, clienttypes.Height{}, err
+ }
+
+ proof, err := cc.Codec.Marshaler.Marshal(&merkleProof)
+ if err != nil {
+ return nil, clienttypes.Height{}, err
+ }
+
+ revision := clienttypes.ParseChainID(cc.PCfg.ChainID)
+
+ // proof height + 1 is returned as the proof created corresponds to the height the proof
+ // was created in the IAVL tree. Tendermint and subsequently the clients that rely on it
+ // have heights 1 above the IAVL tree. Thus we return proof height + 1
+ return proof, clienttypes.Height{
+ RevisionNumber: revision,
+ RevisionHeight: uint64(res.Height + 1),
+ }, nil
+}
+
+// QueryUpgradedClient returns upgraded client info
+func (cc *PenumbraProvider) QueryUpgradedClient(ctx context.Context, height int64) (*clienttypes.QueryClientStateResponse, error) {
+ req := clienttypes.QueryUpgradedClientStateRequest{}
+
+ queryClient := clienttypes.NewQueryClient(cc)
+
+ res, err := queryClient.UpgradedClientState(ctx, &req)
+ if err != nil {
+ return nil, err
+ }
+
+ if res == nil || res.UpgradedClientState == nil {
+ return nil, fmt.Errorf("upgraded client state plan does not exist at height %d", height)
+ }
+
+ proof, proofHeight, err := cc.QueryUpgradeProof(ctx, upgradetypes.UpgradedClientKey(height), uint64(height))
+ if err != nil {
+ return nil, err
+ }
+
+ return &clienttypes.QueryClientStateResponse{
+ ClientState: res.UpgradedClientState,
+ Proof: proof,
+ ProofHeight: proofHeight,
+ }, nil
+}
+
+// QueryUpgradedConsState returns upgraded consensus state and height of client
+func (cc *PenumbraProvider) QueryUpgradedConsState(ctx context.Context, height int64) (*clienttypes.QueryConsensusStateResponse, error) {
+ req := clienttypes.QueryUpgradedConsensusStateRequest{}
+
+ queryClient := clienttypes.NewQueryClient(cc)
+
+ res, err := queryClient.UpgradedConsensusState(ctx, &req)
+ if err != nil {
+ return nil, err
+ }
+
+ if res == nil || res.UpgradedConsensusState == nil {
+ return nil, fmt.Errorf("upgraded consensus state plan does not exist at height %d", height)
+ }
+
+ proof, proofHeight, err := cc.QueryUpgradeProof(ctx, upgradetypes.UpgradedConsStateKey(height), uint64(height))
+ if err != nil {
+ return nil, err
+ }
+
+ return &clienttypes.QueryConsensusStateResponse{
+ ConsensusState: res.UpgradedConsensusState,
+ Proof: proof,
+ ProofHeight: proofHeight,
+ }, nil
+}
+
+// QueryConsensusState returns a consensus state for a given chain to be used as a
+// client in another chain, fetches latest height when passed 0 as arg
+func (cc *PenumbraProvider) QueryConsensusState(ctx context.Context, height int64) (ibcexported.ConsensusState, int64, error) {
+ commit, err := cc.RPCClient.Commit(ctx, &height)
+ if err != nil {
+ return &tmclient.ConsensusState{}, 0, err
+ }
+
+ page := 1
+ count := 10_000
+
+ nextHeight := height + 1
+ nextVals, err := cc.RPCClient.Validators(ctx, &nextHeight, &page, &count)
+ if err != nil {
+ return &tmclient.ConsensusState{}, 0, err
+ }
+
+ state := &tmclient.ConsensusState{
+ Timestamp: commit.Time,
+ Root: commitmenttypes.NewMerkleRoot(commit.AppHash),
+ NextValidatorsHash: tmtypes.NewValidatorSet(nextVals.Validators).Hash(),
+ }
+
+ return state, height, nil
+}
+
+// QueryClients queries all the clients!
+// TODO add pagination support
+func (cc *PenumbraProvider) QueryClients(ctx context.Context) (clienttypes.IdentifiedClientStates, error) {
+ qc := clienttypes.NewQueryClient(cc)
+ state, err := qc.ClientStates(ctx, &clienttypes.QueryClientStatesRequest{
+ Pagination: DefaultPageRequest(),
+ })
+ if err != nil {
+ return nil, err
+ }
+ return state.ClientStates, nil
+}
+
+// QueryConnection returns the remote end of a given connection
+func (cc *PenumbraProvider) QueryConnection(ctx context.Context, height int64, connectionid string) (*conntypes.QueryConnectionResponse, error) {
+ res, err := cc.queryConnectionABCI(ctx, height, connectionid)
+ if err != nil && strings.Contains(err.Error(), "not found") {
+ return &conntypes.QueryConnectionResponse{
+ Connection: &conntypes.ConnectionEnd{
+ ClientId: "client",
+ Versions: []*conntypes.Version{},
+ State: conntypes.UNINITIALIZED,
+ Counterparty: conntypes.Counterparty{
+ ClientId: "client",
+ ConnectionId: "connection",
+ Prefix: commitmenttypes.MerklePrefix{KeyPrefix: []byte{}},
+ },
+ DelayPeriod: 0,
+ },
+ Proof: []byte{},
+ ProofHeight: clienttypes.Height{RevisionNumber: 0, RevisionHeight: 0},
+ }, nil
+ } else if err != nil {
+ return nil, err
+ }
+ return res, nil
+}
+
+func (cc *PenumbraProvider) queryConnectionABCI(ctx context.Context, height int64, connectionID string) (*conntypes.QueryConnectionResponse, error) {
+ key := host.ConnectionKey(connectionID)
+
+ value, proofBz, proofHeight, err := cc.QueryTendermintProof(ctx, height, key)
+ if err != nil {
+ return nil, err
+ }
+
+ // check if connection exists
+ if len(value) == 0 {
+ return nil, sdkerrors.Wrap(conntypes.ErrConnectionNotFound, connectionID)
+ }
+
+ cdc := codec.NewProtoCodec(cc.Codec.InterfaceRegistry)
+
+ var connection conntypes.ConnectionEnd
+ if err := cdc.Unmarshal(value, &connection); err != nil {
+ return nil, err
+ }
+
+ return &conntypes.QueryConnectionResponse{
+ Connection: &connection,
+ Proof: proofBz,
+ ProofHeight: proofHeight,
+ }, nil
+}
+
+// QueryConnections gets any connections on a chain
+// TODO add pagination support
+func (cc *PenumbraProvider) QueryConnections(ctx context.Context) (conns []*conntypes.IdentifiedConnection, err error) {
+ qc := conntypes.NewQueryClient(cc)
+ res, err := qc.Connections(ctx, &conntypes.QueryConnectionsRequest{
+ Pagination: DefaultPageRequest(),
+ })
+ if err != nil || res == nil {
+ return nil, err
+ }
+ return res.Connections, err
+}
+
+// QueryConnectionsUsingClient gets any connections that exist between chain and counterparty
+// TODO add pagination support
+func (cc *PenumbraProvider) QueryConnectionsUsingClient(ctx context.Context, height int64, clientid string) (*conntypes.QueryConnectionsResponse, error) {
+ qc := conntypes.NewQueryClient(cc)
+ res, err := qc.Connections(ctx, &conntypes.QueryConnectionsRequest{
+ Pagination: DefaultPageRequest(),
+ })
+ return res, err
+}
+
+// GenerateConnHandshakeProof generates all the proofs needed to prove the existence of the
+// connection state on this chain. A counterparty should use these generated proofs.
+func (cc *PenumbraProvider) GenerateConnHandshakeProof(ctx context.Context, height int64, clientId, connId string) (clientState ibcexported.ClientState, clientStateProof []byte, consensusProof []byte, connectionProof []byte, connectionProofHeight ibcexported.Height, err error) {
+ var (
+ clientStateRes *clienttypes.QueryClientStateResponse
+ consensusStateRes *clienttypes.QueryConsensusStateResponse
+ connectionStateRes *conntypes.QueryConnectionResponse
+ eg = new(errgroup.Group)
+ )
+
+ // query for the client state for the proof and get the height to query the consensus state at.
+ clientStateRes, err = cc.QueryClientStateResponse(ctx, height, clientId)
+ if err != nil {
+ return nil, nil, nil, nil, clienttypes.Height{}, err
+ }
+
+ clientState, err = clienttypes.UnpackClientState(clientStateRes.ClientState)
+ if err != nil {
+ return nil, nil, nil, nil, clienttypes.Height{}, err
+ }
+
+ eg.Go(func() error {
+ var err error
+ consensusStateRes, err = cc.QueryClientConsensusState(ctx, height, clientId, clientState.GetLatestHeight())
+ return err
+ })
+ eg.Go(func() error {
+ var err error
+ connectionStateRes, err = cc.QueryConnection(ctx, height, connId)
+ return err
+ })
+
+ if err := eg.Wait(); err != nil {
+ return nil, nil, nil, nil, clienttypes.Height{}, err
+ }
+ cc.log.Debug("GenerateConnHandshakeProof", zap.Int64("height", height), zap.Any("connId", connId), zap.Any("connectionStateRes", connectionStateRes))
+
+ return clientState, clientStateRes.Proof, consensusStateRes.Proof, connectionStateRes.Proof, connectionStateRes.ProofHeight, nil
+}
+
+// QueryChannel returns the channel associated with a channelID
+func (cc *PenumbraProvider) QueryChannel(ctx context.Context, height int64, channelid, portid string) (chanRes *chantypes.QueryChannelResponse, err error) {
+ res, err := cc.queryChannelABCI(ctx, height, portid, channelid)
+ if err != nil && strings.Contains(err.Error(), "not found") {
+
+ return &chantypes.QueryChannelResponse{
+ Channel: &chantypes.Channel{
+ State: chantypes.UNINITIALIZED,
+ Ordering: chantypes.UNORDERED,
+ Counterparty: chantypes.Counterparty{
+ PortId: "port",
+ ChannelId: "channel",
+ },
+ ConnectionHops: []string{},
+ Version: "version",
+ },
+ Proof: []byte{},
+ ProofHeight: clienttypes.Height{
+ RevisionNumber: 0,
+ RevisionHeight: 0,
+ },
+ }, nil
+ } else if err != nil {
+ return nil, err
+ }
+ return res, nil
+}
+
+func (cc *PenumbraProvider) queryChannelABCI(ctx context.Context, height int64, portID, channelID string) (*chantypes.QueryChannelResponse, error) {
+ key := host.ChannelKey(portID, channelID)
+
+ value, proofBz, proofHeight, err := cc.QueryTendermintProof(ctx, height, key)
+ if err != nil {
+ return nil, err
+ }
+
+ // check if channel exists
+ if len(value) == 0 {
+ return nil, sdkerrors.Wrapf(chantypes.ErrChannelNotFound, "portID (%s), channelID (%s)", portID, channelID)
+ }
+
+ cdc := codec.NewProtoCodec(cc.Codec.InterfaceRegistry)
+
+ var channel chantypes.Channel
+ if err := cdc.Unmarshal(value, &channel); err != nil {
+ return nil, err
+ }
+
+ return &chantypes.QueryChannelResponse{
+ Channel: &channel,
+ Proof: proofBz,
+ ProofHeight: proofHeight,
+ }, nil
+}
+
+// QueryChannelClient returns the client state of the client supporting a given channel
+func (cc *PenumbraProvider) QueryChannelClient(ctx context.Context, height int64, channelid, portid string) (*clienttypes.IdentifiedClientState, error) {
+ qc := chantypes.NewQueryClient(cc)
+ cState, err := qc.ChannelClientState(ctx, &chantypes.QueryChannelClientStateRequest{
+ PortId: portid,
+ ChannelId: channelid,
+ })
+ if err != nil {
+ return nil, err
+ }
+ return cState.IdentifiedClientState, nil
+}
+
+// QueryConnectionChannels queries the channels associated with a connection
+func (cc *PenumbraProvider) QueryConnectionChannels(ctx context.Context, height int64, connectionid string) ([]*chantypes.IdentifiedChannel, error) {
+ qc := chantypes.NewQueryClient(cc)
+ chans, err := qc.ConnectionChannels(ctx, &chantypes.QueryConnectionChannelsRequest{
+ Connection: connectionid,
+ Pagination: DefaultPageRequest(),
+ })
+ if err != nil {
+ return nil, err
+ }
+ return chans.Channels, nil
+}
+
+// QueryChannels returns all the channels that are registered on a chain
+// TODO add pagination support
+func (cc *PenumbraProvider) QueryChannels(ctx context.Context) ([]*chantypes.IdentifiedChannel, error) {
+ qc := chantypes.NewQueryClient(cc)
+ res, err := qc.Channels(ctx, &chantypes.QueryChannelsRequest{
+ Pagination: DefaultPageRequest(),
+ })
+ if err != nil {
+ return nil, err
+ }
+ return res.Channels, nil
+}
+
+// QueryPacketCommitments returns an array of packet commitments
+// TODO add pagination support
+func (cc *PenumbraProvider) QueryPacketCommitments(ctx context.Context, height uint64, channelid, portid string) (commitments *chantypes.QueryPacketCommitmentsResponse, err error) {
+ qc := chantypes.NewQueryClient(cc)
+ c, err := qc.PacketCommitments(ctx, &chantypes.QueryPacketCommitmentsRequest{
+ PortId: portid,
+ ChannelId: channelid,
+ Pagination: DefaultPageRequest(),
+ })
+ if err != nil {
+ return nil, err
+ }
+ return c, nil
+}
+
+// QueryPacketAcknowledgements returns an array of packet acks
+// TODO add pagination support
+func (cc *PenumbraProvider) QueryPacketAcknowledgements(ctx context.Context, height uint64, channelid, portid string) (acknowledgements []*chantypes.PacketState, err error) {
+ qc := chantypes.NewQueryClient(cc)
+ acks, err := qc.PacketAcknowledgements(ctx, &chantypes.QueryPacketAcknowledgementsRequest{
+ PortId: portid,
+ ChannelId: channelid,
+ Pagination: DefaultPageRequest(),
+ })
+ if err != nil {
+ return nil, err
+ }
+ return acks.Acknowledgements, nil
+}
+
+// QueryUnreceivedPackets returns a list of unrelayed packet commitments
+func (cc *PenumbraProvider) QueryUnreceivedPackets(ctx context.Context, height uint64, channelid, portid string, seqs []uint64) ([]uint64, error) {
+ qc := chantypes.NewQueryClient(cc)
+ res, err := qc.UnreceivedPackets(ctx, &chantypes.QueryUnreceivedPacketsRequest{
+ PortId: portid,
+ ChannelId: channelid,
+ PacketCommitmentSequences: seqs,
+ })
+ if err != nil {
+ return nil, err
+ }
+ return res.Sequences, nil
+}
+
+// QueryUnreceivedAcknowledgements returns a list of unrelayed packet acks
+func (cc *PenumbraProvider) QueryUnreceivedAcknowledgements(ctx context.Context, height uint64, channelid, portid string, seqs []uint64) ([]uint64, error) {
+ qc := chantypes.NewQueryClient(cc)
+ res, err := qc.UnreceivedAcks(ctx, &chantypes.QueryUnreceivedAcksRequest{
+ PortId: portid,
+ ChannelId: channelid,
+ PacketAckSequences: seqs,
+ })
+ if err != nil {
+ return nil, err
+ }
+ return res.Sequences, nil
+}
+
+// QueryNextSeqRecv returns the next seqRecv for a configured channel
+func (cc *PenumbraProvider) QueryNextSeqRecv(ctx context.Context, height int64, channelid, portid string) (recvRes *chantypes.QueryNextSequenceReceiveResponse, err error) {
+ key := host.NextSequenceRecvKey(portid, channelid)
+
+ value, proofBz, proofHeight, err := cc.QueryTendermintProof(ctx, height, key)
+ if err != nil {
+ return nil, err
+ }
+
+ // check if next sequence receive exists
+ if len(value) == 0 {
+ return nil, sdkerrors.Wrapf(chantypes.ErrChannelNotFound, "portID (%s), channelID (%s)", portid, channelid)
+ }
+
+ sequence := binary.BigEndian.Uint64(value)
+
+ return &chantypes.QueryNextSequenceReceiveResponse{
+ NextSequenceReceive: sequence,
+ Proof: proofBz,
+ ProofHeight: proofHeight,
+ }, nil
+}
+
+// QueryNextSeqAck returns the next seqAck for a configured channel
+func (cc *PenumbraProvider) QueryNextSeqAck(ctx context.Context, height int64, channelid, portid string) (recvRes *chantypes.QueryNextSequenceReceiveResponse, err error) {
+ key := host.NextSequenceAckKey(portid, channelid)
+
+ value, proofBz, proofHeight, err := cc.QueryTendermintProof(ctx, height, key)
+ if err != nil {
+ return nil, err
+ }
+
+ // check if next sequence receive exists
+ if len(value) == 0 {
+ return nil, sdkerrors.Wrapf(chantypes.ErrChannelNotFound, "portID (%s), channelID (%s)", portid, channelid)
+ }
+
+ sequence := binary.BigEndian.Uint64(value)
+
+ return &chantypes.QueryNextSequenceReceiveResponse{
+ NextSequenceReceive: sequence,
+ Proof: proofBz,
+ ProofHeight: proofHeight,
+ }, nil
+}
+
+// QueryPacketCommitment returns the packet commitment proof at a given height
+func (cc *PenumbraProvider) QueryPacketCommitment(ctx context.Context, height int64, channelid, portid string, seq uint64) (comRes *chantypes.QueryPacketCommitmentResponse, err error) {
+ key := host.PacketCommitmentKey(portid, channelid, seq)
+
+ value, proofBz, proofHeight, err := cc.QueryTendermintProof(ctx, height, key)
+ if err != nil {
+ return nil, err
+ }
+
+ // check if packet commitment exists
+ if len(value) == 0 {
+ return nil, sdkerrors.Wrapf(chantypes.ErrPacketCommitmentNotFound, "portID (%s), channelID (%s), sequence (%d)", portid, channelid, seq)
+ }
+
+ return &chantypes.QueryPacketCommitmentResponse{
+ Commitment: value,
+ Proof: proofBz,
+ ProofHeight: proofHeight,
+ }, nil
+}
+
+// QueryPacketAcknowledgement returns the packet ack proof at a given height
+func (cc *PenumbraProvider) QueryPacketAcknowledgement(ctx context.Context, height int64, channelid, portid string, seq uint64) (ackRes *chantypes.QueryPacketAcknowledgementResponse, err error) {
+ key := host.PacketAcknowledgementKey(portid, channelid, seq)
+
+ value, proofBz, proofHeight, err := cc.QueryTendermintProof(ctx, height, key)
+ if err != nil {
+ return nil, err
+ }
+
+ if len(value) == 0 {
+ return nil, sdkerrors.Wrapf(chantypes.ErrInvalidAcknowledgement, "portID (%s), channelID (%s), sequence (%d)", portid, channelid, seq)
+ }
+
+ return &chantypes.QueryPacketAcknowledgementResponse{
+ Acknowledgement: value,
+ Proof: proofBz,
+ ProofHeight: proofHeight,
+ }, nil
+}
+
+// QueryPacketReceipt returns the packet receipt proof at a given height
+func (cc *PenumbraProvider) QueryPacketReceipt(ctx context.Context, height int64, channelid, portid string, seq uint64) (recRes *chantypes.QueryPacketReceiptResponse, err error) {
+ key := host.PacketReceiptKey(portid, channelid, seq)
+
+ value, proofBz, proofHeight, err := cc.QueryTendermintProof(ctx, height, key)
+ if err != nil {
+ return nil, err
+ }
+
+ return &chantypes.QueryPacketReceiptResponse{
+ Received: value != nil,
+ Proof: proofBz,
+ ProofHeight: proofHeight,
+ }, nil
+}
+
+func (cc *PenumbraProvider) QueryLatestHeight(ctx context.Context) (int64, error) {
+ stat, err := cc.RPCClient.Status(ctx)
+ if err != nil {
+ return -1, err
+ } else if stat.SyncInfo.CatchingUp {
+ return -1, fmt.Errorf("node at %s running chain %s not caught up", cc.PCfg.RPCAddr, cc.PCfg.ChainID)
+ }
+ return stat.SyncInfo.LatestBlockHeight, nil
+}
+
+// QueryHeaderAtHeight returns the header at a given height
+func (cc *PenumbraProvider) QueryHeaderAtHeight(ctx context.Context, height int64) (ibcexported.ClientMessage, error) {
+ var (
+ page = 1
+ perPage = 100000
+ )
+ if height <= 0 {
+ return nil, fmt.Errorf("must pass in valid height, %d not valid", height)
+ }
+
+ res, err := cc.RPCClient.Commit(ctx, &height)
+ if err != nil {
+ return nil, err
+ }
+
+ val, err := cc.RPCClient.Validators(ctx, &height, &page, &perPage)
+ if err != nil {
+ return nil, err
+ }
+
+ protoVal, err := tmtypes.NewValidatorSet(val.Validators).ToProto()
+ if err != nil {
+ return nil, err
+ }
+
+ return &tmclient.Header{
+ // NOTE: This is not a SignedHeader
+ // We are missing a light.Commit type here
+ SignedHeader: res.SignedHeader.ToProto(),
+ ValidatorSet: protoVal,
+ }, nil
+}
+
+// QueryDenomTrace takes a denom from IBC and queries the information about it
+func (cc *PenumbraProvider) QueryDenomTrace(ctx context.Context, denom string) (*transfertypes.DenomTrace, error) {
+ transfers, err := transfertypes.NewQueryClient(cc).DenomTrace(ctx,
+ &transfertypes.QueryDenomTraceRequest{
+ Hash: denom,
+ })
+ if err != nil {
+ return nil, err
+ }
+ return transfers.DenomTrace, nil
+}
+
+// QueryDenomTraces returns all the denom traces from a given chain
+// TODO add pagination support
+func (cc *PenumbraProvider) QueryDenomTraces(ctx context.Context, offset, limit uint64, height int64) ([]transfertypes.DenomTrace, error) {
+ transfers, err := transfertypes.NewQueryClient(cc).DenomTraces(ctx,
+ &transfertypes.QueryDenomTracesRequest{
+ Pagination: DefaultPageRequest(),
+ })
+ if err != nil {
+ return nil, err
+ }
+ return transfers.DenomTraces, nil
+}
+
+func (cc *PenumbraProvider) QueryStakingParams(ctx context.Context) (*stakingtypes.Params, error) {
+ res, err := stakingtypes.NewQueryClient(cc).Params(ctx, &stakingtypes.QueryParamsRequest{})
+ if err != nil {
+ return nil, err
+ }
+ return &res.Params, nil
+}
+
+func DefaultPageRequest() *querytypes.PageRequest {
+ return &querytypes.PageRequest{
+ Key: []byte(""),
+ Offset: 0,
+ Limit: 1000,
+ CountTotal: true,
+ }
+}
+
+func (cc *PenumbraProvider) QueryConsensusStateABCI(ctx context.Context, clientID string, height ibcexported.Height) (*clienttypes.QueryConsensusStateResponse, error) {
+ key := host.FullConsensusStateKey(clientID, height)
+
+ value, proofBz, proofHeight, err := cc.QueryTendermintProof(ctx, int64(height.GetRevisionHeight()), key)
+ if err != nil {
+ return nil, err
+ }
+
+ // check if consensus state exists
+ if len(value) == 0 {
+ return nil, sdkerrors.Wrap(clienttypes.ErrConsensusStateNotFound, clientID)
+ }
+
+ // TODO do we really want to create a new codec? ChainClient exposes proto.Marshaler
+ cdc := codec.NewProtoCodec(cc.Codec.InterfaceRegistry)
+
+ cs, err := clienttypes.UnmarshalConsensusState(cdc, value)
+ if err != nil {
+ return nil, err
+ }
+
+ anyConsensusState, err := clienttypes.PackConsensusState(cs)
+ if err != nil {
+ return nil, err
+ }
+
+ return &clienttypes.QueryConsensusStateResponse{
+ ConsensusState: anyConsensusState,
+ Proof: proofBz,
+ ProofHeight: proofHeight,
+ }, nil
+}
+
+// queryIBCMessages returns an array of IBC messages given a tag
+func (cc *PenumbraProvider) queryIBCMessages(ctx context.Context, log *zap.Logger, page, limit int, query string) ([]ibcMessage, error) {
+ if query == "" {
+ return nil, errors.New("query string must be provided")
+ }
+
+ if page <= 0 {
+ return nil, errors.New("page must greater than 0")
+ }
+
+ if limit <= 0 {
+ return nil, errors.New("limit must greater than 0")
+ }
+
+ res, err := cc.RPCClient.TxSearch(ctx, query, true, &page, &limit, "")
+ if err != nil {
+ return nil, err
+ }
+ var ibcMsgs []ibcMessage
+ chainID := cc.ChainId()
+ for _, tx := range res.Txs {
+ ibcMsgs = append(ibcMsgs, ibcMessagesFromEvents(log, tx.TxResult.Events, chainID, 0, true)...)
+ }
+
+ return ibcMsgs, nil
+}
+
+func sendPacketQuery(channelID string, portID string, seq uint64) string {
+ x := []string{
+ fmt.Sprintf("%s.packet_src_channel='%s'", spTag, channelID),
+ fmt.Sprintf("%s.packet_src_port='%s'", spTag, portID),
+ fmt.Sprintf("%s.packet_sequence='%d'", spTag, seq),
+ }
+ return strings.Join(x, " AND ")
+}
+
+func (cc *PenumbraProvider) QuerySendPacket(
+ ctx context.Context,
+ srcChanID,
+ srcPortID string,
+ sequence uint64,
+) (provider.PacketInfo, error) {
+ q := sendPacketQuery(srcChanID, srcPortID, sequence)
+ ibcMsgs, err := cc.queryIBCMessages(ctx, cc.log, 1, 1000, q)
+ if err != nil {
+ return provider.PacketInfo{}, err
+ }
+ for _, msg := range ibcMsgs {
+ if msg.eventType != chantypes.EventTypeSendPacket {
+ continue
+ }
+ if pi, ok := msg.info.(*packetInfo); ok {
+ if pi.SourceChannel == srcChanID && pi.SourcePort == srcPortID && pi.Sequence == sequence {
+ return provider.PacketInfo(*pi), nil
+ }
+ }
+ }
+ return provider.PacketInfo{}, fmt.Errorf("no ibc messages found for send_packet query: %s", q)
+}
+
+func writeAcknowledgementQuery(channelID string, portID string, seq uint64) string {
+ x := []string{
+ fmt.Sprintf("%s.packet_dst_channel='%s'", waTag, channelID),
+ fmt.Sprintf("%s.packet_dst_port='%s'", waTag, portID),
+ fmt.Sprintf("%s.packet_sequence='%d'", waTag, seq),
+ }
+ return strings.Join(x, " AND ")
+}
+
+func (cc *PenumbraProvider) QueryRecvPacket(
+ ctx context.Context,
+ dstChanID,
+ dstPortID string,
+ sequence uint64,
+) (provider.PacketInfo, error) {
+ q := writeAcknowledgementQuery(dstChanID, dstPortID, sequence)
+ ibcMsgs, err := cc.queryIBCMessages(ctx, cc.log, 1, 1000, q)
+ if err != nil {
+ return provider.PacketInfo{}, err
+ }
+ for _, msg := range ibcMsgs {
+ if msg.eventType != chantypes.EventTypeWriteAck {
+ continue
+ }
+ if pi, ok := msg.info.(*packetInfo); ok {
+ if pi.DestChannel == dstChanID && pi.DestPort == dstPortID && pi.Sequence == sequence {
+ return provider.PacketInfo(*pi), nil
+ }
+ }
+ }
+ return provider.PacketInfo{}, fmt.Errorf("no ibc messages found for write_acknowledgement query: %s", q)
+}
+
+// QueryStatus queries the current node status.
+func (cc *PenumbraProvider) QueryStatus(ctx context.Context) (*coretypes.ResultStatus, error) {
+ status, err := cc.RPCClient.Status(ctx)
+ if err != nil {
+ return nil, fmt.Errorf("failed to query node status: %w", err)
+ }
+ return status, nil
+}
+
+func (cc *PenumbraProvider) QueryICQWithProof(ctx context.Context, msgType string, request []byte, height uint64) (provider.ICQProof, error) {
+ //TODO implement me
+ panic("implement me")
+}
+
+func (cc *PenumbraProvider) QueryClientPrevConsensusStateHeight(ctx context.Context, chainHeight int64, clientId string, clientHeight int64) (exported.Height, error) {
+ panic("QueryClientPrevConsensusStateHeight not implemented")
+}
diff --git a/relayer/chains/penumbra/relayer_packets.go b/relayer/chains/penumbra/relayer_packets.go
new file mode 100644
index 000000000..7e5057037
--- /dev/null
+++ b/relayer/chains/penumbra/relayer_packets.go
@@ -0,0 +1,232 @@
+package penumbra
+
+import (
+ "context"
+ "fmt"
+
+ clienttypes "github.com/cosmos/ibc-go/v7/modules/core/02-client/types"
+ chantypes "github.com/cosmos/ibc-go/v7/modules/core/04-channel/types"
+ "github.com/cosmos/relayer/v2/relayer/provider"
+)
+
+var (
+ _ provider.RelayPacket = relayMsgTimeout{}
+ _ provider.RelayPacket = relayMsgRecvPacket{}
+ _ provider.RelayPacket = relayMsgPacketAck{}
+)
+
+type relayMsgTimeout struct {
+ packetData []byte
+ seq uint64
+ timeout clienttypes.Height
+ timeoutStamp uint64
+ dstRecvRes *chantypes.QueryPacketReceiptResponse
+
+ pass bool
+}
+
+func (rp relayMsgTimeout) Data() []byte {
+ return rp.packetData
+}
+
+func (rp relayMsgTimeout) Seq() uint64 {
+ return rp.seq
+}
+
+func (rp relayMsgTimeout) Timeout() clienttypes.Height {
+ return rp.timeout
+}
+
+func (rp relayMsgTimeout) TimeoutStamp() uint64 {
+ return rp.timeoutStamp
+}
+
+func (rp relayMsgTimeout) FetchCommitResponse(ctx context.Context, dst provider.ChainProvider, queryHeight uint64, dstChanId, dstPortId string) error {
+ dstRecvRes, err := dst.QueryPacketReceipt(ctx, int64(queryHeight)-1, dstChanId, dstPortId, rp.seq)
+ switch {
+ case err != nil:
+ return err
+ case dstRecvRes.Proof == nil:
+ return fmt.Errorf("timeout packet receipt proof seq(%d) is nil", rp.seq)
+ default:
+ rp.dstRecvRes = dstRecvRes
+ return nil
+ }
+}
+
+func (rp relayMsgTimeout) Msg(src provider.ChainProvider, srcPortId, srcChanId, dstPortId, dstChanId string) (provider.RelayerMessage, error) {
+ if rp.dstRecvRes == nil {
+ return nil, fmt.Errorf("timeout packet [%s]seq{%d} has no associated proofs", src.ChainId(), rp.seq)
+ }
+ addr, err := src.Address()
+ if err != nil {
+ return nil, err
+ }
+
+ msg := &chantypes.MsgTimeout{
+ Packet: chantypes.Packet{
+ Sequence: rp.seq,
+ SourcePort: srcPortId,
+ SourceChannel: srcChanId,
+ DestinationPort: dstPortId,
+ DestinationChannel: dstChanId,
+ Data: rp.packetData,
+ TimeoutHeight: rp.timeout,
+ TimeoutTimestamp: rp.timeoutStamp,
+ },
+ ProofUnreceived: rp.dstRecvRes.Proof,
+ ProofHeight: rp.dstRecvRes.ProofHeight,
+ NextSequenceRecv: rp.seq,
+ Signer: addr,
+ }
+
+ return NewPenumbraMessage(msg), nil
+}
+
+type relayMsgRecvPacket struct {
+ packetData []byte
+ seq uint64
+ timeout clienttypes.Height
+ timeoutStamp uint64
+ dstComRes *chantypes.QueryPacketCommitmentResponse
+}
+
+func (rp relayMsgRecvPacket) timeoutPacket() *relayMsgTimeout {
+ return &relayMsgTimeout{
+ packetData: rp.packetData,
+ seq: rp.seq,
+ timeout: rp.timeout,
+ timeoutStamp: rp.timeoutStamp,
+ dstRecvRes: nil,
+ pass: false,
+ }
+}
+
+func (rp relayMsgRecvPacket) Data() []byte {
+ return rp.packetData
+}
+
+func (rp relayMsgRecvPacket) Seq() uint64 {
+ return rp.seq
+}
+
+func (rp relayMsgRecvPacket) Timeout() clienttypes.Height {
+ return rp.timeout
+}
+
+func (rp relayMsgRecvPacket) TimeoutStamp() uint64 {
+ return rp.timeoutStamp
+}
+
+func (rp relayMsgRecvPacket) FetchCommitResponse(ctx context.Context, dst provider.ChainProvider, queryHeight uint64, dstChanId, dstPortId string) error {
+ dstCommitRes, err := dst.QueryPacketCommitment(ctx, int64(queryHeight)-1, dstChanId, dstPortId, rp.seq)
+ switch {
+ case err != nil:
+ return err
+ case dstCommitRes.Proof == nil:
+ return fmt.Errorf("recv packet commitment proof seq(%d) is nil", rp.seq)
+ case dstCommitRes.Commitment == nil:
+ return fmt.Errorf("recv packet commitment query seq(%d) is nil", rp.seq)
+ default:
+ rp.dstComRes = dstCommitRes
+ return nil
+ }
+}
+
+func (rp relayMsgRecvPacket) Msg(src provider.ChainProvider, srcPortId, srcChanId, dstPortId, dstChanId string) (provider.RelayerMessage, error) {
+ if rp.dstComRes == nil {
+ return nil, fmt.Errorf("receive packet [%s]seq{%d} has no associated proofs", src.ChainId(), rp.seq)
+ }
+ addr, err := src.Address()
+ if err != nil {
+ return nil, err
+ }
+
+ msg := &chantypes.MsgRecvPacket{
+ Packet: chantypes.Packet{
+ Sequence: rp.seq,
+ SourcePort: dstPortId,
+ SourceChannel: dstChanId,
+ DestinationPort: srcPortId,
+ DestinationChannel: srcChanId,
+ Data: rp.packetData,
+ TimeoutHeight: rp.timeout,
+ TimeoutTimestamp: rp.timeoutStamp,
+ },
+ ProofCommitment: rp.dstComRes.Proof,
+ ProofHeight: rp.dstComRes.ProofHeight,
+ Signer: addr,
+ }
+
+ return NewPenumbraMessage(msg), nil
+}
+
+type relayMsgPacketAck struct {
+ packetData []byte
+ ack []byte
+ seq uint64
+ timeout clienttypes.Height
+ timeoutStamp uint64
+ dstComRes *chantypes.QueryPacketAcknowledgementResponse
+
+ pass bool
+}
+
+func (rp relayMsgPacketAck) Data() []byte {
+ return rp.packetData
+}
+func (rp relayMsgPacketAck) Seq() uint64 {
+ return rp.seq
+}
+func (rp relayMsgPacketAck) Timeout() clienttypes.Height {
+ return rp.timeout
+}
+
+func (rp relayMsgPacketAck) TimeoutStamp() uint64 {
+ return rp.timeoutStamp
+}
+
+func (rp relayMsgPacketAck) Msg(src provider.ChainProvider, srcPortId, srcChanId, dstPortId, dstChanId string) (provider.RelayerMessage, error) {
+ if rp.dstComRes == nil {
+ return nil, fmt.Errorf("ack packet [%s]seq{%d} has no associated proofs", src.ChainId(), rp.seq)
+ }
+
+ addr, err := src.Address()
+ if err != nil {
+ return nil, err
+ }
+
+ msg := &chantypes.MsgAcknowledgement{
+ Packet: chantypes.Packet{
+ Sequence: rp.seq,
+ SourcePort: srcPortId,
+ SourceChannel: srcChanId,
+ DestinationPort: dstPortId,
+ DestinationChannel: dstChanId,
+ Data: rp.packetData,
+ TimeoutHeight: rp.timeout,
+ TimeoutTimestamp: rp.timeoutStamp,
+ },
+ Acknowledgement: rp.ack,
+ ProofAcked: rp.dstComRes.Proof,
+ ProofHeight: rp.dstComRes.ProofHeight,
+ Signer: addr,
+ }
+
+ return NewPenumbraMessage(msg), nil
+}
+
+func (rp relayMsgPacketAck) FetchCommitResponse(ctx context.Context, dst provider.ChainProvider, queryHeight uint64, dstChanId, dstPortId string) error {
+ dstCommitRes, err := dst.QueryPacketAcknowledgement(ctx, int64(queryHeight)-1, dstChanId, dstPortId, rp.seq)
+ switch {
+ case err != nil:
+ return err
+ case dstCommitRes.Proof == nil:
+ return fmt.Errorf("ack packet acknowledgement proof seq(%d) is nil", rp.seq)
+ case dstCommitRes.Acknowledgement == nil:
+ return fmt.Errorf("ack packet acknowledgement query seq(%d) is nil", rp.seq)
+ default:
+ rp.dstComRes = dstCommitRes
+ return nil
+ }
+}
diff --git a/relayer/chains/penumbra/tx.go b/relayer/chains/penumbra/tx.go
new file mode 100644
index 000000000..4d626e3b2
--- /dev/null
+++ b/relayer/chains/penumbra/tx.go
@@ -0,0 +1,2313 @@
+package penumbra
+
+import (
+ "context"
+ "encoding/base64"
+ "errors"
+ "fmt"
+ "math/rand"
+ "regexp"
+ "strconv"
+ "strings"
+ "time"
+
+ "github.com/avast/retry-go/v4"
+ abci "github.com/cometbft/cometbft/abci/types"
+ "github.com/cometbft/cometbft/libs/bytes"
+ "github.com/cometbft/cometbft/light"
+ tmcrypto "github.com/cometbft/cometbft/proto/tendermint/crypto"
+ rpcclient "github.com/cometbft/cometbft/rpc/client"
+ coretypes "github.com/cometbft/cometbft/rpc/core/types"
+ tmtypes "github.com/cometbft/cometbft/types"
+ codectypes "github.com/cosmos/cosmos-sdk/codec/types"
+ "github.com/cosmos/cosmos-sdk/store/rootmulti"
+ sdk "github.com/cosmos/cosmos-sdk/types"
+ sdkerrors "github.com/cosmos/cosmos-sdk/types/errors"
+ cosmosproto "github.com/cosmos/gogoproto/proto"
+ transfertypes "github.com/cosmos/ibc-go/v7/modules/apps/transfer/types"
+ clienttypes "github.com/cosmos/ibc-go/v7/modules/core/02-client/types"
+ conntypes "github.com/cosmos/ibc-go/v7/modules/core/03-connection/types"
+ chantypes "github.com/cosmos/ibc-go/v7/modules/core/04-channel/types"
+ commitmenttypes "github.com/cosmos/ibc-go/v7/modules/core/23-commitment/types"
+ host "github.com/cosmos/ibc-go/v7/modules/core/24-host"
+ ibcexported "github.com/cosmos/ibc-go/v7/modules/core/exported"
+ tmclient "github.com/cosmos/ibc-go/v7/modules/light-clients/07-tendermint"
+ ics23 "github.com/cosmos/ics23/go"
+ "github.com/cosmos/relayer/v2/relayer/chains/cosmos"
+ penumbracrypto "github.com/cosmos/relayer/v2/relayer/chains/penumbra/core/crypto/v1alpha1"
+ penumbraibctypes "github.com/cosmos/relayer/v2/relayer/chains/penumbra/core/ibc/v1alpha1"
+ penumbratypes "github.com/cosmos/relayer/v2/relayer/chains/penumbra/core/transaction/v1alpha1"
+ "github.com/cosmos/relayer/v2/relayer/provider"
+ "go.uber.org/zap"
+ "google.golang.org/grpc/codes"
+ "google.golang.org/grpc/status"
+)
+
+// Variables used for retries
+var (
+ rtyAttNum = uint(5)
+ rtyAtt = retry.Attempts(rtyAttNum)
+ rtyDel = retry.Delay(time.Millisecond * 400)
+ rtyErr = retry.LastErrorOnly(true)
+ numRegex = regexp.MustCompile("[0-9]+")
+ defaultBroadcastWaitTimeout = 10 * time.Minute
+ errUnknown = "unknown"
+)
+
+// Default IBC settings
+var (
+ defaultChainPrefix = commitmenttypes.NewMerklePrefix([]byte("ibc"))
+ defaultDelayPeriod = uint64(0)
+)
+
+// Strings for parsing events
+var (
+ spTag = "send_packet"
+ waTag = "write_acknowledgement"
+ srcChanTag = "packet_src_channel"
+ dstChanTag = "packet_dst_channel"
+ srcPortTag = "packet_src_port"
+ dstPortTag = "packet_dst_port"
+ dataTag = "packet_data"
+ ackTag = "packet_ack"
+ toHeightTag = "packet_timeout_height"
+ toTSTag = "packet_timeout_timestamp"
+ seqTag = "packet_sequence"
+)
+
+const (
+ ErrTimeoutAfterWaitingForTxBroadcast _err = "timed out after waiting for tx to get included in the block"
+)
+
+type _err string
+
+func (e _err) Error() string { return string(e) }
+
+// Deprecated: this interface is used only internally for scenario we are
+// deprecating (StdTxConfig support)
+type intoAny interface {
+ AsAny() *codectypes.Any
+}
+
+// SendMessage attempts to sign, encode & send a RelayerMessage
+// This is used extensively in the relayer as an extension of the Provider interface
+func (cc *PenumbraProvider) SendMessage(ctx context.Context, msg provider.RelayerMessage, memo string) (*provider.RelayerTxResponse, bool, error) {
+ return cc.SendMessages(ctx, []provider.RelayerMessage{msg}, memo)
+}
+
+// takes a RelayerMessage, converts it to a PenumbraMessage, and wraps it into
+// Penumbra's equivalent of the "message" abstraction, an Action.
+func msgToPenumbraAction(msg sdk.Msg) (*penumbratypes.Action, error) {
+ anyMsg, err := codectypes.NewAnyWithValue(msg)
+ if err != nil {
+ return nil, err
+ }
+
+ switch msg.(type) {
+ case *clienttypes.MsgCreateClient:
+ return &penumbratypes.Action{
+ Action: &penumbratypes.Action_IbcAction{IbcAction: &penumbraibctypes.IbcAction{
+ RawAction: anyMsg,
+ }},
+ }, nil
+ case *clienttypes.MsgUpdateClient:
+ return &penumbratypes.Action{
+ Action: &penumbratypes.Action_IbcAction{IbcAction: &penumbraibctypes.IbcAction{
+ RawAction: anyMsg,
+ }},
+ }, nil
+ case *conntypes.MsgConnectionOpenInit:
+ return &penumbratypes.Action{
+ Action: &penumbratypes.Action_IbcAction{IbcAction: &penumbraibctypes.IbcAction{
+ RawAction: anyMsg,
+ }},
+ }, nil
+ case *conntypes.MsgConnectionOpenAck:
+ return &penumbratypes.Action{
+ Action: &penumbratypes.Action_IbcAction{IbcAction: &penumbraibctypes.IbcAction{
+ RawAction: anyMsg,
+ }},
+ }, nil
+ case *conntypes.MsgConnectionOpenTry:
+ return &penumbratypes.Action{
+ Action: &penumbratypes.Action_IbcAction{IbcAction: &penumbraibctypes.IbcAction{
+ RawAction: anyMsg,
+ }},
+ }, nil
+ case *conntypes.MsgConnectionOpenConfirm:
+ return &penumbratypes.Action{
+ Action: &penumbratypes.Action_IbcAction{IbcAction: &penumbraibctypes.IbcAction{
+ RawAction: anyMsg,
+ }},
+ }, nil
+ case *chantypes.MsgChannelOpenInit:
+ return &penumbratypes.Action{
+ Action: &penumbratypes.Action_IbcAction{IbcAction: &penumbraibctypes.IbcAction{
+ RawAction: anyMsg,
+ }},
+ }, nil
+ case *chantypes.MsgChannelOpenTry:
+ return &penumbratypes.Action{
+ Action: &penumbratypes.Action_IbcAction{IbcAction: &penumbraibctypes.IbcAction{
+ RawAction: anyMsg,
+ }},
+ }, nil
+ case *chantypes.MsgChannelOpenAck:
+ return &penumbratypes.Action{
+ Action: &penumbratypes.Action_IbcAction{IbcAction: &penumbraibctypes.IbcAction{
+ RawAction: anyMsg,
+ }},
+ }, nil
+ case *chantypes.MsgChannelOpenConfirm:
+ return &penumbratypes.Action{
+ Action: &penumbratypes.Action_IbcAction{IbcAction: &penumbraibctypes.IbcAction{
+ RawAction: anyMsg,
+ }},
+ }, nil
+ case *chantypes.MsgChannelCloseInit:
+ return &penumbratypes.Action{
+ Action: &penumbratypes.Action_IbcAction{IbcAction: &penumbraibctypes.IbcAction{
+ RawAction: anyMsg,
+ }},
+ }, nil
+ case *chantypes.MsgChannelCloseConfirm:
+ return &penumbratypes.Action{
+ Action: &penumbratypes.Action_IbcAction{IbcAction: &penumbraibctypes.IbcAction{
+ RawAction: anyMsg,
+ }},
+ }, nil
+ case *chantypes.MsgRecvPacket:
+ return &penumbratypes.Action{
+ Action: &penumbratypes.Action_IbcAction{IbcAction: &penumbraibctypes.IbcAction{
+ RawAction: anyMsg,
+ }},
+ }, nil
+ case *chantypes.MsgAcknowledgement:
+ return &penumbratypes.Action{
+ Action: &penumbratypes.Action_IbcAction{IbcAction: &penumbraibctypes.IbcAction{
+ RawAction: anyMsg,
+ }},
+ }, nil
+
+ default:
+ return nil, fmt.Errorf("unknown message type: %T", msg)
+ }
+}
+
+// EventAttribute is a single key-value pair, associated with an event.
+type EventAttribute struct {
+ Key string `protobuf:"bytes,1,opt,name=key,proto3" json:"key,omitempty"`
+ Value string `protobuf:"bytes,2,opt,name=value,proto3" json:"value,omitempty"`
+ Index bool `protobuf:"varint,3,opt,name=index,proto3" json:"index,omitempty"`
+}
+
+// Event allows application developers to attach additional information to
+// ResponseFinalizeBlock, ResponseDeliverTx, ExecTxResult
+// Later, transactions may be queried using these events.
+type Event struct {
+ Type string `protobuf:"bytes,1,opt,name=type,proto3" json:"type,omitempty"`
+ Attributes []EventAttribute `protobuf:"bytes,2,rep,name=attributes,proto3" json:"attributes,omitempty"`
+}
+
+// ExecTxResult contains results of executing one individual transaction.
+//
+// * Its structure is equivalent to #ResponseDeliverTx which will be deprecated/deleted
+type ExecTxResult struct {
+ Code uint32 `protobuf:"varint,1,opt,name=code,proto3" json:"code,omitempty"`
+ Data []byte `protobuf:"bytes,2,opt,name=data,proto3" json:"data,omitempty"`
+ Log string `protobuf:"bytes,3,opt,name=log,proto3" json:"log,omitempty"`
+ Info string `protobuf:"bytes,4,opt,name=info,proto3" json:"info,omitempty"`
+ GasWanted int64 `protobuf:"varint,5,opt,name=gas_wanted,json=gasWanted,proto3" json:"gas_wanted,omitempty"`
+ GasUsed int64 `protobuf:"varint,6,opt,name=gas_used,json=gasUsed,proto3" json:"gas_used,omitempty"`
+ Events []Event `protobuf:"bytes,7,rep,name=events,proto3" json:"events,omitempty"`
+ Codespace string `protobuf:"bytes,8,opt,name=codespace,proto3" json:"codespace,omitempty"`
+}
+
+// Result of querying for a tx. This is from the new tendermint API.
+type ResultTx struct {
+ Hash bytes.HexBytes `json:"hash"`
+ Height int64 `json:"height,string"`
+ Index uint32 `json:"index"`
+ TxResult ExecTxResult `json:"tx_result"`
+ Tx tmtypes.Tx `json:"tx"`
+ Proof tmtypes.TxProof `json:"proof,omitempty"`
+}
+
+// ValidatorUpdate
+type ValidatorUpdate struct {
+ PubKey tmcrypto.PublicKey `protobuf:"bytes,1,opt,name=pub_key,json=pubKey,proto3" json:"pub_key"`
+ Power int64 `protobuf:"varint,2,opt,name=power,proto3" json:"power,omitempty"`
+}
+
+func (cc *PenumbraProvider) getAnchor(ctx context.Context) (*penumbracrypto.MerkleRoot, error) {
+ status, err := cc.RPCClient.Status(ctx)
+ if err != nil {
+ return nil, err
+ }
+ maxHeight := status.SyncInfo.LatestBlockHeight
+
+ // Generate a random block height to query between 1 and maxHeight
+ height := rand.Int63n(maxHeight-1) + 1
+
+ path := fmt.Sprintf("shielded_pool/anchor/%d", height)
+
+ req := abci.RequestQuery{
+ Path: "state/key",
+ Height: maxHeight,
+ Data: []byte(path),
+ Prove: false,
+ }
+
+ res, err := cc.QueryABCI(ctx, req)
+ if err != nil {
+ path := fmt.Sprintf("sct/anchor/%d", height)
+
+ req := abci.RequestQuery{
+ Path: "state/key",
+ Height: maxHeight,
+ Data: []byte(path),
+ Prove: false,
+ }
+ res, err := cc.QueryABCI(ctx, req)
+ if err != nil {
+ return nil, err
+ }
+
+ return &penumbracrypto.MerkleRoot{Inner: res.Value[2:]}, nil
+ }
+
+ return &penumbracrypto.MerkleRoot{Inner: res.Value[2:]}, nil
+}
+
+func parseEventsFromABCIResponse(resp abci.ResponseDeliverTx) []provider.RelayerEvent {
+ var events []provider.RelayerEvent
+
+ for _, event := range resp.Events {
+ attributes := make(map[string]string)
+ for _, attribute := range event.Attributes {
+ // The key and value are base64-encoded strings, so we first have to decode them:
+ key, err := base64.StdEncoding.DecodeString(string(attribute.Key))
+ if err != nil {
+ continue
+ }
+ value, err := base64.StdEncoding.DecodeString(string(attribute.Value))
+ if err != nil {
+ continue
+ }
+ attributes[string(key)] = string(value)
+ }
+ events = append(events, provider.RelayerEvent{
+ EventType: event.Type,
+ Attributes: attributes,
+ })
+ }
+ return events
+
+}
+
+func (cc *PenumbraProvider) sendMessagesInner(ctx context.Context, msgs []provider.RelayerMessage, _memo string) (*coretypes.ResultBroadcastTx, error) {
+
+ // TODO: fee estimation, fee payments
+ // NOTE: we do not actually need to sign this tx currently, since there
+ // are no fees required on the testnet. future versions of penumbra
+ // will have a signing protocol for this.
+
+ txBody := penumbratypes.TransactionBody{
+ Actions: make([]*penumbratypes.Action, 0),
+ Fee: &penumbracrypto.Fee{Amount: &penumbracrypto.Amount{Lo: 0, Hi: 0}},
+ MemoData: &penumbratypes.MemoData{},
+ TransactionParameters: &penumbratypes.TransactionParameters{},
+ }
+
+ for _, msg := range PenumbraMsgs(msgs...) {
+ action, err := msgToPenumbraAction(msg)
+ if err != nil {
+ return nil, err
+ }
+ txBody.Actions = append(txBody.Actions, action)
+ }
+
+ anchor, err := cc.getAnchor(ctx)
+ if err != nil {
+ return nil, err
+ }
+
+ tx := &penumbratypes.Transaction{
+ Body: &txBody,
+ BindingSig: make([]byte, 64), // use the Cool Signature
+ Anchor: anchor,
+ }
+
+ cc.log.Debug("Broadcasting penumbra tx")
+ txBytes, err := cosmosproto.Marshal(tx)
+ if err != nil {
+ return nil, err
+ }
+
+ return cc.RPCClient.BroadcastTxSync(ctx, txBytes)
+}
+
+// SendMessages attempts to sign, encode, & send a slice of RelayerMessages
+// This is used extensively in the relayer as an extension of the Provider interface
+//
+// NOTE: An error is returned if there was an issue sending the transaction. A successfully sent, but failed
+// transaction will not return an error. If a transaction is successfully sent, the result of the execution
+// of that transaction will be logged. A boolean indicating if a transaction was successfully
+// sent and executed successfully is returned.
+func (cc *PenumbraProvider) SendMessages(ctx context.Context, msgs []provider.RelayerMessage, _memo string) (*provider.RelayerTxResponse, bool, error) {
+ var events []provider.RelayerEvent
+ var height int64
+ var data []byte
+ var txhash string
+ var code uint32
+
+ syncRes, err := cc.sendMessagesInner(ctx, msgs, _memo)
+ if err != nil {
+ return nil, false, err
+ }
+ cc.log.Debug("Waiting for penumbra tx to commit", zap.String("syncRes", fmt.Sprintf("%+v", syncRes)))
+
+ if err := retry.Do(func() error {
+ ctx, cancel := context.WithTimeout(ctx, 40*time.Second)
+ defer cancel()
+
+ res, err := cc.RPCClient.Tx(ctx, syncRes.Hash, false)
+ if err != nil {
+ return err
+ }
+ cc.log.Debug("Received penumbra tx result", zap.String("res", fmt.Sprintf("%+v", res)))
+
+ height = res.Height
+ txhash = syncRes.Hash.String()
+ code = res.TxResult.Code
+
+ events = append(events, parseEventsFromABCIResponse(res.TxResult)...)
+ return nil
+ }, retry.Context(ctx), rtyAtt, rtyDel, rtyErr, retry.OnRetry(func(n uint, err error) {
+ cc.log.Info(
+ "Error building or broadcasting transaction",
+ zap.String("chain_id", cc.PCfg.ChainID),
+ zap.Uint("attempt", n+1),
+ zap.Uint("max_attempts", rtyAttNum),
+ zap.Error(err),
+ )
+ })); err != nil {
+ return nil, false, err
+ }
+
+ rlyResp := &provider.RelayerTxResponse{
+ Height: height,
+ TxHash: txhash,
+ Code: code,
+ Data: string(data),
+ Events: events,
+ }
+
+ // transaction was executed, log the success or failure using the tx response code
+ // NOTE: error is nil, logic should use the returned error to determine if the
+ // transaction was successfully executed.
+ if rlyResp.Code != 0 {
+ cc.LogFailedTx(rlyResp, nil, msgs)
+ return rlyResp, false, fmt.Errorf("transaction failed with code: %d", code)
+ }
+
+ return rlyResp, true, nil
+}
+
+func parseEventsFromTxResponse(resp *sdk.TxResponse) []provider.RelayerEvent {
+ var events []provider.RelayerEvent
+
+ if resp == nil {
+ return events
+ }
+
+ for _, logs := range resp.Logs {
+ for _, event := range logs.Events {
+ attributes := make(map[string]string)
+ for _, attribute := range event.Attributes {
+ attributes[attribute.Key] = attribute.Value
+ }
+ events = append(events, provider.RelayerEvent{
+ EventType: event.Type,
+ Attributes: attributes,
+ })
+ }
+ }
+ return events
+}
+
+// CreateClient creates an sdk.Msg to update the client on src with consensus state from dst
+func (cc *PenumbraProvider) MsgCreateClient(clientState ibcexported.ClientState, consensusState ibcexported.ConsensusState) (provider.RelayerMessage, error) {
+ signer, err := cc.Address()
+ if err != nil {
+ return nil, err
+ }
+
+ anyClientState, err := clienttypes.PackClientState(clientState)
+ if err != nil {
+ return nil, err
+ }
+
+ anyConsensusState, err := clienttypes.PackConsensusState(consensusState)
+ if err != nil {
+ return nil, err
+ }
+
+ msg := &clienttypes.MsgCreateClient{
+ ClientState: anyClientState,
+ ConsensusState: anyConsensusState,
+ Signer: signer,
+ }
+
+ return NewPenumbraMessage(msg), nil
+}
+
+func (cc *PenumbraProvider) SubmitMisbehavior( /*TBD*/ ) (provider.RelayerMessage, error) {
+ return nil, nil
+}
+
+func (cc *PenumbraProvider) MsgUpdateClient(srcClientId string, dstHeader ibcexported.ClientMessage) (provider.RelayerMessage, error) {
+ acc, err := cc.Address()
+ if err != nil {
+ return nil, err
+ }
+
+ cosmosheader, ok := dstHeader.(*tmclient.Header)
+ if !ok {
+ panic("not cosmos header")
+ }
+
+ valSet, err := tmtypes.ValidatorSetFromProto(cosmosheader.ValidatorSet)
+ if err != nil {
+ return nil, err
+ }
+ trustedValset, err := tmtypes.ValidatorSetFromProto(cosmosheader.TrustedValidators)
+ if err != nil {
+ return nil, err
+ }
+ cosmosheader.ValidatorSet.TotalVotingPower = valSet.TotalVotingPower()
+ cosmosheader.TrustedValidators.TotalVotingPower = trustedValset.TotalVotingPower()
+
+ anyHeader, err := clienttypes.PackClientMessage(cosmosheader)
+ if err != nil {
+ return nil, err
+ }
+
+ msg := &clienttypes.MsgUpdateClient{
+ ClientId: srcClientId,
+ ClientMessage: anyHeader,
+ Signer: acc,
+ }
+
+ return cosmos.NewCosmosMessage(msg, func(signer string) {
+ msg.Signer = signer
+ }), nil
+}
+
+func (cc *PenumbraProvider) ConnectionOpenInit(srcClientId, dstClientId string, dstPrefix commitmenttypes.MerklePrefix, dstHeader ibcexported.ClientMessage) ([]provider.RelayerMessage, error) {
+ var (
+ acc string
+ err error
+ version *conntypes.Version
+ )
+ version = conntypes.DefaultIBCVersion
+
+ updateMsg, err := cc.MsgUpdateClient(srcClientId, dstHeader)
+ if err != nil {
+ return nil, err
+ }
+
+ if acc, err = cc.Address(); err != nil {
+ return nil, err
+ }
+
+ counterparty := conntypes.Counterparty{
+ ClientId: dstClientId,
+ ConnectionId: "",
+ Prefix: dstPrefix,
+ }
+ msg := &conntypes.MsgConnectionOpenInit{
+ ClientId: srcClientId,
+ Counterparty: counterparty,
+ Version: version,
+ DelayPeriod: defaultDelayPeriod,
+ Signer: acc,
+ }
+
+ return []provider.RelayerMessage{updateMsg, cosmos.NewCosmosMessage(msg, func(signer string) {
+ msg.Signer = signer
+ })}, nil
+}
+
+func (cc *PenumbraProvider) ConnectionOpenTry(ctx context.Context, dstQueryProvider provider.QueryProvider, dstHeader ibcexported.ClientMessage, dstPrefix commitmenttypes.MerklePrefix, srcClientId, dstClientId, srcConnId, dstConnId string) ([]provider.RelayerMessage, error) {
+ var (
+ acc string
+ err error
+ )
+ updateMsg, err := cc.MsgUpdateClient(srcClientId, dstHeader)
+ if err != nil {
+ return nil, err
+ }
+
+ cph, err := dstQueryProvider.QueryLatestHeight(ctx)
+ if err != nil {
+ return nil, err
+ }
+
+ clientState, clientStateProof, consensusStateProof, connStateProof, proofHeight, err := dstQueryProvider.GenerateConnHandshakeProof(ctx, cph, dstClientId, dstConnId)
+ if err != nil {
+ return nil, err
+ }
+
+ if len(connStateProof) == 0 {
+ // It is possible that we have asked for a proof too early.
+ // If the connection state proof is empty, there is no point in returning the MsgConnectionOpenTry.
+ // We are not using (*conntypes.MsgConnectionOpenTry).ValidateBasic here because
+ // that chokes on cross-chain bech32 details in ibc-go.
+ return nil, fmt.Errorf("received invalid zero-length connection state proof")
+ }
+
+ if acc, err = cc.Address(); err != nil {
+ return nil, err
+ }
+
+ csAny, err := clienttypes.PackClientState(clientState)
+ if err != nil {
+ return nil, err
+ }
+
+ counterparty := conntypes.Counterparty{
+ ClientId: dstClientId,
+ ConnectionId: dstConnId,
+ Prefix: dstPrefix,
+ }
+
+ // TODO: Get DelayPeriod from counterparty connection rather than using default value
+ msg := &conntypes.MsgConnectionOpenTry{
+ ClientId: srcClientId,
+ PreviousConnectionId: srcConnId,
+ ClientState: csAny,
+ Counterparty: counterparty,
+ DelayPeriod: defaultDelayPeriod,
+ CounterpartyVersions: conntypes.ExportedVersionsToProto(conntypes.GetCompatibleVersions()),
+ ProofHeight: clienttypes.Height{
+ RevisionNumber: proofHeight.GetRevisionNumber(),
+ RevisionHeight: proofHeight.GetRevisionHeight(),
+ },
+ ProofInit: connStateProof,
+ ProofClient: clientStateProof,
+ ProofConsensus: consensusStateProof,
+ ConsensusHeight: clientState.GetLatestHeight().(clienttypes.Height),
+ Signer: acc,
+ }
+
+ return []provider.RelayerMessage{updateMsg, cosmos.NewCosmosMessage(msg, func(signer string) {
+ msg.Signer = signer
+ })}, nil
+}
+
+func (cc *PenumbraProvider) ConnectionOpenAck(ctx context.Context, dstQueryProvider provider.QueryProvider, dstHeader ibcexported.ClientMessage, srcClientId, srcConnId, dstClientId, dstConnId string) ([]provider.RelayerMessage, error) {
+ var (
+ acc string
+ err error
+ )
+
+ updateMsg, err := cc.MsgUpdateClient(srcClientId, dstHeader)
+ if err != nil {
+ return nil, err
+ }
+ cph, err := dstQueryProvider.QueryLatestHeight(ctx)
+ if err != nil {
+ return nil, err
+ }
+
+ clientState, clientStateProof, consensusStateProof, connStateProof,
+ proofHeight, err := dstQueryProvider.GenerateConnHandshakeProof(ctx, cph, dstClientId, dstConnId)
+ if err != nil {
+ return nil, err
+ }
+ cc.log.Debug("ConnectionOpenAck", zap.String("updateMsg", fmt.Sprintf("%+v", updateMsg)), zap.Any("proofHeight", proofHeight))
+
+ if acc, err = cc.Address(); err != nil {
+ return nil, err
+ }
+
+ csAny, err := clienttypes.PackClientState(clientState)
+ if err != nil {
+ return nil, err
+ }
+
+ msg := &conntypes.MsgConnectionOpenAck{
+ ConnectionId: srcConnId,
+ CounterpartyConnectionId: dstConnId,
+ Version: conntypes.DefaultIBCVersion,
+ ClientState: csAny,
+ ProofHeight: clienttypes.Height{
+ RevisionNumber: proofHeight.GetRevisionNumber(),
+ RevisionHeight: proofHeight.GetRevisionHeight(),
+ },
+ ProofTry: connStateProof,
+ ProofClient: clientStateProof,
+ ProofConsensus: consensusStateProof,
+ ConsensusHeight: clientState.GetLatestHeight().(clienttypes.Height),
+ Signer: acc,
+ }
+
+ return []provider.RelayerMessage{updateMsg, cosmos.NewCosmosMessage(msg, func(signer string) {
+ msg.Signer = signer
+ })}, nil
+}
+
+func (cc *PenumbraProvider) ConnectionOpenConfirm(ctx context.Context, dstQueryProvider provider.QueryProvider, dstHeader ibcexported.ClientMessage, dstConnId, srcClientId, srcConnId string) ([]provider.RelayerMessage, error) {
+ var (
+ acc string
+ err error
+ )
+ updateMsg, err := cc.MsgUpdateClient(srcClientId, dstHeader)
+ if err != nil {
+ return nil, err
+ }
+
+ cph, err := dstQueryProvider.QueryLatestHeight(ctx)
+ if err != nil {
+ return nil, err
+ }
+ counterpartyConnState, err := dstQueryProvider.QueryConnection(ctx, cph, dstConnId)
+ if err != nil {
+ return nil, err
+ }
+
+ if acc, err = cc.Address(); err != nil {
+ return nil, err
+ }
+
+ msg := &conntypes.MsgConnectionOpenConfirm{
+ ConnectionId: srcConnId,
+ ProofAck: counterpartyConnState.Proof,
+ ProofHeight: counterpartyConnState.ProofHeight,
+ Signer: acc,
+ }
+
+ return []provider.RelayerMessage{updateMsg, cosmos.NewCosmosMessage(msg, func(signer string) {
+ msg.Signer = signer
+ })}, nil
+}
+
+func (cc *PenumbraProvider) ChannelOpenInit(srcClientId, srcConnId, srcPortId, srcVersion, dstPortId string, order chantypes.Order, dstHeader ibcexported.ClientMessage) ([]provider.RelayerMessage, error) {
+ var (
+ acc string
+ err error
+ )
+ updateMsg, err := cc.MsgUpdateClient(srcClientId, dstHeader)
+ if err != nil {
+ return nil, err
+ }
+
+ if acc, err = cc.Address(); err != nil {
+ return nil, err
+ }
+
+ msg := &chantypes.MsgChannelOpenInit{
+ PortId: srcPortId,
+ Channel: chantypes.Channel{
+ State: chantypes.INIT,
+ Ordering: order,
+ Counterparty: chantypes.Counterparty{
+ PortId: dstPortId,
+ ChannelId: "",
+ },
+ ConnectionHops: []string{srcConnId},
+ Version: srcVersion,
+ },
+ Signer: acc,
+ }
+
+ return []provider.RelayerMessage{updateMsg, cosmos.NewCosmosMessage(msg, func(signer string) {
+ msg.Signer = signer
+ })}, nil
+}
+
+func (cc *PenumbraProvider) ChannelOpenTry(ctx context.Context, dstQueryProvider provider.QueryProvider, dstHeader ibcexported.ClientMessage, srcPortId, dstPortId, srcChanId, dstChanId, srcVersion, srcConnectionId, srcClientId string) ([]provider.RelayerMessage, error) {
+ var (
+ acc string
+ err error
+ )
+ updateMsg, err := cc.MsgUpdateClient(srcClientId, dstHeader)
+ if err != nil {
+ return nil, err
+ }
+ cph, err := dstQueryProvider.QueryLatestHeight(ctx)
+ if err != nil {
+ return nil, err
+ }
+
+ counterpartyChannelRes, err := dstQueryProvider.QueryChannel(ctx, cph, dstChanId, dstPortId)
+ if err != nil {
+ return nil, err
+ }
+
+ if len(counterpartyChannelRes.Proof) == 0 {
+ // It is possible that we have asked for a proof too early.
+ // If the connection state proof is empty, there is no point in returning the MsgChannelOpenTry.
+ // We are not using (*conntypes.MsgChannelOpenTry).ValidateBasic here because
+ // that chokes on cross-chain bech32 details in ibc-go.
+ return nil, fmt.Errorf("received invalid zero-length channel state proof")
+ }
+
+ if acc, err = cc.Address(); err != nil {
+ return nil, err
+ }
+
+ msg := &chantypes.MsgChannelOpenTry{
+ PortId: srcPortId,
+ PreviousChannelId: srcChanId,
+ Channel: chantypes.Channel{
+ State: chantypes.TRYOPEN,
+ Ordering: counterpartyChannelRes.Channel.Ordering,
+ Counterparty: chantypes.Counterparty{
+ PortId: dstPortId,
+ ChannelId: dstChanId,
+ },
+ ConnectionHops: []string{srcConnectionId},
+ Version: srcVersion,
+ },
+ CounterpartyVersion: counterpartyChannelRes.Channel.Version,
+ ProofInit: counterpartyChannelRes.Proof,
+ ProofHeight: counterpartyChannelRes.ProofHeight,
+ Signer: acc,
+ }
+
+ return []provider.RelayerMessage{updateMsg, cosmos.NewCosmosMessage(msg, func(signer string) {
+ msg.Signer = signer
+ })}, nil
+}
+
+func (cc *PenumbraProvider) ChannelOpenAck(ctx context.Context, dstQueryProvider provider.QueryProvider, dstHeader ibcexported.ClientMessage, srcClientId, srcPortId, srcChanId, dstChanId, dstPortId string) ([]provider.RelayerMessage, error) {
+ var (
+ acc string
+ err error
+ )
+ updateMsg, err := cc.MsgUpdateClient(srcClientId, dstHeader)
+ if err != nil {
+ return nil, err
+ }
+
+ cph, err := dstQueryProvider.QueryLatestHeight(ctx)
+ if err != nil {
+ return nil, err
+ }
+
+ counterpartyChannelRes, err := dstQueryProvider.QueryChannel(ctx, cph, dstChanId, dstPortId)
+ if err != nil {
+ return nil, err
+ }
+
+ if acc, err = cc.Address(); err != nil {
+ return nil, err
+ }
+
+ msg := &chantypes.MsgChannelOpenAck{
+ PortId: srcPortId,
+ ChannelId: srcChanId,
+ CounterpartyChannelId: dstChanId,
+ CounterpartyVersion: counterpartyChannelRes.Channel.Version,
+ ProofTry: counterpartyChannelRes.Proof,
+ ProofHeight: counterpartyChannelRes.ProofHeight,
+ Signer: acc,
+ }
+
+ return []provider.RelayerMessage{updateMsg, cosmos.NewCosmosMessage(msg, func(signer string) {
+ msg.Signer = signer
+ })}, nil
+}
+
+func (cc *PenumbraProvider) ChannelOpenConfirm(ctx context.Context, dstQueryProvider provider.QueryProvider, dstHeader ibcexported.ClientMessage, srcClientId, srcPortId, srcChanId, dstPortId, dstChanId string) ([]provider.RelayerMessage, error) {
+ var (
+ acc string
+ err error
+ )
+ updateMsg, err := cc.MsgUpdateClient(srcClientId, dstHeader)
+ if err != nil {
+ return nil, err
+ }
+ cph, err := dstQueryProvider.QueryLatestHeight(ctx)
+ if err != nil {
+ return nil, err
+ }
+
+ counterpartyChanState, err := dstQueryProvider.QueryChannel(ctx, cph, dstChanId, dstPortId)
+ if err != nil {
+ return nil, err
+ }
+
+ if acc, err = cc.Address(); err != nil {
+ return nil, err
+ }
+
+ msg := &chantypes.MsgChannelOpenConfirm{
+ PortId: srcPortId,
+ ChannelId: srcChanId,
+ ProofAck: counterpartyChanState.Proof,
+ ProofHeight: counterpartyChanState.ProofHeight,
+ Signer: acc,
+ }
+
+ return []provider.RelayerMessage{updateMsg, cosmos.NewCosmosMessage(msg, func(signer string) {
+ msg.Signer = signer
+ })}, nil
+}
+
+func (cc *PenumbraProvider) ChannelCloseInit(srcPortId, srcChanId string) (provider.RelayerMessage, error) {
+ var (
+ acc string
+ err error
+ )
+ if acc, err = cc.Address(); err != nil {
+ return nil, err
+ }
+
+ msg := &chantypes.MsgChannelCloseInit{
+ PortId: srcPortId,
+ ChannelId: srcChanId,
+ Signer: acc,
+ }
+
+ return cosmos.NewCosmosMessage(msg, func(signer string) {
+ msg.Signer = signer
+ }), nil
+}
+
+func (cc *PenumbraProvider) ChannelCloseConfirm(ctx context.Context, dstQueryProvider provider.QueryProvider, dsth int64, dstChanId, dstPortId, srcPortId, srcChanId string) (provider.RelayerMessage, error) {
+ var (
+ acc string
+ err error
+ )
+ dstChanResp, err := dstQueryProvider.QueryChannel(ctx, dsth, dstChanId, dstPortId)
+ if err != nil {
+ return nil, err
+ }
+
+ if acc, err = cc.Address(); err != nil {
+ return nil, err
+ }
+
+ msg := &chantypes.MsgChannelCloseConfirm{
+ PortId: srcPortId,
+ ChannelId: srcChanId,
+ ProofInit: dstChanResp.Proof,
+ ProofHeight: dstChanResp.ProofHeight,
+ Signer: acc,
+ }
+
+ return cosmos.NewCosmosMessage(msg, func(signer string) {
+ msg.Signer = signer
+ }), nil
+}
+
+func (cc *PenumbraProvider) MsgUpgradeClient(srcClientId string, consRes *clienttypes.QueryConsensusStateResponse, clientRes *clienttypes.QueryClientStateResponse) (provider.RelayerMessage, error) {
+ var (
+ acc string
+ err error
+ )
+ if acc, err = cc.Address(); err != nil {
+ return nil, err
+ }
+
+ msgUpgradeClient := &clienttypes.MsgUpgradeClient{ClientId: srcClientId, ClientState: clientRes.ClientState,
+ ConsensusState: consRes.ConsensusState, ProofUpgradeClient: consRes.GetProof(),
+ ProofUpgradeConsensusState: consRes.ConsensusState.Value, Signer: acc}
+
+ return cosmos.NewCosmosMessage(msgUpgradeClient, func(signer string) {
+ msgUpgradeClient.Signer = signer
+ }), nil
+}
+
+func (cc *PenumbraProvider) MsgSubmitMisbehaviour(clientID string, misbehaviour ibcexported.ClientMessage) (provider.RelayerMessage, error) {
+ signer, err := cc.Address()
+ if err != nil {
+ return nil, err
+ }
+
+ msg, err := clienttypes.NewMsgSubmitMisbehaviour(clientID, misbehaviour, signer)
+ if err != nil {
+ return nil, err
+ }
+
+ return NewPenumbraMessage(msg), nil
+}
+
+// mustGetHeight takes the height inteface and returns the actual height
+func mustGetHeight(h ibcexported.Height) clienttypes.Height {
+ height, ok := h.(clienttypes.Height)
+ if !ok {
+ panic("height is not an instance of height!")
+ }
+ return height
+}
+
+// MsgRelayAcknowledgement constructs the MsgAcknowledgement which is to be sent to the sending chain.
+// The counterparty represents the receiving chain where the acknowledgement would be stored.
+func (cc *PenumbraProvider) MsgRelayAcknowledgement(ctx context.Context, dst provider.ChainProvider, dstChanId, dstPortId, srcChanId, srcPortId string, dsth int64, packet provider.RelayPacket) (provider.RelayerMessage, error) {
+ var (
+ acc string
+ err error
+ )
+ msgPacketAck, ok := packet.(*relayMsgPacketAck)
+ if !ok {
+ return nil, fmt.Errorf("got data of type %T but wanted relayMsgPacketAck", packet)
+ }
+
+ if acc, err = cc.Address(); err != nil {
+ return nil, err
+ }
+
+ ackRes, err := dst.QueryPacketAcknowledgement(ctx, dsth, dstChanId, dstPortId, packet.Seq())
+ switch {
+ case err != nil:
+ return nil, err
+ case ackRes.Proof == nil || ackRes.Acknowledgement == nil:
+ return nil, fmt.Errorf("ack packet acknowledgement query seq(%d) is nil", packet.Seq())
+ case ackRes == nil:
+ return nil, fmt.Errorf("ack packet [%s]seq{%d} has no associated proofs", dst.ChainId(), packet.Seq())
+ default:
+ msg := &chantypes.MsgAcknowledgement{
+ Packet: chantypes.Packet{
+ Sequence: packet.Seq(),
+ SourcePort: srcPortId,
+ SourceChannel: srcChanId,
+ DestinationPort: dstPortId,
+ DestinationChannel: dstChanId,
+ Data: packet.Data(),
+ TimeoutHeight: packet.Timeout(),
+ TimeoutTimestamp: packet.TimeoutStamp(),
+ },
+ Acknowledgement: msgPacketAck.ack,
+ ProofAcked: ackRes.Proof,
+ ProofHeight: ackRes.ProofHeight,
+ Signer: acc,
+ }
+
+ return cosmos.NewCosmosMessage(msg, func(signer string) {
+ msg.Signer = signer
+ }), nil
+ }
+}
+
+// MsgTransfer creates a new transfer message
+func (cc *PenumbraProvider) MsgTransfer(
+ dstAddr string,
+ amount sdk.Coin,
+ info provider.PacketInfo,
+) (provider.RelayerMessage, error) {
+ acc, err := cc.Address()
+ if err != nil {
+ return nil, err
+ }
+ msg := &transfertypes.MsgTransfer{
+ SourcePort: info.SourcePort,
+ SourceChannel: info.SourceChannel,
+ Token: amount,
+ Sender: acc,
+ Receiver: dstAddr,
+ TimeoutTimestamp: info.TimeoutTimestamp,
+ }
+
+ // If the timeoutHeight is 0 then we don't need to explicitly set it on the MsgTransfer
+ if info.TimeoutHeight.RevisionHeight != 0 {
+ msg.TimeoutHeight = info.TimeoutHeight
+ }
+
+ msgTransfer := cosmos.NewCosmosMessage(msg, nil).(cosmos.CosmosMessage)
+ msgTransfer.FeegrantDisabled = true
+ return msgTransfer, nil
+}
+
+// MsgRelayTimeout constructs the MsgTimeout which is to be sent to the sending chain.
+// The counterparty represents the receiving chain where the receipts would have been
+// stored.
+func (cc *PenumbraProvider) MsgRelayTimeout(
+ ctx context.Context,
+ dst provider.ChainProvider,
+ dsth int64,
+ packet provider.RelayPacket,
+ dstChanId, dstPortId, srcChanId, srcPortId string,
+ order chantypes.Order,
+) (provider.RelayerMessage, error) {
+ var (
+ acc string
+ err error
+ msg provider.RelayerMessage
+ )
+ if acc, err = cc.Address(); err != nil {
+ return nil, err
+ }
+
+ switch order {
+ case chantypes.UNORDERED:
+ msg, err = cc.unorderedChannelTimeoutMsg(ctx, dst, dsth, packet, acc, dstChanId, dstPortId, srcChanId, srcPortId)
+ if err != nil {
+ return nil, err
+ }
+ case chantypes.ORDERED:
+ msg, err = cc.orderedChannelTimeoutMsg(ctx, dst, dsth, packet, acc, dstChanId, dstPortId, srcChanId, srcPortId)
+ if err != nil {
+ return nil, err
+ }
+ default:
+ return nil, fmt.Errorf("invalid order type %s, order should be %s or %s",
+ order, chantypes.ORDERED, chantypes.UNORDERED)
+ }
+
+ return msg, nil
+}
+
+func (cc *PenumbraProvider) orderedChannelTimeoutMsg(
+ ctx context.Context,
+ dst provider.ChainProvider,
+ dsth int64,
+ packet provider.RelayPacket,
+ acc, dstChanId, dstPortId, srcChanId, srcPortId string,
+) (provider.RelayerMessage, error) {
+ seqRes, err := dst.QueryNextSeqRecv(ctx, dsth, dstChanId, dstPortId)
+ if err != nil {
+ return nil, err
+ }
+
+ if seqRes == nil {
+ return nil, fmt.Errorf("timeout packet [%s]seq{%d} has no associated proofs", cc.PCfg.ChainID, packet.Seq())
+ }
+
+ if seqRes.Proof == nil {
+ return nil, fmt.Errorf("timeout packet next sequence received proof seq(%d) is nil", packet.Seq())
+ }
+
+ msg := &chantypes.MsgTimeout{
+ Packet: chantypes.Packet{
+ Sequence: packet.Seq(),
+ SourcePort: srcPortId,
+ SourceChannel: srcChanId,
+ DestinationPort: dstPortId,
+ DestinationChannel: dstChanId,
+ Data: packet.Data(),
+ TimeoutHeight: packet.Timeout(),
+ TimeoutTimestamp: packet.TimeoutStamp(),
+ },
+ ProofUnreceived: seqRes.Proof,
+ ProofHeight: seqRes.ProofHeight,
+ NextSequenceRecv: packet.Seq(),
+ Signer: acc,
+ }
+
+ return cosmos.NewCosmosMessage(msg, func(signer string) {
+ msg.Signer = signer
+ }), nil
+}
+
+func (cc *PenumbraProvider) unorderedChannelTimeoutMsg(
+ ctx context.Context,
+ dst provider.ChainProvider,
+ dsth int64,
+ packet provider.RelayPacket,
+ acc, dstChanId, dstPortId, srcChanId, srcPortId string,
+) (provider.RelayerMessage, error) {
+ recvRes, err := dst.QueryPacketReceipt(ctx, dsth, dstChanId, dstPortId, packet.Seq())
+ if err != nil {
+ return nil, err
+ }
+
+ if recvRes == nil {
+ return nil, fmt.Errorf("timeout packet [%s]seq{%d} has no associated proofs", cc.PCfg.ChainID, packet.Seq())
+ }
+
+ if recvRes.Proof == nil {
+ return nil, fmt.Errorf("timeout packet receipt proof seq(%d) is nil", packet.Seq())
+ }
+
+ msg := &chantypes.MsgTimeout{
+ Packet: chantypes.Packet{
+ Sequence: packet.Seq(),
+ SourcePort: srcPortId,
+ SourceChannel: srcChanId,
+ DestinationPort: dstPortId,
+ DestinationChannel: dstChanId,
+ Data: packet.Data(),
+ TimeoutHeight: packet.Timeout(),
+ TimeoutTimestamp: packet.TimeoutStamp(),
+ },
+ ProofUnreceived: recvRes.Proof,
+ ProofHeight: recvRes.ProofHeight,
+ NextSequenceRecv: packet.Seq(),
+ Signer: acc,
+ }
+ return cosmos.NewCosmosMessage(msg, func(signer string) {
+ msg.Signer = signer
+ }), nil
+}
+
+// MsgRelayRecvPacket constructs the MsgRecvPacket which is to be sent to the receiving chain.
+// The counterparty represents the sending chain where the packet commitment would be stored.
+func (cc *PenumbraProvider) MsgRelayRecvPacket(ctx context.Context, dst provider.ChainProvider, dsth int64, packet provider.RelayPacket, dstChanId, dstPortId, srcChanId, srcPortId string) (provider.RelayerMessage, error) {
+ var (
+ acc string
+ err error
+ )
+ if acc, err = cc.Address(); err != nil {
+ return nil, err
+ }
+
+ comRes, err := dst.QueryPacketCommitment(ctx, dsth, dstChanId, dstPortId, packet.Seq())
+ switch {
+ case err != nil:
+ return nil, err
+ case comRes.Proof == nil || comRes.Commitment == nil:
+ return nil, fmt.Errorf("recv packet commitment query seq(%d) is nil", packet.Seq())
+ case comRes == nil:
+ return nil, fmt.Errorf("receive packet [%s]seq{%d} has no associated proofs", cc.PCfg.ChainID, packet.Seq())
+ default:
+ msg := &chantypes.MsgRecvPacket{
+ Packet: chantypes.Packet{
+ Sequence: packet.Seq(),
+ SourcePort: dstPortId,
+ SourceChannel: dstChanId,
+ DestinationPort: srcPortId,
+ DestinationChannel: srcChanId,
+ Data: packet.Data(),
+ TimeoutHeight: packet.Timeout(),
+ TimeoutTimestamp: packet.TimeoutStamp(),
+ },
+ ProofCommitment: comRes.Proof,
+ ProofHeight: comRes.ProofHeight,
+ Signer: acc,
+ }
+
+ return cosmos.NewCosmosMessage(msg, func(signer string) {
+ msg.Signer = signer
+ }), nil
+ }
+}
+
+func (cc *PenumbraProvider) ValidatePacket(msgTransfer provider.PacketInfo, latest provider.LatestBlock) error {
+ if msgTransfer.Sequence == 0 {
+ return errors.New("refusing to relay packet with sequence: 0")
+ }
+
+ if len(msgTransfer.Data) == 0 {
+ return errors.New("refusing to relay packet with empty data")
+ }
+
+ // This should not be possible, as it violates IBC spec
+ if msgTransfer.TimeoutHeight.IsZero() && msgTransfer.TimeoutTimestamp == 0 {
+ return errors.New("refusing to relay packet without a timeout (height or timestamp must be set)")
+ }
+
+ revision := clienttypes.ParseChainID(cc.PCfg.ChainID)
+ latestClientTypesHeight := clienttypes.NewHeight(revision, latest.Height)
+ if !msgTransfer.TimeoutHeight.IsZero() && latestClientTypesHeight.GTE(msgTransfer.TimeoutHeight) {
+ return provider.NewTimeoutHeightError(latest.Height, msgTransfer.TimeoutHeight.RevisionHeight)
+ }
+ latestTimestamp := uint64(latest.Time.UnixNano())
+ if msgTransfer.TimeoutTimestamp > 0 && latestTimestamp > msgTransfer.TimeoutTimestamp {
+ return provider.NewTimeoutTimestampError(latestTimestamp, msgTransfer.TimeoutTimestamp)
+ }
+
+ return nil
+}
+
+func (cc *PenumbraProvider) PacketCommitment(ctx context.Context, msgTransfer provider.PacketInfo, height uint64) (provider.PacketProof, error) {
+ key := host.PacketCommitmentKey(msgTransfer.SourcePort, msgTransfer.SourceChannel, msgTransfer.Sequence)
+ _, proof, proofHeight, err := cc.QueryTendermintProof(ctx, int64(height), key)
+ if err != nil {
+ return provider.PacketProof{}, fmt.Errorf("error querying tendermint proof for packet commitment: %w", err)
+ }
+ return provider.PacketProof{
+ Proof: proof,
+ ProofHeight: proofHeight,
+ }, nil
+}
+
+func (cc *PenumbraProvider) MsgRecvPacket(msgTransfer provider.PacketInfo, proof provider.PacketProof) (provider.RelayerMessage, error) {
+ signer, err := cc.Address()
+ if err != nil {
+ return nil, err
+ }
+ msg := &chantypes.MsgRecvPacket{
+ Packet: toPenumbraPacket(msgTransfer),
+ ProofCommitment: proof.Proof,
+ ProofHeight: proof.ProofHeight,
+ Signer: signer,
+ }
+
+ return cosmos.NewCosmosMessage(msg, func(signer string) {
+ msg.Signer = signer
+ }), nil
+}
+
+func (cc *PenumbraProvider) PacketAcknowledgement(ctx context.Context, msgRecvPacket provider.PacketInfo, height uint64) (provider.PacketProof, error) {
+ key := host.PacketAcknowledgementKey(msgRecvPacket.DestPort, msgRecvPacket.DestChannel, msgRecvPacket.Sequence)
+ _, proof, proofHeight, err := cc.QueryTendermintProof(ctx, int64(height), key)
+ if err != nil {
+ return provider.PacketProof{}, fmt.Errorf("error querying tendermint proof for packet acknowledgement: %w", err)
+ }
+ return provider.PacketProof{
+ Proof: proof,
+ ProofHeight: proofHeight,
+ }, nil
+}
+
+func (cc *PenumbraProvider) MsgAcknowledgement(msgRecvPacket provider.PacketInfo, proof provider.PacketProof) (provider.RelayerMessage, error) {
+ signer, err := cc.Address()
+ if err != nil {
+ return nil, err
+ }
+ msg := &chantypes.MsgAcknowledgement{
+ Packet: toPenumbraPacket(msgRecvPacket),
+ Acknowledgement: msgRecvPacket.Ack,
+ ProofAcked: proof.Proof,
+ ProofHeight: proof.ProofHeight,
+ Signer: signer,
+ }
+
+ return cosmos.NewCosmosMessage(msg, func(signer string) {
+ msg.Signer = signer
+ }), nil
+}
+
+func (cc *PenumbraProvider) PacketReceipt(ctx context.Context, msgTransfer provider.PacketInfo, height uint64) (provider.PacketProof, error) {
+ key := host.PacketReceiptKey(msgTransfer.DestPort, msgTransfer.DestChannel, msgTransfer.Sequence)
+ _, proof, proofHeight, err := cc.QueryTendermintProof(ctx, int64(height), key)
+ if err != nil {
+ return provider.PacketProof{}, fmt.Errorf("error querying tendermint proof for packet receipt: %w", err)
+ }
+
+ return provider.PacketProof{
+ Proof: proof,
+ ProofHeight: proofHeight,
+ }, nil
+}
+
+func (cc *PenumbraProvider) MsgTimeoutRequest(msgTransfer provider.PacketInfo, proofUnreceived provider.PacketProof) (provider.RelayerMessage, error) {
+ panic("implement me")
+}
+
+func (cc *PenumbraProvider) MsgTimeout(msgTransfer provider.PacketInfo, proof provider.PacketProof) (provider.RelayerMessage, error) {
+ signer, err := cc.Address()
+ if err != nil {
+ return nil, err
+ }
+ assembled := &chantypes.MsgTimeout{
+ Packet: toPenumbraPacket(msgTransfer),
+ ProofUnreceived: proof.Proof,
+ ProofHeight: proof.ProofHeight,
+ NextSequenceRecv: msgTransfer.Sequence,
+ Signer: signer,
+ }
+
+ return cosmos.NewCosmosMessage(assembled, func(signer string) {
+ assembled.Signer = signer
+ }), nil
+}
+
+func (cc *PenumbraProvider) MsgTimeoutOnClose(msgTransfer provider.PacketInfo, proof provider.PacketProof) (provider.RelayerMessage, error) {
+ signer, err := cc.Address()
+ if err != nil {
+ return nil, err
+ }
+ assembled := &chantypes.MsgTimeoutOnClose{
+ Packet: toPenumbraPacket(msgTransfer),
+ ProofUnreceived: proof.Proof,
+ ProofHeight: proof.ProofHeight,
+ NextSequenceRecv: msgTransfer.Sequence,
+ Signer: signer,
+ }
+
+ return cosmos.NewCosmosMessage(assembled, func(signer string) {
+ assembled.Signer = signer
+ }), nil
+}
+
+func (cc *PenumbraProvider) MsgConnectionOpenInit(info provider.ConnectionInfo, proof provider.ConnectionProof) (provider.RelayerMessage, error) {
+ signer, err := cc.Address()
+ if err != nil {
+ return nil, err
+ }
+ msg := &conntypes.MsgConnectionOpenInit{
+ ClientId: info.ClientID,
+ Counterparty: conntypes.Counterparty{
+ ClientId: info.CounterpartyClientID,
+ ConnectionId: "",
+ Prefix: info.CounterpartyCommitmentPrefix,
+ },
+ Version: conntypes.DefaultIBCVersion,
+ DelayPeriod: defaultDelayPeriod,
+ Signer: signer,
+ }
+
+ return cosmos.NewCosmosMessage(msg, func(signer string) {
+ msg.Signer = signer
+ }), nil
+}
+
+func (cc *PenumbraProvider) ConnectionHandshakeProof(ctx context.Context, msgOpenInit provider.ConnectionInfo, height uint64) (provider.ConnectionProof, error) {
+ clientState, clientStateProof, consensusStateProof, connStateProof, proofHeight, err := cc.GenerateConnHandshakeProof(ctx, int64(height), msgOpenInit.ClientID, msgOpenInit.ConnID)
+ if err != nil {
+ return provider.ConnectionProof{}, err
+ }
+
+ if len(connStateProof) == 0 {
+ // It is possible that we have asked for a proof too early.
+ // If the connection state proof is empty, there is no point in returning the next message.
+ // We are not using (*conntypes.MsgConnectionOpenTry).ValidateBasic here because
+ // that chokes on cross-chain bech32 details in ibc-go.
+ return provider.ConnectionProof{}, fmt.Errorf("received invalid zero-length connection state proof")
+ }
+
+ return provider.ConnectionProof{
+ ClientState: clientState,
+ ClientStateProof: clientStateProof,
+ ConsensusStateProof: consensusStateProof,
+ ConnectionStateProof: connStateProof,
+ ProofHeight: proofHeight.(clienttypes.Height),
+ }, nil
+}
+
+func (cc *PenumbraProvider) MsgConnectionOpenTry(msgOpenInit provider.ConnectionInfo, proof provider.ConnectionProof) (provider.RelayerMessage, error) {
+ signer, err := cc.Address()
+ if err != nil {
+ return nil, err
+ }
+
+ csAny, err := clienttypes.PackClientState(proof.ClientState)
+ if err != nil {
+ return nil, err
+ }
+
+ counterparty := conntypes.Counterparty{
+ ClientId: msgOpenInit.ClientID,
+ ConnectionId: msgOpenInit.ConnID,
+ Prefix: msgOpenInit.CounterpartyCommitmentPrefix,
+ }
+
+ msg := &conntypes.MsgConnectionOpenTry{
+ ClientId: msgOpenInit.CounterpartyClientID,
+ PreviousConnectionId: msgOpenInit.CounterpartyConnID,
+ ClientState: csAny,
+ Counterparty: counterparty,
+ DelayPeriod: defaultDelayPeriod,
+ CounterpartyVersions: conntypes.ExportedVersionsToProto(conntypes.GetCompatibleVersions()),
+ ProofHeight: proof.ProofHeight,
+ ProofInit: proof.ConnectionStateProof,
+ ProofClient: proof.ClientStateProof,
+ ProofConsensus: proof.ConsensusStateProof,
+ ConsensusHeight: proof.ClientState.GetLatestHeight().(clienttypes.Height),
+ Signer: signer,
+ }
+
+ return cosmos.NewCosmosMessage(msg, func(signer string) {
+ msg.Signer = signer
+ }), nil
+}
+
+func (cc *PenumbraProvider) MsgConnectionOpenAck(msgOpenTry provider.ConnectionInfo, proof provider.ConnectionProof) (provider.RelayerMessage, error) {
+ signer, err := cc.Address()
+ if err != nil {
+ return nil, err
+ }
+
+ csAny, err := clienttypes.PackClientState(proof.ClientState)
+ if err != nil {
+ return nil, err
+ }
+
+ msg := &conntypes.MsgConnectionOpenAck{
+ ConnectionId: msgOpenTry.CounterpartyConnID,
+ CounterpartyConnectionId: msgOpenTry.ConnID,
+ Version: conntypes.DefaultIBCVersion,
+ ClientState: csAny,
+ ProofHeight: clienttypes.Height{
+ RevisionNumber: proof.ProofHeight.GetRevisionNumber(),
+ RevisionHeight: proof.ProofHeight.GetRevisionHeight(),
+ },
+ ProofTry: proof.ConnectionStateProof,
+ ProofClient: proof.ClientStateProof,
+ ProofConsensus: proof.ConsensusStateProof,
+ ConsensusHeight: proof.ClientState.GetLatestHeight().(clienttypes.Height),
+ Signer: signer,
+ }
+
+ return cosmos.NewCosmosMessage(msg, func(signer string) {
+ msg.Signer = signer
+ }), nil
+}
+
+// NextSeqRecv queries for the appropriate Tendermint proof required to prove the next expected packet sequence number
+// for a given counterparty channel. This is used in ORDERED channels to ensure packets are being delivered in the
+// exact same order as they were sent over the wire.
+func (cc *PenumbraProvider) NextSeqRecv(
+ ctx context.Context,
+ msgTransfer provider.PacketInfo,
+ height uint64,
+) (provider.PacketProof, error) {
+ key := host.NextSequenceRecvKey(msgTransfer.DestPort, msgTransfer.DestChannel)
+ _, proof, proofHeight, err := cc.QueryTendermintProof(ctx, int64(height), key)
+ if err != nil {
+ return provider.PacketProof{}, fmt.Errorf("error querying tendermint proof for next sequence receive: %w", err)
+ }
+
+ return provider.PacketProof{
+ Proof: proof,
+ ProofHeight: proofHeight,
+ }, nil
+}
+
+func (cc *PenumbraProvider) ConnectionProof(ctx context.Context, msgOpenAck provider.ConnectionInfo, height uint64) (provider.ConnectionProof, error) {
+ connState, err := cc.QueryConnection(ctx, int64(height), msgOpenAck.ConnID)
+ if err != nil {
+ return provider.ConnectionProof{}, err
+ }
+
+ return provider.ConnectionProof{
+ ConnectionStateProof: connState.Proof,
+ ProofHeight: connState.ProofHeight,
+ }, nil
+}
+
+func (cc *PenumbraProvider) MsgConnectionOpenConfirm(msgOpenAck provider.ConnectionInfo, proof provider.ConnectionProof) (provider.RelayerMessage, error) {
+ signer, err := cc.Address()
+ if err != nil {
+ return nil, err
+ }
+ msg := &conntypes.MsgConnectionOpenConfirm{
+ ConnectionId: msgOpenAck.CounterpartyConnID,
+ ProofAck: proof.ConnectionStateProof,
+ ProofHeight: proof.ProofHeight,
+ Signer: signer,
+ }
+
+ return cosmos.NewCosmosMessage(msg, func(signer string) {
+ msg.Signer = signer
+ }), nil
+}
+
+func (cc *PenumbraProvider) MsgChannelOpenInit(info provider.ChannelInfo, proof provider.ChannelProof) (provider.RelayerMessage, error) {
+ signer, err := cc.Address()
+ if err != nil {
+ return nil, err
+ }
+ msg := &chantypes.MsgChannelOpenInit{
+ PortId: info.PortID,
+ Channel: chantypes.Channel{
+ State: chantypes.INIT,
+ Ordering: info.Order,
+ Counterparty: chantypes.Counterparty{
+ PortId: info.CounterpartyPortID,
+ ChannelId: "",
+ },
+ ConnectionHops: []string{info.ConnID},
+ Version: info.Version,
+ },
+ Signer: signer,
+ }
+
+ return cosmos.NewCosmosMessage(msg, func(signer string) {
+ msg.Signer = signer
+ }), nil
+}
+
+func (cc *PenumbraProvider) ChannelProof(ctx context.Context, msg provider.ChannelInfo, height uint64) (provider.ChannelProof, error) {
+ channelRes, err := cc.QueryChannel(ctx, int64(height), msg.ChannelID, msg.PortID)
+ if err != nil {
+ return provider.ChannelProof{}, err
+ }
+ return provider.ChannelProof{
+ Proof: channelRes.Proof,
+ ProofHeight: channelRes.ProofHeight,
+ Version: channelRes.Channel.Version,
+ Ordering: channelRes.Channel.Ordering,
+ }, nil
+}
+
+func (cc *PenumbraProvider) MsgChannelOpenTry(msgOpenInit provider.ChannelInfo, proof provider.ChannelProof) (provider.RelayerMessage, error) {
+ signer, err := cc.Address()
+ if err != nil {
+ return nil, err
+ }
+ msg := &chantypes.MsgChannelOpenTry{
+ PortId: msgOpenInit.CounterpartyPortID,
+ PreviousChannelId: msgOpenInit.CounterpartyChannelID,
+ Channel: chantypes.Channel{
+ State: chantypes.TRYOPEN,
+ Ordering: proof.Ordering,
+ Counterparty: chantypes.Counterparty{
+ PortId: msgOpenInit.PortID,
+ ChannelId: msgOpenInit.ChannelID,
+ },
+ ConnectionHops: []string{msgOpenInit.CounterpartyConnID},
+ // In the future, may need to separate this from the CounterpartyVersion.
+ // https://github.com/cosmos/ibc/tree/master/spec/core/ics-004-channel-and-packet-semantics#definitions
+ // Using same version as counterparty for now.
+ Version: proof.Version,
+ },
+ CounterpartyVersion: proof.Version,
+ ProofInit: proof.Proof,
+ ProofHeight: proof.ProofHeight,
+ Signer: signer,
+ }
+
+ return cosmos.NewCosmosMessage(msg, func(signer string) {
+ msg.Signer = signer
+ }), nil
+}
+
+func (cc *PenumbraProvider) MsgChannelOpenAck(msgOpenTry provider.ChannelInfo, proof provider.ChannelProof) (provider.RelayerMessage, error) {
+ signer, err := cc.Address()
+ if err != nil {
+ return nil, err
+ }
+ msg := &chantypes.MsgChannelOpenAck{
+ PortId: msgOpenTry.CounterpartyPortID,
+ ChannelId: msgOpenTry.CounterpartyChannelID,
+ CounterpartyChannelId: msgOpenTry.ChannelID,
+ CounterpartyVersion: proof.Version,
+ ProofTry: proof.Proof,
+ ProofHeight: proof.ProofHeight,
+ Signer: signer,
+ }
+
+ return cosmos.NewCosmosMessage(msg, func(signer string) {
+ msg.Signer = signer
+ }), nil
+}
+
+func (cc *PenumbraProvider) MsgChannelOpenConfirm(msgOpenAck provider.ChannelInfo, proof provider.ChannelProof) (provider.RelayerMessage, error) {
+ signer, err := cc.Address()
+ if err != nil {
+ return nil, err
+ }
+ msg := &chantypes.MsgChannelOpenConfirm{
+ PortId: msgOpenAck.CounterpartyPortID,
+ ChannelId: msgOpenAck.CounterpartyChannelID,
+ ProofAck: proof.Proof,
+ ProofHeight: proof.ProofHeight,
+ Signer: signer,
+ }
+
+ return cosmos.NewCosmosMessage(msg, func(signer string) {
+ msg.Signer = signer
+ }), nil
+}
+
+func (cc *PenumbraProvider) MsgChannelCloseInit(info provider.ChannelInfo, proof provider.ChannelProof) (provider.RelayerMessage, error) {
+ signer, err := cc.Address()
+ if err != nil {
+ return nil, err
+ }
+ msg := &chantypes.MsgChannelCloseInit{
+ PortId: info.PortID,
+ ChannelId: info.ChannelID,
+ Signer: signer,
+ }
+
+ return cosmos.NewCosmosMessage(msg, func(signer string) {
+ msg.Signer = signer
+ }), nil
+}
+
+func (cc *PenumbraProvider) MsgChannelCloseConfirm(msgCloseInit provider.ChannelInfo, proof provider.ChannelProof) (provider.RelayerMessage, error) {
+ signer, err := cc.Address()
+ if err != nil {
+ return nil, err
+ }
+ msg := &chantypes.MsgChannelCloseConfirm{
+ PortId: msgCloseInit.CounterpartyPortID,
+ ChannelId: msgCloseInit.CounterpartyChannelID,
+ ProofInit: proof.Proof,
+ ProofHeight: proof.ProofHeight,
+ Signer: signer,
+ }
+
+ return cosmos.NewCosmosMessage(msg, func(signer string) {
+ msg.Signer = signer
+ }), nil
+}
+
+func (cc *PenumbraProvider) MsgUpdateClientHeader(latestHeader provider.IBCHeader, trustedHeight clienttypes.Height, trustedHeader provider.IBCHeader) (ibcexported.ClientMessage, error) {
+ trustedCosmosHeader, ok := trustedHeader.(PenumbraIBCHeader)
+ if !ok {
+ return nil, fmt.Errorf("unsupported IBC trusted header type, expected: PenumbraIBCHeader, actual: %T", trustedHeader)
+ }
+
+ latestCosmosHeader, ok := latestHeader.(PenumbraIBCHeader)
+ if !ok {
+ return nil, fmt.Errorf("unsupported IBC header type, expected: PenumbraIBCHeader, actual: %T", latestHeader)
+ }
+
+ trustedValidatorsProto, err := trustedCosmosHeader.ValidatorSet.ToProto()
+ if err != nil {
+ return nil, fmt.Errorf("error converting trusted validators to proto object: %w", err)
+ }
+
+ signedHeaderProto := latestCosmosHeader.SignedHeader.ToProto()
+
+ validatorSetProto, err := latestCosmosHeader.ValidatorSet.ToProto()
+ if err != nil {
+ return nil, fmt.Errorf("error converting validator set to proto object: %w", err)
+ }
+
+ return &tmclient.Header{
+ SignedHeader: signedHeaderProto,
+ ValidatorSet: validatorSetProto,
+ TrustedValidators: trustedValidatorsProto,
+ TrustedHeight: trustedHeight,
+ }, nil
+}
+
+// RelayPacketFromSequence relays a packet with a given seq on src and returns recvPacket msgs, timeoutPacketmsgs and error
+func (cc *PenumbraProvider) RelayPacketFromSequence(
+ ctx context.Context,
+ src provider.ChainProvider,
+ srch, dsth, seq uint64,
+ srcChanID, srcPortID string,
+ order chantypes.Order,
+) (provider.RelayerMessage, provider.RelayerMessage, error) {
+ msgTransfer, err := src.QuerySendPacket(ctx, srcChanID, srcPortID, seq)
+ if err != nil {
+ return nil, nil, err
+ }
+
+ dstTime, err := cc.BlockTime(ctx, int64(dsth))
+ if err != nil {
+ return nil, nil, err
+ }
+
+ if err := cc.ValidatePacket(msgTransfer, provider.LatestBlock{
+ Height: dsth,
+ Time: dstTime,
+ }); err != nil {
+ switch err.(type) {
+ case *provider.TimeoutHeightError, *provider.TimeoutTimestampError, *provider.TimeoutOnCloseError:
+ var pp provider.PacketProof
+ switch order {
+ case chantypes.UNORDERED:
+ pp, err = cc.PacketReceipt(ctx, msgTransfer, dsth)
+ if err != nil {
+ return nil, nil, err
+ }
+ case chantypes.ORDERED:
+ pp, err = cc.NextSeqRecv(ctx, msgTransfer, dsth)
+ if err != nil {
+ return nil, nil, err
+ }
+ }
+ if _, ok := err.(*provider.TimeoutOnCloseError); ok {
+ timeout, err := src.MsgTimeoutOnClose(msgTransfer, pp)
+ if err != nil {
+ return nil, nil, err
+ }
+ return nil, timeout, nil
+ } else {
+ timeout, err := src.MsgTimeout(msgTransfer, pp)
+ if err != nil {
+ return nil, nil, err
+ }
+ return nil, timeout, nil
+ }
+ default:
+ return nil, nil, err
+ }
+ }
+
+ pp, err := src.PacketCommitment(ctx, msgTransfer, srch)
+ if err != nil {
+ return nil, nil, err
+ }
+
+ packet, err := cc.MsgRecvPacket(msgTransfer, pp)
+ if err != nil {
+ return nil, nil, err
+ }
+
+ return packet, nil, nil
+}
+
+// AcknowledgementFromSequence relays an acknowledgement with a given seq on src, source is the sending chain, destination is the receiving chain
+func (cc *PenumbraProvider) AcknowledgementFromSequence(ctx context.Context, dst provider.ChainProvider, dsth, seq uint64, dstChanId, dstPortId, srcChanId, srcPortId string) (provider.RelayerMessage, error) {
+ txs, err := dst.QueryTxs(ctx, 1, 1000, ackPacketQuery(dstChanId, int(seq)))
+ switch {
+ case err != nil:
+ return nil, err
+ case len(txs) == 0:
+ return nil, fmt.Errorf("no transactions returned with query")
+ case len(txs) > 1:
+ return nil, fmt.Errorf("more than one transaction returned with query")
+ }
+
+ acks, err := cc.acknowledgementsFromResultTx(dstChanId, dstPortId, srcChanId, srcPortId, txs[0])
+ switch {
+ case err != nil:
+ return nil, err
+ case len(acks) == 0:
+ return nil, fmt.Errorf("no ack msgs created from query response")
+ }
+
+ var out provider.RelayerMessage
+ for _, ack := range acks {
+ if seq != ack.Seq() {
+ continue
+ }
+ msg, err := cc.MsgRelayAcknowledgement(ctx, dst, dstChanId, dstPortId, srcChanId, srcPortId, int64(dsth), ack)
+ if err != nil {
+ return nil, err
+ }
+ out = msg
+ }
+ return out, nil
+}
+
+func rcvPacketQuery(channelID string, seq int) []string {
+ return []string{fmt.Sprintf("%s.packet_src_channel='%s'", spTag, channelID),
+ fmt.Sprintf("%s.packet_sequence='%d'", spTag, seq)}
+}
+
+func ackPacketQuery(channelID string, seq int) []string {
+ return []string{fmt.Sprintf("%s.packet_dst_channel='%s'", waTag, channelID),
+ fmt.Sprintf("%s.packet_sequence='%d'", waTag, seq)}
+}
+
+// acknowledgementsFromResultTx looks through the events in a *ctypes.ResultTx and returns
+// relayPackets with the appropriate data
+func (cc *PenumbraProvider) acknowledgementsFromResultTx(dstChanId, dstPortId, srcChanId, srcPortId string, resp *provider.RelayerTxResponse) ([]provider.RelayPacket, error) {
+ var ackPackets []provider.RelayPacket
+
+EventLoop:
+ for _, event := range resp.Events {
+ rp := &relayMsgPacketAck{}
+
+ if event.EventType != waTag {
+ continue
+ }
+
+ for attributeKey, attributeValue := range event.Attributes {
+
+ switch attributeKey {
+ case srcChanTag:
+ if attributeValue != srcChanId {
+ continue EventLoop
+ }
+ case dstChanTag:
+ if attributeValue != dstChanId {
+ continue EventLoop
+ }
+ case srcPortTag:
+ if attributeValue != srcPortId {
+ continue EventLoop
+ }
+ case dstPortTag:
+ if attributeValue != dstPortId {
+ continue EventLoop
+ }
+ case ackTag:
+ rp.ack = []byte(attributeValue)
+ case dataTag:
+ rp.packetData = []byte(attributeValue)
+ case toHeightTag:
+ timeout, err := clienttypes.ParseHeight(attributeValue)
+ if err != nil {
+ cc.log.Warn("error parsing height timeout",
+ zap.String("chain_id", cc.ChainId()),
+ zap.Uint64("sequence", rp.seq),
+ zap.Error(err),
+ )
+ continue EventLoop
+ }
+ rp.timeout = timeout
+ case toTSTag:
+ timeout, err := strconv.ParseUint(attributeValue, 10, 64)
+ if err != nil {
+ cc.log.Warn("error parsing timestamp timeout",
+ zap.String("chain_id", cc.ChainId()),
+ zap.Uint64("sequence", rp.seq),
+ zap.Error(err),
+ )
+ continue EventLoop
+ }
+ rp.timeoutStamp = timeout
+ case seqTag:
+ seq, err := strconv.ParseUint(attributeValue, 10, 64)
+ if err != nil {
+ cc.log.Warn("error parsing packet sequence",
+ zap.String("chain_id", cc.ChainId()),
+ zap.Error(err),
+ )
+ continue EventLoop
+ }
+ rp.seq = seq
+ }
+ }
+
+ // If packet data is nil or sequence number is 0 keep parsing events,
+ // also check that at least the block height or timestamp is set.
+ if rp.ack == nil || rp.packetData == nil || rp.seq == 0 || (rp.timeout.IsZero() && rp.timeoutStamp == 0) {
+ continue
+ }
+
+ ackPackets = append(ackPackets, rp)
+
+ }
+
+ // If there is a relayPacket, return it
+ if len(ackPackets) > 0 {
+ return ackPackets, nil
+ }
+
+ return nil, fmt.Errorf("no packet data found")
+}
+
+// GetIBCUpdateHeader updates the off chain tendermint light client and
+// returns an IBC Update Header which can be used to update an on chain
+// light client on the destination chain. The source is used to construct
+// the header data.
+func (cc *PenumbraProvider) GetIBCUpdateHeader(ctx context.Context, srch int64, dst provider.ChainProvider, dstClientId string) (ibcexported.ClientMessage, error) {
+ // Construct header data from light client representing source.
+ h, err := cc.GetLightSignedHeaderAtHeight(ctx, srch)
+ if err != nil {
+ return nil, err
+ }
+
+ // Inject trusted fields based on previous header data from source
+ return cc.InjectTrustedFields(ctx, h, dst, dstClientId)
+}
+
+func (cc *PenumbraProvider) IBCHeaderAtHeight(ctx context.Context, h int64) (provider.IBCHeader, error) {
+ if h == 0 {
+ return nil, fmt.Errorf("height cannot be 0")
+ }
+
+ lightBlock, err := cc.LightProvider.LightBlock(ctx, h)
+ if err != nil {
+ return nil, err
+ }
+
+ return PenumbraIBCHeader{
+ SignedHeader: lightBlock.SignedHeader,
+ ValidatorSet: lightBlock.ValidatorSet,
+ }, nil
+}
+
+func (cc *PenumbraProvider) GetLightSignedHeaderAtHeight(ctx context.Context, h int64) (ibcexported.ClientMessage, error) {
+ if h == 0 {
+ return nil, fmt.Errorf("height cannot be 0")
+ }
+
+ lightBlock, err := cc.LightProvider.LightBlock(ctx, h)
+ if err != nil {
+ return nil, err
+ }
+
+ protoVal, err := tmtypes.NewValidatorSet(lightBlock.ValidatorSet.Validators).ToProto()
+ if err != nil {
+ return nil, err
+ }
+
+ return &tmclient.Header{
+ SignedHeader: lightBlock.SignedHeader.ToProto(),
+ ValidatorSet: protoVal,
+ }, nil
+}
+
+// InjectTrustedFields injects the necessary trusted fields for a header to update a light
+// client stored on the destination chain, using the information provided by the source
+// chain.
+// TrustedHeight is the latest height of the IBC client on dst
+// TrustedValidators is the validator set of srcChain at the TrustedHeight
+// InjectTrustedFields returns a copy of the header with TrustedFields modified
+func (cc *PenumbraProvider) InjectTrustedFields(ctx context.Context, header ibcexported.ClientMessage, dst provider.ChainProvider, dstClientId string) (ibcexported.ClientMessage, error) {
+ // make copy of header stored in mop
+ h, ok := header.(*tmclient.Header)
+ if !ok {
+ return nil, fmt.Errorf("trying to inject fields into non-tendermint headers")
+ }
+
+ // retrieve dst client from src chain
+ // this is the client that will be updated
+ cs, err := dst.QueryClientState(ctx, int64(h.TrustedHeight.RevisionHeight), dstClientId)
+ if err != nil {
+ return nil, err
+ }
+
+ // inject TrustedHeight as latest height stored on dst client
+ h.TrustedHeight = cs.GetLatestHeight().(clienttypes.Height)
+
+ // NOTE: We need to get validators from the source chain at height: trustedHeight+1
+ // since the last trusted validators for a header at height h is the NextValidators
+ // at h+1 committed to in header h by NextValidatorsHash
+
+ // TODO: this is likely a source of off by 1 errors but may be impossible to change? Maybe this is the
+ // place where we need to fix the upstream query proof issue?
+ var trustedHeader *tmclient.Header
+ if err := retry.Do(func() error {
+ tmpHeader, err := cc.GetLightSignedHeaderAtHeight(ctx, int64(h.TrustedHeight.RevisionHeight+1))
+ if err != nil {
+ return err
+ }
+
+ th, ok := tmpHeader.(*tmclient.Header)
+ if !ok {
+ err = fmt.Errorf("non-tm client header")
+ }
+
+ trustedHeader = th
+ return err
+ }, retry.Context(ctx), rtyAtt, rtyDel, rtyErr); err != nil {
+ return nil, fmt.Errorf(
+ "failed to get trusted header, please ensure header at the height %d has not been pruned by the connected node: %w",
+ h.TrustedHeight.RevisionHeight, err,
+ )
+ }
+
+ // inject TrustedValidators into header
+ h.TrustedValidators = trustedHeader.ValidatorSet
+ return h, nil
+}
+
+// queryTMClientState retrieves the latest consensus state for a client in state at a given height
+// and unpacks/cast it to tendermint clientstate
+func (cc *PenumbraProvider) queryTMClientState(ctx context.Context, srch int64, srcClientId string) (*tmclient.ClientState, error) {
+ clientStateRes, err := cc.QueryClientStateResponse(ctx, srch, srcClientId)
+ if err != nil {
+ return &tmclient.ClientState{}, err
+ }
+
+ return castClientStateToTMType(clientStateRes.ClientState)
+}
+
+// castClientStateToTMType casts client state to tendermint type
+func castClientStateToTMType(cs *codectypes.Any) (*tmclient.ClientState, error) {
+ clientStateExported, err := clienttypes.UnpackClientState(cs)
+ if err != nil {
+ return &tmclient.ClientState{}, err
+ }
+
+ // cast from interface to concrete type
+ clientState, ok := clientStateExported.(*tmclient.ClientState)
+ if !ok {
+ return &tmclient.ClientState{},
+ fmt.Errorf("error when casting exported clientstate to tendermint type")
+ }
+
+ return clientState, nil
+}
+
+// DefaultUpgradePath is the default IBC upgrade path set for an on-chain light client
+var defaultUpgradePath = []string{"upgrade", "upgradedIBCState"}
+
+var JmtSpec = &ics23.ProofSpec{
+ LeafSpec: &ics23.LeafOp{
+ Hash: ics23.HashOp_SHA256,
+ PrehashKey: ics23.HashOp_SHA256,
+ PrehashValue: ics23.HashOp_SHA256,
+ Length: ics23.LengthOp_NO_PREFIX,
+ Prefix: []byte("JMT::LeafNode"),
+ },
+ InnerSpec: &ics23.InnerSpec{
+ Hash: ics23.HashOp_SHA256,
+ ChildOrder: []int32{0, 1},
+ MinPrefixLength: 16,
+ MaxPrefixLength: 16,
+ ChildSize: 32,
+ EmptyChild: []byte("SPARSE_MERKLE_PLACEHOLDER_HASH__"),
+ },
+ MinDepth: 0,
+ MaxDepth: 64,
+ PrehashKeyBeforeComparison: true,
+}
+
+var ApphashSpec = &ics23.ProofSpec{
+ LeafSpec: &ics23.LeafOp{
+ Prefix: nil,
+ Hash: ics23.HashOp_SHA256,
+ Length: ics23.LengthOp_NO_PREFIX,
+ PrehashKey: ics23.HashOp_NO_HASH,
+ PrehashValue: ics23.HashOp_NO_HASH,
+ },
+ InnerSpec: &ics23.InnerSpec{
+ Hash: ics23.HashOp_SHA256,
+ MaxPrefixLength: 0,
+ MinPrefixLength: 0,
+ ChildOrder: []int32{0, 1},
+ ChildSize: 32,
+ EmptyChild: nil,
+ },
+ MinDepth: 0,
+ MaxDepth: 1,
+ PrehashKeyBeforeComparison: true,
+}
+
+var PenumbraProofSpecs = []*ics23.ProofSpec{JmtSpec, ApphashSpec}
+
+// NewClientState creates a new tendermint client state tracking the dst chain.
+func (cc *PenumbraProvider) NewClientState(
+ dstChainID string,
+ dstUpdateHeader provider.IBCHeader,
+ dstTrustingPeriod,
+ dstUbdPeriod time.Duration,
+ allowUpdateAfterExpiry,
+ allowUpdateAfterMisbehaviour bool,
+) (ibcexported.ClientState, error) {
+ revisionNumber := clienttypes.ParseChainID(dstChainID)
+
+ // Create the ClientState we want on 'c' tracking 'dst'
+ return &tmclient.ClientState{
+ ChainId: dstChainID,
+ TrustLevel: tmclient.NewFractionFromTm(light.DefaultTrustLevel),
+ TrustingPeriod: dstTrustingPeriod,
+ UnbondingPeriod: dstUbdPeriod,
+ MaxClockDrift: time.Minute * 10,
+ FrozenHeight: clienttypes.ZeroHeight(),
+ LatestHeight: clienttypes.Height{
+ RevisionNumber: revisionNumber,
+ RevisionHeight: dstUpdateHeader.Height(),
+ },
+ ProofSpecs: PenumbraProofSpecs,
+ UpgradePath: defaultUpgradePath,
+ AllowUpdateAfterExpiry: allowUpdateAfterExpiry,
+ AllowUpdateAfterMisbehaviour: allowUpdateAfterMisbehaviour,
+ }, nil
+}
+
+// QueryIBCHeader returns the IBC compatible block header (CosmosIBCHeader) at a specific height.
+func (cc *PenumbraProvider) QueryIBCHeader(ctx context.Context, h int64) (provider.IBCHeader, error) {
+ if h == 0 {
+ return nil, fmt.Errorf("height cannot be 0")
+ }
+
+ lightBlock, err := cc.LightProvider.LightBlock(ctx, h)
+ if err != nil {
+ return nil, err
+ }
+
+ return PenumbraIBCHeader{
+ SignedHeader: lightBlock.SignedHeader,
+ ValidatorSet: lightBlock.ValidatorSet,
+ }, nil
+}
+
+// QueryABCI performs an ABCI query and returns the appropriate response and error sdk error code.
+func (cc *PenumbraProvider) QueryABCI(ctx context.Context, req abci.RequestQuery) (abci.ResponseQuery, error) {
+ opts := rpcclient.ABCIQueryOptions{
+ Height: req.Height,
+ Prove: req.Prove,
+ }
+ result, err := cc.RPCClient.ABCIQueryWithOptions(ctx, req.Path, req.Data, opts)
+ if err != nil {
+ return abci.ResponseQuery{}, err
+ }
+
+ if !result.Response.IsOK() {
+ return abci.ResponseQuery{}, sdkErrorToGRPCError(result.Response)
+ }
+
+ // data from trusted node or subspace query doesn't need verification
+ if !opts.Prove || !isQueryStoreWithProof(req.Path) {
+ return result.Response, nil
+ }
+
+ return result.Response, nil
+}
+
+func sdkErrorToGRPCError(resp abci.ResponseQuery) error {
+ switch resp.Code {
+ case sdkerrors.ErrInvalidRequest.ABCICode():
+ return status.Error(codes.InvalidArgument, resp.Log)
+ case sdkerrors.ErrUnauthorized.ABCICode():
+ return status.Error(codes.Unauthenticated, resp.Log)
+ case sdkerrors.ErrKeyNotFound.ABCICode():
+ return status.Error(codes.NotFound, resp.Log)
+ default:
+ return status.Error(codes.Unknown, resp.Log)
+ }
+}
+
+// isQueryStoreWithProof expects a format like ///
+// queryType must be "store" and subpath must be "key" to require a proof.
+func isQueryStoreWithProof(path string) bool {
+ if !strings.HasPrefix(path, "/") {
+ return false
+ }
+
+ paths := strings.SplitN(path[1:], "/", 3)
+
+ switch {
+ case len(paths) != 3:
+ return false
+ case paths[0] != "store":
+ return false
+ case rootmulti.RequireProof("/" + paths[2]):
+ return true
+ }
+
+ return false
+}
+
+// sdkError will return the Cosmos SDK registered error for a given codespace/code combo if registered, otherwise nil.
+func (cc *PenumbraProvider) sdkError(codespace string, code uint32) error {
+ // ABCIError will return an error other than "unknown" if syncRes.Code is a registered error in syncRes.Codespace
+ // This catches all of the sdk errors https://github.com/cosmos/cosmos-sdk/blob/f10f5e5974d2ecbf9efc05bc0bfe1c99fdeed4b6/types/errors/errors.go
+ err := errors.Unwrap(sdkerrors.ABCIError(codespace, code, "error broadcasting transaction"))
+ if err.Error() != errUnknown {
+ return err
+ }
+ return nil
+}
+
+// broadcastTx broadcasts a transaction with the given raw bytes and then, in an async goroutine, waits for the tx to be included in the block.
+// The wait will end after either the asyncTimeout has run out or the asyncCtx exits.
+// If there is no error broadcasting, the asyncCallback will be called with success/failure of the wait for block inclusion.
+func (cc *PenumbraProvider) broadcastTx(
+ ctx context.Context, // context for tx broadcast
+ tx []byte, // raw tx to be broadcasted
+ msgs []provider.RelayerMessage, // used for logging only
+ fees sdk.Coins, // used for metrics
+
+ asyncCtx context.Context, // context for async wait for block inclusion after successful tx broadcast
+ asyncTimeout time.Duration, // timeout for waiting for block inclusion
+ asyncCallback func(*provider.RelayerTxResponse, error), // callback for success/fail of the wait for block inclusion
+) error {
+ res, err := cc.RPCClient.BroadcastTxSync(ctx, tx)
+ isErr := err != nil
+ isFailed := res != nil && res.Code != 0
+ if isErr || isFailed {
+ if isErr && res == nil {
+ // There are some cases where BroadcastTxSync will return an error but the associated
+ // ResultBroadcastTx will be nil.
+ return err
+ }
+ rlyResp := &provider.RelayerTxResponse{
+ TxHash: res.Hash.String(),
+ Codespace: res.Codespace,
+ Code: res.Code,
+ Data: res.Data.String(),
+ }
+ if isFailed {
+ err = cc.sdkError(res.Codespace, res.Code)
+ if err == nil {
+ err = fmt.Errorf("transaction failed to execute")
+ }
+ }
+ cc.LogFailedTx(rlyResp, err, msgs)
+ return err
+ }
+
+ // TODO: maybe we need to check if the node has tx indexing enabled?
+ // if not, we need to find a new way to block until inclusion in a block
+
+ go cc.waitForTx(asyncCtx, res.Hash, msgs, asyncTimeout, asyncCallback)
+
+ return nil
+}
+
+// waitForTx waits for a transaction to be included in a block, logs success/fail, then invokes callback.
+// This is intended to be called as an async goroutine.
+func (cc *PenumbraProvider) waitForTx(
+ ctx context.Context,
+ txHash []byte,
+ msgs []provider.RelayerMessage, // used for logging only
+ waitTimeout time.Duration,
+ callback func(*provider.RelayerTxResponse, error),
+) {
+ res, err := cc.waitForBlockInclusion(ctx, txHash, waitTimeout)
+ if err != nil {
+ cc.log.Error("Failed to wait for block inclusion", zap.Error(err))
+ if callback != nil {
+ callback(nil, err)
+ }
+ return
+ }
+
+ rlyResp := &provider.RelayerTxResponse{
+ Height: res.Height,
+ TxHash: res.TxHash,
+ Codespace: res.Codespace,
+ Code: res.Code,
+ Data: res.Data,
+ Events: parseEventsFromTxResponse(res),
+ }
+
+ // transaction was executed, log the success or failure using the tx response code
+ // NOTE: error is nil, logic should use the returned error to determine if the
+ // transaction was successfully executed.
+
+ if res.Code != 0 {
+ // Check for any registered SDK errors
+ err := cc.sdkError(res.Codespace, res.Code)
+ if err == nil {
+ err = fmt.Errorf("transaction failed to execute")
+ }
+ if callback != nil {
+ callback(nil, err)
+ }
+ cc.LogFailedTx(rlyResp, nil, msgs)
+ return
+ }
+
+ if callback != nil {
+ callback(rlyResp, nil)
+ }
+ cc.LogSuccessTx(res, msgs)
+}
+
+// waitForBlockInclusion will wait for a transaction to be included in a block, up to waitTimeout or context cancellation.
+func (cc *PenumbraProvider) waitForBlockInclusion(
+ ctx context.Context,
+ txHash []byte,
+ waitTimeout time.Duration,
+) (*sdk.TxResponse, error) {
+ exitAfter := time.After(waitTimeout)
+ for {
+ select {
+ case <-exitAfter:
+ return nil, fmt.Errorf("timed out after: %d; %w", waitTimeout, ErrTimeoutAfterWaitingForTxBroadcast)
+ // This fixed poll is fine because it's only for logging and updating prometheus metrics currently.
+ case <-time.After(time.Millisecond * 100):
+ res, err := cc.RPCClient.Tx(ctx, txHash, false)
+ if err == nil {
+ return cc.mkTxResult(res)
+ }
+ if strings.Contains(err.Error(), "transaction indexing is disabled") {
+ return nil, fmt.Errorf("cannot determine success/failure of tx because transaction indexing is disabled on rpc url")
+ }
+ case <-ctx.Done():
+ return nil, ctx.Err()
+ }
+ }
+}
+
+// mkTxResult decodes a comet transaction into an SDK TxResponse.
+func (cc *PenumbraProvider) mkTxResult(resTx *coretypes.ResultTx) (*sdk.TxResponse, error) {
+ txbz, err := cc.Codec.TxConfig.TxDecoder()(resTx.Tx)
+ if err != nil {
+ return nil, err
+ }
+ p, ok := txbz.(intoAny)
+ if !ok {
+ return nil, fmt.Errorf("expecting a type implementing intoAny, got: %T", txbz)
+ }
+ any := p.AsAny()
+ return sdk.NewResponseResultTx(resTx, any, ""), nil
+}
+
+func (cc *PenumbraProvider) MsgSubmitQueryResponse(chainID string, queryID provider.ClientICQQueryID, proof provider.ICQProof) (provider.RelayerMessage, error) {
+ //TODO implement me
+ panic("implement me")
+}
+
+func (cc *PenumbraProvider) SendMessagesToMempool(ctx context.Context, msgs []provider.RelayerMessage, memo string, asyncCtx context.Context, asyncCallback []func(*provider.RelayerTxResponse, error)) error {
+ sendRsp, err := cc.sendMessagesInner(ctx, msgs, memo)
+ cc.log.Debug("Received response from sending messages", zap.Any("response", sendRsp), zap.Error(err))
+ return err
+}
+
+// MsgRegisterCounterpartyPayee creates an sdk.Msg to broadcast the counterparty address
+func (cc *PenumbraProvider) MsgRegisterCounterpartyPayee(portID, channelID, relayerAddr, counterpartyPayee string) (provider.RelayerMessage, error) {
+ //TODO implement me
+ panic("implement me")
+}
diff --git a/relayer/chains/penumbra/view/v1alpha1/view.pb.go b/relayer/chains/penumbra/view/v1alpha1/view.pb.go
new file mode 100644
index 000000000..35056567e
--- /dev/null
+++ b/relayer/chains/penumbra/view/v1alpha1/view.pb.go
@@ -0,0 +1,15438 @@
+// Code generated by protoc-gen-gogo. DO NOT EDIT.
+// source: penumbra/view/v1alpha1/view.proto
+
+package viewv1alpha1
+
+import (
+ context "context"
+ fmt "fmt"
+ grpc1 "github.com/cosmos/gogoproto/grpc"
+ proto "github.com/cosmos/gogoproto/proto"
+ v1alpha14 "github.com/cosmos/relayer/v2/relayer/chains/penumbra/core/chain/v1alpha1"
+ v1alpha11 "github.com/cosmos/relayer/v2/relayer/chains/penumbra/core/crypto/v1alpha1"
+ v1alpha15 "github.com/cosmos/relayer/v2/relayer/chains/penumbra/core/dex/v1alpha1"
+ v1alpha12 "github.com/cosmos/relayer/v2/relayer/chains/penumbra/core/ibc/v1alpha1"
+ v1alpha13 "github.com/cosmos/relayer/v2/relayer/chains/penumbra/core/stake/v1alpha1"
+ v1alpha1 "github.com/cosmos/relayer/v2/relayer/chains/penumbra/core/transaction/v1alpha1"
+ grpc "google.golang.org/grpc"
+ codes "google.golang.org/grpc/codes"
+ status "google.golang.org/grpc/status"
+ io "io"
+ math "math"
+ math_bits "math/bits"
+)
+
+// Reference imports to suppress errors if they are not otherwise used.
+var _ = proto.Marshal
+var _ = fmt.Errorf
+var _ = math.Inf
+
+// This is a compile-time assertion to ensure that this generated file
+// is compatible with the proto package it is being compiled against.
+// A compilation error at this line likely means your copy of the
+// proto package needs to be updated.
+const _ = proto.GoGoProtoPackageIsVersion3 // please upgrade the proto package
+
+type AuthorizeAndBuildRequest struct {
+ // The transaction plan to authorize and build.
+ TransactionPlan *v1alpha1.TransactionPlan `protobuf:"bytes,1,opt,name=transaction_plan,json=transactionPlan,proto3" json:"transaction_plan,omitempty"`
+ // The authorization data to use to authorize the transaction plan.
+ AuthorizationData *v1alpha1.AuthorizationData `protobuf:"bytes,2,opt,name=authorization_data,json=authorizationData,proto3" json:"authorization_data,omitempty"`
+}
+
+func (m *AuthorizeAndBuildRequest) Reset() { *m = AuthorizeAndBuildRequest{} }
+func (m *AuthorizeAndBuildRequest) String() string { return proto.CompactTextString(m) }
+func (*AuthorizeAndBuildRequest) ProtoMessage() {}
+func (*AuthorizeAndBuildRequest) Descriptor() ([]byte, []int) {
+ return fileDescriptor_0aa947b204e6a7c2, []int{0}
+}
+func (m *AuthorizeAndBuildRequest) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *AuthorizeAndBuildRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_AuthorizeAndBuildRequest.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *AuthorizeAndBuildRequest) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_AuthorizeAndBuildRequest.Merge(m, src)
+}
+func (m *AuthorizeAndBuildRequest) XXX_Size() int {
+ return m.Size()
+}
+func (m *AuthorizeAndBuildRequest) XXX_DiscardUnknown() {
+ xxx_messageInfo_AuthorizeAndBuildRequest.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_AuthorizeAndBuildRequest proto.InternalMessageInfo
+
+func (m *AuthorizeAndBuildRequest) GetTransactionPlan() *v1alpha1.TransactionPlan {
+ if m != nil {
+ return m.TransactionPlan
+ }
+ return nil
+}
+
+func (m *AuthorizeAndBuildRequest) GetAuthorizationData() *v1alpha1.AuthorizationData {
+ if m != nil {
+ return m.AuthorizationData
+ }
+ return nil
+}
+
+type AuthorizeAndBuildResponse struct {
+ // The transaction that was built.
+ Transaction *v1alpha1.Transaction `protobuf:"bytes,1,opt,name=transaction,proto3" json:"transaction,omitempty"`
+}
+
+func (m *AuthorizeAndBuildResponse) Reset() { *m = AuthorizeAndBuildResponse{} }
+func (m *AuthorizeAndBuildResponse) String() string { return proto.CompactTextString(m) }
+func (*AuthorizeAndBuildResponse) ProtoMessage() {}
+func (*AuthorizeAndBuildResponse) Descriptor() ([]byte, []int) {
+ return fileDescriptor_0aa947b204e6a7c2, []int{1}
+}
+func (m *AuthorizeAndBuildResponse) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *AuthorizeAndBuildResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_AuthorizeAndBuildResponse.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *AuthorizeAndBuildResponse) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_AuthorizeAndBuildResponse.Merge(m, src)
+}
+func (m *AuthorizeAndBuildResponse) XXX_Size() int {
+ return m.Size()
+}
+func (m *AuthorizeAndBuildResponse) XXX_DiscardUnknown() {
+ xxx_messageInfo_AuthorizeAndBuildResponse.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_AuthorizeAndBuildResponse proto.InternalMessageInfo
+
+func (m *AuthorizeAndBuildResponse) GetTransaction() *v1alpha1.Transaction {
+ if m != nil {
+ return m.Transaction
+ }
+ return nil
+}
+
+type BroadcastTransactionRequest struct {
+ // The transaction to broadcast.
+ Transaction *v1alpha1.Transaction `protobuf:"bytes,1,opt,name=transaction,proto3" json:"transaction,omitempty"`
+ // If true, wait for the view service to detect the transaction during sync.
+ AwaitDetection bool `protobuf:"varint,2,opt,name=await_detection,json=awaitDetection,proto3" json:"await_detection,omitempty"`
+}
+
+func (m *BroadcastTransactionRequest) Reset() { *m = BroadcastTransactionRequest{} }
+func (m *BroadcastTransactionRequest) String() string { return proto.CompactTextString(m) }
+func (*BroadcastTransactionRequest) ProtoMessage() {}
+func (*BroadcastTransactionRequest) Descriptor() ([]byte, []int) {
+ return fileDescriptor_0aa947b204e6a7c2, []int{2}
+}
+func (m *BroadcastTransactionRequest) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *BroadcastTransactionRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_BroadcastTransactionRequest.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *BroadcastTransactionRequest) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_BroadcastTransactionRequest.Merge(m, src)
+}
+func (m *BroadcastTransactionRequest) XXX_Size() int {
+ return m.Size()
+}
+func (m *BroadcastTransactionRequest) XXX_DiscardUnknown() {
+ xxx_messageInfo_BroadcastTransactionRequest.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_BroadcastTransactionRequest proto.InternalMessageInfo
+
+func (m *BroadcastTransactionRequest) GetTransaction() *v1alpha1.Transaction {
+ if m != nil {
+ return m.Transaction
+ }
+ return nil
+}
+
+func (m *BroadcastTransactionRequest) GetAwaitDetection() bool {
+ if m != nil {
+ return m.AwaitDetection
+ }
+ return false
+}
+
+type BroadcastTransactionResponse struct {
+ // The hash of the transaction that was broadcast.
+ Id *v1alpha1.Id `protobuf:"bytes,1,opt,name=id,proto3" json:"id,omitempty"`
+ // The height in which the transaction was detected as included in the chain, if any.
+ // Will not be included unless await_detection was true.
+ DetectionHeight uint64 `protobuf:"varint,2,opt,name=detection_height,json=detectionHeight,proto3" json:"detection_height,omitempty"`
+}
+
+func (m *BroadcastTransactionResponse) Reset() { *m = BroadcastTransactionResponse{} }
+func (m *BroadcastTransactionResponse) String() string { return proto.CompactTextString(m) }
+func (*BroadcastTransactionResponse) ProtoMessage() {}
+func (*BroadcastTransactionResponse) Descriptor() ([]byte, []int) {
+ return fileDescriptor_0aa947b204e6a7c2, []int{3}
+}
+func (m *BroadcastTransactionResponse) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *BroadcastTransactionResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_BroadcastTransactionResponse.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *BroadcastTransactionResponse) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_BroadcastTransactionResponse.Merge(m, src)
+}
+func (m *BroadcastTransactionResponse) XXX_Size() int {
+ return m.Size()
+}
+func (m *BroadcastTransactionResponse) XXX_DiscardUnknown() {
+ xxx_messageInfo_BroadcastTransactionResponse.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_BroadcastTransactionResponse proto.InternalMessageInfo
+
+func (m *BroadcastTransactionResponse) GetId() *v1alpha1.Id {
+ if m != nil {
+ return m.Id
+ }
+ return nil
+}
+
+func (m *BroadcastTransactionResponse) GetDetectionHeight() uint64 {
+ if m != nil {
+ return m.DetectionHeight
+ }
+ return 0
+}
+
+type TransactionPlannerRequest struct {
+ // The expiry height for the requested TransactionPlan
+ ExpiryHeight uint64 `protobuf:"varint,1,opt,name=expiry_height,json=expiryHeight,proto3" json:"expiry_height,omitempty"`
+ // The fee for the requested TransactionPlan, if any.
+ Fee *v1alpha11.Fee `protobuf:"bytes,2,opt,name=fee,proto3" json:"fee,omitempty"`
+ // The memo for the requested TransactionPlan
+ Memo *v1alpha1.MemoPlaintext `protobuf:"bytes,3,opt,name=memo,proto3" json:"memo,omitempty"`
+ // Types that are valid to be assigned to XAccountGroupId:
+ // *TransactionPlannerRequest_AccountGroupId
+ XAccountGroupId isTransactionPlannerRequest_XAccountGroupId `protobuf_oneof:"_account_group_id"`
+ // Request contents
+ Outputs []*TransactionPlannerRequest_Output `protobuf:"bytes,20,rep,name=outputs,proto3" json:"outputs,omitempty"`
+ Swaps []*TransactionPlannerRequest_Swap `protobuf:"bytes,30,rep,name=swaps,proto3" json:"swaps,omitempty"`
+ SwapClaims []*TransactionPlannerRequest_SwapClaim `protobuf:"bytes,31,rep,name=swap_claims,json=swapClaims,proto3" json:"swap_claims,omitempty"`
+ Delegations []*TransactionPlannerRequest_Delegate `protobuf:"bytes,40,rep,name=delegations,proto3" json:"delegations,omitempty"`
+ Undelegations []*TransactionPlannerRequest_Undelegate `protobuf:"bytes,50,rep,name=undelegations,proto3" json:"undelegations,omitempty"`
+ IbcActions []*v1alpha12.IbcAction `protobuf:"bytes,60,rep,name=ibc_actions,json=ibcActions,proto3" json:"ibc_actions,omitempty"`
+}
+
+func (m *TransactionPlannerRequest) Reset() { *m = TransactionPlannerRequest{} }
+func (m *TransactionPlannerRequest) String() string { return proto.CompactTextString(m) }
+func (*TransactionPlannerRequest) ProtoMessage() {}
+func (*TransactionPlannerRequest) Descriptor() ([]byte, []int) {
+ return fileDescriptor_0aa947b204e6a7c2, []int{4}
+}
+func (m *TransactionPlannerRequest) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *TransactionPlannerRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_TransactionPlannerRequest.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *TransactionPlannerRequest) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_TransactionPlannerRequest.Merge(m, src)
+}
+func (m *TransactionPlannerRequest) XXX_Size() int {
+ return m.Size()
+}
+func (m *TransactionPlannerRequest) XXX_DiscardUnknown() {
+ xxx_messageInfo_TransactionPlannerRequest.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_TransactionPlannerRequest proto.InternalMessageInfo
+
+type isTransactionPlannerRequest_XAccountGroupId interface {
+ isTransactionPlannerRequest_XAccountGroupId()
+ MarshalTo([]byte) (int, error)
+ Size() int
+}
+
+type TransactionPlannerRequest_AccountGroupId struct {
+ AccountGroupId *v1alpha11.AccountGroupId `protobuf:"bytes,14,opt,name=account_group_id,json=accountGroupId,proto3,oneof" json:"account_group_id,omitempty"`
+}
+
+func (*TransactionPlannerRequest_AccountGroupId) isTransactionPlannerRequest_XAccountGroupId() {}
+
+func (m *TransactionPlannerRequest) GetXAccountGroupId() isTransactionPlannerRequest_XAccountGroupId {
+ if m != nil {
+ return m.XAccountGroupId
+ }
+ return nil
+}
+
+func (m *TransactionPlannerRequest) GetExpiryHeight() uint64 {
+ if m != nil {
+ return m.ExpiryHeight
+ }
+ return 0
+}
+
+func (m *TransactionPlannerRequest) GetFee() *v1alpha11.Fee {
+ if m != nil {
+ return m.Fee
+ }
+ return nil
+}
+
+func (m *TransactionPlannerRequest) GetMemo() *v1alpha1.MemoPlaintext {
+ if m != nil {
+ return m.Memo
+ }
+ return nil
+}
+
+func (m *TransactionPlannerRequest) GetAccountGroupId() *v1alpha11.AccountGroupId {
+ if x, ok := m.GetXAccountGroupId().(*TransactionPlannerRequest_AccountGroupId); ok {
+ return x.AccountGroupId
+ }
+ return nil
+}
+
+func (m *TransactionPlannerRequest) GetOutputs() []*TransactionPlannerRequest_Output {
+ if m != nil {
+ return m.Outputs
+ }
+ return nil
+}
+
+func (m *TransactionPlannerRequest) GetSwaps() []*TransactionPlannerRequest_Swap {
+ if m != nil {
+ return m.Swaps
+ }
+ return nil
+}
+
+func (m *TransactionPlannerRequest) GetSwapClaims() []*TransactionPlannerRequest_SwapClaim {
+ if m != nil {
+ return m.SwapClaims
+ }
+ return nil
+}
+
+func (m *TransactionPlannerRequest) GetDelegations() []*TransactionPlannerRequest_Delegate {
+ if m != nil {
+ return m.Delegations
+ }
+ return nil
+}
+
+func (m *TransactionPlannerRequest) GetUndelegations() []*TransactionPlannerRequest_Undelegate {
+ if m != nil {
+ return m.Undelegations
+ }
+ return nil
+}
+
+func (m *TransactionPlannerRequest) GetIbcActions() []*v1alpha12.IbcAction {
+ if m != nil {
+ return m.IbcActions
+ }
+ return nil
+}
+
+// XXX_OneofWrappers is for the internal use of the proto package.
+func (*TransactionPlannerRequest) XXX_OneofWrappers() []interface{} {
+ return []interface{}{
+ (*TransactionPlannerRequest_AccountGroupId)(nil),
+ }
+}
+
+// Request message subtypes
+type TransactionPlannerRequest_Output struct {
+ // The amount and denomination in which the Output is issued.
+ Value *v1alpha11.Value `protobuf:"bytes,1,opt,name=value,proto3" json:"value,omitempty"`
+ // The address to which Output will be sent.
+ Address *v1alpha11.Address `protobuf:"bytes,2,opt,name=address,proto3" json:"address,omitempty"`
+}
+
+func (m *TransactionPlannerRequest_Output) Reset() { *m = TransactionPlannerRequest_Output{} }
+func (m *TransactionPlannerRequest_Output) String() string { return proto.CompactTextString(m) }
+func (*TransactionPlannerRequest_Output) ProtoMessage() {}
+func (*TransactionPlannerRequest_Output) Descriptor() ([]byte, []int) {
+ return fileDescriptor_0aa947b204e6a7c2, []int{4, 0}
+}
+func (m *TransactionPlannerRequest_Output) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *TransactionPlannerRequest_Output) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_TransactionPlannerRequest_Output.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *TransactionPlannerRequest_Output) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_TransactionPlannerRequest_Output.Merge(m, src)
+}
+func (m *TransactionPlannerRequest_Output) XXX_Size() int {
+ return m.Size()
+}
+func (m *TransactionPlannerRequest_Output) XXX_DiscardUnknown() {
+ xxx_messageInfo_TransactionPlannerRequest_Output.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_TransactionPlannerRequest_Output proto.InternalMessageInfo
+
+func (m *TransactionPlannerRequest_Output) GetValue() *v1alpha11.Value {
+ if m != nil {
+ return m.Value
+ }
+ return nil
+}
+
+func (m *TransactionPlannerRequest_Output) GetAddress() *v1alpha11.Address {
+ if m != nil {
+ return m.Address
+ }
+ return nil
+}
+
+type TransactionPlannerRequest_Swap struct {
+ // The amount and denomination to be traded in the Swap.
+ Value *v1alpha11.Value `protobuf:"bytes,1,opt,name=value,proto3" json:"value,omitempty"`
+ // The denomination to be received as a Output of the Swap.
+ TargetAsset *v1alpha11.AssetId `protobuf:"bytes,2,opt,name=target_asset,json=targetAsset,proto3" json:"target_asset,omitempty"`
+ // An optional fee to be paid for performing the Swap.
+ Fee *v1alpha11.Fee `protobuf:"bytes,3,opt,name=fee,proto3" json:"fee,omitempty"`
+}
+
+func (m *TransactionPlannerRequest_Swap) Reset() { *m = TransactionPlannerRequest_Swap{} }
+func (m *TransactionPlannerRequest_Swap) String() string { return proto.CompactTextString(m) }
+func (*TransactionPlannerRequest_Swap) ProtoMessage() {}
+func (*TransactionPlannerRequest_Swap) Descriptor() ([]byte, []int) {
+ return fileDescriptor_0aa947b204e6a7c2, []int{4, 1}
+}
+func (m *TransactionPlannerRequest_Swap) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *TransactionPlannerRequest_Swap) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_TransactionPlannerRequest_Swap.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *TransactionPlannerRequest_Swap) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_TransactionPlannerRequest_Swap.Merge(m, src)
+}
+func (m *TransactionPlannerRequest_Swap) XXX_Size() int {
+ return m.Size()
+}
+func (m *TransactionPlannerRequest_Swap) XXX_DiscardUnknown() {
+ xxx_messageInfo_TransactionPlannerRequest_Swap.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_TransactionPlannerRequest_Swap proto.InternalMessageInfo
+
+func (m *TransactionPlannerRequest_Swap) GetValue() *v1alpha11.Value {
+ if m != nil {
+ return m.Value
+ }
+ return nil
+}
+
+func (m *TransactionPlannerRequest_Swap) GetTargetAsset() *v1alpha11.AssetId {
+ if m != nil {
+ return m.TargetAsset
+ }
+ return nil
+}
+
+func (m *TransactionPlannerRequest_Swap) GetFee() *v1alpha11.Fee {
+ if m != nil {
+ return m.Fee
+ }
+ return nil
+}
+
+type TransactionPlannerRequest_SwapClaim struct {
+ // SwapCommitment to identify the Swap to be claimed.
+ // Use the commitment from the Swap message:
+ // penumbra.core.dex.v1alpha1.Swap.body.payload.commitment.
+ SwapCommitment *v1alpha11.StateCommitment `protobuf:"bytes,1,opt,name=swap_commitment,json=swapCommitment,proto3" json:"swap_commitment,omitempty"`
+}
+
+func (m *TransactionPlannerRequest_SwapClaim) Reset() { *m = TransactionPlannerRequest_SwapClaim{} }
+func (m *TransactionPlannerRequest_SwapClaim) String() string { return proto.CompactTextString(m) }
+func (*TransactionPlannerRequest_SwapClaim) ProtoMessage() {}
+func (*TransactionPlannerRequest_SwapClaim) Descriptor() ([]byte, []int) {
+ return fileDescriptor_0aa947b204e6a7c2, []int{4, 2}
+}
+func (m *TransactionPlannerRequest_SwapClaim) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *TransactionPlannerRequest_SwapClaim) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_TransactionPlannerRequest_SwapClaim.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *TransactionPlannerRequest_SwapClaim) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_TransactionPlannerRequest_SwapClaim.Merge(m, src)
+}
+func (m *TransactionPlannerRequest_SwapClaim) XXX_Size() int {
+ return m.Size()
+}
+func (m *TransactionPlannerRequest_SwapClaim) XXX_DiscardUnknown() {
+ xxx_messageInfo_TransactionPlannerRequest_SwapClaim.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_TransactionPlannerRequest_SwapClaim proto.InternalMessageInfo
+
+func (m *TransactionPlannerRequest_SwapClaim) GetSwapCommitment() *v1alpha11.StateCommitment {
+ if m != nil {
+ return m.SwapCommitment
+ }
+ return nil
+}
+
+type TransactionPlannerRequest_Delegate struct {
+ Amount *v1alpha11.Amount `protobuf:"bytes,1,opt,name=amount,proto3" json:"amount,omitempty"`
+ RateData *v1alpha13.RateData `protobuf:"bytes,3,opt,name=rate_data,json=rateData,proto3" json:"rate_data,omitempty"`
+}
+
+func (m *TransactionPlannerRequest_Delegate) Reset() { *m = TransactionPlannerRequest_Delegate{} }
+func (m *TransactionPlannerRequest_Delegate) String() string { return proto.CompactTextString(m) }
+func (*TransactionPlannerRequest_Delegate) ProtoMessage() {}
+func (*TransactionPlannerRequest_Delegate) Descriptor() ([]byte, []int) {
+ return fileDescriptor_0aa947b204e6a7c2, []int{4, 3}
+}
+func (m *TransactionPlannerRequest_Delegate) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *TransactionPlannerRequest_Delegate) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_TransactionPlannerRequest_Delegate.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *TransactionPlannerRequest_Delegate) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_TransactionPlannerRequest_Delegate.Merge(m, src)
+}
+func (m *TransactionPlannerRequest_Delegate) XXX_Size() int {
+ return m.Size()
+}
+func (m *TransactionPlannerRequest_Delegate) XXX_DiscardUnknown() {
+ xxx_messageInfo_TransactionPlannerRequest_Delegate.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_TransactionPlannerRequest_Delegate proto.InternalMessageInfo
+
+func (m *TransactionPlannerRequest_Delegate) GetAmount() *v1alpha11.Amount {
+ if m != nil {
+ return m.Amount
+ }
+ return nil
+}
+
+func (m *TransactionPlannerRequest_Delegate) GetRateData() *v1alpha13.RateData {
+ if m != nil {
+ return m.RateData
+ }
+ return nil
+}
+
+type TransactionPlannerRequest_Undelegate struct {
+ Value *v1alpha11.Value `protobuf:"bytes,1,opt,name=value,proto3" json:"value,omitempty"`
+ RateData *v1alpha13.RateData `protobuf:"bytes,2,opt,name=rate_data,json=rateData,proto3" json:"rate_data,omitempty"`
+}
+
+func (m *TransactionPlannerRequest_Undelegate) Reset() { *m = TransactionPlannerRequest_Undelegate{} }
+func (m *TransactionPlannerRequest_Undelegate) String() string { return proto.CompactTextString(m) }
+func (*TransactionPlannerRequest_Undelegate) ProtoMessage() {}
+func (*TransactionPlannerRequest_Undelegate) Descriptor() ([]byte, []int) {
+ return fileDescriptor_0aa947b204e6a7c2, []int{4, 4}
+}
+func (m *TransactionPlannerRequest_Undelegate) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *TransactionPlannerRequest_Undelegate) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_TransactionPlannerRequest_Undelegate.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *TransactionPlannerRequest_Undelegate) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_TransactionPlannerRequest_Undelegate.Merge(m, src)
+}
+func (m *TransactionPlannerRequest_Undelegate) XXX_Size() int {
+ return m.Size()
+}
+func (m *TransactionPlannerRequest_Undelegate) XXX_DiscardUnknown() {
+ xxx_messageInfo_TransactionPlannerRequest_Undelegate.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_TransactionPlannerRequest_Undelegate proto.InternalMessageInfo
+
+func (m *TransactionPlannerRequest_Undelegate) GetValue() *v1alpha11.Value {
+ if m != nil {
+ return m.Value
+ }
+ return nil
+}
+
+func (m *TransactionPlannerRequest_Undelegate) GetRateData() *v1alpha13.RateData {
+ if m != nil {
+ return m.RateData
+ }
+ return nil
+}
+
+type TransactionPlannerResponse struct {
+ Plan *v1alpha1.TransactionPlan `protobuf:"bytes,1,opt,name=plan,proto3" json:"plan,omitempty"`
+}
+
+func (m *TransactionPlannerResponse) Reset() { *m = TransactionPlannerResponse{} }
+func (m *TransactionPlannerResponse) String() string { return proto.CompactTextString(m) }
+func (*TransactionPlannerResponse) ProtoMessage() {}
+func (*TransactionPlannerResponse) Descriptor() ([]byte, []int) {
+ return fileDescriptor_0aa947b204e6a7c2, []int{5}
+}
+func (m *TransactionPlannerResponse) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *TransactionPlannerResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_TransactionPlannerResponse.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *TransactionPlannerResponse) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_TransactionPlannerResponse.Merge(m, src)
+}
+func (m *TransactionPlannerResponse) XXX_Size() int {
+ return m.Size()
+}
+func (m *TransactionPlannerResponse) XXX_DiscardUnknown() {
+ xxx_messageInfo_TransactionPlannerResponse.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_TransactionPlannerResponse proto.InternalMessageInfo
+
+func (m *TransactionPlannerResponse) GetPlan() *v1alpha1.TransactionPlan {
+ if m != nil {
+ return m.Plan
+ }
+ return nil
+}
+
+type AddressByIndexRequest struct {
+ AddressIndex *v1alpha11.AddressIndex `protobuf:"bytes,1,opt,name=address_index,json=addressIndex,proto3" json:"address_index,omitempty"`
+ DisplayConfirm bool `protobuf:"varint,2,opt,name=display_confirm,json=displayConfirm,proto3" json:"display_confirm,omitempty"`
+}
+
+func (m *AddressByIndexRequest) Reset() { *m = AddressByIndexRequest{} }
+func (m *AddressByIndexRequest) String() string { return proto.CompactTextString(m) }
+func (*AddressByIndexRequest) ProtoMessage() {}
+func (*AddressByIndexRequest) Descriptor() ([]byte, []int) {
+ return fileDescriptor_0aa947b204e6a7c2, []int{6}
+}
+func (m *AddressByIndexRequest) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *AddressByIndexRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_AddressByIndexRequest.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *AddressByIndexRequest) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_AddressByIndexRequest.Merge(m, src)
+}
+func (m *AddressByIndexRequest) XXX_Size() int {
+ return m.Size()
+}
+func (m *AddressByIndexRequest) XXX_DiscardUnknown() {
+ xxx_messageInfo_AddressByIndexRequest.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_AddressByIndexRequest proto.InternalMessageInfo
+
+func (m *AddressByIndexRequest) GetAddressIndex() *v1alpha11.AddressIndex {
+ if m != nil {
+ return m.AddressIndex
+ }
+ return nil
+}
+
+func (m *AddressByIndexRequest) GetDisplayConfirm() bool {
+ if m != nil {
+ return m.DisplayConfirm
+ }
+ return false
+}
+
+type AddressByIndexResponse struct {
+ Address *v1alpha11.Address `protobuf:"bytes,1,opt,name=address,proto3" json:"address,omitempty"`
+}
+
+func (m *AddressByIndexResponse) Reset() { *m = AddressByIndexResponse{} }
+func (m *AddressByIndexResponse) String() string { return proto.CompactTextString(m) }
+func (*AddressByIndexResponse) ProtoMessage() {}
+func (*AddressByIndexResponse) Descriptor() ([]byte, []int) {
+ return fileDescriptor_0aa947b204e6a7c2, []int{7}
+}
+func (m *AddressByIndexResponse) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *AddressByIndexResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_AddressByIndexResponse.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *AddressByIndexResponse) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_AddressByIndexResponse.Merge(m, src)
+}
+func (m *AddressByIndexResponse) XXX_Size() int {
+ return m.Size()
+}
+func (m *AddressByIndexResponse) XXX_DiscardUnknown() {
+ xxx_messageInfo_AddressByIndexResponse.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_AddressByIndexResponse proto.InternalMessageInfo
+
+func (m *AddressByIndexResponse) GetAddress() *v1alpha11.Address {
+ if m != nil {
+ return m.Address
+ }
+ return nil
+}
+
+type IndexByAddressRequest struct {
+ Address *v1alpha11.Address `protobuf:"bytes,1,opt,name=address,proto3" json:"address,omitempty"`
+}
+
+func (m *IndexByAddressRequest) Reset() { *m = IndexByAddressRequest{} }
+func (m *IndexByAddressRequest) String() string { return proto.CompactTextString(m) }
+func (*IndexByAddressRequest) ProtoMessage() {}
+func (*IndexByAddressRequest) Descriptor() ([]byte, []int) {
+ return fileDescriptor_0aa947b204e6a7c2, []int{8}
+}
+func (m *IndexByAddressRequest) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *IndexByAddressRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_IndexByAddressRequest.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *IndexByAddressRequest) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_IndexByAddressRequest.Merge(m, src)
+}
+func (m *IndexByAddressRequest) XXX_Size() int {
+ return m.Size()
+}
+func (m *IndexByAddressRequest) XXX_DiscardUnknown() {
+ xxx_messageInfo_IndexByAddressRequest.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_IndexByAddressRequest proto.InternalMessageInfo
+
+func (m *IndexByAddressRequest) GetAddress() *v1alpha11.Address {
+ if m != nil {
+ return m.Address
+ }
+ return nil
+}
+
+type IndexByAddressResponse struct {
+ // Types that are valid to be assigned to XAddressIndex:
+ // *IndexByAddressResponse_AddressIndex
+ XAddressIndex isIndexByAddressResponse_XAddressIndex `protobuf_oneof:"_address_index"`
+}
+
+func (m *IndexByAddressResponse) Reset() { *m = IndexByAddressResponse{} }
+func (m *IndexByAddressResponse) String() string { return proto.CompactTextString(m) }
+func (*IndexByAddressResponse) ProtoMessage() {}
+func (*IndexByAddressResponse) Descriptor() ([]byte, []int) {
+ return fileDescriptor_0aa947b204e6a7c2, []int{9}
+}
+func (m *IndexByAddressResponse) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *IndexByAddressResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_IndexByAddressResponse.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *IndexByAddressResponse) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_IndexByAddressResponse.Merge(m, src)
+}
+func (m *IndexByAddressResponse) XXX_Size() int {
+ return m.Size()
+}
+func (m *IndexByAddressResponse) XXX_DiscardUnknown() {
+ xxx_messageInfo_IndexByAddressResponse.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_IndexByAddressResponse proto.InternalMessageInfo
+
+type isIndexByAddressResponse_XAddressIndex interface {
+ isIndexByAddressResponse_XAddressIndex()
+ MarshalTo([]byte) (int, error)
+ Size() int
+}
+
+type IndexByAddressResponse_AddressIndex struct {
+ AddressIndex *v1alpha11.AddressIndex `protobuf:"bytes,1,opt,name=address_index,json=addressIndex,proto3,oneof" json:"address_index,omitempty"`
+}
+
+func (*IndexByAddressResponse_AddressIndex) isIndexByAddressResponse_XAddressIndex() {}
+
+func (m *IndexByAddressResponse) GetXAddressIndex() isIndexByAddressResponse_XAddressIndex {
+ if m != nil {
+ return m.XAddressIndex
+ }
+ return nil
+}
+
+func (m *IndexByAddressResponse) GetAddressIndex() *v1alpha11.AddressIndex {
+ if x, ok := m.GetXAddressIndex().(*IndexByAddressResponse_AddressIndex); ok {
+ return x.AddressIndex
+ }
+ return nil
+}
+
+// XXX_OneofWrappers is for the internal use of the proto package.
+func (*IndexByAddressResponse) XXX_OneofWrappers() []interface{} {
+ return []interface{}{
+ (*IndexByAddressResponse_AddressIndex)(nil),
+ }
+}
+
+type EphemeralAddressRequest struct {
+ AddressIndex *v1alpha11.AddressIndex `protobuf:"bytes,1,opt,name=address_index,json=addressIndex,proto3" json:"address_index,omitempty"`
+ DisplayConfirm bool `protobuf:"varint,2,opt,name=display_confirm,json=displayConfirm,proto3" json:"display_confirm,omitempty"`
+}
+
+func (m *EphemeralAddressRequest) Reset() { *m = EphemeralAddressRequest{} }
+func (m *EphemeralAddressRequest) String() string { return proto.CompactTextString(m) }
+func (*EphemeralAddressRequest) ProtoMessage() {}
+func (*EphemeralAddressRequest) Descriptor() ([]byte, []int) {
+ return fileDescriptor_0aa947b204e6a7c2, []int{10}
+}
+func (m *EphemeralAddressRequest) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *EphemeralAddressRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_EphemeralAddressRequest.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *EphemeralAddressRequest) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_EphemeralAddressRequest.Merge(m, src)
+}
+func (m *EphemeralAddressRequest) XXX_Size() int {
+ return m.Size()
+}
+func (m *EphemeralAddressRequest) XXX_DiscardUnknown() {
+ xxx_messageInfo_EphemeralAddressRequest.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_EphemeralAddressRequest proto.InternalMessageInfo
+
+func (m *EphemeralAddressRequest) GetAddressIndex() *v1alpha11.AddressIndex {
+ if m != nil {
+ return m.AddressIndex
+ }
+ return nil
+}
+
+func (m *EphemeralAddressRequest) GetDisplayConfirm() bool {
+ if m != nil {
+ return m.DisplayConfirm
+ }
+ return false
+}
+
+type EphemeralAddressResponse struct {
+ Address *v1alpha11.Address `protobuf:"bytes,1,opt,name=address,proto3" json:"address,omitempty"`
+}
+
+func (m *EphemeralAddressResponse) Reset() { *m = EphemeralAddressResponse{} }
+func (m *EphemeralAddressResponse) String() string { return proto.CompactTextString(m) }
+func (*EphemeralAddressResponse) ProtoMessage() {}
+func (*EphemeralAddressResponse) Descriptor() ([]byte, []int) {
+ return fileDescriptor_0aa947b204e6a7c2, []int{11}
+}
+func (m *EphemeralAddressResponse) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *EphemeralAddressResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_EphemeralAddressResponse.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *EphemeralAddressResponse) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_EphemeralAddressResponse.Merge(m, src)
+}
+func (m *EphemeralAddressResponse) XXX_Size() int {
+ return m.Size()
+}
+func (m *EphemeralAddressResponse) XXX_DiscardUnknown() {
+ xxx_messageInfo_EphemeralAddressResponse.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_EphemeralAddressResponse proto.InternalMessageInfo
+
+func (m *EphemeralAddressResponse) GetAddress() *v1alpha11.Address {
+ if m != nil {
+ return m.Address
+ }
+ return nil
+}
+
+type BalancesRequest struct {
+ // If present, filter balances to only include the account specified by the `AddressIndex`.
+ AccountFilter *v1alpha11.AddressIndex `protobuf:"bytes,1,opt,name=account_filter,json=accountFilter,proto3" json:"account_filter,omitempty"`
+ // If present, filter balances to only include the specified asset ID.
+ AssetIdFilter *v1alpha11.AssetId `protobuf:"bytes,2,opt,name=asset_id_filter,json=assetIdFilter,proto3" json:"asset_id_filter,omitempty"`
+}
+
+func (m *BalancesRequest) Reset() { *m = BalancesRequest{} }
+func (m *BalancesRequest) String() string { return proto.CompactTextString(m) }
+func (*BalancesRequest) ProtoMessage() {}
+func (*BalancesRequest) Descriptor() ([]byte, []int) {
+ return fileDescriptor_0aa947b204e6a7c2, []int{12}
+}
+func (m *BalancesRequest) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *BalancesRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_BalancesRequest.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *BalancesRequest) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_BalancesRequest.Merge(m, src)
+}
+func (m *BalancesRequest) XXX_Size() int {
+ return m.Size()
+}
+func (m *BalancesRequest) XXX_DiscardUnknown() {
+ xxx_messageInfo_BalancesRequest.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_BalancesRequest proto.InternalMessageInfo
+
+func (m *BalancesRequest) GetAccountFilter() *v1alpha11.AddressIndex {
+ if m != nil {
+ return m.AccountFilter
+ }
+ return nil
+}
+
+func (m *BalancesRequest) GetAssetIdFilter() *v1alpha11.AssetId {
+ if m != nil {
+ return m.AssetIdFilter
+ }
+ return nil
+}
+
+type BalancesResponse struct {
+ Account *v1alpha11.AddressIndex `protobuf:"bytes,1,opt,name=account,proto3" json:"account,omitempty"`
+ Balance *v1alpha11.Value `protobuf:"bytes,2,opt,name=balance,proto3" json:"balance,omitempty"`
+}
+
+func (m *BalancesResponse) Reset() { *m = BalancesResponse{} }
+func (m *BalancesResponse) String() string { return proto.CompactTextString(m) }
+func (*BalancesResponse) ProtoMessage() {}
+func (*BalancesResponse) Descriptor() ([]byte, []int) {
+ return fileDescriptor_0aa947b204e6a7c2, []int{13}
+}
+func (m *BalancesResponse) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *BalancesResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_BalancesResponse.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *BalancesResponse) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_BalancesResponse.Merge(m, src)
+}
+func (m *BalancesResponse) XXX_Size() int {
+ return m.Size()
+}
+func (m *BalancesResponse) XXX_DiscardUnknown() {
+ xxx_messageInfo_BalancesResponse.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_BalancesResponse proto.InternalMessageInfo
+
+func (m *BalancesResponse) GetAccount() *v1alpha11.AddressIndex {
+ if m != nil {
+ return m.Account
+ }
+ return nil
+}
+
+func (m *BalancesResponse) GetBalance() *v1alpha11.Value {
+ if m != nil {
+ return m.Balance
+ }
+ return nil
+}
+
+// Scaffolding for bearer-token authentication for the ViewService.
+type ViewAuthToken struct {
+ Inner []byte `protobuf:"bytes,1,opt,name=inner,proto3" json:"inner,omitempty"`
+}
+
+func (m *ViewAuthToken) Reset() { *m = ViewAuthToken{} }
+func (m *ViewAuthToken) String() string { return proto.CompactTextString(m) }
+func (*ViewAuthToken) ProtoMessage() {}
+func (*ViewAuthToken) Descriptor() ([]byte, []int) {
+ return fileDescriptor_0aa947b204e6a7c2, []int{14}
+}
+func (m *ViewAuthToken) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *ViewAuthToken) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_ViewAuthToken.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *ViewAuthToken) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_ViewAuthToken.Merge(m, src)
+}
+func (m *ViewAuthToken) XXX_Size() int {
+ return m.Size()
+}
+func (m *ViewAuthToken) XXX_DiscardUnknown() {
+ xxx_messageInfo_ViewAuthToken.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_ViewAuthToken proto.InternalMessageInfo
+
+func (m *ViewAuthToken) GetInner() []byte {
+ if m != nil {
+ return m.Inner
+ }
+ return nil
+}
+
+type ViewAuthRequest struct {
+ Fvk *v1alpha11.FullViewingKey `protobuf:"bytes,1,opt,name=fvk,proto3" json:"fvk,omitempty"`
+}
+
+func (m *ViewAuthRequest) Reset() { *m = ViewAuthRequest{} }
+func (m *ViewAuthRequest) String() string { return proto.CompactTextString(m) }
+func (*ViewAuthRequest) ProtoMessage() {}
+func (*ViewAuthRequest) Descriptor() ([]byte, []int) {
+ return fileDescriptor_0aa947b204e6a7c2, []int{15}
+}
+func (m *ViewAuthRequest) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *ViewAuthRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_ViewAuthRequest.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *ViewAuthRequest) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_ViewAuthRequest.Merge(m, src)
+}
+func (m *ViewAuthRequest) XXX_Size() int {
+ return m.Size()
+}
+func (m *ViewAuthRequest) XXX_DiscardUnknown() {
+ xxx_messageInfo_ViewAuthRequest.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_ViewAuthRequest proto.InternalMessageInfo
+
+func (m *ViewAuthRequest) GetFvk() *v1alpha11.FullViewingKey {
+ if m != nil {
+ return m.Fvk
+ }
+ return nil
+}
+
+type ViewAuthResponse struct {
+ Token *ViewAuthToken `protobuf:"bytes,1,opt,name=token,proto3" json:"token,omitempty"`
+}
+
+func (m *ViewAuthResponse) Reset() { *m = ViewAuthResponse{} }
+func (m *ViewAuthResponse) String() string { return proto.CompactTextString(m) }
+func (*ViewAuthResponse) ProtoMessage() {}
+func (*ViewAuthResponse) Descriptor() ([]byte, []int) {
+ return fileDescriptor_0aa947b204e6a7c2, []int{16}
+}
+func (m *ViewAuthResponse) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *ViewAuthResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_ViewAuthResponse.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *ViewAuthResponse) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_ViewAuthResponse.Merge(m, src)
+}
+func (m *ViewAuthResponse) XXX_Size() int {
+ return m.Size()
+}
+func (m *ViewAuthResponse) XXX_DiscardUnknown() {
+ xxx_messageInfo_ViewAuthResponse.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_ViewAuthResponse proto.InternalMessageInfo
+
+func (m *ViewAuthResponse) GetToken() *ViewAuthToken {
+ if m != nil {
+ return m.Token
+ }
+ return nil
+}
+
+// Requests sync status of the view service.
+type StatusRequest struct {
+ // Types that are valid to be assigned to XAccountGroupId:
+ // *StatusRequest_AccountGroupId
+ XAccountGroupId isStatusRequest_XAccountGroupId `protobuf_oneof:"_account_group_id"`
+}
+
+func (m *StatusRequest) Reset() { *m = StatusRequest{} }
+func (m *StatusRequest) String() string { return proto.CompactTextString(m) }
+func (*StatusRequest) ProtoMessage() {}
+func (*StatusRequest) Descriptor() ([]byte, []int) {
+ return fileDescriptor_0aa947b204e6a7c2, []int{17}
+}
+func (m *StatusRequest) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *StatusRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_StatusRequest.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *StatusRequest) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_StatusRequest.Merge(m, src)
+}
+func (m *StatusRequest) XXX_Size() int {
+ return m.Size()
+}
+func (m *StatusRequest) XXX_DiscardUnknown() {
+ xxx_messageInfo_StatusRequest.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_StatusRequest proto.InternalMessageInfo
+
+type isStatusRequest_XAccountGroupId interface {
+ isStatusRequest_XAccountGroupId()
+ MarshalTo([]byte) (int, error)
+ Size() int
+}
+
+type StatusRequest_AccountGroupId struct {
+ AccountGroupId *v1alpha11.AccountGroupId `protobuf:"bytes,14,opt,name=account_group_id,json=accountGroupId,proto3,oneof" json:"account_group_id,omitempty"`
+}
+
+func (*StatusRequest_AccountGroupId) isStatusRequest_XAccountGroupId() {}
+
+func (m *StatusRequest) GetXAccountGroupId() isStatusRequest_XAccountGroupId {
+ if m != nil {
+ return m.XAccountGroupId
+ }
+ return nil
+}
+
+func (m *StatusRequest) GetAccountGroupId() *v1alpha11.AccountGroupId {
+ if x, ok := m.GetXAccountGroupId().(*StatusRequest_AccountGroupId); ok {
+ return x.AccountGroupId
+ }
+ return nil
+}
+
+// XXX_OneofWrappers is for the internal use of the proto package.
+func (*StatusRequest) XXX_OneofWrappers() []interface{} {
+ return []interface{}{
+ (*StatusRequest_AccountGroupId)(nil),
+ }
+}
+
+// Returns the status of the view service and whether it is synchronized with the chain state.
+type StatusResponse struct {
+ // The height the view service has synchronized to so far
+ SyncHeight uint64 `protobuf:"varint,1,opt,name=sync_height,json=syncHeight,proto3" json:"sync_height,omitempty"`
+ // Whether the view service is catching up with the chain state
+ CatchingUp bool `protobuf:"varint,2,opt,name=catching_up,json=catchingUp,proto3" json:"catching_up,omitempty"`
+}
+
+func (m *StatusResponse) Reset() { *m = StatusResponse{} }
+func (m *StatusResponse) String() string { return proto.CompactTextString(m) }
+func (*StatusResponse) ProtoMessage() {}
+func (*StatusResponse) Descriptor() ([]byte, []int) {
+ return fileDescriptor_0aa947b204e6a7c2, []int{18}
+}
+func (m *StatusResponse) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *StatusResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_StatusResponse.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *StatusResponse) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_StatusResponse.Merge(m, src)
+}
+func (m *StatusResponse) XXX_Size() int {
+ return m.Size()
+}
+func (m *StatusResponse) XXX_DiscardUnknown() {
+ xxx_messageInfo_StatusResponse.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_StatusResponse proto.InternalMessageInfo
+
+func (m *StatusResponse) GetSyncHeight() uint64 {
+ if m != nil {
+ return m.SyncHeight
+ }
+ return 0
+}
+
+func (m *StatusResponse) GetCatchingUp() bool {
+ if m != nil {
+ return m.CatchingUp
+ }
+ return false
+}
+
+// Requests streaming updates on the sync height until the view service is synchronized.
+type StatusStreamRequest struct {
+ // Types that are valid to be assigned to XAccountGroupId:
+ // *StatusStreamRequest_AccountGroupId
+ XAccountGroupId isStatusStreamRequest_XAccountGroupId `protobuf_oneof:"_account_group_id"`
+}
+
+func (m *StatusStreamRequest) Reset() { *m = StatusStreamRequest{} }
+func (m *StatusStreamRequest) String() string { return proto.CompactTextString(m) }
+func (*StatusStreamRequest) ProtoMessage() {}
+func (*StatusStreamRequest) Descriptor() ([]byte, []int) {
+ return fileDescriptor_0aa947b204e6a7c2, []int{19}
+}
+func (m *StatusStreamRequest) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *StatusStreamRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_StatusStreamRequest.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *StatusStreamRequest) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_StatusStreamRequest.Merge(m, src)
+}
+func (m *StatusStreamRequest) XXX_Size() int {
+ return m.Size()
+}
+func (m *StatusStreamRequest) XXX_DiscardUnknown() {
+ xxx_messageInfo_StatusStreamRequest.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_StatusStreamRequest proto.InternalMessageInfo
+
+type isStatusStreamRequest_XAccountGroupId interface {
+ isStatusStreamRequest_XAccountGroupId()
+ MarshalTo([]byte) (int, error)
+ Size() int
+}
+
+type StatusStreamRequest_AccountGroupId struct {
+ AccountGroupId *v1alpha11.AccountGroupId `protobuf:"bytes,14,opt,name=account_group_id,json=accountGroupId,proto3,oneof" json:"account_group_id,omitempty"`
+}
+
+func (*StatusStreamRequest_AccountGroupId) isStatusStreamRequest_XAccountGroupId() {}
+
+func (m *StatusStreamRequest) GetXAccountGroupId() isStatusStreamRequest_XAccountGroupId {
+ if m != nil {
+ return m.XAccountGroupId
+ }
+ return nil
+}
+
+func (m *StatusStreamRequest) GetAccountGroupId() *v1alpha11.AccountGroupId {
+ if x, ok := m.GetXAccountGroupId().(*StatusStreamRequest_AccountGroupId); ok {
+ return x.AccountGroupId
+ }
+ return nil
+}
+
+// XXX_OneofWrappers is for the internal use of the proto package.
+func (*StatusStreamRequest) XXX_OneofWrappers() []interface{} {
+ return []interface{}{
+ (*StatusStreamRequest_AccountGroupId)(nil),
+ }
+}
+
+// A streaming sync status update
+type StatusStreamResponse struct {
+ LatestKnownBlockHeight uint64 `protobuf:"varint,1,opt,name=latest_known_block_height,json=latestKnownBlockHeight,proto3" json:"latest_known_block_height,omitempty"`
+ SyncHeight uint64 `protobuf:"varint,2,opt,name=sync_height,json=syncHeight,proto3" json:"sync_height,omitempty"`
+}
+
+func (m *StatusStreamResponse) Reset() { *m = StatusStreamResponse{} }
+func (m *StatusStreamResponse) String() string { return proto.CompactTextString(m) }
+func (*StatusStreamResponse) ProtoMessage() {}
+func (*StatusStreamResponse) Descriptor() ([]byte, []int) {
+ return fileDescriptor_0aa947b204e6a7c2, []int{20}
+}
+func (m *StatusStreamResponse) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *StatusStreamResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_StatusStreamResponse.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *StatusStreamResponse) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_StatusStreamResponse.Merge(m, src)
+}
+func (m *StatusStreamResponse) XXX_Size() int {
+ return m.Size()
+}
+func (m *StatusStreamResponse) XXX_DiscardUnknown() {
+ xxx_messageInfo_StatusStreamResponse.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_StatusStreamResponse proto.InternalMessageInfo
+
+func (m *StatusStreamResponse) GetLatestKnownBlockHeight() uint64 {
+ if m != nil {
+ return m.LatestKnownBlockHeight
+ }
+ return 0
+}
+
+func (m *StatusStreamResponse) GetSyncHeight() uint64 {
+ if m != nil {
+ return m.SyncHeight
+ }
+ return 0
+}
+
+// A query for notes known by the view service.
+//
+// This message uses the fact that all proto fields are optional
+// to allow various filtering on the returned notes.
+type NotesRequest struct {
+ // If set, return spent notes as well as unspent notes.
+ IncludeSpent bool `protobuf:"varint,2,opt,name=include_spent,json=includeSpent,proto3" json:"include_spent,omitempty"`
+ // If set, only return notes with the specified asset id.
+ AssetId *v1alpha11.AssetId `protobuf:"bytes,3,opt,name=asset_id,json=assetId,proto3" json:"asset_id,omitempty"`
+ // If set, only return notes with the specified address incore.dex.v1alpha1.
+ AddressIndex *v1alpha11.AddressIndex `protobuf:"bytes,4,opt,name=address_index,json=addressIndex,proto3" json:"address_index,omitempty"`
+ // If set, stop returning notes once the total exceeds this amount.
+ //
+ // Ignored if `asset_id` is unset or if `include_spent` is set.
+ AmountToSpend *v1alpha11.Amount `protobuf:"bytes,6,opt,name=amount_to_spend,json=amountToSpend,proto3" json:"amount_to_spend,omitempty"`
+ // Types that are valid to be assigned to XAccountGroupId:
+ // *NotesRequest_AccountGroupId
+ XAccountGroupId isNotesRequest_XAccountGroupId `protobuf_oneof:"_account_group_id"`
+}
+
+func (m *NotesRequest) Reset() { *m = NotesRequest{} }
+func (m *NotesRequest) String() string { return proto.CompactTextString(m) }
+func (*NotesRequest) ProtoMessage() {}
+func (*NotesRequest) Descriptor() ([]byte, []int) {
+ return fileDescriptor_0aa947b204e6a7c2, []int{21}
+}
+func (m *NotesRequest) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *NotesRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_NotesRequest.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *NotesRequest) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_NotesRequest.Merge(m, src)
+}
+func (m *NotesRequest) XXX_Size() int {
+ return m.Size()
+}
+func (m *NotesRequest) XXX_DiscardUnknown() {
+ xxx_messageInfo_NotesRequest.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_NotesRequest proto.InternalMessageInfo
+
+type isNotesRequest_XAccountGroupId interface {
+ isNotesRequest_XAccountGroupId()
+ MarshalTo([]byte) (int, error)
+ Size() int
+}
+
+type NotesRequest_AccountGroupId struct {
+ AccountGroupId *v1alpha11.AccountGroupId `protobuf:"bytes,14,opt,name=account_group_id,json=accountGroupId,proto3,oneof" json:"account_group_id,omitempty"`
+}
+
+func (*NotesRequest_AccountGroupId) isNotesRequest_XAccountGroupId() {}
+
+func (m *NotesRequest) GetXAccountGroupId() isNotesRequest_XAccountGroupId {
+ if m != nil {
+ return m.XAccountGroupId
+ }
+ return nil
+}
+
+func (m *NotesRequest) GetIncludeSpent() bool {
+ if m != nil {
+ return m.IncludeSpent
+ }
+ return false
+}
+
+func (m *NotesRequest) GetAssetId() *v1alpha11.AssetId {
+ if m != nil {
+ return m.AssetId
+ }
+ return nil
+}
+
+func (m *NotesRequest) GetAddressIndex() *v1alpha11.AddressIndex {
+ if m != nil {
+ return m.AddressIndex
+ }
+ return nil
+}
+
+func (m *NotesRequest) GetAmountToSpend() *v1alpha11.Amount {
+ if m != nil {
+ return m.AmountToSpend
+ }
+ return nil
+}
+
+func (m *NotesRequest) GetAccountGroupId() *v1alpha11.AccountGroupId {
+ if x, ok := m.GetXAccountGroupId().(*NotesRequest_AccountGroupId); ok {
+ return x.AccountGroupId
+ }
+ return nil
+}
+
+// XXX_OneofWrappers is for the internal use of the proto package.
+func (*NotesRequest) XXX_OneofWrappers() []interface{} {
+ return []interface{}{
+ (*NotesRequest_AccountGroupId)(nil),
+ }
+}
+
+// A query for notes to be used for voting on a proposal.
+type NotesForVotingRequest struct {
+ // The starting height of the proposal.
+ VotableAtHeight uint64 `protobuf:"varint,1,opt,name=votable_at_height,json=votableAtHeight,proto3" json:"votable_at_height,omitempty"`
+ // If set, only return notes with the specified asset id.
+ AddressIndex *v1alpha11.AddressIndex `protobuf:"bytes,3,opt,name=address_index,json=addressIndex,proto3" json:"address_index,omitempty"`
+ // Types that are valid to be assigned to XAccountGroupId:
+ // *NotesForVotingRequest_AccountGroupId
+ XAccountGroupId isNotesForVotingRequest_XAccountGroupId `protobuf_oneof:"_account_group_id"`
+}
+
+func (m *NotesForVotingRequest) Reset() { *m = NotesForVotingRequest{} }
+func (m *NotesForVotingRequest) String() string { return proto.CompactTextString(m) }
+func (*NotesForVotingRequest) ProtoMessage() {}
+func (*NotesForVotingRequest) Descriptor() ([]byte, []int) {
+ return fileDescriptor_0aa947b204e6a7c2, []int{22}
+}
+func (m *NotesForVotingRequest) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *NotesForVotingRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_NotesForVotingRequest.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *NotesForVotingRequest) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_NotesForVotingRequest.Merge(m, src)
+}
+func (m *NotesForVotingRequest) XXX_Size() int {
+ return m.Size()
+}
+func (m *NotesForVotingRequest) XXX_DiscardUnknown() {
+ xxx_messageInfo_NotesForVotingRequest.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_NotesForVotingRequest proto.InternalMessageInfo
+
+type isNotesForVotingRequest_XAccountGroupId interface {
+ isNotesForVotingRequest_XAccountGroupId()
+ MarshalTo([]byte) (int, error)
+ Size() int
+}
+
+type NotesForVotingRequest_AccountGroupId struct {
+ AccountGroupId *v1alpha11.AccountGroupId `protobuf:"bytes,14,opt,name=account_group_id,json=accountGroupId,proto3,oneof" json:"account_group_id,omitempty"`
+}
+
+func (*NotesForVotingRequest_AccountGroupId) isNotesForVotingRequest_XAccountGroupId() {}
+
+func (m *NotesForVotingRequest) GetXAccountGroupId() isNotesForVotingRequest_XAccountGroupId {
+ if m != nil {
+ return m.XAccountGroupId
+ }
+ return nil
+}
+
+func (m *NotesForVotingRequest) GetVotableAtHeight() uint64 {
+ if m != nil {
+ return m.VotableAtHeight
+ }
+ return 0
+}
+
+func (m *NotesForVotingRequest) GetAddressIndex() *v1alpha11.AddressIndex {
+ if m != nil {
+ return m.AddressIndex
+ }
+ return nil
+}
+
+func (m *NotesForVotingRequest) GetAccountGroupId() *v1alpha11.AccountGroupId {
+ if x, ok := m.GetXAccountGroupId().(*NotesForVotingRequest_AccountGroupId); ok {
+ return x.AccountGroupId
+ }
+ return nil
+}
+
+// XXX_OneofWrappers is for the internal use of the proto package.
+func (*NotesForVotingRequest) XXX_OneofWrappers() []interface{} {
+ return []interface{}{
+ (*NotesForVotingRequest_AccountGroupId)(nil),
+ }
+}
+
+type WitnessRequest struct {
+ // The note commitments to obtain auth paths for.
+ NoteCommitments []*v1alpha11.StateCommitment `protobuf:"bytes,2,rep,name=note_commitments,json=noteCommitments,proto3" json:"note_commitments,omitempty"`
+ // The transaction plan to witness
+ TransactionPlan *v1alpha1.TransactionPlan `protobuf:"bytes,3,opt,name=transaction_plan,json=transactionPlan,proto3" json:"transaction_plan,omitempty"`
+ // Types that are valid to be assigned to XAccountGroupId:
+ // *WitnessRequest_AccountGroupId
+ XAccountGroupId isWitnessRequest_XAccountGroupId `protobuf_oneof:"_account_group_id"`
+}
+
+func (m *WitnessRequest) Reset() { *m = WitnessRequest{} }
+func (m *WitnessRequest) String() string { return proto.CompactTextString(m) }
+func (*WitnessRequest) ProtoMessage() {}
+func (*WitnessRequest) Descriptor() ([]byte, []int) {
+ return fileDescriptor_0aa947b204e6a7c2, []int{23}
+}
+func (m *WitnessRequest) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *WitnessRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_WitnessRequest.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *WitnessRequest) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_WitnessRequest.Merge(m, src)
+}
+func (m *WitnessRequest) XXX_Size() int {
+ return m.Size()
+}
+func (m *WitnessRequest) XXX_DiscardUnknown() {
+ xxx_messageInfo_WitnessRequest.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_WitnessRequest proto.InternalMessageInfo
+
+type isWitnessRequest_XAccountGroupId interface {
+ isWitnessRequest_XAccountGroupId()
+ MarshalTo([]byte) (int, error)
+ Size() int
+}
+
+type WitnessRequest_AccountGroupId struct {
+ AccountGroupId *v1alpha11.AccountGroupId `protobuf:"bytes,14,opt,name=account_group_id,json=accountGroupId,proto3,oneof" json:"account_group_id,omitempty"`
+}
+
+func (*WitnessRequest_AccountGroupId) isWitnessRequest_XAccountGroupId() {}
+
+func (m *WitnessRequest) GetXAccountGroupId() isWitnessRequest_XAccountGroupId {
+ if m != nil {
+ return m.XAccountGroupId
+ }
+ return nil
+}
+
+func (m *WitnessRequest) GetNoteCommitments() []*v1alpha11.StateCommitment {
+ if m != nil {
+ return m.NoteCommitments
+ }
+ return nil
+}
+
+func (m *WitnessRequest) GetTransactionPlan() *v1alpha1.TransactionPlan {
+ if m != nil {
+ return m.TransactionPlan
+ }
+ return nil
+}
+
+func (m *WitnessRequest) GetAccountGroupId() *v1alpha11.AccountGroupId {
+ if x, ok := m.GetXAccountGroupId().(*WitnessRequest_AccountGroupId); ok {
+ return x.AccountGroupId
+ }
+ return nil
+}
+
+// XXX_OneofWrappers is for the internal use of the proto package.
+func (*WitnessRequest) XXX_OneofWrappers() []interface{} {
+ return []interface{}{
+ (*WitnessRequest_AccountGroupId)(nil),
+ }
+}
+
+type WitnessResponse struct {
+ WitnessData *v1alpha1.WitnessData `protobuf:"bytes,1,opt,name=witness_data,json=witnessData,proto3" json:"witness_data,omitempty"`
+}
+
+func (m *WitnessResponse) Reset() { *m = WitnessResponse{} }
+func (m *WitnessResponse) String() string { return proto.CompactTextString(m) }
+func (*WitnessResponse) ProtoMessage() {}
+func (*WitnessResponse) Descriptor() ([]byte, []int) {
+ return fileDescriptor_0aa947b204e6a7c2, []int{24}
+}
+func (m *WitnessResponse) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *WitnessResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_WitnessResponse.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *WitnessResponse) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_WitnessResponse.Merge(m, src)
+}
+func (m *WitnessResponse) XXX_Size() int {
+ return m.Size()
+}
+func (m *WitnessResponse) XXX_DiscardUnknown() {
+ xxx_messageInfo_WitnessResponse.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_WitnessResponse proto.InternalMessageInfo
+
+func (m *WitnessResponse) GetWitnessData() *v1alpha1.WitnessData {
+ if m != nil {
+ return m.WitnessData
+ }
+ return nil
+}
+
+type WitnessAndBuildRequest struct {
+ TransactionPlan *v1alpha1.TransactionPlan `protobuf:"bytes,1,opt,name=transaction_plan,json=transactionPlan,proto3" json:"transaction_plan,omitempty"`
+ AuthorizationData *v1alpha1.AuthorizationData `protobuf:"bytes,2,opt,name=authorization_data,json=authorizationData,proto3" json:"authorization_data,omitempty"`
+}
+
+func (m *WitnessAndBuildRequest) Reset() { *m = WitnessAndBuildRequest{} }
+func (m *WitnessAndBuildRequest) String() string { return proto.CompactTextString(m) }
+func (*WitnessAndBuildRequest) ProtoMessage() {}
+func (*WitnessAndBuildRequest) Descriptor() ([]byte, []int) {
+ return fileDescriptor_0aa947b204e6a7c2, []int{25}
+}
+func (m *WitnessAndBuildRequest) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *WitnessAndBuildRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_WitnessAndBuildRequest.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *WitnessAndBuildRequest) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_WitnessAndBuildRequest.Merge(m, src)
+}
+func (m *WitnessAndBuildRequest) XXX_Size() int {
+ return m.Size()
+}
+func (m *WitnessAndBuildRequest) XXX_DiscardUnknown() {
+ xxx_messageInfo_WitnessAndBuildRequest.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_WitnessAndBuildRequest proto.InternalMessageInfo
+
+func (m *WitnessAndBuildRequest) GetTransactionPlan() *v1alpha1.TransactionPlan {
+ if m != nil {
+ return m.TransactionPlan
+ }
+ return nil
+}
+
+func (m *WitnessAndBuildRequest) GetAuthorizationData() *v1alpha1.AuthorizationData {
+ if m != nil {
+ return m.AuthorizationData
+ }
+ return nil
+}
+
+type WitnessAndBuildResponse struct {
+ Transaction *v1alpha1.Transaction `protobuf:"bytes,1,opt,name=transaction,proto3" json:"transaction,omitempty"`
+}
+
+func (m *WitnessAndBuildResponse) Reset() { *m = WitnessAndBuildResponse{} }
+func (m *WitnessAndBuildResponse) String() string { return proto.CompactTextString(m) }
+func (*WitnessAndBuildResponse) ProtoMessage() {}
+func (*WitnessAndBuildResponse) Descriptor() ([]byte, []int) {
+ return fileDescriptor_0aa947b204e6a7c2, []int{26}
+}
+func (m *WitnessAndBuildResponse) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *WitnessAndBuildResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_WitnessAndBuildResponse.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *WitnessAndBuildResponse) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_WitnessAndBuildResponse.Merge(m, src)
+}
+func (m *WitnessAndBuildResponse) XXX_Size() int {
+ return m.Size()
+}
+func (m *WitnessAndBuildResponse) XXX_DiscardUnknown() {
+ xxx_messageInfo_WitnessAndBuildResponse.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_WitnessAndBuildResponse proto.InternalMessageInfo
+
+func (m *WitnessAndBuildResponse) GetTransaction() *v1alpha1.Transaction {
+ if m != nil {
+ return m.Transaction
+ }
+ return nil
+}
+
+// Requests all assets known to the view service.
+type AssetsRequest struct {
+ // If set to false (default), returns all assets, regardless of whether the rest of the fields of
+ // the request indicate a filter.
+ Filtered bool `protobuf:"varint,1,opt,name=filtered,proto3" json:"filtered,omitempty"`
+ // Include these specific denominations in the response.
+ IncludeSpecificDenominations []*v1alpha11.Denom `protobuf:"bytes,2,rep,name=include_specific_denominations,json=includeSpecificDenominations,proto3" json:"include_specific_denominations,omitempty"`
+ // Include all delegation tokens, to any validator, in the response.
+ IncludeDelegationTokens bool `protobuf:"varint,3,opt,name=include_delegation_tokens,json=includeDelegationTokens,proto3" json:"include_delegation_tokens,omitempty"`
+ // Include all unbonding tokens, from any validator, in the response.
+ IncludeUnbondingTokens bool `protobuf:"varint,4,opt,name=include_unbonding_tokens,json=includeUnbondingTokens,proto3" json:"include_unbonding_tokens,omitempty"`
+ // Include all LP NFTs in the response.
+ IncludeLpNfts bool `protobuf:"varint,5,opt,name=include_lp_nfts,json=includeLpNfts,proto3" json:"include_lp_nfts,omitempty"`
+ // Include all proposal NFTs in the response.
+ IncludeProposalNfts bool `protobuf:"varint,6,opt,name=include_proposal_nfts,json=includeProposalNfts,proto3" json:"include_proposal_nfts,omitempty"`
+ // Include all voting receipt tokens in the response.
+ IncludeVotingReceiptTokens bool `protobuf:"varint,7,opt,name=include_voting_receipt_tokens,json=includeVotingReceiptTokens,proto3" json:"include_voting_receipt_tokens,omitempty"`
+}
+
+func (m *AssetsRequest) Reset() { *m = AssetsRequest{} }
+func (m *AssetsRequest) String() string { return proto.CompactTextString(m) }
+func (*AssetsRequest) ProtoMessage() {}
+func (*AssetsRequest) Descriptor() ([]byte, []int) {
+ return fileDescriptor_0aa947b204e6a7c2, []int{27}
+}
+func (m *AssetsRequest) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *AssetsRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_AssetsRequest.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *AssetsRequest) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_AssetsRequest.Merge(m, src)
+}
+func (m *AssetsRequest) XXX_Size() int {
+ return m.Size()
+}
+func (m *AssetsRequest) XXX_DiscardUnknown() {
+ xxx_messageInfo_AssetsRequest.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_AssetsRequest proto.InternalMessageInfo
+
+func (m *AssetsRequest) GetFiltered() bool {
+ if m != nil {
+ return m.Filtered
+ }
+ return false
+}
+
+func (m *AssetsRequest) GetIncludeSpecificDenominations() []*v1alpha11.Denom {
+ if m != nil {
+ return m.IncludeSpecificDenominations
+ }
+ return nil
+}
+
+func (m *AssetsRequest) GetIncludeDelegationTokens() bool {
+ if m != nil {
+ return m.IncludeDelegationTokens
+ }
+ return false
+}
+
+func (m *AssetsRequest) GetIncludeUnbondingTokens() bool {
+ if m != nil {
+ return m.IncludeUnbondingTokens
+ }
+ return false
+}
+
+func (m *AssetsRequest) GetIncludeLpNfts() bool {
+ if m != nil {
+ return m.IncludeLpNfts
+ }
+ return false
+}
+
+func (m *AssetsRequest) GetIncludeProposalNfts() bool {
+ if m != nil {
+ return m.IncludeProposalNfts
+ }
+ return false
+}
+
+func (m *AssetsRequest) GetIncludeVotingReceiptTokens() bool {
+ if m != nil {
+ return m.IncludeVotingReceiptTokens
+ }
+ return false
+}
+
+// Requests all assets known to the view service.
+type AssetsResponse struct {
+ DenomMetadata *v1alpha11.DenomMetadata `protobuf:"bytes,2,opt,name=denom_metadata,json=denomMetadata,proto3" json:"denom_metadata,omitempty"`
+}
+
+func (m *AssetsResponse) Reset() { *m = AssetsResponse{} }
+func (m *AssetsResponse) String() string { return proto.CompactTextString(m) }
+func (*AssetsResponse) ProtoMessage() {}
+func (*AssetsResponse) Descriptor() ([]byte, []int) {
+ return fileDescriptor_0aa947b204e6a7c2, []int{28}
+}
+func (m *AssetsResponse) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *AssetsResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_AssetsResponse.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *AssetsResponse) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_AssetsResponse.Merge(m, src)
+}
+func (m *AssetsResponse) XXX_Size() int {
+ return m.Size()
+}
+func (m *AssetsResponse) XXX_DiscardUnknown() {
+ xxx_messageInfo_AssetsResponse.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_AssetsResponse proto.InternalMessageInfo
+
+func (m *AssetsResponse) GetDenomMetadata() *v1alpha11.DenomMetadata {
+ if m != nil {
+ return m.DenomMetadata
+ }
+ return nil
+}
+
+// Requests the current chain parameters from the view service.
+type ChainParametersRequest struct {
+}
+
+func (m *ChainParametersRequest) Reset() { *m = ChainParametersRequest{} }
+func (m *ChainParametersRequest) String() string { return proto.CompactTextString(m) }
+func (*ChainParametersRequest) ProtoMessage() {}
+func (*ChainParametersRequest) Descriptor() ([]byte, []int) {
+ return fileDescriptor_0aa947b204e6a7c2, []int{29}
+}
+func (m *ChainParametersRequest) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *ChainParametersRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_ChainParametersRequest.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *ChainParametersRequest) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_ChainParametersRequest.Merge(m, src)
+}
+func (m *ChainParametersRequest) XXX_Size() int {
+ return m.Size()
+}
+func (m *ChainParametersRequest) XXX_DiscardUnknown() {
+ xxx_messageInfo_ChainParametersRequest.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_ChainParametersRequest proto.InternalMessageInfo
+
+type ChainParametersResponse struct {
+ Parameters *v1alpha14.ChainParameters `protobuf:"bytes,1,opt,name=parameters,proto3" json:"parameters,omitempty"`
+}
+
+func (m *ChainParametersResponse) Reset() { *m = ChainParametersResponse{} }
+func (m *ChainParametersResponse) String() string { return proto.CompactTextString(m) }
+func (*ChainParametersResponse) ProtoMessage() {}
+func (*ChainParametersResponse) Descriptor() ([]byte, []int) {
+ return fileDescriptor_0aa947b204e6a7c2, []int{30}
+}
+func (m *ChainParametersResponse) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *ChainParametersResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_ChainParametersResponse.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *ChainParametersResponse) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_ChainParametersResponse.Merge(m, src)
+}
+func (m *ChainParametersResponse) XXX_Size() int {
+ return m.Size()
+}
+func (m *ChainParametersResponse) XXX_DiscardUnknown() {
+ xxx_messageInfo_ChainParametersResponse.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_ChainParametersResponse proto.InternalMessageInfo
+
+func (m *ChainParametersResponse) GetParameters() *v1alpha14.ChainParameters {
+ if m != nil {
+ return m.Parameters
+ }
+ return nil
+}
+
+// Requests the current FMD parameters from the view service.
+type FMDParametersRequest struct {
+}
+
+func (m *FMDParametersRequest) Reset() { *m = FMDParametersRequest{} }
+func (m *FMDParametersRequest) String() string { return proto.CompactTextString(m) }
+func (*FMDParametersRequest) ProtoMessage() {}
+func (*FMDParametersRequest) Descriptor() ([]byte, []int) {
+ return fileDescriptor_0aa947b204e6a7c2, []int{31}
+}
+func (m *FMDParametersRequest) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *FMDParametersRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_FMDParametersRequest.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *FMDParametersRequest) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_FMDParametersRequest.Merge(m, src)
+}
+func (m *FMDParametersRequest) XXX_Size() int {
+ return m.Size()
+}
+func (m *FMDParametersRequest) XXX_DiscardUnknown() {
+ xxx_messageInfo_FMDParametersRequest.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_FMDParametersRequest proto.InternalMessageInfo
+
+type FMDParametersResponse struct {
+ Parameters *v1alpha14.FmdParameters `protobuf:"bytes,1,opt,name=parameters,proto3" json:"parameters,omitempty"`
+}
+
+func (m *FMDParametersResponse) Reset() { *m = FMDParametersResponse{} }
+func (m *FMDParametersResponse) String() string { return proto.CompactTextString(m) }
+func (*FMDParametersResponse) ProtoMessage() {}
+func (*FMDParametersResponse) Descriptor() ([]byte, []int) {
+ return fileDescriptor_0aa947b204e6a7c2, []int{32}
+}
+func (m *FMDParametersResponse) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *FMDParametersResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_FMDParametersResponse.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *FMDParametersResponse) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_FMDParametersResponse.Merge(m, src)
+}
+func (m *FMDParametersResponse) XXX_Size() int {
+ return m.Size()
+}
+func (m *FMDParametersResponse) XXX_DiscardUnknown() {
+ xxx_messageInfo_FMDParametersResponse.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_FMDParametersResponse proto.InternalMessageInfo
+
+func (m *FMDParametersResponse) GetParameters() *v1alpha14.FmdParameters {
+ if m != nil {
+ return m.Parameters
+ }
+ return nil
+}
+
+type NoteByCommitmentRequest struct {
+ NoteCommitment *v1alpha11.StateCommitment `protobuf:"bytes,2,opt,name=note_commitment,json=noteCommitment,proto3" json:"note_commitment,omitempty"`
+ // If set to true, waits to return until the requested note is detected.
+ AwaitDetection bool `protobuf:"varint,3,opt,name=await_detection,json=awaitDetection,proto3" json:"await_detection,omitempty"`
+ // Types that are valid to be assigned to XAccountGroupId:
+ // *NoteByCommitmentRequest_AccountGroupId
+ XAccountGroupId isNoteByCommitmentRequest_XAccountGroupId `protobuf_oneof:"_account_group_id"`
+}
+
+func (m *NoteByCommitmentRequest) Reset() { *m = NoteByCommitmentRequest{} }
+func (m *NoteByCommitmentRequest) String() string { return proto.CompactTextString(m) }
+func (*NoteByCommitmentRequest) ProtoMessage() {}
+func (*NoteByCommitmentRequest) Descriptor() ([]byte, []int) {
+ return fileDescriptor_0aa947b204e6a7c2, []int{33}
+}
+func (m *NoteByCommitmentRequest) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *NoteByCommitmentRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_NoteByCommitmentRequest.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *NoteByCommitmentRequest) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_NoteByCommitmentRequest.Merge(m, src)
+}
+func (m *NoteByCommitmentRequest) XXX_Size() int {
+ return m.Size()
+}
+func (m *NoteByCommitmentRequest) XXX_DiscardUnknown() {
+ xxx_messageInfo_NoteByCommitmentRequest.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_NoteByCommitmentRequest proto.InternalMessageInfo
+
+type isNoteByCommitmentRequest_XAccountGroupId interface {
+ isNoteByCommitmentRequest_XAccountGroupId()
+ MarshalTo([]byte) (int, error)
+ Size() int
+}
+
+type NoteByCommitmentRequest_AccountGroupId struct {
+ AccountGroupId *v1alpha11.AccountGroupId `protobuf:"bytes,14,opt,name=account_group_id,json=accountGroupId,proto3,oneof" json:"account_group_id,omitempty"`
+}
+
+func (*NoteByCommitmentRequest_AccountGroupId) isNoteByCommitmentRequest_XAccountGroupId() {}
+
+func (m *NoteByCommitmentRequest) GetXAccountGroupId() isNoteByCommitmentRequest_XAccountGroupId {
+ if m != nil {
+ return m.XAccountGroupId
+ }
+ return nil
+}
+
+func (m *NoteByCommitmentRequest) GetNoteCommitment() *v1alpha11.StateCommitment {
+ if m != nil {
+ return m.NoteCommitment
+ }
+ return nil
+}
+
+func (m *NoteByCommitmentRequest) GetAwaitDetection() bool {
+ if m != nil {
+ return m.AwaitDetection
+ }
+ return false
+}
+
+func (m *NoteByCommitmentRequest) GetAccountGroupId() *v1alpha11.AccountGroupId {
+ if x, ok := m.GetXAccountGroupId().(*NoteByCommitmentRequest_AccountGroupId); ok {
+ return x.AccountGroupId
+ }
+ return nil
+}
+
+// XXX_OneofWrappers is for the internal use of the proto package.
+func (*NoteByCommitmentRequest) XXX_OneofWrappers() []interface{} {
+ return []interface{}{
+ (*NoteByCommitmentRequest_AccountGroupId)(nil),
+ }
+}
+
+type NoteByCommitmentResponse struct {
+ SpendableNote *SpendableNoteRecord `protobuf:"bytes,1,opt,name=spendable_note,json=spendableNote,proto3" json:"spendable_note,omitempty"`
+}
+
+func (m *NoteByCommitmentResponse) Reset() { *m = NoteByCommitmentResponse{} }
+func (m *NoteByCommitmentResponse) String() string { return proto.CompactTextString(m) }
+func (*NoteByCommitmentResponse) ProtoMessage() {}
+func (*NoteByCommitmentResponse) Descriptor() ([]byte, []int) {
+ return fileDescriptor_0aa947b204e6a7c2, []int{34}
+}
+func (m *NoteByCommitmentResponse) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *NoteByCommitmentResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_NoteByCommitmentResponse.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *NoteByCommitmentResponse) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_NoteByCommitmentResponse.Merge(m, src)
+}
+func (m *NoteByCommitmentResponse) XXX_Size() int {
+ return m.Size()
+}
+func (m *NoteByCommitmentResponse) XXX_DiscardUnknown() {
+ xxx_messageInfo_NoteByCommitmentResponse.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_NoteByCommitmentResponse proto.InternalMessageInfo
+
+func (m *NoteByCommitmentResponse) GetSpendableNote() *SpendableNoteRecord {
+ if m != nil {
+ return m.SpendableNote
+ }
+ return nil
+}
+
+type SwapByCommitmentRequest struct {
+ SwapCommitment *v1alpha11.StateCommitment `protobuf:"bytes,2,opt,name=swap_commitment,json=swapCommitment,proto3" json:"swap_commitment,omitempty"`
+ // If set to true, waits to return until the requested swap is detected.
+ AwaitDetection bool `protobuf:"varint,3,opt,name=await_detection,json=awaitDetection,proto3" json:"await_detection,omitempty"`
+ // Types that are valid to be assigned to XAccountGroupId:
+ // *SwapByCommitmentRequest_AccountGroupId
+ XAccountGroupId isSwapByCommitmentRequest_XAccountGroupId `protobuf_oneof:"_account_group_id"`
+}
+
+func (m *SwapByCommitmentRequest) Reset() { *m = SwapByCommitmentRequest{} }
+func (m *SwapByCommitmentRequest) String() string { return proto.CompactTextString(m) }
+func (*SwapByCommitmentRequest) ProtoMessage() {}
+func (*SwapByCommitmentRequest) Descriptor() ([]byte, []int) {
+ return fileDescriptor_0aa947b204e6a7c2, []int{35}
+}
+func (m *SwapByCommitmentRequest) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *SwapByCommitmentRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_SwapByCommitmentRequest.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *SwapByCommitmentRequest) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_SwapByCommitmentRequest.Merge(m, src)
+}
+func (m *SwapByCommitmentRequest) XXX_Size() int {
+ return m.Size()
+}
+func (m *SwapByCommitmentRequest) XXX_DiscardUnknown() {
+ xxx_messageInfo_SwapByCommitmentRequest.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_SwapByCommitmentRequest proto.InternalMessageInfo
+
+type isSwapByCommitmentRequest_XAccountGroupId interface {
+ isSwapByCommitmentRequest_XAccountGroupId()
+ MarshalTo([]byte) (int, error)
+ Size() int
+}
+
+type SwapByCommitmentRequest_AccountGroupId struct {
+ AccountGroupId *v1alpha11.AccountGroupId `protobuf:"bytes,14,opt,name=account_group_id,json=accountGroupId,proto3,oneof" json:"account_group_id,omitempty"`
+}
+
+func (*SwapByCommitmentRequest_AccountGroupId) isSwapByCommitmentRequest_XAccountGroupId() {}
+
+func (m *SwapByCommitmentRequest) GetXAccountGroupId() isSwapByCommitmentRequest_XAccountGroupId {
+ if m != nil {
+ return m.XAccountGroupId
+ }
+ return nil
+}
+
+func (m *SwapByCommitmentRequest) GetSwapCommitment() *v1alpha11.StateCommitment {
+ if m != nil {
+ return m.SwapCommitment
+ }
+ return nil
+}
+
+func (m *SwapByCommitmentRequest) GetAwaitDetection() bool {
+ if m != nil {
+ return m.AwaitDetection
+ }
+ return false
+}
+
+func (m *SwapByCommitmentRequest) GetAccountGroupId() *v1alpha11.AccountGroupId {
+ if x, ok := m.GetXAccountGroupId().(*SwapByCommitmentRequest_AccountGroupId); ok {
+ return x.AccountGroupId
+ }
+ return nil
+}
+
+// XXX_OneofWrappers is for the internal use of the proto package.
+func (*SwapByCommitmentRequest) XXX_OneofWrappers() []interface{} {
+ return []interface{}{
+ (*SwapByCommitmentRequest_AccountGroupId)(nil),
+ }
+}
+
+type SwapByCommitmentResponse struct {
+ Swap *SwapRecord `protobuf:"bytes,1,opt,name=swap,proto3" json:"swap,omitempty"`
+}
+
+func (m *SwapByCommitmentResponse) Reset() { *m = SwapByCommitmentResponse{} }
+func (m *SwapByCommitmentResponse) String() string { return proto.CompactTextString(m) }
+func (*SwapByCommitmentResponse) ProtoMessage() {}
+func (*SwapByCommitmentResponse) Descriptor() ([]byte, []int) {
+ return fileDescriptor_0aa947b204e6a7c2, []int{36}
+}
+func (m *SwapByCommitmentResponse) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *SwapByCommitmentResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_SwapByCommitmentResponse.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *SwapByCommitmentResponse) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_SwapByCommitmentResponse.Merge(m, src)
+}
+func (m *SwapByCommitmentResponse) XXX_Size() int {
+ return m.Size()
+}
+func (m *SwapByCommitmentResponse) XXX_DiscardUnknown() {
+ xxx_messageInfo_SwapByCommitmentResponse.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_SwapByCommitmentResponse proto.InternalMessageInfo
+
+func (m *SwapByCommitmentResponse) GetSwap() *SwapRecord {
+ if m != nil {
+ return m.Swap
+ }
+ return nil
+}
+
+type NullifierStatusRequest struct {
+ Nullifier *v1alpha11.Nullifier `protobuf:"bytes,2,opt,name=nullifier,proto3" json:"nullifier,omitempty"`
+ AwaitDetection bool `protobuf:"varint,3,opt,name=await_detection,json=awaitDetection,proto3" json:"await_detection,omitempty"`
+ // Types that are valid to be assigned to XAccountGroupId:
+ // *NullifierStatusRequest_AccountGroupId
+ XAccountGroupId isNullifierStatusRequest_XAccountGroupId `protobuf_oneof:"_account_group_id"`
+}
+
+func (m *NullifierStatusRequest) Reset() { *m = NullifierStatusRequest{} }
+func (m *NullifierStatusRequest) String() string { return proto.CompactTextString(m) }
+func (*NullifierStatusRequest) ProtoMessage() {}
+func (*NullifierStatusRequest) Descriptor() ([]byte, []int) {
+ return fileDescriptor_0aa947b204e6a7c2, []int{37}
+}
+func (m *NullifierStatusRequest) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *NullifierStatusRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_NullifierStatusRequest.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *NullifierStatusRequest) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_NullifierStatusRequest.Merge(m, src)
+}
+func (m *NullifierStatusRequest) XXX_Size() int {
+ return m.Size()
+}
+func (m *NullifierStatusRequest) XXX_DiscardUnknown() {
+ xxx_messageInfo_NullifierStatusRequest.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_NullifierStatusRequest proto.InternalMessageInfo
+
+type isNullifierStatusRequest_XAccountGroupId interface {
+ isNullifierStatusRequest_XAccountGroupId()
+ MarshalTo([]byte) (int, error)
+ Size() int
+}
+
+type NullifierStatusRequest_AccountGroupId struct {
+ AccountGroupId *v1alpha11.AccountGroupId `protobuf:"bytes,14,opt,name=account_group_id,json=accountGroupId,proto3,oneof" json:"account_group_id,omitempty"`
+}
+
+func (*NullifierStatusRequest_AccountGroupId) isNullifierStatusRequest_XAccountGroupId() {}
+
+func (m *NullifierStatusRequest) GetXAccountGroupId() isNullifierStatusRequest_XAccountGroupId {
+ if m != nil {
+ return m.XAccountGroupId
+ }
+ return nil
+}
+
+func (m *NullifierStatusRequest) GetNullifier() *v1alpha11.Nullifier {
+ if m != nil {
+ return m.Nullifier
+ }
+ return nil
+}
+
+func (m *NullifierStatusRequest) GetAwaitDetection() bool {
+ if m != nil {
+ return m.AwaitDetection
+ }
+ return false
+}
+
+func (m *NullifierStatusRequest) GetAccountGroupId() *v1alpha11.AccountGroupId {
+ if x, ok := m.GetXAccountGroupId().(*NullifierStatusRequest_AccountGroupId); ok {
+ return x.AccountGroupId
+ }
+ return nil
+}
+
+// XXX_OneofWrappers is for the internal use of the proto package.
+func (*NullifierStatusRequest) XXX_OneofWrappers() []interface{} {
+ return []interface{}{
+ (*NullifierStatusRequest_AccountGroupId)(nil),
+ }
+}
+
+type NullifierStatusResponse struct {
+ Spent bool `protobuf:"varint,1,opt,name=spent,proto3" json:"spent,omitempty"`
+}
+
+func (m *NullifierStatusResponse) Reset() { *m = NullifierStatusResponse{} }
+func (m *NullifierStatusResponse) String() string { return proto.CompactTextString(m) }
+func (*NullifierStatusResponse) ProtoMessage() {}
+func (*NullifierStatusResponse) Descriptor() ([]byte, []int) {
+ return fileDescriptor_0aa947b204e6a7c2, []int{38}
+}
+func (m *NullifierStatusResponse) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *NullifierStatusResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_NullifierStatusResponse.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *NullifierStatusResponse) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_NullifierStatusResponse.Merge(m, src)
+}
+func (m *NullifierStatusResponse) XXX_Size() int {
+ return m.Size()
+}
+func (m *NullifierStatusResponse) XXX_DiscardUnknown() {
+ xxx_messageInfo_NullifierStatusResponse.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_NullifierStatusResponse proto.InternalMessageInfo
+
+func (m *NullifierStatusResponse) GetSpent() bool {
+ if m != nil {
+ return m.Spent
+ }
+ return false
+}
+
+type TransactionInfoByHashRequest struct {
+ // The transaction hash to query for.
+ Id *v1alpha1.Id `protobuf:"bytes,2,opt,name=id,proto3" json:"id,omitempty"`
+}
+
+func (m *TransactionInfoByHashRequest) Reset() { *m = TransactionInfoByHashRequest{} }
+func (m *TransactionInfoByHashRequest) String() string { return proto.CompactTextString(m) }
+func (*TransactionInfoByHashRequest) ProtoMessage() {}
+func (*TransactionInfoByHashRequest) Descriptor() ([]byte, []int) {
+ return fileDescriptor_0aa947b204e6a7c2, []int{39}
+}
+func (m *TransactionInfoByHashRequest) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *TransactionInfoByHashRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_TransactionInfoByHashRequest.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *TransactionInfoByHashRequest) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_TransactionInfoByHashRequest.Merge(m, src)
+}
+func (m *TransactionInfoByHashRequest) XXX_Size() int {
+ return m.Size()
+}
+func (m *TransactionInfoByHashRequest) XXX_DiscardUnknown() {
+ xxx_messageInfo_TransactionInfoByHashRequest.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_TransactionInfoByHashRequest proto.InternalMessageInfo
+
+func (m *TransactionInfoByHashRequest) GetId() *v1alpha1.Id {
+ if m != nil {
+ return m.Id
+ }
+ return nil
+}
+
+type TransactionInfoRequest struct {
+ // Types that are valid to be assigned to XStartHeight:
+ // *TransactionInfoRequest_StartHeight
+ XStartHeight isTransactionInfoRequest_XStartHeight `protobuf_oneof:"_start_height"`
+ // Types that are valid to be assigned to XEndHeight:
+ // *TransactionInfoRequest_EndHeight
+ XEndHeight isTransactionInfoRequest_XEndHeight `protobuf_oneof:"_end_height"`
+}
+
+func (m *TransactionInfoRequest) Reset() { *m = TransactionInfoRequest{} }
+func (m *TransactionInfoRequest) String() string { return proto.CompactTextString(m) }
+func (*TransactionInfoRequest) ProtoMessage() {}
+func (*TransactionInfoRequest) Descriptor() ([]byte, []int) {
+ return fileDescriptor_0aa947b204e6a7c2, []int{40}
+}
+func (m *TransactionInfoRequest) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *TransactionInfoRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_TransactionInfoRequest.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *TransactionInfoRequest) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_TransactionInfoRequest.Merge(m, src)
+}
+func (m *TransactionInfoRequest) XXX_Size() int {
+ return m.Size()
+}
+func (m *TransactionInfoRequest) XXX_DiscardUnknown() {
+ xxx_messageInfo_TransactionInfoRequest.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_TransactionInfoRequest proto.InternalMessageInfo
+
+type isTransactionInfoRequest_XStartHeight interface {
+ isTransactionInfoRequest_XStartHeight()
+ MarshalTo([]byte) (int, error)
+ Size() int
+}
+type isTransactionInfoRequest_XEndHeight interface {
+ isTransactionInfoRequest_XEndHeight()
+ MarshalTo([]byte) (int, error)
+ Size() int
+}
+
+type TransactionInfoRequest_StartHeight struct {
+ StartHeight uint64 `protobuf:"varint,1,opt,name=start_height,json=startHeight,proto3,oneof" json:"start_height,omitempty"`
+}
+type TransactionInfoRequest_EndHeight struct {
+ EndHeight uint64 `protobuf:"varint,2,opt,name=end_height,json=endHeight,proto3,oneof" json:"end_height,omitempty"`
+}
+
+func (*TransactionInfoRequest_StartHeight) isTransactionInfoRequest_XStartHeight() {}
+func (*TransactionInfoRequest_EndHeight) isTransactionInfoRequest_XEndHeight() {}
+
+func (m *TransactionInfoRequest) GetXStartHeight() isTransactionInfoRequest_XStartHeight {
+ if m != nil {
+ return m.XStartHeight
+ }
+ return nil
+}
+func (m *TransactionInfoRequest) GetXEndHeight() isTransactionInfoRequest_XEndHeight {
+ if m != nil {
+ return m.XEndHeight
+ }
+ return nil
+}
+
+func (m *TransactionInfoRequest) GetStartHeight() uint64 {
+ if x, ok := m.GetXStartHeight().(*TransactionInfoRequest_StartHeight); ok {
+ return x.StartHeight
+ }
+ return 0
+}
+
+func (m *TransactionInfoRequest) GetEndHeight() uint64 {
+ if x, ok := m.GetXEndHeight().(*TransactionInfoRequest_EndHeight); ok {
+ return x.EndHeight
+ }
+ return 0
+}
+
+// XXX_OneofWrappers is for the internal use of the proto package.
+func (*TransactionInfoRequest) XXX_OneofWrappers() []interface{} {
+ return []interface{}{
+ (*TransactionInfoRequest_StartHeight)(nil),
+ (*TransactionInfoRequest_EndHeight)(nil),
+ }
+}
+
+type TransactionInfo struct {
+ // Types that are valid to be assigned to XHeight:
+ // *TransactionInfo_Height
+ XHeight isTransactionInfo_XHeight `protobuf_oneof:"_height"`
+ // The hash of the transaction.
+ Id *v1alpha1.Id `protobuf:"bytes,2,opt,name=id,proto3" json:"id,omitempty"`
+ // The transaction data itself.
+ Transaction *v1alpha1.Transaction `protobuf:"bytes,3,opt,name=transaction,proto3" json:"transaction,omitempty"`
+ // The transaction perspective, as seen by this view server.
+ Perspective *v1alpha1.TransactionPerspective `protobuf:"bytes,4,opt,name=perspective,proto3" json:"perspective,omitempty"`
+ // A precomputed transaction view of `transaction` from `perspective`, included for convenience of clients that don't have support for viewing transactions on their own.
+ View *v1alpha1.TransactionView `protobuf:"bytes,5,opt,name=view,proto3" json:"view,omitempty"`
+}
+
+func (m *TransactionInfo) Reset() { *m = TransactionInfo{} }
+func (m *TransactionInfo) String() string { return proto.CompactTextString(m) }
+func (*TransactionInfo) ProtoMessage() {}
+func (*TransactionInfo) Descriptor() ([]byte, []int) {
+ return fileDescriptor_0aa947b204e6a7c2, []int{41}
+}
+func (m *TransactionInfo) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *TransactionInfo) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_TransactionInfo.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *TransactionInfo) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_TransactionInfo.Merge(m, src)
+}
+func (m *TransactionInfo) XXX_Size() int {
+ return m.Size()
+}
+func (m *TransactionInfo) XXX_DiscardUnknown() {
+ xxx_messageInfo_TransactionInfo.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_TransactionInfo proto.InternalMessageInfo
+
+type isTransactionInfo_XHeight interface {
+ isTransactionInfo_XHeight()
+ MarshalTo([]byte) (int, error)
+ Size() int
+}
+
+type TransactionInfo_Height struct {
+ Height uint64 `protobuf:"varint,1,opt,name=height,proto3,oneof" json:"height,omitempty"`
+}
+
+func (*TransactionInfo_Height) isTransactionInfo_XHeight() {}
+
+func (m *TransactionInfo) GetXHeight() isTransactionInfo_XHeight {
+ if m != nil {
+ return m.XHeight
+ }
+ return nil
+}
+
+func (m *TransactionInfo) GetHeight() uint64 {
+ if x, ok := m.GetXHeight().(*TransactionInfo_Height); ok {
+ return x.Height
+ }
+ return 0
+}
+
+func (m *TransactionInfo) GetId() *v1alpha1.Id {
+ if m != nil {
+ return m.Id
+ }
+ return nil
+}
+
+func (m *TransactionInfo) GetTransaction() *v1alpha1.Transaction {
+ if m != nil {
+ return m.Transaction
+ }
+ return nil
+}
+
+func (m *TransactionInfo) GetPerspective() *v1alpha1.TransactionPerspective {
+ if m != nil {
+ return m.Perspective
+ }
+ return nil
+}
+
+func (m *TransactionInfo) GetView() *v1alpha1.TransactionView {
+ if m != nil {
+ return m.View
+ }
+ return nil
+}
+
+// XXX_OneofWrappers is for the internal use of the proto package.
+func (*TransactionInfo) XXX_OneofWrappers() []interface{} {
+ return []interface{}{
+ (*TransactionInfo_Height)(nil),
+ }
+}
+
+type TransactionInfoResponse struct {
+ TxInfo *TransactionInfo `protobuf:"bytes,1,opt,name=tx_info,json=txInfo,proto3" json:"tx_info,omitempty"`
+}
+
+func (m *TransactionInfoResponse) Reset() { *m = TransactionInfoResponse{} }
+func (m *TransactionInfoResponse) String() string { return proto.CompactTextString(m) }
+func (*TransactionInfoResponse) ProtoMessage() {}
+func (*TransactionInfoResponse) Descriptor() ([]byte, []int) {
+ return fileDescriptor_0aa947b204e6a7c2, []int{42}
+}
+func (m *TransactionInfoResponse) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *TransactionInfoResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_TransactionInfoResponse.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *TransactionInfoResponse) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_TransactionInfoResponse.Merge(m, src)
+}
+func (m *TransactionInfoResponse) XXX_Size() int {
+ return m.Size()
+}
+func (m *TransactionInfoResponse) XXX_DiscardUnknown() {
+ xxx_messageInfo_TransactionInfoResponse.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_TransactionInfoResponse proto.InternalMessageInfo
+
+func (m *TransactionInfoResponse) GetTxInfo() *TransactionInfo {
+ if m != nil {
+ return m.TxInfo
+ }
+ return nil
+}
+
+type TransactionInfoByHashResponse struct {
+ TxInfo *TransactionInfo `protobuf:"bytes,1,opt,name=tx_info,json=txInfo,proto3" json:"tx_info,omitempty"`
+}
+
+func (m *TransactionInfoByHashResponse) Reset() { *m = TransactionInfoByHashResponse{} }
+func (m *TransactionInfoByHashResponse) String() string { return proto.CompactTextString(m) }
+func (*TransactionInfoByHashResponse) ProtoMessage() {}
+func (*TransactionInfoByHashResponse) Descriptor() ([]byte, []int) {
+ return fileDescriptor_0aa947b204e6a7c2, []int{43}
+}
+func (m *TransactionInfoByHashResponse) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *TransactionInfoByHashResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_TransactionInfoByHashResponse.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *TransactionInfoByHashResponse) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_TransactionInfoByHashResponse.Merge(m, src)
+}
+func (m *TransactionInfoByHashResponse) XXX_Size() int {
+ return m.Size()
+}
+func (m *TransactionInfoByHashResponse) XXX_DiscardUnknown() {
+ xxx_messageInfo_TransactionInfoByHashResponse.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_TransactionInfoByHashResponse proto.InternalMessageInfo
+
+func (m *TransactionInfoByHashResponse) GetTxInfo() *TransactionInfo {
+ if m != nil {
+ return m.TxInfo
+ }
+ return nil
+}
+
+type NotesResponse struct {
+ NoteRecord *SpendableNoteRecord `protobuf:"bytes,1,opt,name=note_record,json=noteRecord,proto3" json:"note_record,omitempty"`
+}
+
+func (m *NotesResponse) Reset() { *m = NotesResponse{} }
+func (m *NotesResponse) String() string { return proto.CompactTextString(m) }
+func (*NotesResponse) ProtoMessage() {}
+func (*NotesResponse) Descriptor() ([]byte, []int) {
+ return fileDescriptor_0aa947b204e6a7c2, []int{44}
+}
+func (m *NotesResponse) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *NotesResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_NotesResponse.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *NotesResponse) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_NotesResponse.Merge(m, src)
+}
+func (m *NotesResponse) XXX_Size() int {
+ return m.Size()
+}
+func (m *NotesResponse) XXX_DiscardUnknown() {
+ xxx_messageInfo_NotesResponse.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_NotesResponse proto.InternalMessageInfo
+
+func (m *NotesResponse) GetNoteRecord() *SpendableNoteRecord {
+ if m != nil {
+ return m.NoteRecord
+ }
+ return nil
+}
+
+type NotesForVotingResponse struct {
+ NoteRecord *SpendableNoteRecord `protobuf:"bytes,1,opt,name=note_record,json=noteRecord,proto3" json:"note_record,omitempty"`
+ IdentityKey *v1alpha11.IdentityKey `protobuf:"bytes,2,opt,name=identity_key,json=identityKey,proto3" json:"identity_key,omitempty"`
+}
+
+func (m *NotesForVotingResponse) Reset() { *m = NotesForVotingResponse{} }
+func (m *NotesForVotingResponse) String() string { return proto.CompactTextString(m) }
+func (*NotesForVotingResponse) ProtoMessage() {}
+func (*NotesForVotingResponse) Descriptor() ([]byte, []int) {
+ return fileDescriptor_0aa947b204e6a7c2, []int{45}
+}
+func (m *NotesForVotingResponse) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *NotesForVotingResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_NotesForVotingResponse.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *NotesForVotingResponse) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_NotesForVotingResponse.Merge(m, src)
+}
+func (m *NotesForVotingResponse) XXX_Size() int {
+ return m.Size()
+}
+func (m *NotesForVotingResponse) XXX_DiscardUnknown() {
+ xxx_messageInfo_NotesForVotingResponse.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_NotesForVotingResponse proto.InternalMessageInfo
+
+func (m *NotesForVotingResponse) GetNoteRecord() *SpendableNoteRecord {
+ if m != nil {
+ return m.NoteRecord
+ }
+ return nil
+}
+
+func (m *NotesForVotingResponse) GetIdentityKey() *v1alpha11.IdentityKey {
+ if m != nil {
+ return m.IdentityKey
+ }
+ return nil
+}
+
+// A note plaintext with associated metadata about its status.
+type SpendableNoteRecord struct {
+ // The note commitment, identifying the note.
+ NoteCommitment *v1alpha11.StateCommitment `protobuf:"bytes,1,opt,name=note_commitment,json=noteCommitment,proto3" json:"note_commitment,omitempty"`
+ // The note plaintext itself.
+ Note *v1alpha11.Note `protobuf:"bytes,2,opt,name=note,proto3" json:"note,omitempty"`
+ // A precomputed decryption of the note's address incore.dex.v1alpha1.
+ AddressIndex *v1alpha11.AddressIndex `protobuf:"bytes,3,opt,name=address_index,json=addressIndex,proto3" json:"address_index,omitempty"`
+ // The note's nullifier.
+ Nullifier *v1alpha11.Nullifier `protobuf:"bytes,4,opt,name=nullifier,proto3" json:"nullifier,omitempty"`
+ // The height at which the note was created.
+ HeightCreated uint64 `protobuf:"varint,5,opt,name=height_created,json=heightCreated,proto3" json:"height_created,omitempty"`
+ // Types that are valid to be assigned to XHeightSpent:
+ // *SpendableNoteRecord_HeightSpent
+ XHeightSpent isSpendableNoteRecord_XHeightSpent `protobuf_oneof:"_height_spent"`
+ // The note position.
+ Position uint64 `protobuf:"varint,7,opt,name=position,proto3" json:"position,omitempty"`
+ // The source of the note (a tx hash or otherwise)
+ Source *v1alpha14.NoteSource `protobuf:"bytes,8,opt,name=source,proto3" json:"source,omitempty"`
+}
+
+func (m *SpendableNoteRecord) Reset() { *m = SpendableNoteRecord{} }
+func (m *SpendableNoteRecord) String() string { return proto.CompactTextString(m) }
+func (*SpendableNoteRecord) ProtoMessage() {}
+func (*SpendableNoteRecord) Descriptor() ([]byte, []int) {
+ return fileDescriptor_0aa947b204e6a7c2, []int{46}
+}
+func (m *SpendableNoteRecord) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *SpendableNoteRecord) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_SpendableNoteRecord.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *SpendableNoteRecord) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_SpendableNoteRecord.Merge(m, src)
+}
+func (m *SpendableNoteRecord) XXX_Size() int {
+ return m.Size()
+}
+func (m *SpendableNoteRecord) XXX_DiscardUnknown() {
+ xxx_messageInfo_SpendableNoteRecord.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_SpendableNoteRecord proto.InternalMessageInfo
+
+type isSpendableNoteRecord_XHeightSpent interface {
+ isSpendableNoteRecord_XHeightSpent()
+ MarshalTo([]byte) (int, error)
+ Size() int
+}
+
+type SpendableNoteRecord_HeightSpent struct {
+ HeightSpent uint64 `protobuf:"varint,6,opt,name=height_spent,json=heightSpent,proto3,oneof" json:"height_spent,omitempty"`
+}
+
+func (*SpendableNoteRecord_HeightSpent) isSpendableNoteRecord_XHeightSpent() {}
+
+func (m *SpendableNoteRecord) GetXHeightSpent() isSpendableNoteRecord_XHeightSpent {
+ if m != nil {
+ return m.XHeightSpent
+ }
+ return nil
+}
+
+func (m *SpendableNoteRecord) GetNoteCommitment() *v1alpha11.StateCommitment {
+ if m != nil {
+ return m.NoteCommitment
+ }
+ return nil
+}
+
+func (m *SpendableNoteRecord) GetNote() *v1alpha11.Note {
+ if m != nil {
+ return m.Note
+ }
+ return nil
+}
+
+func (m *SpendableNoteRecord) GetAddressIndex() *v1alpha11.AddressIndex {
+ if m != nil {
+ return m.AddressIndex
+ }
+ return nil
+}
+
+func (m *SpendableNoteRecord) GetNullifier() *v1alpha11.Nullifier {
+ if m != nil {
+ return m.Nullifier
+ }
+ return nil
+}
+
+func (m *SpendableNoteRecord) GetHeightCreated() uint64 {
+ if m != nil {
+ return m.HeightCreated
+ }
+ return 0
+}
+
+func (m *SpendableNoteRecord) GetHeightSpent() uint64 {
+ if x, ok := m.GetXHeightSpent().(*SpendableNoteRecord_HeightSpent); ok {
+ return x.HeightSpent
+ }
+ return 0
+}
+
+func (m *SpendableNoteRecord) GetPosition() uint64 {
+ if m != nil {
+ return m.Position
+ }
+ return 0
+}
+
+func (m *SpendableNoteRecord) GetSource() *v1alpha14.NoteSource {
+ if m != nil {
+ return m.Source
+ }
+ return nil
+}
+
+// XXX_OneofWrappers is for the internal use of the proto package.
+func (*SpendableNoteRecord) XXX_OneofWrappers() []interface{} {
+ return []interface{}{
+ (*SpendableNoteRecord_HeightSpent)(nil),
+ }
+}
+
+type SwapRecord struct {
+ SwapCommitment *v1alpha11.StateCommitment `protobuf:"bytes,1,opt,name=swap_commitment,json=swapCommitment,proto3" json:"swap_commitment,omitempty"`
+ Swap *v1alpha15.SwapPlaintext `protobuf:"bytes,2,opt,name=swap,proto3" json:"swap,omitempty"`
+ Position uint64 `protobuf:"varint,3,opt,name=position,proto3" json:"position,omitempty"`
+ Nullifier *v1alpha11.Nullifier `protobuf:"bytes,4,opt,name=nullifier,proto3" json:"nullifier,omitempty"`
+ OutputData *v1alpha15.BatchSwapOutputData `protobuf:"bytes,5,opt,name=output_data,json=outputData,proto3" json:"output_data,omitempty"`
+ // Types that are valid to be assigned to XHeightClaimed:
+ // *SwapRecord_HeightClaimed
+ XHeightClaimed isSwapRecord_XHeightClaimed `protobuf_oneof:"_height_claimed"`
+ Source *v1alpha14.NoteSource `protobuf:"bytes,7,opt,name=source,proto3" json:"source,omitempty"`
+}
+
+func (m *SwapRecord) Reset() { *m = SwapRecord{} }
+func (m *SwapRecord) String() string { return proto.CompactTextString(m) }
+func (*SwapRecord) ProtoMessage() {}
+func (*SwapRecord) Descriptor() ([]byte, []int) {
+ return fileDescriptor_0aa947b204e6a7c2, []int{47}
+}
+func (m *SwapRecord) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *SwapRecord) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_SwapRecord.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *SwapRecord) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_SwapRecord.Merge(m, src)
+}
+func (m *SwapRecord) XXX_Size() int {
+ return m.Size()
+}
+func (m *SwapRecord) XXX_DiscardUnknown() {
+ xxx_messageInfo_SwapRecord.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_SwapRecord proto.InternalMessageInfo
+
+type isSwapRecord_XHeightClaimed interface {
+ isSwapRecord_XHeightClaimed()
+ MarshalTo([]byte) (int, error)
+ Size() int
+}
+
+type SwapRecord_HeightClaimed struct {
+ HeightClaimed uint64 `protobuf:"varint,6,opt,name=height_claimed,json=heightClaimed,proto3,oneof" json:"height_claimed,omitempty"`
+}
+
+func (*SwapRecord_HeightClaimed) isSwapRecord_XHeightClaimed() {}
+
+func (m *SwapRecord) GetXHeightClaimed() isSwapRecord_XHeightClaimed {
+ if m != nil {
+ return m.XHeightClaimed
+ }
+ return nil
+}
+
+func (m *SwapRecord) GetSwapCommitment() *v1alpha11.StateCommitment {
+ if m != nil {
+ return m.SwapCommitment
+ }
+ return nil
+}
+
+func (m *SwapRecord) GetSwap() *v1alpha15.SwapPlaintext {
+ if m != nil {
+ return m.Swap
+ }
+ return nil
+}
+
+func (m *SwapRecord) GetPosition() uint64 {
+ if m != nil {
+ return m.Position
+ }
+ return 0
+}
+
+func (m *SwapRecord) GetNullifier() *v1alpha11.Nullifier {
+ if m != nil {
+ return m.Nullifier
+ }
+ return nil
+}
+
+func (m *SwapRecord) GetOutputData() *v1alpha15.BatchSwapOutputData {
+ if m != nil {
+ return m.OutputData
+ }
+ return nil
+}
+
+func (m *SwapRecord) GetHeightClaimed() uint64 {
+ if x, ok := m.GetXHeightClaimed().(*SwapRecord_HeightClaimed); ok {
+ return x.HeightClaimed
+ }
+ return 0
+}
+
+func (m *SwapRecord) GetSource() *v1alpha14.NoteSource {
+ if m != nil {
+ return m.Source
+ }
+ return nil
+}
+
+// XXX_OneofWrappers is for the internal use of the proto package.
+func (*SwapRecord) XXX_OneofWrappers() []interface{} {
+ return []interface{}{
+ (*SwapRecord_HeightClaimed)(nil),
+ }
+}
+
+type OwnedPositionIdsRequest struct {
+ // Types that are valid to be assigned to XPositionState:
+ // *OwnedPositionIdsRequest_PositionState
+ XPositionState isOwnedPositionIdsRequest_XPositionState `protobuf_oneof:"_position_state"`
+ // Types that are valid to be assigned to XTradingPair:
+ // *OwnedPositionIdsRequest_TradingPair
+ XTradingPair isOwnedPositionIdsRequest_XTradingPair `protobuf_oneof:"_trading_pair"`
+}
+
+func (m *OwnedPositionIdsRequest) Reset() { *m = OwnedPositionIdsRequest{} }
+func (m *OwnedPositionIdsRequest) String() string { return proto.CompactTextString(m) }
+func (*OwnedPositionIdsRequest) ProtoMessage() {}
+func (*OwnedPositionIdsRequest) Descriptor() ([]byte, []int) {
+ return fileDescriptor_0aa947b204e6a7c2, []int{48}
+}
+func (m *OwnedPositionIdsRequest) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *OwnedPositionIdsRequest) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_OwnedPositionIdsRequest.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *OwnedPositionIdsRequest) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_OwnedPositionIdsRequest.Merge(m, src)
+}
+func (m *OwnedPositionIdsRequest) XXX_Size() int {
+ return m.Size()
+}
+func (m *OwnedPositionIdsRequest) XXX_DiscardUnknown() {
+ xxx_messageInfo_OwnedPositionIdsRequest.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_OwnedPositionIdsRequest proto.InternalMessageInfo
+
+type isOwnedPositionIdsRequest_XPositionState interface {
+ isOwnedPositionIdsRequest_XPositionState()
+ MarshalTo([]byte) (int, error)
+ Size() int
+}
+type isOwnedPositionIdsRequest_XTradingPair interface {
+ isOwnedPositionIdsRequest_XTradingPair()
+ MarshalTo([]byte) (int, error)
+ Size() int
+}
+
+type OwnedPositionIdsRequest_PositionState struct {
+ PositionState *v1alpha15.PositionState `protobuf:"bytes,1,opt,name=position_state,json=positionState,proto3,oneof" json:"position_state,omitempty"`
+}
+type OwnedPositionIdsRequest_TradingPair struct {
+ TradingPair *v1alpha15.TradingPair `protobuf:"bytes,2,opt,name=trading_pair,json=tradingPair,proto3,oneof" json:"trading_pair,omitempty"`
+}
+
+func (*OwnedPositionIdsRequest_PositionState) isOwnedPositionIdsRequest_XPositionState() {}
+func (*OwnedPositionIdsRequest_TradingPair) isOwnedPositionIdsRequest_XTradingPair() {}
+
+func (m *OwnedPositionIdsRequest) GetXPositionState() isOwnedPositionIdsRequest_XPositionState {
+ if m != nil {
+ return m.XPositionState
+ }
+ return nil
+}
+func (m *OwnedPositionIdsRequest) GetXTradingPair() isOwnedPositionIdsRequest_XTradingPair {
+ if m != nil {
+ return m.XTradingPair
+ }
+ return nil
+}
+
+func (m *OwnedPositionIdsRequest) GetPositionState() *v1alpha15.PositionState {
+ if x, ok := m.GetXPositionState().(*OwnedPositionIdsRequest_PositionState); ok {
+ return x.PositionState
+ }
+ return nil
+}
+
+func (m *OwnedPositionIdsRequest) GetTradingPair() *v1alpha15.TradingPair {
+ if x, ok := m.GetXTradingPair().(*OwnedPositionIdsRequest_TradingPair); ok {
+ return x.TradingPair
+ }
+ return nil
+}
+
+// XXX_OneofWrappers is for the internal use of the proto package.
+func (*OwnedPositionIdsRequest) XXX_OneofWrappers() []interface{} {
+ return []interface{}{
+ (*OwnedPositionIdsRequest_PositionState)(nil),
+ (*OwnedPositionIdsRequest_TradingPair)(nil),
+ }
+}
+
+type OwnedPositionIdsResponse struct {
+ PositionId *v1alpha15.PositionId `protobuf:"bytes,1,opt,name=position_id,json=positionId,proto3" json:"position_id,omitempty"`
+}
+
+func (m *OwnedPositionIdsResponse) Reset() { *m = OwnedPositionIdsResponse{} }
+func (m *OwnedPositionIdsResponse) String() string { return proto.CompactTextString(m) }
+func (*OwnedPositionIdsResponse) ProtoMessage() {}
+func (*OwnedPositionIdsResponse) Descriptor() ([]byte, []int) {
+ return fileDescriptor_0aa947b204e6a7c2, []int{49}
+}
+func (m *OwnedPositionIdsResponse) XXX_Unmarshal(b []byte) error {
+ return m.Unmarshal(b)
+}
+func (m *OwnedPositionIdsResponse) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
+ if deterministic {
+ return xxx_messageInfo_OwnedPositionIdsResponse.Marshal(b, m, deterministic)
+ } else {
+ b = b[:cap(b)]
+ n, err := m.MarshalToSizedBuffer(b)
+ if err != nil {
+ return nil, err
+ }
+ return b[:n], nil
+ }
+}
+func (m *OwnedPositionIdsResponse) XXX_Merge(src proto.Message) {
+ xxx_messageInfo_OwnedPositionIdsResponse.Merge(m, src)
+}
+func (m *OwnedPositionIdsResponse) XXX_Size() int {
+ return m.Size()
+}
+func (m *OwnedPositionIdsResponse) XXX_DiscardUnknown() {
+ xxx_messageInfo_OwnedPositionIdsResponse.DiscardUnknown(m)
+}
+
+var xxx_messageInfo_OwnedPositionIdsResponse proto.InternalMessageInfo
+
+func (m *OwnedPositionIdsResponse) GetPositionId() *v1alpha15.PositionId {
+ if m != nil {
+ return m.PositionId
+ }
+ return nil
+}
+
+func init() {
+ proto.RegisterType((*AuthorizeAndBuildRequest)(nil), "penumbra.view.v1alpha1.AuthorizeAndBuildRequest")
+ proto.RegisterType((*AuthorizeAndBuildResponse)(nil), "penumbra.view.v1alpha1.AuthorizeAndBuildResponse")
+ proto.RegisterType((*BroadcastTransactionRequest)(nil), "penumbra.view.v1alpha1.BroadcastTransactionRequest")
+ proto.RegisterType((*BroadcastTransactionResponse)(nil), "penumbra.view.v1alpha1.BroadcastTransactionResponse")
+ proto.RegisterType((*TransactionPlannerRequest)(nil), "penumbra.view.v1alpha1.TransactionPlannerRequest")
+ proto.RegisterType((*TransactionPlannerRequest_Output)(nil), "penumbra.view.v1alpha1.TransactionPlannerRequest.Output")
+ proto.RegisterType((*TransactionPlannerRequest_Swap)(nil), "penumbra.view.v1alpha1.TransactionPlannerRequest.Swap")
+ proto.RegisterType((*TransactionPlannerRequest_SwapClaim)(nil), "penumbra.view.v1alpha1.TransactionPlannerRequest.SwapClaim")
+ proto.RegisterType((*TransactionPlannerRequest_Delegate)(nil), "penumbra.view.v1alpha1.TransactionPlannerRequest.Delegate")
+ proto.RegisterType((*TransactionPlannerRequest_Undelegate)(nil), "penumbra.view.v1alpha1.TransactionPlannerRequest.Undelegate")
+ proto.RegisterType((*TransactionPlannerResponse)(nil), "penumbra.view.v1alpha1.TransactionPlannerResponse")
+ proto.RegisterType((*AddressByIndexRequest)(nil), "penumbra.view.v1alpha1.AddressByIndexRequest")
+ proto.RegisterType((*AddressByIndexResponse)(nil), "penumbra.view.v1alpha1.AddressByIndexResponse")
+ proto.RegisterType((*IndexByAddressRequest)(nil), "penumbra.view.v1alpha1.IndexByAddressRequest")
+ proto.RegisterType((*IndexByAddressResponse)(nil), "penumbra.view.v1alpha1.IndexByAddressResponse")
+ proto.RegisterType((*EphemeralAddressRequest)(nil), "penumbra.view.v1alpha1.EphemeralAddressRequest")
+ proto.RegisterType((*EphemeralAddressResponse)(nil), "penumbra.view.v1alpha1.EphemeralAddressResponse")
+ proto.RegisterType((*BalancesRequest)(nil), "penumbra.view.v1alpha1.BalancesRequest")
+ proto.RegisterType((*BalancesResponse)(nil), "penumbra.view.v1alpha1.BalancesResponse")
+ proto.RegisterType((*ViewAuthToken)(nil), "penumbra.view.v1alpha1.ViewAuthToken")
+ proto.RegisterType((*ViewAuthRequest)(nil), "penumbra.view.v1alpha1.ViewAuthRequest")
+ proto.RegisterType((*ViewAuthResponse)(nil), "penumbra.view.v1alpha1.ViewAuthResponse")
+ proto.RegisterType((*StatusRequest)(nil), "penumbra.view.v1alpha1.StatusRequest")
+ proto.RegisterType((*StatusResponse)(nil), "penumbra.view.v1alpha1.StatusResponse")
+ proto.RegisterType((*StatusStreamRequest)(nil), "penumbra.view.v1alpha1.StatusStreamRequest")
+ proto.RegisterType((*StatusStreamResponse)(nil), "penumbra.view.v1alpha1.StatusStreamResponse")
+ proto.RegisterType((*NotesRequest)(nil), "penumbra.view.v1alpha1.NotesRequest")
+ proto.RegisterType((*NotesForVotingRequest)(nil), "penumbra.view.v1alpha1.NotesForVotingRequest")
+ proto.RegisterType((*WitnessRequest)(nil), "penumbra.view.v1alpha1.WitnessRequest")
+ proto.RegisterType((*WitnessResponse)(nil), "penumbra.view.v1alpha1.WitnessResponse")
+ proto.RegisterType((*WitnessAndBuildRequest)(nil), "penumbra.view.v1alpha1.WitnessAndBuildRequest")
+ proto.RegisterType((*WitnessAndBuildResponse)(nil), "penumbra.view.v1alpha1.WitnessAndBuildResponse")
+ proto.RegisterType((*AssetsRequest)(nil), "penumbra.view.v1alpha1.AssetsRequest")
+ proto.RegisterType((*AssetsResponse)(nil), "penumbra.view.v1alpha1.AssetsResponse")
+ proto.RegisterType((*ChainParametersRequest)(nil), "penumbra.view.v1alpha1.ChainParametersRequest")
+ proto.RegisterType((*ChainParametersResponse)(nil), "penumbra.view.v1alpha1.ChainParametersResponse")
+ proto.RegisterType((*FMDParametersRequest)(nil), "penumbra.view.v1alpha1.FMDParametersRequest")
+ proto.RegisterType((*FMDParametersResponse)(nil), "penumbra.view.v1alpha1.FMDParametersResponse")
+ proto.RegisterType((*NoteByCommitmentRequest)(nil), "penumbra.view.v1alpha1.NoteByCommitmentRequest")
+ proto.RegisterType((*NoteByCommitmentResponse)(nil), "penumbra.view.v1alpha1.NoteByCommitmentResponse")
+ proto.RegisterType((*SwapByCommitmentRequest)(nil), "penumbra.view.v1alpha1.SwapByCommitmentRequest")
+ proto.RegisterType((*SwapByCommitmentResponse)(nil), "penumbra.view.v1alpha1.SwapByCommitmentResponse")
+ proto.RegisterType((*NullifierStatusRequest)(nil), "penumbra.view.v1alpha1.NullifierStatusRequest")
+ proto.RegisterType((*NullifierStatusResponse)(nil), "penumbra.view.v1alpha1.NullifierStatusResponse")
+ proto.RegisterType((*TransactionInfoByHashRequest)(nil), "penumbra.view.v1alpha1.TransactionInfoByHashRequest")
+ proto.RegisterType((*TransactionInfoRequest)(nil), "penumbra.view.v1alpha1.TransactionInfoRequest")
+ proto.RegisterType((*TransactionInfo)(nil), "penumbra.view.v1alpha1.TransactionInfo")
+ proto.RegisterType((*TransactionInfoResponse)(nil), "penumbra.view.v1alpha1.TransactionInfoResponse")
+ proto.RegisterType((*TransactionInfoByHashResponse)(nil), "penumbra.view.v1alpha1.TransactionInfoByHashResponse")
+ proto.RegisterType((*NotesResponse)(nil), "penumbra.view.v1alpha1.NotesResponse")
+ proto.RegisterType((*NotesForVotingResponse)(nil), "penumbra.view.v1alpha1.NotesForVotingResponse")
+ proto.RegisterType((*SpendableNoteRecord)(nil), "penumbra.view.v1alpha1.SpendableNoteRecord")
+ proto.RegisterType((*SwapRecord)(nil), "penumbra.view.v1alpha1.SwapRecord")
+ proto.RegisterType((*OwnedPositionIdsRequest)(nil), "penumbra.view.v1alpha1.OwnedPositionIdsRequest")
+ proto.RegisterType((*OwnedPositionIdsResponse)(nil), "penumbra.view.v1alpha1.OwnedPositionIdsResponse")
+}
+
+func init() { proto.RegisterFile("penumbra/view/v1alpha1/view.proto", fileDescriptor_0aa947b204e6a7c2) }
+
+var fileDescriptor_0aa947b204e6a7c2 = []byte{
+ // 3002 bytes of a gzipped FileDescriptorProto
+ 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xdc, 0x5b, 0xcd, 0x6f, 0x1b, 0xc7,
+ 0x15, 0xf7, 0x92, 0xfa, 0xf2, 0xa3, 0x48, 0xca, 0x63, 0x5b, 0xa2, 0x99, 0x44, 0x49, 0x37, 0xf1,
+ 0x47, 0x9c, 0x84, 0xb2, 0x15, 0x27, 0x4d, 0x95, 0xa4, 0x8d, 0x68, 0x45, 0x96, 0xe0, 0xd8, 0x56,
+ 0x57, 0xb6, 0xdc, 0xa4, 0x4a, 0x17, 0xa3, 0xdd, 0x91, 0xb4, 0x15, 0xb9, 0xbb, 0xd9, 0x1d, 0xea,
+ 0xa3, 0x3d, 0xa5, 0x08, 0x0a, 0x23, 0x40, 0x83, 0xa0, 0xe8, 0xa5, 0xd7, 0x1e, 0x8b, 0x5e, 0x73,
+ 0x2d, 0x0a, 0xf4, 0x52, 0xf4, 0x94, 0x63, 0x81, 0x02, 0x45, 0x60, 0xa3, 0x97, 0xf6, 0x5f, 0x28,
+ 0xd0, 0x62, 0xbe, 0x96, 0xbb, 0x4b, 0xae, 0x49, 0x4a, 0x32, 0x1c, 0xf4, 0x24, 0xce, 0xcc, 0x7b,
+ 0xbf, 0xf7, 0x31, 0x33, 0x6f, 0xde, 0xbc, 0x59, 0xc1, 0x77, 0x7c, 0xe2, 0xb6, 0x9a, 0x1b, 0x01,
+ 0x9e, 0xd9, 0x75, 0xc8, 0xde, 0xcc, 0xee, 0x55, 0xdc, 0xf0, 0xb7, 0xf1, 0x55, 0xde, 0xaa, 0xf9,
+ 0x81, 0x47, 0x3d, 0x34, 0xa9, 0x48, 0x6a, 0xbc, 0x53, 0x91, 0x54, 0x2f, 0x45, 0xac, 0x96, 0x17,
+ 0x90, 0x19, 0x6b, 0x1b, 0x3b, 0x6e, 0x1b, 0x80, 0x37, 0x05, 0x42, 0xf5, 0x72, 0x8a, 0x32, 0x38,
+ 0xf0, 0xa9, 0x17, 0x23, 0xe5, 0x6d, 0x49, 0xfb, 0x52, 0x92, 0xd6, 0x26, 0xfb, 0x6d, 0x42, 0x9b,
+ 0xec, 0x4b, 0xaa, 0x6b, 0x49, 0x2a, 0x1a, 0x60, 0x37, 0xc4, 0x16, 0x75, 0xbc, 0x98, 0x06, 0xb1,
+ 0xce, 0xee, 0xd8, 0xce, 0x86, 0xd5, 0xa6, 0x76, 0x36, 0x2c, 0x49, 0x95, 0xb2, 0x2b, 0xa4, 0x78,
+ 0x87, 0xb4, 0xe9, 0x78, 0x53, 0x50, 0xea, 0xdf, 0x68, 0x50, 0x99, 0x6f, 0xd1, 0x6d, 0x2f, 0x70,
+ 0x7e, 0x46, 0xe6, 0x5d, 0xbb, 0xde, 0x72, 0x1a, 0xb6, 0x41, 0x3e, 0x69, 0x91, 0x90, 0xa2, 0x9f,
+ 0xc0, 0x44, 0x4c, 0x03, 0xd3, 0x6f, 0x60, 0xb7, 0xa2, 0xbd, 0xa0, 0x5d, 0x2a, 0xcc, 0xbe, 0x5e,
+ 0x8b, 0x3c, 0xca, 0x24, 0xd4, 0xe2, 0x8a, 0x2a, 0x39, 0xb5, 0xbb, 0xed, 0xce, 0x95, 0x06, 0x76,
+ 0x8d, 0x32, 0x4d, 0x76, 0x20, 0x1b, 0x10, 0x96, 0xb2, 0x31, 0x97, 0x60, 0x63, 0x8a, 0x2b, 0x39,
+ 0x2e, 0xe1, 0x8d, 0x7e, 0x24, 0xcc, 0xc7, 0xb9, 0x17, 0x30, 0xc5, 0xc6, 0x29, 0x9c, 0xee, 0xd2,
+ 0x5d, 0x38, 0xd7, 0xc5, 0xc2, 0xd0, 0xf7, 0xdc, 0x90, 0xa0, 0x1f, 0x42, 0x21, 0x86, 0x2c, 0xad,
+ 0x9b, 0x19, 0xd0, 0x3a, 0x23, 0x8e, 0xa1, 0xff, 0x56, 0x83, 0x67, 0xea, 0x81, 0x87, 0x6d, 0x0b,
+ 0x87, 0x34, 0x4e, 0x25, 0xbd, 0x7a, 0xfc, 0x22, 0xd1, 0x45, 0x28, 0xe3, 0x3d, 0xec, 0x50, 0xd3,
+ 0x26, 0x94, 0x08, 0x58, 0xe6, 0xc5, 0x31, 0xa3, 0xc4, 0xbb, 0x17, 0x54, 0xaf, 0xfe, 0xa9, 0x06,
+ 0xcf, 0x76, 0xd7, 0x4d, 0xfa, 0xe3, 0x4d, 0xc8, 0x39, 0xb6, 0xd4, 0xe9, 0x42, 0x3f, 0x3a, 0x2d,
+ 0xdb, 0x46, 0xce, 0xb1, 0xd1, 0xcb, 0x30, 0x11, 0xc9, 0x36, 0xb7, 0x89, 0xb3, 0xb5, 0x4d, 0xb9,
+ 0x0a, 0x43, 0x46, 0x39, 0xea, 0x5f, 0xe2, 0xdd, 0xfa, 0x97, 0xe3, 0x70, 0x2e, 0xb5, 0x34, 0x5c,
+ 0x12, 0x28, 0xef, 0xbc, 0x08, 0x45, 0xb2, 0xef, 0x3b, 0xc1, 0x81, 0x42, 0xd1, 0x38, 0xca, 0xb8,
+ 0xe8, 0x14, 0x10, 0xe8, 0x1a, 0xe4, 0x37, 0x09, 0x91, 0x2b, 0x45, 0x4f, 0xa9, 0x29, 0xf7, 0x62,
+ 0xa4, 0xe1, 0x22, 0x21, 0x06, 0x23, 0x47, 0xef, 0xc3, 0x50, 0x93, 0x34, 0xbd, 0x4a, 0x9e, 0xb3,
+ 0x5d, 0xed, 0xc7, 0xba, 0x5b, 0xa4, 0xe9, 0xad, 0x34, 0xb0, 0xe3, 0x52, 0xb2, 0x4f, 0x0d, 0xce,
+ 0x8e, 0xd6, 0x61, 0x02, 0x5b, 0x96, 0xd7, 0x72, 0xa9, 0xb9, 0x15, 0x78, 0x2d, 0xdf, 0x74, 0xec,
+ 0x4a, 0x89, 0x43, 0xbe, 0xd6, 0x43, 0x93, 0x79, 0xc1, 0x76, 0x83, 0x71, 0x2d, 0xdb, 0x4b, 0x27,
+ 0x8c, 0x12, 0x4e, 0xf4, 0x3c, 0xd0, 0x34, 0x64, 0xc0, 0xa8, 0xd7, 0xa2, 0x7e, 0x8b, 0x86, 0x95,
+ 0x33, 0x2f, 0xe4, 0x2f, 0x15, 0x66, 0xdf, 0xaa, 0x75, 0x0f, 0x5e, 0xb5, 0x4c, 0x1f, 0xd6, 0xee,
+ 0x70, 0x00, 0x43, 0x01, 0xa1, 0x0f, 0x60, 0x38, 0xdc, 0xc3, 0x7e, 0x58, 0x99, 0xe6, 0x88, 0x6f,
+ 0x0e, 0x8e, 0xb8, 0xba, 0x87, 0x7d, 0x43, 0x80, 0xa0, 0x75, 0x28, 0xb0, 0x1f, 0xa6, 0xd5, 0xc0,
+ 0x4e, 0x33, 0xac, 0x3c, 0xcf, 0x31, 0xdf, 0x3e, 0x1c, 0xe6, 0x75, 0x86, 0x61, 0x40, 0xa8, 0x7e,
+ 0x72, 0x74, 0x9b, 0x34, 0xc8, 0x16, 0xdf, 0xbf, 0x61, 0xe5, 0x12, 0x47, 0x9f, 0x1b, 0x1c, 0x7d,
+ 0x41, 0x80, 0x10, 0x23, 0x0e, 0x87, 0x36, 0xa0, 0xd8, 0x72, 0xe3, 0xf8, 0xb3, 0x1c, 0xff, 0x9d,
+ 0xc1, 0xf1, 0xef, 0x29, 0x18, 0x62, 0x24, 0x21, 0xd1, 0x22, 0x14, 0x9c, 0x0d, 0xcb, 0x14, 0x5c,
+ 0x61, 0xe5, 0x1d, 0x2e, 0xe1, 0x7c, 0x6a, 0x69, 0xb0, 0x58, 0xdd, 0xde, 0x43, 0x1b, 0xd6, 0xbc,
+ 0xd8, 0x86, 0xe0, 0xa8, 0x9f, 0x61, 0xf5, 0x97, 0x1a, 0x8c, 0x88, 0x99, 0x44, 0x73, 0x30, 0xbc,
+ 0x8b, 0x1b, 0x2d, 0x22, 0x37, 0xe6, 0x4b, 0x3d, 0xd6, 0xd9, 0x1a, 0xa3, 0x35, 0x04, 0x0b, 0x7a,
+ 0x0f, 0x46, 0xb1, 0x6d, 0x07, 0x24, 0x0c, 0xe5, 0x7e, 0xb9, 0xd0, 0x6b, 0x95, 0x0a, 0x6a, 0x43,
+ 0xb1, 0x55, 0xff, 0xac, 0xc1, 0x10, 0x9b, 0xac, 0x23, 0xa9, 0xb1, 0x0c, 0xe3, 0x14, 0x07, 0x5b,
+ 0x84, 0x9a, 0x38, 0x0c, 0x09, 0xed, 0x57, 0x17, 0x46, 0xbb, 0x6c, 0x1b, 0x05, 0xc1, 0xcb, 0x9b,
+ 0x6a, 0xf7, 0xe7, 0x07, 0xda, 0xfd, 0x55, 0x1b, 0x4e, 0x46, 0x2b, 0x0e, 0xdd, 0x87, 0xb2, 0x58,
+ 0xc3, 0x5e, 0xb3, 0xe9, 0xd0, 0x26, 0x71, 0xa9, 0xb4, 0xa9, 0xd6, 0x03, 0x6e, 0x95, 0x62, 0x4a,
+ 0xae, 0x47, 0x5c, 0x46, 0x89, 0x2f, 0xdd, 0xa8, 0x5d, 0xfd, 0x42, 0x83, 0x31, 0xb5, 0xf4, 0xd0,
+ 0xbb, 0x30, 0x82, 0x9b, 0x6c, 0x7f, 0x4b, 0xf0, 0xf3, 0xbd, 0xac, 0xe5, 0xc4, 0x86, 0x64, 0x42,
+ 0xd7, 0xe1, 0x64, 0x80, 0x29, 0x11, 0xa7, 0x62, 0xbe, 0xab, 0xbf, 0xc4, 0x51, 0x1e, 0x01, 0x18,
+ 0x98, 0x12, 0x7e, 0x0c, 0x8e, 0x05, 0xf2, 0x57, 0xf5, 0x57, 0x1a, 0x40, 0x7b, 0xad, 0x1e, 0x69,
+ 0x0a, 0x13, 0xfa, 0xe4, 0x0e, 0xa7, 0x4f, 0xfd, 0x34, 0x9c, 0x32, 0xd3, 0xe1, 0x53, 0x27, 0x50,
+ 0xed, 0xb6, 0xd3, 0xe4, 0x99, 0x74, 0x03, 0x86, 0x8e, 0x9a, 0x7a, 0x70, 0x00, 0xfd, 0xd7, 0x1a,
+ 0x9c, 0x95, 0xab, 0xbb, 0x7e, 0xb0, 0xec, 0xda, 0x64, 0x5f, 0x9d, 0x3a, 0x2b, 0x50, 0x94, 0xab,
+ 0xdd, 0x74, 0x58, 0xbf, 0x94, 0xf5, 0x4a, 0x7f, 0x5b, 0x45, 0x40, 0x8d, 0xe3, 0x58, 0x8b, 0x1d,
+ 0xc9, 0xb6, 0x13, 0xfa, 0x0d, 0x7c, 0x60, 0x5a, 0x9e, 0xbb, 0xe9, 0x04, 0x4d, 0x75, 0x24, 0xcb,
+ 0xee, 0xeb, 0xa2, 0x57, 0xff, 0x08, 0x26, 0xd3, 0x3a, 0x49, 0xbb, 0x63, 0x3b, 0x57, 0x3b, 0xd4,
+ 0xce, 0xd5, 0x3f, 0x84, 0xb3, 0x1c, 0xb2, 0x7e, 0xa0, 0x86, 0xa4, 0xbd, 0x47, 0x87, 0xfe, 0x54,
+ 0x83, 0xc9, 0x34, 0xb6, 0xd4, 0xfb, 0xde, 0xd1, 0x9d, 0xb9, 0x74, 0x22, 0xe9, 0xce, 0x07, 0x9a,
+ 0x56, 0x9f, 0x80, 0x92, 0x99, 0xc0, 0xd5, 0x7f, 0xa3, 0xc1, 0xd4, 0xfb, 0xfe, 0x36, 0x69, 0x92,
+ 0x00, 0x37, 0x52, 0x16, 0x3e, 0xc5, 0x19, 0x5d, 0x87, 0x4a, 0xa7, 0x56, 0xc7, 0x36, 0xa7, 0x5f,
+ 0x69, 0x50, 0xae, 0xe3, 0x06, 0x76, 0x2d, 0x12, 0x19, 0x6b, 0x80, 0xca, 0x24, 0xcc, 0x4d, 0xa7,
+ 0x41, 0x49, 0x70, 0x18, 0x6b, 0x8b, 0x12, 0x62, 0x91, 0x23, 0xa0, 0xdb, 0x50, 0xe6, 0x91, 0xda,
+ 0x74, 0x6c, 0x05, 0x3a, 0x58, 0xcc, 0x2e, 0x62, 0xf1, 0x43, 0xe0, 0xb1, 0xb4, 0x78, 0xa2, 0xad,
+ 0xb7, 0x74, 0xc7, 0xfb, 0x30, 0x2a, 0xa5, 0x1e, 0x46, 0x63, 0xc5, 0x8b, 0xbe, 0x0f, 0xa3, 0x1b,
+ 0x02, 0x5a, 0xea, 0xd8, 0x5f, 0x5c, 0x53, 0x4c, 0xfa, 0x79, 0x28, 0xae, 0x39, 0x64, 0x8f, 0x5d,
+ 0x13, 0xee, 0x7a, 0x3b, 0xc4, 0x45, 0x67, 0x60, 0xd8, 0x61, 0x31, 0x88, 0x6b, 0x35, 0x6e, 0x88,
+ 0x86, 0x6e, 0x40, 0x59, 0x91, 0x29, 0xcf, 0xff, 0x00, 0xf2, 0x9b, 0xbb, 0x3b, 0x52, 0xf9, 0x5e,
+ 0xf9, 0xdf, 0x62, 0xab, 0xd1, 0x60, 0x00, 0x8e, 0xbb, 0x75, 0x93, 0x1c, 0x18, 0x8c, 0x53, 0xbf,
+ 0x03, 0x13, 0x6d, 0x4c, 0xe9, 0x95, 0xb7, 0x61, 0x98, 0x32, 0x35, 0x3a, 0x8f, 0x8d, 0x64, 0x76,
+ 0x92, 0xd0, 0xd9, 0x10, 0x3c, 0xfa, 0x2f, 0x34, 0x28, 0xb2, 0x53, 0xaa, 0x15, 0xad, 0x8e, 0x27,
+ 0x9a, 0xb0, 0x76, 0x0f, 0xe8, 0x06, 0x94, 0x94, 0x0e, 0xd2, 0xa6, 0xe7, 0xa1, 0x10, 0x1e, 0xb8,
+ 0x56, 0x32, 0xab, 0x07, 0xd6, 0x25, 0x73, 0xfa, 0xe7, 0xa1, 0x60, 0x61, 0x6a, 0x6d, 0x3b, 0xee,
+ 0x96, 0xd9, 0xf2, 0xe5, 0xd6, 0x02, 0xd5, 0x75, 0xcf, 0xd7, 0x1f, 0x68, 0x70, 0x5a, 0x80, 0xae,
+ 0xd2, 0x80, 0xe0, 0xe6, 0x53, 0x34, 0x2f, 0x80, 0x33, 0x49, 0x4d, 0xa4, 0x91, 0xdf, 0x83, 0x73,
+ 0x0d, 0x4c, 0x49, 0x48, 0xcd, 0x1d, 0xd7, 0xdb, 0x73, 0xcd, 0x8d, 0x86, 0x67, 0xed, 0x24, 0x4d,
+ 0x9e, 0x14, 0x04, 0x37, 0xd9, 0x78, 0x9d, 0x0d, 0xb7, 0xcd, 0x8f, 0xfb, 0x27, 0x97, 0xf6, 0x8f,
+ 0xfe, 0x79, 0x1e, 0xc6, 0x6f, 0x7b, 0xb4, 0xbd, 0xe9, 0x5f, 0x84, 0xa2, 0xe3, 0x5a, 0x8d, 0x96,
+ 0x4d, 0xcc, 0xd0, 0x67, 0x19, 0x8c, 0x70, 0xd9, 0xb8, 0xec, 0x5c, 0x65, 0x7d, 0x68, 0x1e, 0xc6,
+ 0xd4, 0x2e, 0xce, 0x48, 0x21, 0xb2, 0xb6, 0xef, 0xa8, 0xdc, 0xbe, 0x9d, 0x91, 0x74, 0xe8, 0xa8,
+ 0x91, 0xf4, 0x16, 0x94, 0x45, 0x8a, 0x63, 0x52, 0x8f, 0xeb, 0x6e, 0x57, 0x46, 0x06, 0x49, 0x90,
+ 0x8a, 0x82, 0xfb, 0xae, 0xc7, 0x6c, 0xb4, 0x9f, 0xc6, 0x02, 0x78, 0x90, 0x83, 0xb3, 0x7c, 0x32,
+ 0x16, 0xbd, 0x60, 0xcd, 0xa3, 0x8e, 0xbb, 0xa5, 0x66, 0xe5, 0x32, 0x9c, 0xda, 0xf5, 0x28, 0xde,
+ 0x68, 0x10, 0x13, 0xd3, 0xe4, 0xd4, 0x97, 0xe5, 0xc0, 0x3c, 0x95, 0x73, 0xde, 0xe1, 0xd9, 0xfc,
+ 0x51, 0x3d, 0xfb, 0x14, 0x5c, 0xf1, 0xc7, 0x1c, 0x94, 0xee, 0x3b, 0xd4, 0x8d, 0x9d, 0xbd, 0x1f,
+ 0xc2, 0x84, 0xeb, 0x51, 0x12, 0xcb, 0xae, 0xd9, 0xdd, 0x23, 0x7f, 0x88, 0xf4, 0xba, 0xcc, 0x70,
+ 0xda, 0xed, 0xb0, 0x6b, 0x49, 0x2a, 0x7f, 0x8c, 0x25, 0xa9, 0xa7, 0xe0, 0x40, 0x02, 0xe5, 0xc8,
+ 0x7f, 0x32, 0x8e, 0x18, 0x30, 0xbe, 0x27, 0xba, 0x44, 0xb2, 0x3d, 0x40, 0x8d, 0x48, 0x42, 0xf1,
+ 0xac, 0xbb, 0xb0, 0xd7, 0x6e, 0xe8, 0xff, 0xd0, 0x60, 0x52, 0x0e, 0xfe, 0x7f, 0xd6, 0xf9, 0x1a,
+ 0x30, 0xd5, 0x61, 0xdf, 0x93, 0xab, 0xf2, 0xfd, 0x21, 0x0f, 0x45, 0x1e, 0x2a, 0xa3, 0x55, 0x5f,
+ 0x85, 0x31, 0x91, 0x27, 0x11, 0x51, 0x40, 0x1b, 0x33, 0xa2, 0x36, 0xfa, 0x29, 0x4c, 0xc7, 0x62,
+ 0xb5, 0xe5, 0x6c, 0x3a, 0x96, 0x69, 0x13, 0xd7, 0x6b, 0x3a, 0xae, 0x2c, 0x44, 0x88, 0xfd, 0xd1,
+ 0x2b, 0x6f, 0x59, 0x60, 0x3c, 0xc6, 0xb3, 0xed, 0x10, 0xcf, 0xa1, 0x16, 0xe2, 0x48, 0x68, 0x0e,
+ 0xce, 0x29, 0x59, 0xed, 0xb2, 0x84, 0xc9, 0x93, 0x83, 0x90, 0xef, 0x95, 0x31, 0x63, 0x4a, 0x12,
+ 0x2c, 0x44, 0xe3, 0x3c, 0x85, 0x08, 0xd1, 0x5b, 0x50, 0x51, 0xbc, 0x2d, 0x77, 0xc3, 0x73, 0x6d,
+ 0x76, 0x1a, 0x4b, 0xd6, 0x21, 0xce, 0x3a, 0x29, 0xc7, 0xef, 0xa9, 0x61, 0xc9, 0x79, 0x01, 0xca,
+ 0x8a, 0xb3, 0xe1, 0x9b, 0xee, 0x26, 0x0d, 0x2b, 0xc3, 0x9c, 0x41, 0x1d, 0x52, 0x1f, 0xf8, 0xb7,
+ 0x37, 0x69, 0x88, 0x66, 0xe1, 0xac, 0xa2, 0xf3, 0x03, 0xcf, 0xf7, 0x42, 0xdc, 0x10, 0xd4, 0x23,
+ 0x9c, 0xfa, 0xb4, 0x1c, 0x5c, 0x91, 0x63, 0x9c, 0x67, 0x1e, 0x9e, 0x53, 0x3c, 0xbb, 0x3c, 0xd8,
+ 0x9a, 0x01, 0xb1, 0x88, 0xe3, 0x53, 0xa5, 0xda, 0x28, 0xe7, 0xad, 0x4a, 0x22, 0x15, 0x90, 0x39,
+ 0x89, 0x50, 0x4f, 0x27, 0x50, 0x52, 0xb3, 0x25, 0xd7, 0xc4, 0x2a, 0x94, 0xf8, 0x0c, 0x98, 0x4d,
+ 0x42, 0x71, 0x6c, 0x41, 0xbe, 0xda, 0xcf, 0x14, 0xdc, 0x92, 0x3c, 0x46, 0xd1, 0x8e, 0x37, 0xf5,
+ 0x0a, 0x4c, 0x5e, 0xdf, 0xc6, 0x8e, 0xbb, 0x82, 0x03, 0xdc, 0x24, 0x94, 0x04, 0x6a, 0x75, 0xe8,
+ 0xdb, 0x30, 0xd5, 0x31, 0x22, 0x35, 0xb9, 0x05, 0xe0, 0x47, 0xbd, 0x59, 0xa9, 0x24, 0x7f, 0x8b,
+ 0x88, 0x94, 0x48, 0x43, 0xc5, 0x00, 0xf4, 0x49, 0x38, 0xb3, 0x78, 0x6b, 0xa1, 0x53, 0x03, 0x1b,
+ 0xce, 0xa6, 0xfa, 0xa5, 0xfc, 0x9b, 0x5d, 0xe4, 0xbf, 0xf2, 0x78, 0xf9, 0x8b, 0x4d, 0x3b, 0x43,
+ 0xfa, 0x17, 0x39, 0x98, 0x62, 0x27, 0x63, 0xfd, 0x20, 0x16, 0xc6, 0xe5, 0x0e, 0xb9, 0x0f, 0xe5,
+ 0xd4, 0xb9, 0x20, 0x7d, 0x3e, 0x70, 0xd5, 0x25, 0x79, 0x2c, 0x74, 0xab, 0x7f, 0xe7, 0xbb, 0xd5,
+ 0xbf, 0x9f, 0x46, 0x78, 0x77, 0xa1, 0xd2, 0xe9, 0x8f, 0x28, 0xce, 0x97, 0x78, 0xfa, 0xc3, 0xd3,
+ 0x05, 0x66, 0x53, 0xa7, 0xf7, 0x93, 0x19, 0xff, 0xaa, 0xa2, 0x66, 0x90, 0x06, 0xb1, 0xbc, 0xc0,
+ 0x36, 0x8a, 0x61, 0xbc, 0x93, 0x4f, 0xc0, 0xea, 0x1e, 0xf6, 0x33, 0x26, 0x20, 0x5d, 0xf6, 0xca,
+ 0x1d, 0x47, 0xd9, 0xeb, 0x5b, 0x3d, 0x01, 0x06, 0x54, 0x3a, 0xfd, 0x11, 0x3d, 0x77, 0x0c, 0x31,
+ 0x4b, 0xa4, 0xdb, 0xf5, 0x4c, 0xb7, 0xef, 0x61, 0x5f, 0x7a, 0x9b, 0xd3, 0xeb, 0xff, 0xd1, 0x60,
+ 0xf2, 0x76, 0xab, 0xd1, 0x70, 0x36, 0x1d, 0x12, 0x24, 0x6f, 0x5b, 0x8b, 0x70, 0xd2, 0x55, 0x23,
+ 0xd2, 0xbb, 0x97, 0x7a, 0x98, 0x16, 0x21, 0x19, 0x6d, 0xd6, 0x6f, 0xb5, 0x4b, 0x67, 0x60, 0xaa,
+ 0xc3, 0x7a, 0xe9, 0xd1, 0x33, 0x30, 0x2c, 0x6e, 0x23, 0xe2, 0x08, 0x14, 0x0d, 0x7d, 0x0d, 0x9e,
+ 0x8d, 0x9d, 0xa4, 0xcb, 0xee, 0xa6, 0x57, 0x3f, 0x58, 0xc2, 0x61, 0x74, 0x8d, 0x16, 0xcf, 0x4e,
+ 0xb9, 0x41, 0x9f, 0x9d, 0xf4, 0xcf, 0x34, 0x98, 0x4c, 0x01, 0x2b, 0xc8, 0x0b, 0x30, 0x1e, 0x52,
+ 0x1c, 0x24, 0x73, 0xf0, 0xa5, 0x13, 0x46, 0x81, 0xf7, 0x8a, 0x0c, 0xfc, 0x81, 0xa6, 0x21, 0x1d,
+ 0x80, 0xb8, 0x76, 0xe2, 0xde, 0xb5, 0xa4, 0x19, 0x27, 0x89, 0x6b, 0x47, 0x34, 0xf5, 0x32, 0x14,
+ 0xcd, 0x38, 0x58, 0xbd, 0x08, 0x05, 0xb3, 0xcd, 0xa5, 0xff, 0x3b, 0x07, 0xe5, 0x94, 0x1a, 0xe8,
+ 0x19, 0x18, 0x49, 0x49, 0x96, 0x6d, 0x26, 0xf4, 0x90, 0xf6, 0xa6, 0x13, 0x99, 0xfc, 0x31, 0xbc,
+ 0x1d, 0xae, 0x43, 0xc1, 0x27, 0x01, 0xcb, 0x4a, 0xa8, 0xb3, 0x4b, 0xe4, 0xe5, 0x6e, 0x6e, 0xd0,
+ 0xbc, 0xaf, 0x8d, 0x60, 0xc4, 0xe1, 0xd0, 0x0d, 0x18, 0x62, 0x5b, 0x89, 0xe7, 0x02, 0x83, 0xa7,
+ 0x93, 0x6b, 0x0e, 0xd9, 0x33, 0x38, 0x40, 0xfd, 0x24, 0x8c, 0x2a, 0x6f, 0xff, 0x18, 0xa6, 0x3a,
+ 0xe6, 0xbc, 0x5d, 0x5e, 0xa3, 0xfb, 0xa6, 0xe3, 0x6e, 0x7a, 0x72, 0x4b, 0x5f, 0xec, 0xe3, 0x65,
+ 0x87, 0x23, 0x8c, 0xd0, 0x7d, 0xf6, 0x57, 0xc7, 0xf0, 0x5c, 0xc6, 0x4a, 0x3d, 0x36, 0x11, 0x1f,
+ 0x43, 0x51, 0x5e, 0xe4, 0x25, 0xe4, 0x07, 0x50, 0xe0, 0xe7, 0x62, 0xc0, 0x43, 0xcc, 0x61, 0xce,
+ 0x00, 0x70, 0xa3, 0xdf, 0xfa, 0x57, 0x2c, 0x36, 0xa5, 0xee, 0xa6, 0x4f, 0x42, 0x10, 0xba, 0x05,
+ 0xe3, 0x8e, 0x4d, 0x5c, 0xea, 0xd0, 0x03, 0x73, 0x87, 0x1c, 0xc8, 0xe5, 0x7c, 0xb9, 0x47, 0xd0,
+ 0x59, 0x96, 0x2c, 0x37, 0xc9, 0x81, 0x51, 0x70, 0xda, 0x0d, 0xfd, 0xbf, 0x79, 0x38, 0xdd, 0x45,
+ 0x64, 0xb7, 0xac, 0x41, 0x3b, 0x96, 0xac, 0xe1, 0xbb, 0x30, 0xc4, 0xcf, 0x5c, 0xa1, 0xf7, 0x8b,
+ 0xbd, 0x82, 0x34, 0xd3, 0x88, 0x33, 0x3c, 0x81, 0x7b, 0x7b, 0xe2, 0xd0, 0x18, 0x3a, 0xfc, 0xa1,
+ 0x71, 0x1e, 0x4a, 0x62, 0x93, 0x98, 0x56, 0x40, 0x30, 0x25, 0x36, 0xdf, 0x78, 0x43, 0x46, 0x51,
+ 0xf4, 0x5e, 0x17, 0x9d, 0x2c, 0x36, 0x4a, 0x32, 0x11, 0xab, 0x47, 0x54, 0x6c, 0x14, 0xbd, 0xbc,
+ 0x74, 0xc4, 0xc2, 0x54, 0x15, 0xc6, 0x7c, 0x2f, 0x74, 0x78, 0xac, 0x19, 0xe5, 0x40, 0x51, 0x1b,
+ 0xbd, 0x07, 0x23, 0xa1, 0xd7, 0x0a, 0x2c, 0x52, 0x19, 0xeb, 0xae, 0x6f, 0x32, 0x63, 0x64, 0xee,
+ 0x5b, 0xe5, 0xf4, 0x86, 0xe4, 0xe3, 0x51, 0x35, 0xae, 0x86, 0xfe, 0xf7, 0x3c, 0x40, 0xfb, 0xa8,
+ 0x7d, 0x62, 0x8f, 0x74, 0xe8, 0x5d, 0x79, 0xea, 0x8b, 0x89, 0x7f, 0x39, 0x85, 0x66, 0x93, 0xfd,
+ 0xe4, 0xc9, 0x1f, 0xfb, 0x00, 0x80, 0xb1, 0x25, 0xbc, 0x92, 0x4f, 0x79, 0xe5, 0xb8, 0x26, 0x72,
+ 0x05, 0x0a, 0xe2, 0xf5, 0x5e, 0xdc, 0x95, 0x87, 0xbb, 0x06, 0xfa, 0x84, 0xa6, 0x75, 0x4c, 0xad,
+ 0x6d, 0xa6, 0xae, 0x78, 0x33, 0xe6, 0xb7, 0x64, 0xf0, 0xa2, 0xdf, 0xe8, 0x72, 0x7b, 0x69, 0x34,
+ 0xb0, 0xd3, 0x24, 0x76, 0x34, 0xeb, 0x6a, 0x71, 0x88, 0x6e, 0x36, 0xef, 0xed, 0xb9, 0x1d, 0x3d,
+ 0xe4, 0xdc, 0x9e, 0x82, 0xb2, 0x99, 0x14, 0xa7, 0xff, 0x53, 0x83, 0xa9, 0x3b, 0x7b, 0x2e, 0xb1,
+ 0x57, 0xa4, 0xb3, 0x96, 0xed, 0x28, 0x69, 0xba, 0x07, 0x25, 0xe5, 0x42, 0x76, 0xd0, 0x46, 0x89,
+ 0xf0, 0x63, 0xe7, 0x46, 0xe1, 0xf0, 0xe9, 0x66, 0x76, 0xf8, 0xf1, 0x0e, 0x66, 0xc7, 0x1d, 0x18,
+ 0xa7, 0x01, 0xe6, 0x97, 0x58, 0x1f, 0x3b, 0x2a, 0x1d, 0xbb, 0xf8, 0x38, 0xd0, 0xbb, 0x82, 0x7e,
+ 0x05, 0x3b, 0xc1, 0x92, 0xc6, 0x4f, 0x4a, 0xd5, 0x64, 0x89, 0x00, 0x33, 0x2b, 0xa9, 0x28, 0x5f,
+ 0xc5, 0x71, 0x21, 0xba, 0x05, 0x95, 0x4e, 0x33, 0xa3, 0xa7, 0xcc, 0x42, 0xc4, 0x9e, 0xf9, 0x9d,
+ 0x4d, 0x57, 0x23, 0x97, 0x6d, 0x03, 0xfc, 0xe8, 0xf7, 0xec, 0x9f, 0x4e, 0xc3, 0x69, 0x76, 0x3a,
+ 0xae, 0x04, 0x1e, 0xf5, 0x2c, 0xaf, 0xb1, 0x4a, 0x82, 0x5d, 0xc7, 0x22, 0xe8, 0x3e, 0x8c, 0x88,
+ 0x84, 0x0c, 0x65, 0xbe, 0x1a, 0x24, 0xd2, 0xd5, 0xea, 0x85, 0x5e, 0x64, 0x52, 0xf3, 0x1d, 0x18,
+ 0x8f, 0x97, 0xbc, 0xd1, 0x2b, 0x8f, 0xe7, 0x4b, 0x94, 0xe8, 0xab, 0xaf, 0xf6, 0x47, 0x2c, 0x44,
+ 0x5d, 0xd1, 0xd0, 0x1a, 0x0c, 0xf3, 0x13, 0x0c, 0xbd, 0x94, 0xc5, 0x18, 0xaf, 0x84, 0x57, 0xcf,
+ 0xf7, 0xa0, 0x8a, 0x70, 0x3f, 0x81, 0x52, 0xf2, 0x64, 0x44, 0xaf, 0x3d, 0x96, 0x35, 0x5d, 0xdd,
+ 0xad, 0xd6, 0xfa, 0x25, 0x8f, 0x44, 0x7e, 0x04, 0xa3, 0xb2, 0x2a, 0x85, 0x32, 0x5d, 0x9d, 0x2c,
+ 0x9f, 0x56, 0x2f, 0xf6, 0xa4, 0x93, 0x73, 0x12, 0x44, 0x95, 0x43, 0x55, 0xf1, 0x42, 0xb5, 0x1e,
+ 0xbc, 0xa9, 0xd2, 0x5f, 0x75, 0xa6, 0x6f, 0x7a, 0x29, 0xf3, 0x43, 0x18, 0x11, 0x85, 0x94, 0xec,
+ 0x05, 0x96, 0x28, 0x8b, 0x65, 0x2f, 0xb0, 0x64, 0x3d, 0xe6, 0x8a, 0xc6, 0xcc, 0x49, 0xd5, 0x35,
+ 0xb2, 0xcd, 0xe9, 0x5e, 0x65, 0xc9, 0x36, 0x27, 0xab, 0xf6, 0xd2, 0x80, 0x62, 0xa2, 0x28, 0x82,
+ 0x32, 0x97, 0x6a, 0xb7, 0x9a, 0x4a, 0xf5, 0xb5, 0x3e, 0xa9, 0xa5, 0x34, 0x0f, 0x4a, 0xc9, 0xb7,
+ 0xfe, 0xec, 0xf5, 0xd7, 0xf5, 0x3b, 0x85, 0xec, 0xf5, 0x97, 0xf1, 0x09, 0x81, 0x07, 0xa5, 0xe4,
+ 0x23, 0x7d, 0xb6, 0xc0, 0xae, 0x1f, 0x0a, 0x64, 0x0b, 0xcc, 0x78, 0xfb, 0x6f, 0xc1, 0x44, 0xfa,
+ 0xed, 0x1b, 0x65, 0x4e, 0x4a, 0xc6, 0xdb, 0x7d, 0xf5, 0x4a, 0xff, 0x0c, 0x52, 0xac, 0x09, 0x63,
+ 0xea, 0x6d, 0x19, 0x65, 0x6e, 0x9f, 0xd4, 0xab, 0x79, 0xf5, 0x52, 0x6f, 0xc2, 0x68, 0x6d, 0xb6,
+ 0x60, 0x22, 0x5d, 0xc5, 0xc9, 0xb6, 0x2b, 0xa3, 0xfe, 0x95, 0x6d, 0x57, 0x66, 0x81, 0xa8, 0x05,
+ 0x13, 0xe9, 0xda, 0x45, 0xb6, 0xd8, 0x8c, 0xaa, 0x4f, 0xb6, 0xd8, 0xcc, 0xb2, 0x48, 0x00, 0xe5,
+ 0xd4, 0xfd, 0x3e, 0x7b, 0x27, 0x76, 0x2f, 0x83, 0x64, 0xef, 0xc4, 0xac, 0xc2, 0xc1, 0x67, 0x1a,
+ 0x9c, 0xed, 0x7a, 0xf3, 0x42, 0xd7, 0xfa, 0xbc, 0x60, 0x25, 0x4a, 0x0a, 0xd5, 0x37, 0x06, 0xe4,
+ 0x92, 0x6a, 0xd0, 0xce, 0x9b, 0x7c, 0xad, 0xdf, 0x0b, 0x5e, 0x2f, 0xd3, 0x33, 0x6e, 0xad, 0x57,
+ 0x34, 0xf4, 0x73, 0x40, 0x9d, 0x1f, 0x40, 0xa1, 0xab, 0x03, 0x7f, 0x96, 0x58, 0x9d, 0x1d, 0x84,
+ 0x45, 0x9a, 0xfc, 0xa9, 0x06, 0x67, 0xba, 0x7d, 0x14, 0x8c, 0x5e, 0xcf, 0xdc, 0x20, 0xd9, 0x9f,
+ 0x37, 0x57, 0xaf, 0x0d, 0xc6, 0x24, 0x75, 0xd8, 0x83, 0x89, 0x74, 0xd2, 0x94, 0xbd, 0xd0, 0x33,
+ 0xb2, 0xc8, 0xec, 0x85, 0x9e, 0x95, 0x8f, 0x5d, 0xd1, 0xd0, 0x3e, 0x9c, 0xea, 0xf8, 0x3a, 0x1c,
+ 0x65, 0x02, 0x65, 0x7d, 0x2a, 0x5f, 0xbd, 0x3a, 0x00, 0x87, 0x90, 0x3d, 0xeb, 0xb7, 0xbf, 0x26,
+ 0x51, 0xd9, 0xdb, 0xc7, 0x30, 0xa6, 0xba, 0xb2, 0xc3, 0x58, 0xea, 0x13, 0x94, 0xec, 0x30, 0x96,
+ 0xfe, 0xae, 0xa4, 0xfe, 0x79, 0xee, 0x2f, 0x0f, 0xa7, 0xb5, 0xaf, 0x1f, 0x4e, 0x6b, 0xdf, 0x3c,
+ 0x9c, 0xd6, 0xbe, 0x7c, 0x34, 0x7d, 0xe2, 0xeb, 0x47, 0xd3, 0x27, 0xfe, 0xf6, 0x68, 0xfa, 0x04,
+ 0x54, 0x2d, 0xaf, 0x99, 0x81, 0x53, 0x3f, 0x19, 0x25, 0x9a, 0x2b, 0xda, 0x47, 0x77, 0xb6, 0x1c,
+ 0xba, 0xdd, 0xda, 0xa8, 0x59, 0x5e, 0x73, 0xc6, 0xf2, 0xc2, 0xa6, 0x17, 0xce, 0x04, 0xa4, 0x81,
+ 0x0f, 0x48, 0x30, 0xb3, 0x3b, 0x1b, 0xfd, 0xe4, 0x17, 0x84, 0x70, 0xa6, 0xfb, 0x7f, 0x66, 0xbc,
+ 0xcd, 0x5a, 0xaa, 0xf1, 0xbb, 0x5c, 0x7e, 0x65, 0xed, 0x47, 0xbf, 0xcf, 0x4d, 0xae, 0x28, 0xe1,
+ 0x4c, 0x5a, 0x6d, 0x4d, 0x0e, 0xff, 0xb5, 0x3d, 0xb0, 0xce, 0x06, 0xd6, 0xd5, 0xc0, 0xc3, 0x9c,
+ 0xde, 0x7d, 0x60, 0xfd, 0xc6, 0x4a, 0x5d, 0xbd, 0xc7, 0xfc, 0x2b, 0x57, 0x51, 0x44, 0x73, 0x73,
+ 0x8c, 0x6a, 0x6e, 0x4e, 0x91, 0x6d, 0x8c, 0xf0, 0x7f, 0x80, 0x78, 0xfd, 0x7f, 0x01, 0x00, 0x00,
+ 0xff, 0xff, 0x8e, 0xb9, 0xe6, 0x1e, 0x3f, 0x32, 0x00, 0x00,
+}
+
+// Reference imports to suppress errors if they are not otherwise used.
+var _ context.Context
+var _ grpc.ClientConn
+
+// This is a compile-time assertion to ensure that this generated file
+// is compatible with the grpc package it is being compiled against.
+const _ = grpc.SupportPackageIsVersion4
+
+// ViewProtocolServiceClient is the client API for ViewProtocolService service.
+//
+// For semantics around ctx use and closing/ending streaming RPCs, please refer to https://godoc.org/google.golang.org/grpc#ClientConn.NewStream.
+type ViewProtocolServiceClient interface {
+ // Get current status of chain sync
+ Status(ctx context.Context, in *StatusRequest, opts ...grpc.CallOption) (*StatusResponse, error)
+ // Stream sync status updates until the view service has caught up with the core.chain.v1alpha1.
+ // Returns a stream of `StatusStreamResponse`s.
+ StatusStream(ctx context.Context, in *StatusStreamRequest, opts ...grpc.CallOption) (ViewProtocolService_StatusStreamClient, error)
+ // Queries for notes that have been accepted by the core.chain.v1alpha1.
+ // Returns a stream of `NotesResponse`s.
+ Notes(ctx context.Context, in *NotesRequest, opts ...grpc.CallOption) (ViewProtocolService_NotesClient, error)
+ // Returns a stream of `NotesForVotingResponse`s.
+ NotesForVoting(ctx context.Context, in *NotesForVotingRequest, opts ...grpc.CallOption) (ViewProtocolService_NotesForVotingClient, error)
+ // Returns authentication paths for the given note commitments.
+ //
+ // This method takes a batch of input commitments, rather than just one, so
+ // that the client can get a consistent set of authentication paths to a
+ // common root. (Otherwise, if a client made multiple requests, the wallet
+ // service could have advanced the state commitment tree state between queries).
+ Witness(ctx context.Context, in *WitnessRequest, opts ...grpc.CallOption) (*WitnessResponse, error)
+ WitnessAndBuild(ctx context.Context, in *WitnessAndBuildRequest, opts ...grpc.CallOption) (*WitnessAndBuildResponse, error)
+ // Queries for assets.
+ // Returns a stream of `AssetsResponse`s.
+ Assets(ctx context.Context, in *AssetsRequest, opts ...grpc.CallOption) (ViewProtocolService_AssetsClient, error)
+ // Query for the current chain parameters.
+ ChainParameters(ctx context.Context, in *ChainParametersRequest, opts ...grpc.CallOption) (*ChainParametersResponse, error)
+ // Query for the current FMD parameters.
+ FMDParameters(ctx context.Context, in *FMDParametersRequest, opts ...grpc.CallOption) (*FMDParametersResponse, error)
+ // Query for an address given an address index
+ AddressByIndex(ctx context.Context, in *AddressByIndexRequest, opts ...grpc.CallOption) (*AddressByIndexResponse, error)
+ // Query for an address given an address index
+ IndexByAddress(ctx context.Context, in *IndexByAddressRequest, opts ...grpc.CallOption) (*IndexByAddressResponse, error)
+ // Query for an ephemeral address
+ EphemeralAddress(ctx context.Context, in *EphemeralAddressRequest, opts ...grpc.CallOption) (*EphemeralAddressResponse, error)
+ // Query for balance of a given address.
+ // Returns a stream of `BalancesResponses`.
+ Balances(ctx context.Context, in *BalancesRequest, opts ...grpc.CallOption) (ViewProtocolService_BalancesClient, error)
+ // Query for a note by its note commitment, optionally waiting until the note is detected.
+ NoteByCommitment(ctx context.Context, in *NoteByCommitmentRequest, opts ...grpc.CallOption) (*NoteByCommitmentResponse, error)
+ // Query for a swap by its swap commitment, optionally waiting until the swap is detected.
+ SwapByCommitment(ctx context.Context, in *SwapByCommitmentRequest, opts ...grpc.CallOption) (*SwapByCommitmentResponse, error)
+ // Query for whether a nullifier has been spent, optionally waiting until it is spent.
+ NullifierStatus(ctx context.Context, in *NullifierStatusRequest, opts ...grpc.CallOption) (*NullifierStatusResponse, error)
+ // Query for a given transaction by its hash.
+ TransactionInfoByHash(ctx context.Context, in *TransactionInfoByHashRequest, opts ...grpc.CallOption) (*TransactionInfoByHashResponse, error)
+ // Query for the full transactions in the given range of blocks.
+ // Returns a stream of `TransactionInfoResponse`s.
+ TransactionInfo(ctx context.Context, in *TransactionInfoRequest, opts ...grpc.CallOption) (ViewProtocolService_TransactionInfoClient, error)
+ // Query for a transaction plan
+ TransactionPlanner(ctx context.Context, in *TransactionPlannerRequest, opts ...grpc.CallOption) (*TransactionPlannerResponse, error)
+ // Broadcast a transaction to the network, optionally waiting for full confirmation.
+ BroadcastTransaction(ctx context.Context, in *BroadcastTransactionRequest, opts ...grpc.CallOption) (*BroadcastTransactionResponse, error)
+ // Query for owned position IDs for the given trading pair and in the given position state.
+ OwnedPositionIds(ctx context.Context, in *OwnedPositionIdsRequest, opts ...grpc.CallOption) (ViewProtocolService_OwnedPositionIdsClient, error)
+ // Authorize a transaction plan and build the transaction.
+ AuthorizeAndBuild(ctx context.Context, in *AuthorizeAndBuildRequest, opts ...grpc.CallOption) (*AuthorizeAndBuildResponse, error)
+}
+
+type viewProtocolServiceClient struct {
+ cc grpc1.ClientConn
+}
+
+func NewViewProtocolServiceClient(cc grpc1.ClientConn) ViewProtocolServiceClient {
+ return &viewProtocolServiceClient{cc}
+}
+
+func (c *viewProtocolServiceClient) Status(ctx context.Context, in *StatusRequest, opts ...grpc.CallOption) (*StatusResponse, error) {
+ out := new(StatusResponse)
+ err := c.cc.Invoke(ctx, "/penumbra.view.v1alpha1.ViewProtocolService/Status", in, out, opts...)
+ if err != nil {
+ return nil, err
+ }
+ return out, nil
+}
+
+func (c *viewProtocolServiceClient) StatusStream(ctx context.Context, in *StatusStreamRequest, opts ...grpc.CallOption) (ViewProtocolService_StatusStreamClient, error) {
+ stream, err := c.cc.NewStream(ctx, &_ViewProtocolService_serviceDesc.Streams[0], "/penumbra.view.v1alpha1.ViewProtocolService/StatusStream", opts...)
+ if err != nil {
+ return nil, err
+ }
+ x := &viewProtocolServiceStatusStreamClient{stream}
+ if err := x.ClientStream.SendMsg(in); err != nil {
+ return nil, err
+ }
+ if err := x.ClientStream.CloseSend(); err != nil {
+ return nil, err
+ }
+ return x, nil
+}
+
+type ViewProtocolService_StatusStreamClient interface {
+ Recv() (*StatusStreamResponse, error)
+ grpc.ClientStream
+}
+
+type viewProtocolServiceStatusStreamClient struct {
+ grpc.ClientStream
+}
+
+func (x *viewProtocolServiceStatusStreamClient) Recv() (*StatusStreamResponse, error) {
+ m := new(StatusStreamResponse)
+ if err := x.ClientStream.RecvMsg(m); err != nil {
+ return nil, err
+ }
+ return m, nil
+}
+
+func (c *viewProtocolServiceClient) Notes(ctx context.Context, in *NotesRequest, opts ...grpc.CallOption) (ViewProtocolService_NotesClient, error) {
+ stream, err := c.cc.NewStream(ctx, &_ViewProtocolService_serviceDesc.Streams[1], "/penumbra.view.v1alpha1.ViewProtocolService/Notes", opts...)
+ if err != nil {
+ return nil, err
+ }
+ x := &viewProtocolServiceNotesClient{stream}
+ if err := x.ClientStream.SendMsg(in); err != nil {
+ return nil, err
+ }
+ if err := x.ClientStream.CloseSend(); err != nil {
+ return nil, err
+ }
+ return x, nil
+}
+
+type ViewProtocolService_NotesClient interface {
+ Recv() (*NotesResponse, error)
+ grpc.ClientStream
+}
+
+type viewProtocolServiceNotesClient struct {
+ grpc.ClientStream
+}
+
+func (x *viewProtocolServiceNotesClient) Recv() (*NotesResponse, error) {
+ m := new(NotesResponse)
+ if err := x.ClientStream.RecvMsg(m); err != nil {
+ return nil, err
+ }
+ return m, nil
+}
+
+func (c *viewProtocolServiceClient) NotesForVoting(ctx context.Context, in *NotesForVotingRequest, opts ...grpc.CallOption) (ViewProtocolService_NotesForVotingClient, error) {
+ stream, err := c.cc.NewStream(ctx, &_ViewProtocolService_serviceDesc.Streams[2], "/penumbra.view.v1alpha1.ViewProtocolService/NotesForVoting", opts...)
+ if err != nil {
+ return nil, err
+ }
+ x := &viewProtocolServiceNotesForVotingClient{stream}
+ if err := x.ClientStream.SendMsg(in); err != nil {
+ return nil, err
+ }
+ if err := x.ClientStream.CloseSend(); err != nil {
+ return nil, err
+ }
+ return x, nil
+}
+
+type ViewProtocolService_NotesForVotingClient interface {
+ Recv() (*NotesForVotingResponse, error)
+ grpc.ClientStream
+}
+
+type viewProtocolServiceNotesForVotingClient struct {
+ grpc.ClientStream
+}
+
+func (x *viewProtocolServiceNotesForVotingClient) Recv() (*NotesForVotingResponse, error) {
+ m := new(NotesForVotingResponse)
+ if err := x.ClientStream.RecvMsg(m); err != nil {
+ return nil, err
+ }
+ return m, nil
+}
+
+func (c *viewProtocolServiceClient) Witness(ctx context.Context, in *WitnessRequest, opts ...grpc.CallOption) (*WitnessResponse, error) {
+ out := new(WitnessResponse)
+ err := c.cc.Invoke(ctx, "/penumbra.view.v1alpha1.ViewProtocolService/Witness", in, out, opts...)
+ if err != nil {
+ return nil, err
+ }
+ return out, nil
+}
+
+func (c *viewProtocolServiceClient) WitnessAndBuild(ctx context.Context, in *WitnessAndBuildRequest, opts ...grpc.CallOption) (*WitnessAndBuildResponse, error) {
+ out := new(WitnessAndBuildResponse)
+ err := c.cc.Invoke(ctx, "/penumbra.view.v1alpha1.ViewProtocolService/WitnessAndBuild", in, out, opts...)
+ if err != nil {
+ return nil, err
+ }
+ return out, nil
+}
+
+func (c *viewProtocolServiceClient) Assets(ctx context.Context, in *AssetsRequest, opts ...grpc.CallOption) (ViewProtocolService_AssetsClient, error) {
+ stream, err := c.cc.NewStream(ctx, &_ViewProtocolService_serviceDesc.Streams[3], "/penumbra.view.v1alpha1.ViewProtocolService/Assets", opts...)
+ if err != nil {
+ return nil, err
+ }
+ x := &viewProtocolServiceAssetsClient{stream}
+ if err := x.ClientStream.SendMsg(in); err != nil {
+ return nil, err
+ }
+ if err := x.ClientStream.CloseSend(); err != nil {
+ return nil, err
+ }
+ return x, nil
+}
+
+type ViewProtocolService_AssetsClient interface {
+ Recv() (*AssetsResponse, error)
+ grpc.ClientStream
+}
+
+type viewProtocolServiceAssetsClient struct {
+ grpc.ClientStream
+}
+
+func (x *viewProtocolServiceAssetsClient) Recv() (*AssetsResponse, error) {
+ m := new(AssetsResponse)
+ if err := x.ClientStream.RecvMsg(m); err != nil {
+ return nil, err
+ }
+ return m, nil
+}
+
+func (c *viewProtocolServiceClient) ChainParameters(ctx context.Context, in *ChainParametersRequest, opts ...grpc.CallOption) (*ChainParametersResponse, error) {
+ out := new(ChainParametersResponse)
+ err := c.cc.Invoke(ctx, "/penumbra.view.v1alpha1.ViewProtocolService/ChainParameters", in, out, opts...)
+ if err != nil {
+ return nil, err
+ }
+ return out, nil
+}
+
+func (c *viewProtocolServiceClient) FMDParameters(ctx context.Context, in *FMDParametersRequest, opts ...grpc.CallOption) (*FMDParametersResponse, error) {
+ out := new(FMDParametersResponse)
+ err := c.cc.Invoke(ctx, "/penumbra.view.v1alpha1.ViewProtocolService/FMDParameters", in, out, opts...)
+ if err != nil {
+ return nil, err
+ }
+ return out, nil
+}
+
+func (c *viewProtocolServiceClient) AddressByIndex(ctx context.Context, in *AddressByIndexRequest, opts ...grpc.CallOption) (*AddressByIndexResponse, error) {
+ out := new(AddressByIndexResponse)
+ err := c.cc.Invoke(ctx, "/penumbra.view.v1alpha1.ViewProtocolService/AddressByIndex", in, out, opts...)
+ if err != nil {
+ return nil, err
+ }
+ return out, nil
+}
+
+func (c *viewProtocolServiceClient) IndexByAddress(ctx context.Context, in *IndexByAddressRequest, opts ...grpc.CallOption) (*IndexByAddressResponse, error) {
+ out := new(IndexByAddressResponse)
+ err := c.cc.Invoke(ctx, "/penumbra.view.v1alpha1.ViewProtocolService/IndexByAddress", in, out, opts...)
+ if err != nil {
+ return nil, err
+ }
+ return out, nil
+}
+
+func (c *viewProtocolServiceClient) EphemeralAddress(ctx context.Context, in *EphemeralAddressRequest, opts ...grpc.CallOption) (*EphemeralAddressResponse, error) {
+ out := new(EphemeralAddressResponse)
+ err := c.cc.Invoke(ctx, "/penumbra.view.v1alpha1.ViewProtocolService/EphemeralAddress", in, out, opts...)
+ if err != nil {
+ return nil, err
+ }
+ return out, nil
+}
+
+func (c *viewProtocolServiceClient) Balances(ctx context.Context, in *BalancesRequest, opts ...grpc.CallOption) (ViewProtocolService_BalancesClient, error) {
+ stream, err := c.cc.NewStream(ctx, &_ViewProtocolService_serviceDesc.Streams[4], "/penumbra.view.v1alpha1.ViewProtocolService/Balances", opts...)
+ if err != nil {
+ return nil, err
+ }
+ x := &viewProtocolServiceBalancesClient{stream}
+ if err := x.ClientStream.SendMsg(in); err != nil {
+ return nil, err
+ }
+ if err := x.ClientStream.CloseSend(); err != nil {
+ return nil, err
+ }
+ return x, nil
+}
+
+type ViewProtocolService_BalancesClient interface {
+ Recv() (*BalancesResponse, error)
+ grpc.ClientStream
+}
+
+type viewProtocolServiceBalancesClient struct {
+ grpc.ClientStream
+}
+
+func (x *viewProtocolServiceBalancesClient) Recv() (*BalancesResponse, error) {
+ m := new(BalancesResponse)
+ if err := x.ClientStream.RecvMsg(m); err != nil {
+ return nil, err
+ }
+ return m, nil
+}
+
+func (c *viewProtocolServiceClient) NoteByCommitment(ctx context.Context, in *NoteByCommitmentRequest, opts ...grpc.CallOption) (*NoteByCommitmentResponse, error) {
+ out := new(NoteByCommitmentResponse)
+ err := c.cc.Invoke(ctx, "/penumbra.view.v1alpha1.ViewProtocolService/NoteByCommitment", in, out, opts...)
+ if err != nil {
+ return nil, err
+ }
+ return out, nil
+}
+
+func (c *viewProtocolServiceClient) SwapByCommitment(ctx context.Context, in *SwapByCommitmentRequest, opts ...grpc.CallOption) (*SwapByCommitmentResponse, error) {
+ out := new(SwapByCommitmentResponse)
+ err := c.cc.Invoke(ctx, "/penumbra.view.v1alpha1.ViewProtocolService/SwapByCommitment", in, out, opts...)
+ if err != nil {
+ return nil, err
+ }
+ return out, nil
+}
+
+func (c *viewProtocolServiceClient) NullifierStatus(ctx context.Context, in *NullifierStatusRequest, opts ...grpc.CallOption) (*NullifierStatusResponse, error) {
+ out := new(NullifierStatusResponse)
+ err := c.cc.Invoke(ctx, "/penumbra.view.v1alpha1.ViewProtocolService/NullifierStatus", in, out, opts...)
+ if err != nil {
+ return nil, err
+ }
+ return out, nil
+}
+
+func (c *viewProtocolServiceClient) TransactionInfoByHash(ctx context.Context, in *TransactionInfoByHashRequest, opts ...grpc.CallOption) (*TransactionInfoByHashResponse, error) {
+ out := new(TransactionInfoByHashResponse)
+ err := c.cc.Invoke(ctx, "/penumbra.view.v1alpha1.ViewProtocolService/TransactionInfoByHash", in, out, opts...)
+ if err != nil {
+ return nil, err
+ }
+ return out, nil
+}
+
+func (c *viewProtocolServiceClient) TransactionInfo(ctx context.Context, in *TransactionInfoRequest, opts ...grpc.CallOption) (ViewProtocolService_TransactionInfoClient, error) {
+ stream, err := c.cc.NewStream(ctx, &_ViewProtocolService_serviceDesc.Streams[5], "/penumbra.view.v1alpha1.ViewProtocolService/TransactionInfo", opts...)
+ if err != nil {
+ return nil, err
+ }
+ x := &viewProtocolServiceTransactionInfoClient{stream}
+ if err := x.ClientStream.SendMsg(in); err != nil {
+ return nil, err
+ }
+ if err := x.ClientStream.CloseSend(); err != nil {
+ return nil, err
+ }
+ return x, nil
+}
+
+type ViewProtocolService_TransactionInfoClient interface {
+ Recv() (*TransactionInfoResponse, error)
+ grpc.ClientStream
+}
+
+type viewProtocolServiceTransactionInfoClient struct {
+ grpc.ClientStream
+}
+
+func (x *viewProtocolServiceTransactionInfoClient) Recv() (*TransactionInfoResponse, error) {
+ m := new(TransactionInfoResponse)
+ if err := x.ClientStream.RecvMsg(m); err != nil {
+ return nil, err
+ }
+ return m, nil
+}
+
+func (c *viewProtocolServiceClient) TransactionPlanner(ctx context.Context, in *TransactionPlannerRequest, opts ...grpc.CallOption) (*TransactionPlannerResponse, error) {
+ out := new(TransactionPlannerResponse)
+ err := c.cc.Invoke(ctx, "/penumbra.view.v1alpha1.ViewProtocolService/TransactionPlanner", in, out, opts...)
+ if err != nil {
+ return nil, err
+ }
+ return out, nil
+}
+
+func (c *viewProtocolServiceClient) BroadcastTransaction(ctx context.Context, in *BroadcastTransactionRequest, opts ...grpc.CallOption) (*BroadcastTransactionResponse, error) {
+ out := new(BroadcastTransactionResponse)
+ err := c.cc.Invoke(ctx, "/penumbra.view.v1alpha1.ViewProtocolService/BroadcastTransaction", in, out, opts...)
+ if err != nil {
+ return nil, err
+ }
+ return out, nil
+}
+
+func (c *viewProtocolServiceClient) OwnedPositionIds(ctx context.Context, in *OwnedPositionIdsRequest, opts ...grpc.CallOption) (ViewProtocolService_OwnedPositionIdsClient, error) {
+ stream, err := c.cc.NewStream(ctx, &_ViewProtocolService_serviceDesc.Streams[6], "/penumbra.view.v1alpha1.ViewProtocolService/OwnedPositionIds", opts...)
+ if err != nil {
+ return nil, err
+ }
+ x := &viewProtocolServiceOwnedPositionIdsClient{stream}
+ if err := x.ClientStream.SendMsg(in); err != nil {
+ return nil, err
+ }
+ if err := x.ClientStream.CloseSend(); err != nil {
+ return nil, err
+ }
+ return x, nil
+}
+
+type ViewProtocolService_OwnedPositionIdsClient interface {
+ Recv() (*OwnedPositionIdsResponse, error)
+ grpc.ClientStream
+}
+
+type viewProtocolServiceOwnedPositionIdsClient struct {
+ grpc.ClientStream
+}
+
+func (x *viewProtocolServiceOwnedPositionIdsClient) Recv() (*OwnedPositionIdsResponse, error) {
+ m := new(OwnedPositionIdsResponse)
+ if err := x.ClientStream.RecvMsg(m); err != nil {
+ return nil, err
+ }
+ return m, nil
+}
+
+func (c *viewProtocolServiceClient) AuthorizeAndBuild(ctx context.Context, in *AuthorizeAndBuildRequest, opts ...grpc.CallOption) (*AuthorizeAndBuildResponse, error) {
+ out := new(AuthorizeAndBuildResponse)
+ err := c.cc.Invoke(ctx, "/penumbra.view.v1alpha1.ViewProtocolService/AuthorizeAndBuild", in, out, opts...)
+ if err != nil {
+ return nil, err
+ }
+ return out, nil
+}
+
+// ViewProtocolServiceServer is the server API for ViewProtocolService service.
+type ViewProtocolServiceServer interface {
+ // Get current status of chain sync
+ Status(context.Context, *StatusRequest) (*StatusResponse, error)
+ // Stream sync status updates until the view service has caught up with the core.chain.v1alpha1.
+ // Returns a stream of `StatusStreamResponse`s.
+ StatusStream(*StatusStreamRequest, ViewProtocolService_StatusStreamServer) error
+ // Queries for notes that have been accepted by the core.chain.v1alpha1.
+ // Returns a stream of `NotesResponse`s.
+ Notes(*NotesRequest, ViewProtocolService_NotesServer) error
+ // Returns a stream of `NotesForVotingResponse`s.
+ NotesForVoting(*NotesForVotingRequest, ViewProtocolService_NotesForVotingServer) error
+ // Returns authentication paths for the given note commitments.
+ //
+ // This method takes a batch of input commitments, rather than just one, so
+ // that the client can get a consistent set of authentication paths to a
+ // common root. (Otherwise, if a client made multiple requests, the wallet
+ // service could have advanced the state commitment tree state between queries).
+ Witness(context.Context, *WitnessRequest) (*WitnessResponse, error)
+ WitnessAndBuild(context.Context, *WitnessAndBuildRequest) (*WitnessAndBuildResponse, error)
+ // Queries for assets.
+ // Returns a stream of `AssetsResponse`s.
+ Assets(*AssetsRequest, ViewProtocolService_AssetsServer) error
+ // Query for the current chain parameters.
+ ChainParameters(context.Context, *ChainParametersRequest) (*ChainParametersResponse, error)
+ // Query for the current FMD parameters.
+ FMDParameters(context.Context, *FMDParametersRequest) (*FMDParametersResponse, error)
+ // Query for an address given an address index
+ AddressByIndex(context.Context, *AddressByIndexRequest) (*AddressByIndexResponse, error)
+ // Query for an address given an address index
+ IndexByAddress(context.Context, *IndexByAddressRequest) (*IndexByAddressResponse, error)
+ // Query for an ephemeral address
+ EphemeralAddress(context.Context, *EphemeralAddressRequest) (*EphemeralAddressResponse, error)
+ // Query for balance of a given address.
+ // Returns a stream of `BalancesResponses`.
+ Balances(*BalancesRequest, ViewProtocolService_BalancesServer) error
+ // Query for a note by its note commitment, optionally waiting until the note is detected.
+ NoteByCommitment(context.Context, *NoteByCommitmentRequest) (*NoteByCommitmentResponse, error)
+ // Query for a swap by its swap commitment, optionally waiting until the swap is detected.
+ SwapByCommitment(context.Context, *SwapByCommitmentRequest) (*SwapByCommitmentResponse, error)
+ // Query for whether a nullifier has been spent, optionally waiting until it is spent.
+ NullifierStatus(context.Context, *NullifierStatusRequest) (*NullifierStatusResponse, error)
+ // Query for a given transaction by its hash.
+ TransactionInfoByHash(context.Context, *TransactionInfoByHashRequest) (*TransactionInfoByHashResponse, error)
+ // Query for the full transactions in the given range of blocks.
+ // Returns a stream of `TransactionInfoResponse`s.
+ TransactionInfo(*TransactionInfoRequest, ViewProtocolService_TransactionInfoServer) error
+ // Query for a transaction plan
+ TransactionPlanner(context.Context, *TransactionPlannerRequest) (*TransactionPlannerResponse, error)
+ // Broadcast a transaction to the network, optionally waiting for full confirmation.
+ BroadcastTransaction(context.Context, *BroadcastTransactionRequest) (*BroadcastTransactionResponse, error)
+ // Query for owned position IDs for the given trading pair and in the given position state.
+ OwnedPositionIds(*OwnedPositionIdsRequest, ViewProtocolService_OwnedPositionIdsServer) error
+ // Authorize a transaction plan and build the transaction.
+ AuthorizeAndBuild(context.Context, *AuthorizeAndBuildRequest) (*AuthorizeAndBuildResponse, error)
+}
+
+// UnimplementedViewProtocolServiceServer can be embedded to have forward compatible implementations.
+type UnimplementedViewProtocolServiceServer struct {
+}
+
+func (*UnimplementedViewProtocolServiceServer) Status(ctx context.Context, req *StatusRequest) (*StatusResponse, error) {
+ return nil, status.Errorf(codes.Unimplemented, "method Status not implemented")
+}
+func (*UnimplementedViewProtocolServiceServer) StatusStream(req *StatusStreamRequest, srv ViewProtocolService_StatusStreamServer) error {
+ return status.Errorf(codes.Unimplemented, "method StatusStream not implemented")
+}
+func (*UnimplementedViewProtocolServiceServer) Notes(req *NotesRequest, srv ViewProtocolService_NotesServer) error {
+ return status.Errorf(codes.Unimplemented, "method Notes not implemented")
+}
+func (*UnimplementedViewProtocolServiceServer) NotesForVoting(req *NotesForVotingRequest, srv ViewProtocolService_NotesForVotingServer) error {
+ return status.Errorf(codes.Unimplemented, "method NotesForVoting not implemented")
+}
+func (*UnimplementedViewProtocolServiceServer) Witness(ctx context.Context, req *WitnessRequest) (*WitnessResponse, error) {
+ return nil, status.Errorf(codes.Unimplemented, "method Witness not implemented")
+}
+func (*UnimplementedViewProtocolServiceServer) WitnessAndBuild(ctx context.Context, req *WitnessAndBuildRequest) (*WitnessAndBuildResponse, error) {
+ return nil, status.Errorf(codes.Unimplemented, "method WitnessAndBuild not implemented")
+}
+func (*UnimplementedViewProtocolServiceServer) Assets(req *AssetsRequest, srv ViewProtocolService_AssetsServer) error {
+ return status.Errorf(codes.Unimplemented, "method Assets not implemented")
+}
+func (*UnimplementedViewProtocolServiceServer) ChainParameters(ctx context.Context, req *ChainParametersRequest) (*ChainParametersResponse, error) {
+ return nil, status.Errorf(codes.Unimplemented, "method ChainParameters not implemented")
+}
+func (*UnimplementedViewProtocolServiceServer) FMDParameters(ctx context.Context, req *FMDParametersRequest) (*FMDParametersResponse, error) {
+ return nil, status.Errorf(codes.Unimplemented, "method FMDParameters not implemented")
+}
+func (*UnimplementedViewProtocolServiceServer) AddressByIndex(ctx context.Context, req *AddressByIndexRequest) (*AddressByIndexResponse, error) {
+ return nil, status.Errorf(codes.Unimplemented, "method AddressByIndex not implemented")
+}
+func (*UnimplementedViewProtocolServiceServer) IndexByAddress(ctx context.Context, req *IndexByAddressRequest) (*IndexByAddressResponse, error) {
+ return nil, status.Errorf(codes.Unimplemented, "method IndexByAddress not implemented")
+}
+func (*UnimplementedViewProtocolServiceServer) EphemeralAddress(ctx context.Context, req *EphemeralAddressRequest) (*EphemeralAddressResponse, error) {
+ return nil, status.Errorf(codes.Unimplemented, "method EphemeralAddress not implemented")
+}
+func (*UnimplementedViewProtocolServiceServer) Balances(req *BalancesRequest, srv ViewProtocolService_BalancesServer) error {
+ return status.Errorf(codes.Unimplemented, "method Balances not implemented")
+}
+func (*UnimplementedViewProtocolServiceServer) NoteByCommitment(ctx context.Context, req *NoteByCommitmentRequest) (*NoteByCommitmentResponse, error) {
+ return nil, status.Errorf(codes.Unimplemented, "method NoteByCommitment not implemented")
+}
+func (*UnimplementedViewProtocolServiceServer) SwapByCommitment(ctx context.Context, req *SwapByCommitmentRequest) (*SwapByCommitmentResponse, error) {
+ return nil, status.Errorf(codes.Unimplemented, "method SwapByCommitment not implemented")
+}
+func (*UnimplementedViewProtocolServiceServer) NullifierStatus(ctx context.Context, req *NullifierStatusRequest) (*NullifierStatusResponse, error) {
+ return nil, status.Errorf(codes.Unimplemented, "method NullifierStatus not implemented")
+}
+func (*UnimplementedViewProtocolServiceServer) TransactionInfoByHash(ctx context.Context, req *TransactionInfoByHashRequest) (*TransactionInfoByHashResponse, error) {
+ return nil, status.Errorf(codes.Unimplemented, "method TransactionInfoByHash not implemented")
+}
+func (*UnimplementedViewProtocolServiceServer) TransactionInfo(req *TransactionInfoRequest, srv ViewProtocolService_TransactionInfoServer) error {
+ return status.Errorf(codes.Unimplemented, "method TransactionInfo not implemented")
+}
+func (*UnimplementedViewProtocolServiceServer) TransactionPlanner(ctx context.Context, req *TransactionPlannerRequest) (*TransactionPlannerResponse, error) {
+ return nil, status.Errorf(codes.Unimplemented, "method TransactionPlanner not implemented")
+}
+func (*UnimplementedViewProtocolServiceServer) BroadcastTransaction(ctx context.Context, req *BroadcastTransactionRequest) (*BroadcastTransactionResponse, error) {
+ return nil, status.Errorf(codes.Unimplemented, "method BroadcastTransaction not implemented")
+}
+func (*UnimplementedViewProtocolServiceServer) OwnedPositionIds(req *OwnedPositionIdsRequest, srv ViewProtocolService_OwnedPositionIdsServer) error {
+ return status.Errorf(codes.Unimplemented, "method OwnedPositionIds not implemented")
+}
+func (*UnimplementedViewProtocolServiceServer) AuthorizeAndBuild(ctx context.Context, req *AuthorizeAndBuildRequest) (*AuthorizeAndBuildResponse, error) {
+ return nil, status.Errorf(codes.Unimplemented, "method AuthorizeAndBuild not implemented")
+}
+
+func RegisterViewProtocolServiceServer(s grpc1.Server, srv ViewProtocolServiceServer) {
+ s.RegisterService(&_ViewProtocolService_serviceDesc, srv)
+}
+
+func _ViewProtocolService_Status_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) {
+ in := new(StatusRequest)
+ if err := dec(in); err != nil {
+ return nil, err
+ }
+ if interceptor == nil {
+ return srv.(ViewProtocolServiceServer).Status(ctx, in)
+ }
+ info := &grpc.UnaryServerInfo{
+ Server: srv,
+ FullMethod: "/penumbra.view.v1alpha1.ViewProtocolService/Status",
+ }
+ handler := func(ctx context.Context, req interface{}) (interface{}, error) {
+ return srv.(ViewProtocolServiceServer).Status(ctx, req.(*StatusRequest))
+ }
+ return interceptor(ctx, in, info, handler)
+}
+
+func _ViewProtocolService_StatusStream_Handler(srv interface{}, stream grpc.ServerStream) error {
+ m := new(StatusStreamRequest)
+ if err := stream.RecvMsg(m); err != nil {
+ return err
+ }
+ return srv.(ViewProtocolServiceServer).StatusStream(m, &viewProtocolServiceStatusStreamServer{stream})
+}
+
+type ViewProtocolService_StatusStreamServer interface {
+ Send(*StatusStreamResponse) error
+ grpc.ServerStream
+}
+
+type viewProtocolServiceStatusStreamServer struct {
+ grpc.ServerStream
+}
+
+func (x *viewProtocolServiceStatusStreamServer) Send(m *StatusStreamResponse) error {
+ return x.ServerStream.SendMsg(m)
+}
+
+func _ViewProtocolService_Notes_Handler(srv interface{}, stream grpc.ServerStream) error {
+ m := new(NotesRequest)
+ if err := stream.RecvMsg(m); err != nil {
+ return err
+ }
+ return srv.(ViewProtocolServiceServer).Notes(m, &viewProtocolServiceNotesServer{stream})
+}
+
+type ViewProtocolService_NotesServer interface {
+ Send(*NotesResponse) error
+ grpc.ServerStream
+}
+
+type viewProtocolServiceNotesServer struct {
+ grpc.ServerStream
+}
+
+func (x *viewProtocolServiceNotesServer) Send(m *NotesResponse) error {
+ return x.ServerStream.SendMsg(m)
+}
+
+func _ViewProtocolService_NotesForVoting_Handler(srv interface{}, stream grpc.ServerStream) error {
+ m := new(NotesForVotingRequest)
+ if err := stream.RecvMsg(m); err != nil {
+ return err
+ }
+ return srv.(ViewProtocolServiceServer).NotesForVoting(m, &viewProtocolServiceNotesForVotingServer{stream})
+}
+
+type ViewProtocolService_NotesForVotingServer interface {
+ Send(*NotesForVotingResponse) error
+ grpc.ServerStream
+}
+
+type viewProtocolServiceNotesForVotingServer struct {
+ grpc.ServerStream
+}
+
+func (x *viewProtocolServiceNotesForVotingServer) Send(m *NotesForVotingResponse) error {
+ return x.ServerStream.SendMsg(m)
+}
+
+func _ViewProtocolService_Witness_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) {
+ in := new(WitnessRequest)
+ if err := dec(in); err != nil {
+ return nil, err
+ }
+ if interceptor == nil {
+ return srv.(ViewProtocolServiceServer).Witness(ctx, in)
+ }
+ info := &grpc.UnaryServerInfo{
+ Server: srv,
+ FullMethod: "/penumbra.view.v1alpha1.ViewProtocolService/Witness",
+ }
+ handler := func(ctx context.Context, req interface{}) (interface{}, error) {
+ return srv.(ViewProtocolServiceServer).Witness(ctx, req.(*WitnessRequest))
+ }
+ return interceptor(ctx, in, info, handler)
+}
+
+func _ViewProtocolService_WitnessAndBuild_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) {
+ in := new(WitnessAndBuildRequest)
+ if err := dec(in); err != nil {
+ return nil, err
+ }
+ if interceptor == nil {
+ return srv.(ViewProtocolServiceServer).WitnessAndBuild(ctx, in)
+ }
+ info := &grpc.UnaryServerInfo{
+ Server: srv,
+ FullMethod: "/penumbra.view.v1alpha1.ViewProtocolService/WitnessAndBuild",
+ }
+ handler := func(ctx context.Context, req interface{}) (interface{}, error) {
+ return srv.(ViewProtocolServiceServer).WitnessAndBuild(ctx, req.(*WitnessAndBuildRequest))
+ }
+ return interceptor(ctx, in, info, handler)
+}
+
+func _ViewProtocolService_Assets_Handler(srv interface{}, stream grpc.ServerStream) error {
+ m := new(AssetsRequest)
+ if err := stream.RecvMsg(m); err != nil {
+ return err
+ }
+ return srv.(ViewProtocolServiceServer).Assets(m, &viewProtocolServiceAssetsServer{stream})
+}
+
+type ViewProtocolService_AssetsServer interface {
+ Send(*AssetsResponse) error
+ grpc.ServerStream
+}
+
+type viewProtocolServiceAssetsServer struct {
+ grpc.ServerStream
+}
+
+func (x *viewProtocolServiceAssetsServer) Send(m *AssetsResponse) error {
+ return x.ServerStream.SendMsg(m)
+}
+
+func _ViewProtocolService_ChainParameters_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) {
+ in := new(ChainParametersRequest)
+ if err := dec(in); err != nil {
+ return nil, err
+ }
+ if interceptor == nil {
+ return srv.(ViewProtocolServiceServer).ChainParameters(ctx, in)
+ }
+ info := &grpc.UnaryServerInfo{
+ Server: srv,
+ FullMethod: "/penumbra.view.v1alpha1.ViewProtocolService/ChainParameters",
+ }
+ handler := func(ctx context.Context, req interface{}) (interface{}, error) {
+ return srv.(ViewProtocolServiceServer).ChainParameters(ctx, req.(*ChainParametersRequest))
+ }
+ return interceptor(ctx, in, info, handler)
+}
+
+func _ViewProtocolService_FMDParameters_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) {
+ in := new(FMDParametersRequest)
+ if err := dec(in); err != nil {
+ return nil, err
+ }
+ if interceptor == nil {
+ return srv.(ViewProtocolServiceServer).FMDParameters(ctx, in)
+ }
+ info := &grpc.UnaryServerInfo{
+ Server: srv,
+ FullMethod: "/penumbra.view.v1alpha1.ViewProtocolService/FMDParameters",
+ }
+ handler := func(ctx context.Context, req interface{}) (interface{}, error) {
+ return srv.(ViewProtocolServiceServer).FMDParameters(ctx, req.(*FMDParametersRequest))
+ }
+ return interceptor(ctx, in, info, handler)
+}
+
+func _ViewProtocolService_AddressByIndex_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) {
+ in := new(AddressByIndexRequest)
+ if err := dec(in); err != nil {
+ return nil, err
+ }
+ if interceptor == nil {
+ return srv.(ViewProtocolServiceServer).AddressByIndex(ctx, in)
+ }
+ info := &grpc.UnaryServerInfo{
+ Server: srv,
+ FullMethod: "/penumbra.view.v1alpha1.ViewProtocolService/AddressByIndex",
+ }
+ handler := func(ctx context.Context, req interface{}) (interface{}, error) {
+ return srv.(ViewProtocolServiceServer).AddressByIndex(ctx, req.(*AddressByIndexRequest))
+ }
+ return interceptor(ctx, in, info, handler)
+}
+
+func _ViewProtocolService_IndexByAddress_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) {
+ in := new(IndexByAddressRequest)
+ if err := dec(in); err != nil {
+ return nil, err
+ }
+ if interceptor == nil {
+ return srv.(ViewProtocolServiceServer).IndexByAddress(ctx, in)
+ }
+ info := &grpc.UnaryServerInfo{
+ Server: srv,
+ FullMethod: "/penumbra.view.v1alpha1.ViewProtocolService/IndexByAddress",
+ }
+ handler := func(ctx context.Context, req interface{}) (interface{}, error) {
+ return srv.(ViewProtocolServiceServer).IndexByAddress(ctx, req.(*IndexByAddressRequest))
+ }
+ return interceptor(ctx, in, info, handler)
+}
+
+func _ViewProtocolService_EphemeralAddress_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) {
+ in := new(EphemeralAddressRequest)
+ if err := dec(in); err != nil {
+ return nil, err
+ }
+ if interceptor == nil {
+ return srv.(ViewProtocolServiceServer).EphemeralAddress(ctx, in)
+ }
+ info := &grpc.UnaryServerInfo{
+ Server: srv,
+ FullMethod: "/penumbra.view.v1alpha1.ViewProtocolService/EphemeralAddress",
+ }
+ handler := func(ctx context.Context, req interface{}) (interface{}, error) {
+ return srv.(ViewProtocolServiceServer).EphemeralAddress(ctx, req.(*EphemeralAddressRequest))
+ }
+ return interceptor(ctx, in, info, handler)
+}
+
+func _ViewProtocolService_Balances_Handler(srv interface{}, stream grpc.ServerStream) error {
+ m := new(BalancesRequest)
+ if err := stream.RecvMsg(m); err != nil {
+ return err
+ }
+ return srv.(ViewProtocolServiceServer).Balances(m, &viewProtocolServiceBalancesServer{stream})
+}
+
+type ViewProtocolService_BalancesServer interface {
+ Send(*BalancesResponse) error
+ grpc.ServerStream
+}
+
+type viewProtocolServiceBalancesServer struct {
+ grpc.ServerStream
+}
+
+func (x *viewProtocolServiceBalancesServer) Send(m *BalancesResponse) error {
+ return x.ServerStream.SendMsg(m)
+}
+
+func _ViewProtocolService_NoteByCommitment_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) {
+ in := new(NoteByCommitmentRequest)
+ if err := dec(in); err != nil {
+ return nil, err
+ }
+ if interceptor == nil {
+ return srv.(ViewProtocolServiceServer).NoteByCommitment(ctx, in)
+ }
+ info := &grpc.UnaryServerInfo{
+ Server: srv,
+ FullMethod: "/penumbra.view.v1alpha1.ViewProtocolService/NoteByCommitment",
+ }
+ handler := func(ctx context.Context, req interface{}) (interface{}, error) {
+ return srv.(ViewProtocolServiceServer).NoteByCommitment(ctx, req.(*NoteByCommitmentRequest))
+ }
+ return interceptor(ctx, in, info, handler)
+}
+
+func _ViewProtocolService_SwapByCommitment_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) {
+ in := new(SwapByCommitmentRequest)
+ if err := dec(in); err != nil {
+ return nil, err
+ }
+ if interceptor == nil {
+ return srv.(ViewProtocolServiceServer).SwapByCommitment(ctx, in)
+ }
+ info := &grpc.UnaryServerInfo{
+ Server: srv,
+ FullMethod: "/penumbra.view.v1alpha1.ViewProtocolService/SwapByCommitment",
+ }
+ handler := func(ctx context.Context, req interface{}) (interface{}, error) {
+ return srv.(ViewProtocolServiceServer).SwapByCommitment(ctx, req.(*SwapByCommitmentRequest))
+ }
+ return interceptor(ctx, in, info, handler)
+}
+
+func _ViewProtocolService_NullifierStatus_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) {
+ in := new(NullifierStatusRequest)
+ if err := dec(in); err != nil {
+ return nil, err
+ }
+ if interceptor == nil {
+ return srv.(ViewProtocolServiceServer).NullifierStatus(ctx, in)
+ }
+ info := &grpc.UnaryServerInfo{
+ Server: srv,
+ FullMethod: "/penumbra.view.v1alpha1.ViewProtocolService/NullifierStatus",
+ }
+ handler := func(ctx context.Context, req interface{}) (interface{}, error) {
+ return srv.(ViewProtocolServiceServer).NullifierStatus(ctx, req.(*NullifierStatusRequest))
+ }
+ return interceptor(ctx, in, info, handler)
+}
+
+func _ViewProtocolService_TransactionInfoByHash_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) {
+ in := new(TransactionInfoByHashRequest)
+ if err := dec(in); err != nil {
+ return nil, err
+ }
+ if interceptor == nil {
+ return srv.(ViewProtocolServiceServer).TransactionInfoByHash(ctx, in)
+ }
+ info := &grpc.UnaryServerInfo{
+ Server: srv,
+ FullMethod: "/penumbra.view.v1alpha1.ViewProtocolService/TransactionInfoByHash",
+ }
+ handler := func(ctx context.Context, req interface{}) (interface{}, error) {
+ return srv.(ViewProtocolServiceServer).TransactionInfoByHash(ctx, req.(*TransactionInfoByHashRequest))
+ }
+ return interceptor(ctx, in, info, handler)
+}
+
+func _ViewProtocolService_TransactionInfo_Handler(srv interface{}, stream grpc.ServerStream) error {
+ m := new(TransactionInfoRequest)
+ if err := stream.RecvMsg(m); err != nil {
+ return err
+ }
+ return srv.(ViewProtocolServiceServer).TransactionInfo(m, &viewProtocolServiceTransactionInfoServer{stream})
+}
+
+type ViewProtocolService_TransactionInfoServer interface {
+ Send(*TransactionInfoResponse) error
+ grpc.ServerStream
+}
+
+type viewProtocolServiceTransactionInfoServer struct {
+ grpc.ServerStream
+}
+
+func (x *viewProtocolServiceTransactionInfoServer) Send(m *TransactionInfoResponse) error {
+ return x.ServerStream.SendMsg(m)
+}
+
+func _ViewProtocolService_TransactionPlanner_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) {
+ in := new(TransactionPlannerRequest)
+ if err := dec(in); err != nil {
+ return nil, err
+ }
+ if interceptor == nil {
+ return srv.(ViewProtocolServiceServer).TransactionPlanner(ctx, in)
+ }
+ info := &grpc.UnaryServerInfo{
+ Server: srv,
+ FullMethod: "/penumbra.view.v1alpha1.ViewProtocolService/TransactionPlanner",
+ }
+ handler := func(ctx context.Context, req interface{}) (interface{}, error) {
+ return srv.(ViewProtocolServiceServer).TransactionPlanner(ctx, req.(*TransactionPlannerRequest))
+ }
+ return interceptor(ctx, in, info, handler)
+}
+
+func _ViewProtocolService_BroadcastTransaction_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) {
+ in := new(BroadcastTransactionRequest)
+ if err := dec(in); err != nil {
+ return nil, err
+ }
+ if interceptor == nil {
+ return srv.(ViewProtocolServiceServer).BroadcastTransaction(ctx, in)
+ }
+ info := &grpc.UnaryServerInfo{
+ Server: srv,
+ FullMethod: "/penumbra.view.v1alpha1.ViewProtocolService/BroadcastTransaction",
+ }
+ handler := func(ctx context.Context, req interface{}) (interface{}, error) {
+ return srv.(ViewProtocolServiceServer).BroadcastTransaction(ctx, req.(*BroadcastTransactionRequest))
+ }
+ return interceptor(ctx, in, info, handler)
+}
+
+func _ViewProtocolService_OwnedPositionIds_Handler(srv interface{}, stream grpc.ServerStream) error {
+ m := new(OwnedPositionIdsRequest)
+ if err := stream.RecvMsg(m); err != nil {
+ return err
+ }
+ return srv.(ViewProtocolServiceServer).OwnedPositionIds(m, &viewProtocolServiceOwnedPositionIdsServer{stream})
+}
+
+type ViewProtocolService_OwnedPositionIdsServer interface {
+ Send(*OwnedPositionIdsResponse) error
+ grpc.ServerStream
+}
+
+type viewProtocolServiceOwnedPositionIdsServer struct {
+ grpc.ServerStream
+}
+
+func (x *viewProtocolServiceOwnedPositionIdsServer) Send(m *OwnedPositionIdsResponse) error {
+ return x.ServerStream.SendMsg(m)
+}
+
+func _ViewProtocolService_AuthorizeAndBuild_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) {
+ in := new(AuthorizeAndBuildRequest)
+ if err := dec(in); err != nil {
+ return nil, err
+ }
+ if interceptor == nil {
+ return srv.(ViewProtocolServiceServer).AuthorizeAndBuild(ctx, in)
+ }
+ info := &grpc.UnaryServerInfo{
+ Server: srv,
+ FullMethod: "/penumbra.view.v1alpha1.ViewProtocolService/AuthorizeAndBuild",
+ }
+ handler := func(ctx context.Context, req interface{}) (interface{}, error) {
+ return srv.(ViewProtocolServiceServer).AuthorizeAndBuild(ctx, req.(*AuthorizeAndBuildRequest))
+ }
+ return interceptor(ctx, in, info, handler)
+}
+
+var _ViewProtocolService_serviceDesc = grpc.ServiceDesc{
+ ServiceName: "penumbra.view.v1alpha1.ViewProtocolService",
+ HandlerType: (*ViewProtocolServiceServer)(nil),
+ Methods: []grpc.MethodDesc{
+ {
+ MethodName: "Status",
+ Handler: _ViewProtocolService_Status_Handler,
+ },
+ {
+ MethodName: "Witness",
+ Handler: _ViewProtocolService_Witness_Handler,
+ },
+ {
+ MethodName: "WitnessAndBuild",
+ Handler: _ViewProtocolService_WitnessAndBuild_Handler,
+ },
+ {
+ MethodName: "ChainParameters",
+ Handler: _ViewProtocolService_ChainParameters_Handler,
+ },
+ {
+ MethodName: "FMDParameters",
+ Handler: _ViewProtocolService_FMDParameters_Handler,
+ },
+ {
+ MethodName: "AddressByIndex",
+ Handler: _ViewProtocolService_AddressByIndex_Handler,
+ },
+ {
+ MethodName: "IndexByAddress",
+ Handler: _ViewProtocolService_IndexByAddress_Handler,
+ },
+ {
+ MethodName: "EphemeralAddress",
+ Handler: _ViewProtocolService_EphemeralAddress_Handler,
+ },
+ {
+ MethodName: "NoteByCommitment",
+ Handler: _ViewProtocolService_NoteByCommitment_Handler,
+ },
+ {
+ MethodName: "SwapByCommitment",
+ Handler: _ViewProtocolService_SwapByCommitment_Handler,
+ },
+ {
+ MethodName: "NullifierStatus",
+ Handler: _ViewProtocolService_NullifierStatus_Handler,
+ },
+ {
+ MethodName: "TransactionInfoByHash",
+ Handler: _ViewProtocolService_TransactionInfoByHash_Handler,
+ },
+ {
+ MethodName: "TransactionPlanner",
+ Handler: _ViewProtocolService_TransactionPlanner_Handler,
+ },
+ {
+ MethodName: "BroadcastTransaction",
+ Handler: _ViewProtocolService_BroadcastTransaction_Handler,
+ },
+ {
+ MethodName: "AuthorizeAndBuild",
+ Handler: _ViewProtocolService_AuthorizeAndBuild_Handler,
+ },
+ },
+ Streams: []grpc.StreamDesc{
+ {
+ StreamName: "StatusStream",
+ Handler: _ViewProtocolService_StatusStream_Handler,
+ ServerStreams: true,
+ },
+ {
+ StreamName: "Notes",
+ Handler: _ViewProtocolService_Notes_Handler,
+ ServerStreams: true,
+ },
+ {
+ StreamName: "NotesForVoting",
+ Handler: _ViewProtocolService_NotesForVoting_Handler,
+ ServerStreams: true,
+ },
+ {
+ StreamName: "Assets",
+ Handler: _ViewProtocolService_Assets_Handler,
+ ServerStreams: true,
+ },
+ {
+ StreamName: "Balances",
+ Handler: _ViewProtocolService_Balances_Handler,
+ ServerStreams: true,
+ },
+ {
+ StreamName: "TransactionInfo",
+ Handler: _ViewProtocolService_TransactionInfo_Handler,
+ ServerStreams: true,
+ },
+ {
+ StreamName: "OwnedPositionIds",
+ Handler: _ViewProtocolService_OwnedPositionIds_Handler,
+ ServerStreams: true,
+ },
+ },
+ Metadata: "penumbra/view/v1alpha1/view.proto",
+}
+
+// ViewAuthServiceClient is the client API for ViewAuthService service.
+//
+// For semantics around ctx use and closing/ending streaming RPCs, please refer to https://godoc.org/google.golang.org/grpc#ClientConn.NewStream.
+type ViewAuthServiceClient interface {
+ ViewAuth(ctx context.Context, in *ViewAuthRequest, opts ...grpc.CallOption) (*ViewAuthResponse, error)
+}
+
+type viewAuthServiceClient struct {
+ cc grpc1.ClientConn
+}
+
+func NewViewAuthServiceClient(cc grpc1.ClientConn) ViewAuthServiceClient {
+ return &viewAuthServiceClient{cc}
+}
+
+func (c *viewAuthServiceClient) ViewAuth(ctx context.Context, in *ViewAuthRequest, opts ...grpc.CallOption) (*ViewAuthResponse, error) {
+ out := new(ViewAuthResponse)
+ err := c.cc.Invoke(ctx, "/penumbra.view.v1alpha1.ViewAuthService/ViewAuth", in, out, opts...)
+ if err != nil {
+ return nil, err
+ }
+ return out, nil
+}
+
+// ViewAuthServiceServer is the server API for ViewAuthService service.
+type ViewAuthServiceServer interface {
+ ViewAuth(context.Context, *ViewAuthRequest) (*ViewAuthResponse, error)
+}
+
+// UnimplementedViewAuthServiceServer can be embedded to have forward compatible implementations.
+type UnimplementedViewAuthServiceServer struct {
+}
+
+func (*UnimplementedViewAuthServiceServer) ViewAuth(ctx context.Context, req *ViewAuthRequest) (*ViewAuthResponse, error) {
+ return nil, status.Errorf(codes.Unimplemented, "method ViewAuth not implemented")
+}
+
+func RegisterViewAuthServiceServer(s grpc1.Server, srv ViewAuthServiceServer) {
+ s.RegisterService(&_ViewAuthService_serviceDesc, srv)
+}
+
+func _ViewAuthService_ViewAuth_Handler(srv interface{}, ctx context.Context, dec func(interface{}) error, interceptor grpc.UnaryServerInterceptor) (interface{}, error) {
+ in := new(ViewAuthRequest)
+ if err := dec(in); err != nil {
+ return nil, err
+ }
+ if interceptor == nil {
+ return srv.(ViewAuthServiceServer).ViewAuth(ctx, in)
+ }
+ info := &grpc.UnaryServerInfo{
+ Server: srv,
+ FullMethod: "/penumbra.view.v1alpha1.ViewAuthService/ViewAuth",
+ }
+ handler := func(ctx context.Context, req interface{}) (interface{}, error) {
+ return srv.(ViewAuthServiceServer).ViewAuth(ctx, req.(*ViewAuthRequest))
+ }
+ return interceptor(ctx, in, info, handler)
+}
+
+var _ViewAuthService_serviceDesc = grpc.ServiceDesc{
+ ServiceName: "penumbra.view.v1alpha1.ViewAuthService",
+ HandlerType: (*ViewAuthServiceServer)(nil),
+ Methods: []grpc.MethodDesc{
+ {
+ MethodName: "ViewAuth",
+ Handler: _ViewAuthService_ViewAuth_Handler,
+ },
+ },
+ Streams: []grpc.StreamDesc{},
+ Metadata: "penumbra/view/v1alpha1/view.proto",
+}
+
+func (m *AuthorizeAndBuildRequest) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *AuthorizeAndBuildRequest) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *AuthorizeAndBuildRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.AuthorizationData != nil {
+ {
+ size, err := m.AuthorizationData.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.TransactionPlan != nil {
+ {
+ size, err := m.TransactionPlan.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *AuthorizeAndBuildResponse) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *AuthorizeAndBuildResponse) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *AuthorizeAndBuildResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Transaction != nil {
+ {
+ size, err := m.Transaction.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *BroadcastTransactionRequest) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *BroadcastTransactionRequest) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *BroadcastTransactionRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.AwaitDetection {
+ i--
+ if m.AwaitDetection {
+ dAtA[i] = 1
+ } else {
+ dAtA[i] = 0
+ }
+ i--
+ dAtA[i] = 0x10
+ }
+ if m.Transaction != nil {
+ {
+ size, err := m.Transaction.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *BroadcastTransactionResponse) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *BroadcastTransactionResponse) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *BroadcastTransactionResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.DetectionHeight != 0 {
+ i = encodeVarintView(dAtA, i, uint64(m.DetectionHeight))
+ i--
+ dAtA[i] = 0x10
+ }
+ if m.Id != nil {
+ {
+ size, err := m.Id.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *TransactionPlannerRequest) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *TransactionPlannerRequest) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *TransactionPlannerRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.IbcActions) > 0 {
+ for iNdEx := len(m.IbcActions) - 1; iNdEx >= 0; iNdEx-- {
+ {
+ size, err := m.IbcActions[iNdEx].MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x3
+ i--
+ dAtA[i] = 0xe2
+ }
+ }
+ if len(m.Undelegations) > 0 {
+ for iNdEx := len(m.Undelegations) - 1; iNdEx >= 0; iNdEx-- {
+ {
+ size, err := m.Undelegations[iNdEx].MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x3
+ i--
+ dAtA[i] = 0x92
+ }
+ }
+ if len(m.Delegations) > 0 {
+ for iNdEx := len(m.Delegations) - 1; iNdEx >= 0; iNdEx-- {
+ {
+ size, err := m.Delegations[iNdEx].MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x2
+ i--
+ dAtA[i] = 0xc2
+ }
+ }
+ if len(m.SwapClaims) > 0 {
+ for iNdEx := len(m.SwapClaims) - 1; iNdEx >= 0; iNdEx-- {
+ {
+ size, err := m.SwapClaims[iNdEx].MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1
+ i--
+ dAtA[i] = 0xfa
+ }
+ }
+ if len(m.Swaps) > 0 {
+ for iNdEx := len(m.Swaps) - 1; iNdEx >= 0; iNdEx-- {
+ {
+ size, err := m.Swaps[iNdEx].MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1
+ i--
+ dAtA[i] = 0xf2
+ }
+ }
+ if len(m.Outputs) > 0 {
+ for iNdEx := len(m.Outputs) - 1; iNdEx >= 0; iNdEx-- {
+ {
+ size, err := m.Outputs[iNdEx].MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1
+ i--
+ dAtA[i] = 0xa2
+ }
+ }
+ if m.XAccountGroupId != nil {
+ {
+ size := m.XAccountGroupId.Size()
+ i -= size
+ if _, err := m.XAccountGroupId.MarshalTo(dAtA[i:]); err != nil {
+ return 0, err
+ }
+ }
+ }
+ if m.Memo != nil {
+ {
+ size, err := m.Memo.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1a
+ }
+ if m.Fee != nil {
+ {
+ size, err := m.Fee.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.ExpiryHeight != 0 {
+ i = encodeVarintView(dAtA, i, uint64(m.ExpiryHeight))
+ i--
+ dAtA[i] = 0x8
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *TransactionPlannerRequest_AccountGroupId) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *TransactionPlannerRequest_AccountGroupId) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.AccountGroupId != nil {
+ {
+ size, err := m.AccountGroupId.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x72
+ }
+ return len(dAtA) - i, nil
+}
+func (m *TransactionPlannerRequest_Output) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *TransactionPlannerRequest_Output) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *TransactionPlannerRequest_Output) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Address != nil {
+ {
+ size, err := m.Address.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.Value != nil {
+ {
+ size, err := m.Value.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *TransactionPlannerRequest_Swap) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *TransactionPlannerRequest_Swap) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *TransactionPlannerRequest_Swap) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Fee != nil {
+ {
+ size, err := m.Fee.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1a
+ }
+ if m.TargetAsset != nil {
+ {
+ size, err := m.TargetAsset.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.Value != nil {
+ {
+ size, err := m.Value.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *TransactionPlannerRequest_SwapClaim) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *TransactionPlannerRequest_SwapClaim) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *TransactionPlannerRequest_SwapClaim) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.SwapCommitment != nil {
+ {
+ size, err := m.SwapCommitment.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *TransactionPlannerRequest_Delegate) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *TransactionPlannerRequest_Delegate) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *TransactionPlannerRequest_Delegate) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.RateData != nil {
+ {
+ size, err := m.RateData.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1a
+ }
+ if m.Amount != nil {
+ {
+ size, err := m.Amount.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *TransactionPlannerRequest_Undelegate) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *TransactionPlannerRequest_Undelegate) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *TransactionPlannerRequest_Undelegate) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.RateData != nil {
+ {
+ size, err := m.RateData.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.Value != nil {
+ {
+ size, err := m.Value.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *TransactionPlannerResponse) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *TransactionPlannerResponse) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *TransactionPlannerResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Plan != nil {
+ {
+ size, err := m.Plan.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *AddressByIndexRequest) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *AddressByIndexRequest) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *AddressByIndexRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.DisplayConfirm {
+ i--
+ if m.DisplayConfirm {
+ dAtA[i] = 1
+ } else {
+ dAtA[i] = 0
+ }
+ i--
+ dAtA[i] = 0x10
+ }
+ if m.AddressIndex != nil {
+ {
+ size, err := m.AddressIndex.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *AddressByIndexResponse) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *AddressByIndexResponse) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *AddressByIndexResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Address != nil {
+ {
+ size, err := m.Address.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *IndexByAddressRequest) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *IndexByAddressRequest) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *IndexByAddressRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Address != nil {
+ {
+ size, err := m.Address.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *IndexByAddressResponse) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *IndexByAddressResponse) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *IndexByAddressResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.XAddressIndex != nil {
+ {
+ size := m.XAddressIndex.Size()
+ i -= size
+ if _, err := m.XAddressIndex.MarshalTo(dAtA[i:]); err != nil {
+ return 0, err
+ }
+ }
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *IndexByAddressResponse_AddressIndex) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *IndexByAddressResponse_AddressIndex) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.AddressIndex != nil {
+ {
+ size, err := m.AddressIndex.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+func (m *EphemeralAddressRequest) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *EphemeralAddressRequest) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *EphemeralAddressRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.DisplayConfirm {
+ i--
+ if m.DisplayConfirm {
+ dAtA[i] = 1
+ } else {
+ dAtA[i] = 0
+ }
+ i--
+ dAtA[i] = 0x10
+ }
+ if m.AddressIndex != nil {
+ {
+ size, err := m.AddressIndex.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *EphemeralAddressResponse) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *EphemeralAddressResponse) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *EphemeralAddressResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Address != nil {
+ {
+ size, err := m.Address.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *BalancesRequest) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *BalancesRequest) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *BalancesRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.AssetIdFilter != nil {
+ {
+ size, err := m.AssetIdFilter.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.AccountFilter != nil {
+ {
+ size, err := m.AccountFilter.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *BalancesResponse) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *BalancesResponse) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *BalancesResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Balance != nil {
+ {
+ size, err := m.Balance.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.Account != nil {
+ {
+ size, err := m.Account.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *ViewAuthToken) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *ViewAuthToken) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ViewAuthToken) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if len(m.Inner) > 0 {
+ i -= len(m.Inner)
+ copy(dAtA[i:], m.Inner)
+ i = encodeVarintView(dAtA, i, uint64(len(m.Inner)))
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *ViewAuthRequest) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *ViewAuthRequest) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ViewAuthRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Fvk != nil {
+ {
+ size, err := m.Fvk.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *ViewAuthResponse) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *ViewAuthResponse) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ViewAuthResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Token != nil {
+ {
+ size, err := m.Token.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *StatusRequest) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *StatusRequest) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *StatusRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.XAccountGroupId != nil {
+ {
+ size := m.XAccountGroupId.Size()
+ i -= size
+ if _, err := m.XAccountGroupId.MarshalTo(dAtA[i:]); err != nil {
+ return 0, err
+ }
+ }
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *StatusRequest_AccountGroupId) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *StatusRequest_AccountGroupId) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.AccountGroupId != nil {
+ {
+ size, err := m.AccountGroupId.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x72
+ }
+ return len(dAtA) - i, nil
+}
+func (m *StatusResponse) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *StatusResponse) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *StatusResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.CatchingUp {
+ i--
+ if m.CatchingUp {
+ dAtA[i] = 1
+ } else {
+ dAtA[i] = 0
+ }
+ i--
+ dAtA[i] = 0x10
+ }
+ if m.SyncHeight != 0 {
+ i = encodeVarintView(dAtA, i, uint64(m.SyncHeight))
+ i--
+ dAtA[i] = 0x8
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *StatusStreamRequest) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *StatusStreamRequest) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *StatusStreamRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.XAccountGroupId != nil {
+ {
+ size := m.XAccountGroupId.Size()
+ i -= size
+ if _, err := m.XAccountGroupId.MarshalTo(dAtA[i:]); err != nil {
+ return 0, err
+ }
+ }
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *StatusStreamRequest_AccountGroupId) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *StatusStreamRequest_AccountGroupId) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.AccountGroupId != nil {
+ {
+ size, err := m.AccountGroupId.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x72
+ }
+ return len(dAtA) - i, nil
+}
+func (m *StatusStreamResponse) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *StatusStreamResponse) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *StatusStreamResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.SyncHeight != 0 {
+ i = encodeVarintView(dAtA, i, uint64(m.SyncHeight))
+ i--
+ dAtA[i] = 0x10
+ }
+ if m.LatestKnownBlockHeight != 0 {
+ i = encodeVarintView(dAtA, i, uint64(m.LatestKnownBlockHeight))
+ i--
+ dAtA[i] = 0x8
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *NotesRequest) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *NotesRequest) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *NotesRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.XAccountGroupId != nil {
+ {
+ size := m.XAccountGroupId.Size()
+ i -= size
+ if _, err := m.XAccountGroupId.MarshalTo(dAtA[i:]); err != nil {
+ return 0, err
+ }
+ }
+ }
+ if m.AmountToSpend != nil {
+ {
+ size, err := m.AmountToSpend.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x32
+ }
+ if m.AddressIndex != nil {
+ {
+ size, err := m.AddressIndex.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x22
+ }
+ if m.AssetId != nil {
+ {
+ size, err := m.AssetId.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1a
+ }
+ if m.IncludeSpent {
+ i--
+ if m.IncludeSpent {
+ dAtA[i] = 1
+ } else {
+ dAtA[i] = 0
+ }
+ i--
+ dAtA[i] = 0x10
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *NotesRequest_AccountGroupId) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *NotesRequest_AccountGroupId) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.AccountGroupId != nil {
+ {
+ size, err := m.AccountGroupId.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x72
+ }
+ return len(dAtA) - i, nil
+}
+func (m *NotesForVotingRequest) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *NotesForVotingRequest) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *NotesForVotingRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.XAccountGroupId != nil {
+ {
+ size := m.XAccountGroupId.Size()
+ i -= size
+ if _, err := m.XAccountGroupId.MarshalTo(dAtA[i:]); err != nil {
+ return 0, err
+ }
+ }
+ }
+ if m.AddressIndex != nil {
+ {
+ size, err := m.AddressIndex.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1a
+ }
+ if m.VotableAtHeight != 0 {
+ i = encodeVarintView(dAtA, i, uint64(m.VotableAtHeight))
+ i--
+ dAtA[i] = 0x8
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *NotesForVotingRequest_AccountGroupId) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *NotesForVotingRequest_AccountGroupId) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.AccountGroupId != nil {
+ {
+ size, err := m.AccountGroupId.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x72
+ }
+ return len(dAtA) - i, nil
+}
+func (m *WitnessRequest) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *WitnessRequest) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *WitnessRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.XAccountGroupId != nil {
+ {
+ size := m.XAccountGroupId.Size()
+ i -= size
+ if _, err := m.XAccountGroupId.MarshalTo(dAtA[i:]); err != nil {
+ return 0, err
+ }
+ }
+ }
+ if m.TransactionPlan != nil {
+ {
+ size, err := m.TransactionPlan.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1a
+ }
+ if len(m.NoteCommitments) > 0 {
+ for iNdEx := len(m.NoteCommitments) - 1; iNdEx >= 0; iNdEx-- {
+ {
+ size, err := m.NoteCommitments[iNdEx].MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *WitnessRequest_AccountGroupId) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *WitnessRequest_AccountGroupId) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.AccountGroupId != nil {
+ {
+ size, err := m.AccountGroupId.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x72
+ }
+ return len(dAtA) - i, nil
+}
+func (m *WitnessResponse) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *WitnessResponse) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *WitnessResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.WitnessData != nil {
+ {
+ size, err := m.WitnessData.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *WitnessAndBuildRequest) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *WitnessAndBuildRequest) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *WitnessAndBuildRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.AuthorizationData != nil {
+ {
+ size, err := m.AuthorizationData.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.TransactionPlan != nil {
+ {
+ size, err := m.TransactionPlan.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *WitnessAndBuildResponse) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *WitnessAndBuildResponse) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *WitnessAndBuildResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Transaction != nil {
+ {
+ size, err := m.Transaction.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *AssetsRequest) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *AssetsRequest) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *AssetsRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.IncludeVotingReceiptTokens {
+ i--
+ if m.IncludeVotingReceiptTokens {
+ dAtA[i] = 1
+ } else {
+ dAtA[i] = 0
+ }
+ i--
+ dAtA[i] = 0x38
+ }
+ if m.IncludeProposalNfts {
+ i--
+ if m.IncludeProposalNfts {
+ dAtA[i] = 1
+ } else {
+ dAtA[i] = 0
+ }
+ i--
+ dAtA[i] = 0x30
+ }
+ if m.IncludeLpNfts {
+ i--
+ if m.IncludeLpNfts {
+ dAtA[i] = 1
+ } else {
+ dAtA[i] = 0
+ }
+ i--
+ dAtA[i] = 0x28
+ }
+ if m.IncludeUnbondingTokens {
+ i--
+ if m.IncludeUnbondingTokens {
+ dAtA[i] = 1
+ } else {
+ dAtA[i] = 0
+ }
+ i--
+ dAtA[i] = 0x20
+ }
+ if m.IncludeDelegationTokens {
+ i--
+ if m.IncludeDelegationTokens {
+ dAtA[i] = 1
+ } else {
+ dAtA[i] = 0
+ }
+ i--
+ dAtA[i] = 0x18
+ }
+ if len(m.IncludeSpecificDenominations) > 0 {
+ for iNdEx := len(m.IncludeSpecificDenominations) - 1; iNdEx >= 0; iNdEx-- {
+ {
+ size, err := m.IncludeSpecificDenominations[iNdEx].MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ }
+ if m.Filtered {
+ i--
+ if m.Filtered {
+ dAtA[i] = 1
+ } else {
+ dAtA[i] = 0
+ }
+ i--
+ dAtA[i] = 0x8
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *AssetsResponse) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *AssetsResponse) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *AssetsResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.DenomMetadata != nil {
+ {
+ size, err := m.DenomMetadata.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *ChainParametersRequest) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *ChainParametersRequest) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ChainParametersRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ return len(dAtA) - i, nil
+}
+
+func (m *ChainParametersResponse) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *ChainParametersResponse) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *ChainParametersResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Parameters != nil {
+ {
+ size, err := m.Parameters.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *FMDParametersRequest) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *FMDParametersRequest) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *FMDParametersRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ return len(dAtA) - i, nil
+}
+
+func (m *FMDParametersResponse) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *FMDParametersResponse) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *FMDParametersResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Parameters != nil {
+ {
+ size, err := m.Parameters.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *NoteByCommitmentRequest) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *NoteByCommitmentRequest) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *NoteByCommitmentRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.XAccountGroupId != nil {
+ {
+ size := m.XAccountGroupId.Size()
+ i -= size
+ if _, err := m.XAccountGroupId.MarshalTo(dAtA[i:]); err != nil {
+ return 0, err
+ }
+ }
+ }
+ if m.AwaitDetection {
+ i--
+ if m.AwaitDetection {
+ dAtA[i] = 1
+ } else {
+ dAtA[i] = 0
+ }
+ i--
+ dAtA[i] = 0x18
+ }
+ if m.NoteCommitment != nil {
+ {
+ size, err := m.NoteCommitment.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *NoteByCommitmentRequest_AccountGroupId) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *NoteByCommitmentRequest_AccountGroupId) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.AccountGroupId != nil {
+ {
+ size, err := m.AccountGroupId.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x72
+ }
+ return len(dAtA) - i, nil
+}
+func (m *NoteByCommitmentResponse) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *NoteByCommitmentResponse) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *NoteByCommitmentResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.SpendableNote != nil {
+ {
+ size, err := m.SpendableNote.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *SwapByCommitmentRequest) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *SwapByCommitmentRequest) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *SwapByCommitmentRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.XAccountGroupId != nil {
+ {
+ size := m.XAccountGroupId.Size()
+ i -= size
+ if _, err := m.XAccountGroupId.MarshalTo(dAtA[i:]); err != nil {
+ return 0, err
+ }
+ }
+ }
+ if m.AwaitDetection {
+ i--
+ if m.AwaitDetection {
+ dAtA[i] = 1
+ } else {
+ dAtA[i] = 0
+ }
+ i--
+ dAtA[i] = 0x18
+ }
+ if m.SwapCommitment != nil {
+ {
+ size, err := m.SwapCommitment.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *SwapByCommitmentRequest_AccountGroupId) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *SwapByCommitmentRequest_AccountGroupId) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.AccountGroupId != nil {
+ {
+ size, err := m.AccountGroupId.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x72
+ }
+ return len(dAtA) - i, nil
+}
+func (m *SwapByCommitmentResponse) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *SwapByCommitmentResponse) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *SwapByCommitmentResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Swap != nil {
+ {
+ size, err := m.Swap.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *NullifierStatusRequest) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *NullifierStatusRequest) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *NullifierStatusRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.XAccountGroupId != nil {
+ {
+ size := m.XAccountGroupId.Size()
+ i -= size
+ if _, err := m.XAccountGroupId.MarshalTo(dAtA[i:]); err != nil {
+ return 0, err
+ }
+ }
+ }
+ if m.AwaitDetection {
+ i--
+ if m.AwaitDetection {
+ dAtA[i] = 1
+ } else {
+ dAtA[i] = 0
+ }
+ i--
+ dAtA[i] = 0x18
+ }
+ if m.Nullifier != nil {
+ {
+ size, err := m.Nullifier.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *NullifierStatusRequest_AccountGroupId) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *NullifierStatusRequest_AccountGroupId) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.AccountGroupId != nil {
+ {
+ size, err := m.AccountGroupId.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x72
+ }
+ return len(dAtA) - i, nil
+}
+func (m *NullifierStatusResponse) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *NullifierStatusResponse) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *NullifierStatusResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Spent {
+ i--
+ if m.Spent {
+ dAtA[i] = 1
+ } else {
+ dAtA[i] = 0
+ }
+ i--
+ dAtA[i] = 0x8
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *TransactionInfoByHashRequest) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *TransactionInfoByHashRequest) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *TransactionInfoByHashRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Id != nil {
+ {
+ size, err := m.Id.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *TransactionInfoRequest) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *TransactionInfoRequest) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *TransactionInfoRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.XEndHeight != nil {
+ {
+ size := m.XEndHeight.Size()
+ i -= size
+ if _, err := m.XEndHeight.MarshalTo(dAtA[i:]); err != nil {
+ return 0, err
+ }
+ }
+ }
+ if m.XStartHeight != nil {
+ {
+ size := m.XStartHeight.Size()
+ i -= size
+ if _, err := m.XStartHeight.MarshalTo(dAtA[i:]); err != nil {
+ return 0, err
+ }
+ }
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *TransactionInfoRequest_StartHeight) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *TransactionInfoRequest_StartHeight) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ i = encodeVarintView(dAtA, i, uint64(m.StartHeight))
+ i--
+ dAtA[i] = 0x8
+ return len(dAtA) - i, nil
+}
+func (m *TransactionInfoRequest_EndHeight) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *TransactionInfoRequest_EndHeight) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ i = encodeVarintView(dAtA, i, uint64(m.EndHeight))
+ i--
+ dAtA[i] = 0x10
+ return len(dAtA) - i, nil
+}
+func (m *TransactionInfo) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *TransactionInfo) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *TransactionInfo) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.View != nil {
+ {
+ size, err := m.View.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x2a
+ }
+ if m.Perspective != nil {
+ {
+ size, err := m.Perspective.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x22
+ }
+ if m.Transaction != nil {
+ {
+ size, err := m.Transaction.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1a
+ }
+ if m.Id != nil {
+ {
+ size, err := m.Id.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.XHeight != nil {
+ {
+ size := m.XHeight.Size()
+ i -= size
+ if _, err := m.XHeight.MarshalTo(dAtA[i:]); err != nil {
+ return 0, err
+ }
+ }
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *TransactionInfo_Height) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *TransactionInfo_Height) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ i = encodeVarintView(dAtA, i, uint64(m.Height))
+ i--
+ dAtA[i] = 0x8
+ return len(dAtA) - i, nil
+}
+func (m *TransactionInfoResponse) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *TransactionInfoResponse) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *TransactionInfoResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.TxInfo != nil {
+ {
+ size, err := m.TxInfo.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *TransactionInfoByHashResponse) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *TransactionInfoByHashResponse) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *TransactionInfoByHashResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.TxInfo != nil {
+ {
+ size, err := m.TxInfo.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *NotesResponse) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *NotesResponse) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *NotesResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.NoteRecord != nil {
+ {
+ size, err := m.NoteRecord.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *NotesForVotingResponse) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *NotesForVotingResponse) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *NotesForVotingResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.IdentityKey != nil {
+ {
+ size, err := m.IdentityKey.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.NoteRecord != nil {
+ {
+ size, err := m.NoteRecord.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *SpendableNoteRecord) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *SpendableNoteRecord) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *SpendableNoteRecord) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Source != nil {
+ {
+ size, err := m.Source.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x42
+ }
+ if m.Position != 0 {
+ i = encodeVarintView(dAtA, i, uint64(m.Position))
+ i--
+ dAtA[i] = 0x38
+ }
+ if m.XHeightSpent != nil {
+ {
+ size := m.XHeightSpent.Size()
+ i -= size
+ if _, err := m.XHeightSpent.MarshalTo(dAtA[i:]); err != nil {
+ return 0, err
+ }
+ }
+ }
+ if m.HeightCreated != 0 {
+ i = encodeVarintView(dAtA, i, uint64(m.HeightCreated))
+ i--
+ dAtA[i] = 0x28
+ }
+ if m.Nullifier != nil {
+ {
+ size, err := m.Nullifier.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x22
+ }
+ if m.AddressIndex != nil {
+ {
+ size, err := m.AddressIndex.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x1a
+ }
+ if m.Note != nil {
+ {
+ size, err := m.Note.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.NoteCommitment != nil {
+ {
+ size, err := m.NoteCommitment.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *SpendableNoteRecord_HeightSpent) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *SpendableNoteRecord_HeightSpent) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ i = encodeVarintView(dAtA, i, uint64(m.HeightSpent))
+ i--
+ dAtA[i] = 0x30
+ return len(dAtA) - i, nil
+}
+func (m *SwapRecord) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *SwapRecord) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *SwapRecord) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.Source != nil {
+ {
+ size, err := m.Source.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x3a
+ }
+ if m.XHeightClaimed != nil {
+ {
+ size := m.XHeightClaimed.Size()
+ i -= size
+ if _, err := m.XHeightClaimed.MarshalTo(dAtA[i:]); err != nil {
+ return 0, err
+ }
+ }
+ }
+ if m.OutputData != nil {
+ {
+ size, err := m.OutputData.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x2a
+ }
+ if m.Nullifier != nil {
+ {
+ size, err := m.Nullifier.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x22
+ }
+ if m.Position != 0 {
+ i = encodeVarintView(dAtA, i, uint64(m.Position))
+ i--
+ dAtA[i] = 0x18
+ }
+ if m.Swap != nil {
+ {
+ size, err := m.Swap.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ if m.SwapCommitment != nil {
+ {
+ size, err := m.SwapCommitment.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *SwapRecord_HeightClaimed) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *SwapRecord_HeightClaimed) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ i = encodeVarintView(dAtA, i, uint64(m.HeightClaimed))
+ i--
+ dAtA[i] = 0x30
+ return len(dAtA) - i, nil
+}
+func (m *OwnedPositionIdsRequest) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *OwnedPositionIdsRequest) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *OwnedPositionIdsRequest) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.XTradingPair != nil {
+ {
+ size := m.XTradingPair.Size()
+ i -= size
+ if _, err := m.XTradingPair.MarshalTo(dAtA[i:]); err != nil {
+ return 0, err
+ }
+ }
+ }
+ if m.XPositionState != nil {
+ {
+ size := m.XPositionState.Size()
+ i -= size
+ if _, err := m.XPositionState.MarshalTo(dAtA[i:]); err != nil {
+ return 0, err
+ }
+ }
+ }
+ return len(dAtA) - i, nil
+}
+
+func (m *OwnedPositionIdsRequest_PositionState) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *OwnedPositionIdsRequest_PositionState) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.PositionState != nil {
+ {
+ size, err := m.PositionState.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+func (m *OwnedPositionIdsRequest_TradingPair) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *OwnedPositionIdsRequest_TradingPair) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ if m.TradingPair != nil {
+ {
+ size, err := m.TradingPair.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0x12
+ }
+ return len(dAtA) - i, nil
+}
+func (m *OwnedPositionIdsResponse) Marshal() (dAtA []byte, err error) {
+ size := m.Size()
+ dAtA = make([]byte, size)
+ n, err := m.MarshalToSizedBuffer(dAtA[:size])
+ if err != nil {
+ return nil, err
+ }
+ return dAtA[:n], nil
+}
+
+func (m *OwnedPositionIdsResponse) MarshalTo(dAtA []byte) (int, error) {
+ size := m.Size()
+ return m.MarshalToSizedBuffer(dAtA[:size])
+}
+
+func (m *OwnedPositionIdsResponse) MarshalToSizedBuffer(dAtA []byte) (int, error) {
+ i := len(dAtA)
+ _ = i
+ var l int
+ _ = l
+ if m.PositionId != nil {
+ {
+ size, err := m.PositionId.MarshalToSizedBuffer(dAtA[:i])
+ if err != nil {
+ return 0, err
+ }
+ i -= size
+ i = encodeVarintView(dAtA, i, uint64(size))
+ }
+ i--
+ dAtA[i] = 0xa
+ }
+ return len(dAtA) - i, nil
+}
+
+func encodeVarintView(dAtA []byte, offset int, v uint64) int {
+ offset -= sovView(v)
+ base := offset
+ for v >= 1<<7 {
+ dAtA[offset] = uint8(v&0x7f | 0x80)
+ v >>= 7
+ offset++
+ }
+ dAtA[offset] = uint8(v)
+ return base
+}
+func (m *AuthorizeAndBuildRequest) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.TransactionPlan != nil {
+ l = m.TransactionPlan.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ if m.AuthorizationData != nil {
+ l = m.AuthorizationData.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ return n
+}
+
+func (m *AuthorizeAndBuildResponse) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Transaction != nil {
+ l = m.Transaction.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ return n
+}
+
+func (m *BroadcastTransactionRequest) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Transaction != nil {
+ l = m.Transaction.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ if m.AwaitDetection {
+ n += 2
+ }
+ return n
+}
+
+func (m *BroadcastTransactionResponse) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Id != nil {
+ l = m.Id.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ if m.DetectionHeight != 0 {
+ n += 1 + sovView(uint64(m.DetectionHeight))
+ }
+ return n
+}
+
+func (m *TransactionPlannerRequest) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.ExpiryHeight != 0 {
+ n += 1 + sovView(uint64(m.ExpiryHeight))
+ }
+ if m.Fee != nil {
+ l = m.Fee.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ if m.Memo != nil {
+ l = m.Memo.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ if m.XAccountGroupId != nil {
+ n += m.XAccountGroupId.Size()
+ }
+ if len(m.Outputs) > 0 {
+ for _, e := range m.Outputs {
+ l = e.Size()
+ n += 2 + l + sovView(uint64(l))
+ }
+ }
+ if len(m.Swaps) > 0 {
+ for _, e := range m.Swaps {
+ l = e.Size()
+ n += 2 + l + sovView(uint64(l))
+ }
+ }
+ if len(m.SwapClaims) > 0 {
+ for _, e := range m.SwapClaims {
+ l = e.Size()
+ n += 2 + l + sovView(uint64(l))
+ }
+ }
+ if len(m.Delegations) > 0 {
+ for _, e := range m.Delegations {
+ l = e.Size()
+ n += 2 + l + sovView(uint64(l))
+ }
+ }
+ if len(m.Undelegations) > 0 {
+ for _, e := range m.Undelegations {
+ l = e.Size()
+ n += 2 + l + sovView(uint64(l))
+ }
+ }
+ if len(m.IbcActions) > 0 {
+ for _, e := range m.IbcActions {
+ l = e.Size()
+ n += 2 + l + sovView(uint64(l))
+ }
+ }
+ return n
+}
+
+func (m *TransactionPlannerRequest_AccountGroupId) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.AccountGroupId != nil {
+ l = m.AccountGroupId.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ return n
+}
+func (m *TransactionPlannerRequest_Output) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Value != nil {
+ l = m.Value.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ if m.Address != nil {
+ l = m.Address.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ return n
+}
+
+func (m *TransactionPlannerRequest_Swap) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Value != nil {
+ l = m.Value.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ if m.TargetAsset != nil {
+ l = m.TargetAsset.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ if m.Fee != nil {
+ l = m.Fee.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ return n
+}
+
+func (m *TransactionPlannerRequest_SwapClaim) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.SwapCommitment != nil {
+ l = m.SwapCommitment.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ return n
+}
+
+func (m *TransactionPlannerRequest_Delegate) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Amount != nil {
+ l = m.Amount.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ if m.RateData != nil {
+ l = m.RateData.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ return n
+}
+
+func (m *TransactionPlannerRequest_Undelegate) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Value != nil {
+ l = m.Value.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ if m.RateData != nil {
+ l = m.RateData.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ return n
+}
+
+func (m *TransactionPlannerResponse) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Plan != nil {
+ l = m.Plan.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ return n
+}
+
+func (m *AddressByIndexRequest) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.AddressIndex != nil {
+ l = m.AddressIndex.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ if m.DisplayConfirm {
+ n += 2
+ }
+ return n
+}
+
+func (m *AddressByIndexResponse) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Address != nil {
+ l = m.Address.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ return n
+}
+
+func (m *IndexByAddressRequest) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Address != nil {
+ l = m.Address.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ return n
+}
+
+func (m *IndexByAddressResponse) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.XAddressIndex != nil {
+ n += m.XAddressIndex.Size()
+ }
+ return n
+}
+
+func (m *IndexByAddressResponse_AddressIndex) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.AddressIndex != nil {
+ l = m.AddressIndex.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ return n
+}
+func (m *EphemeralAddressRequest) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.AddressIndex != nil {
+ l = m.AddressIndex.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ if m.DisplayConfirm {
+ n += 2
+ }
+ return n
+}
+
+func (m *EphemeralAddressResponse) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Address != nil {
+ l = m.Address.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ return n
+}
+
+func (m *BalancesRequest) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.AccountFilter != nil {
+ l = m.AccountFilter.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ if m.AssetIdFilter != nil {
+ l = m.AssetIdFilter.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ return n
+}
+
+func (m *BalancesResponse) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Account != nil {
+ l = m.Account.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ if m.Balance != nil {
+ l = m.Balance.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ return n
+}
+
+func (m *ViewAuthToken) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ l = len(m.Inner)
+ if l > 0 {
+ n += 1 + l + sovView(uint64(l))
+ }
+ return n
+}
+
+func (m *ViewAuthRequest) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Fvk != nil {
+ l = m.Fvk.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ return n
+}
+
+func (m *ViewAuthResponse) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Token != nil {
+ l = m.Token.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ return n
+}
+
+func (m *StatusRequest) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.XAccountGroupId != nil {
+ n += m.XAccountGroupId.Size()
+ }
+ return n
+}
+
+func (m *StatusRequest_AccountGroupId) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.AccountGroupId != nil {
+ l = m.AccountGroupId.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ return n
+}
+func (m *StatusResponse) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.SyncHeight != 0 {
+ n += 1 + sovView(uint64(m.SyncHeight))
+ }
+ if m.CatchingUp {
+ n += 2
+ }
+ return n
+}
+
+func (m *StatusStreamRequest) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.XAccountGroupId != nil {
+ n += m.XAccountGroupId.Size()
+ }
+ return n
+}
+
+func (m *StatusStreamRequest_AccountGroupId) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.AccountGroupId != nil {
+ l = m.AccountGroupId.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ return n
+}
+func (m *StatusStreamResponse) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.LatestKnownBlockHeight != 0 {
+ n += 1 + sovView(uint64(m.LatestKnownBlockHeight))
+ }
+ if m.SyncHeight != 0 {
+ n += 1 + sovView(uint64(m.SyncHeight))
+ }
+ return n
+}
+
+func (m *NotesRequest) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.IncludeSpent {
+ n += 2
+ }
+ if m.AssetId != nil {
+ l = m.AssetId.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ if m.AddressIndex != nil {
+ l = m.AddressIndex.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ if m.AmountToSpend != nil {
+ l = m.AmountToSpend.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ if m.XAccountGroupId != nil {
+ n += m.XAccountGroupId.Size()
+ }
+ return n
+}
+
+func (m *NotesRequest_AccountGroupId) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.AccountGroupId != nil {
+ l = m.AccountGroupId.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ return n
+}
+func (m *NotesForVotingRequest) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.VotableAtHeight != 0 {
+ n += 1 + sovView(uint64(m.VotableAtHeight))
+ }
+ if m.AddressIndex != nil {
+ l = m.AddressIndex.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ if m.XAccountGroupId != nil {
+ n += m.XAccountGroupId.Size()
+ }
+ return n
+}
+
+func (m *NotesForVotingRequest_AccountGroupId) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.AccountGroupId != nil {
+ l = m.AccountGroupId.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ return n
+}
+func (m *WitnessRequest) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if len(m.NoteCommitments) > 0 {
+ for _, e := range m.NoteCommitments {
+ l = e.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ }
+ if m.TransactionPlan != nil {
+ l = m.TransactionPlan.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ if m.XAccountGroupId != nil {
+ n += m.XAccountGroupId.Size()
+ }
+ return n
+}
+
+func (m *WitnessRequest_AccountGroupId) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.AccountGroupId != nil {
+ l = m.AccountGroupId.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ return n
+}
+func (m *WitnessResponse) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.WitnessData != nil {
+ l = m.WitnessData.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ return n
+}
+
+func (m *WitnessAndBuildRequest) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.TransactionPlan != nil {
+ l = m.TransactionPlan.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ if m.AuthorizationData != nil {
+ l = m.AuthorizationData.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ return n
+}
+
+func (m *WitnessAndBuildResponse) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Transaction != nil {
+ l = m.Transaction.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ return n
+}
+
+func (m *AssetsRequest) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Filtered {
+ n += 2
+ }
+ if len(m.IncludeSpecificDenominations) > 0 {
+ for _, e := range m.IncludeSpecificDenominations {
+ l = e.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ }
+ if m.IncludeDelegationTokens {
+ n += 2
+ }
+ if m.IncludeUnbondingTokens {
+ n += 2
+ }
+ if m.IncludeLpNfts {
+ n += 2
+ }
+ if m.IncludeProposalNfts {
+ n += 2
+ }
+ if m.IncludeVotingReceiptTokens {
+ n += 2
+ }
+ return n
+}
+
+func (m *AssetsResponse) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.DenomMetadata != nil {
+ l = m.DenomMetadata.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ return n
+}
+
+func (m *ChainParametersRequest) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ return n
+}
+
+func (m *ChainParametersResponse) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Parameters != nil {
+ l = m.Parameters.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ return n
+}
+
+func (m *FMDParametersRequest) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ return n
+}
+
+func (m *FMDParametersResponse) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Parameters != nil {
+ l = m.Parameters.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ return n
+}
+
+func (m *NoteByCommitmentRequest) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.NoteCommitment != nil {
+ l = m.NoteCommitment.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ if m.AwaitDetection {
+ n += 2
+ }
+ if m.XAccountGroupId != nil {
+ n += m.XAccountGroupId.Size()
+ }
+ return n
+}
+
+func (m *NoteByCommitmentRequest_AccountGroupId) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.AccountGroupId != nil {
+ l = m.AccountGroupId.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ return n
+}
+func (m *NoteByCommitmentResponse) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.SpendableNote != nil {
+ l = m.SpendableNote.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ return n
+}
+
+func (m *SwapByCommitmentRequest) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.SwapCommitment != nil {
+ l = m.SwapCommitment.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ if m.AwaitDetection {
+ n += 2
+ }
+ if m.XAccountGroupId != nil {
+ n += m.XAccountGroupId.Size()
+ }
+ return n
+}
+
+func (m *SwapByCommitmentRequest_AccountGroupId) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.AccountGroupId != nil {
+ l = m.AccountGroupId.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ return n
+}
+func (m *SwapByCommitmentResponse) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Swap != nil {
+ l = m.Swap.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ return n
+}
+
+func (m *NullifierStatusRequest) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Nullifier != nil {
+ l = m.Nullifier.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ if m.AwaitDetection {
+ n += 2
+ }
+ if m.XAccountGroupId != nil {
+ n += m.XAccountGroupId.Size()
+ }
+ return n
+}
+
+func (m *NullifierStatusRequest_AccountGroupId) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.AccountGroupId != nil {
+ l = m.AccountGroupId.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ return n
+}
+func (m *NullifierStatusResponse) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Spent {
+ n += 2
+ }
+ return n
+}
+
+func (m *TransactionInfoByHashRequest) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.Id != nil {
+ l = m.Id.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ return n
+}
+
+func (m *TransactionInfoRequest) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.XStartHeight != nil {
+ n += m.XStartHeight.Size()
+ }
+ if m.XEndHeight != nil {
+ n += m.XEndHeight.Size()
+ }
+ return n
+}
+
+func (m *TransactionInfoRequest_StartHeight) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ n += 1 + sovView(uint64(m.StartHeight))
+ return n
+}
+func (m *TransactionInfoRequest_EndHeight) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ n += 1 + sovView(uint64(m.EndHeight))
+ return n
+}
+func (m *TransactionInfo) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.XHeight != nil {
+ n += m.XHeight.Size()
+ }
+ if m.Id != nil {
+ l = m.Id.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ if m.Transaction != nil {
+ l = m.Transaction.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ if m.Perspective != nil {
+ l = m.Perspective.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ if m.View != nil {
+ l = m.View.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ return n
+}
+
+func (m *TransactionInfo_Height) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ n += 1 + sovView(uint64(m.Height))
+ return n
+}
+func (m *TransactionInfoResponse) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.TxInfo != nil {
+ l = m.TxInfo.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ return n
+}
+
+func (m *TransactionInfoByHashResponse) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.TxInfo != nil {
+ l = m.TxInfo.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ return n
+}
+
+func (m *NotesResponse) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.NoteRecord != nil {
+ l = m.NoteRecord.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ return n
+}
+
+func (m *NotesForVotingResponse) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.NoteRecord != nil {
+ l = m.NoteRecord.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ if m.IdentityKey != nil {
+ l = m.IdentityKey.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ return n
+}
+
+func (m *SpendableNoteRecord) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.NoteCommitment != nil {
+ l = m.NoteCommitment.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ if m.Note != nil {
+ l = m.Note.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ if m.AddressIndex != nil {
+ l = m.AddressIndex.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ if m.Nullifier != nil {
+ l = m.Nullifier.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ if m.HeightCreated != 0 {
+ n += 1 + sovView(uint64(m.HeightCreated))
+ }
+ if m.XHeightSpent != nil {
+ n += m.XHeightSpent.Size()
+ }
+ if m.Position != 0 {
+ n += 1 + sovView(uint64(m.Position))
+ }
+ if m.Source != nil {
+ l = m.Source.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ return n
+}
+
+func (m *SpendableNoteRecord_HeightSpent) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ n += 1 + sovView(uint64(m.HeightSpent))
+ return n
+}
+func (m *SwapRecord) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.SwapCommitment != nil {
+ l = m.SwapCommitment.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ if m.Swap != nil {
+ l = m.Swap.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ if m.Position != 0 {
+ n += 1 + sovView(uint64(m.Position))
+ }
+ if m.Nullifier != nil {
+ l = m.Nullifier.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ if m.OutputData != nil {
+ l = m.OutputData.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ if m.XHeightClaimed != nil {
+ n += m.XHeightClaimed.Size()
+ }
+ if m.Source != nil {
+ l = m.Source.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ return n
+}
+
+func (m *SwapRecord_HeightClaimed) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ n += 1 + sovView(uint64(m.HeightClaimed))
+ return n
+}
+func (m *OwnedPositionIdsRequest) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.XPositionState != nil {
+ n += m.XPositionState.Size()
+ }
+ if m.XTradingPair != nil {
+ n += m.XTradingPair.Size()
+ }
+ return n
+}
+
+func (m *OwnedPositionIdsRequest_PositionState) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.PositionState != nil {
+ l = m.PositionState.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ return n
+}
+func (m *OwnedPositionIdsRequest_TradingPair) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.TradingPair != nil {
+ l = m.TradingPair.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ return n
+}
+func (m *OwnedPositionIdsResponse) Size() (n int) {
+ if m == nil {
+ return 0
+ }
+ var l int
+ _ = l
+ if m.PositionId != nil {
+ l = m.PositionId.Size()
+ n += 1 + l + sovView(uint64(l))
+ }
+ return n
+}
+
+func sovView(x uint64) (n int) {
+ return (math_bits.Len64(x|1) + 6) / 7
+}
+func sozView(x uint64) (n int) {
+ return sovView(uint64((x << 1) ^ uint64((int64(x) >> 63))))
+}
+func (m *AuthorizeAndBuildRequest) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: AuthorizeAndBuildRequest: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: AuthorizeAndBuildRequest: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field TransactionPlan", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.TransactionPlan == nil {
+ m.TransactionPlan = &v1alpha1.TransactionPlan{}
+ }
+ if err := m.TransactionPlan.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field AuthorizationData", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.AuthorizationData == nil {
+ m.AuthorizationData = &v1alpha1.AuthorizationData{}
+ }
+ if err := m.AuthorizationData.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipView(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthView
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *AuthorizeAndBuildResponse) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: AuthorizeAndBuildResponse: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: AuthorizeAndBuildResponse: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Transaction", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Transaction == nil {
+ m.Transaction = &v1alpha1.Transaction{}
+ }
+ if err := m.Transaction.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipView(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthView
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *BroadcastTransactionRequest) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: BroadcastTransactionRequest: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: BroadcastTransactionRequest: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Transaction", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Transaction == nil {
+ m.Transaction = &v1alpha1.Transaction{}
+ }
+ if err := m.Transaction.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field AwaitDetection", wireType)
+ }
+ var v int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ v |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ m.AwaitDetection = bool(v != 0)
+ default:
+ iNdEx = preIndex
+ skippy, err := skipView(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthView
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *BroadcastTransactionResponse) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: BroadcastTransactionResponse: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: BroadcastTransactionResponse: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Id", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Id == nil {
+ m.Id = &v1alpha1.Id{}
+ }
+ if err := m.Id.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field DetectionHeight", wireType)
+ }
+ m.DetectionHeight = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.DetectionHeight |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ default:
+ iNdEx = preIndex
+ skippy, err := skipView(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthView
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *TransactionPlannerRequest) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: TransactionPlannerRequest: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: TransactionPlannerRequest: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field ExpiryHeight", wireType)
+ }
+ m.ExpiryHeight = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.ExpiryHeight |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Fee", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Fee == nil {
+ m.Fee = &v1alpha11.Fee{}
+ }
+ if err := m.Fee.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Memo", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Memo == nil {
+ m.Memo = &v1alpha1.MemoPlaintext{}
+ }
+ if err := m.Memo.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 14:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field AccountGroupId", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha11.AccountGroupId{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.XAccountGroupId = &TransactionPlannerRequest_AccountGroupId{v}
+ iNdEx = postIndex
+ case 20:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Outputs", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Outputs = append(m.Outputs, &TransactionPlannerRequest_Output{})
+ if err := m.Outputs[len(m.Outputs)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 30:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Swaps", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Swaps = append(m.Swaps, &TransactionPlannerRequest_Swap{})
+ if err := m.Swaps[len(m.Swaps)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 31:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field SwapClaims", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.SwapClaims = append(m.SwapClaims, &TransactionPlannerRequest_SwapClaim{})
+ if err := m.SwapClaims[len(m.SwapClaims)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 40:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Delegations", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Delegations = append(m.Delegations, &TransactionPlannerRequest_Delegate{})
+ if err := m.Delegations[len(m.Delegations)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 50:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Undelegations", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Undelegations = append(m.Undelegations, &TransactionPlannerRequest_Undelegate{})
+ if err := m.Undelegations[len(m.Undelegations)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 60:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field IbcActions", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.IbcActions = append(m.IbcActions, &v1alpha12.IbcAction{})
+ if err := m.IbcActions[len(m.IbcActions)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipView(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthView
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *TransactionPlannerRequest_Output) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Output: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Output: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Value", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Value == nil {
+ m.Value = &v1alpha11.Value{}
+ }
+ if err := m.Value.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Address", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Address == nil {
+ m.Address = &v1alpha11.Address{}
+ }
+ if err := m.Address.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipView(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthView
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *TransactionPlannerRequest_Swap) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Swap: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Swap: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Value", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Value == nil {
+ m.Value = &v1alpha11.Value{}
+ }
+ if err := m.Value.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field TargetAsset", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.TargetAsset == nil {
+ m.TargetAsset = &v1alpha11.AssetId{}
+ }
+ if err := m.TargetAsset.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Fee", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Fee == nil {
+ m.Fee = &v1alpha11.Fee{}
+ }
+ if err := m.Fee.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipView(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthView
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *TransactionPlannerRequest_SwapClaim) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: SwapClaim: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: SwapClaim: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field SwapCommitment", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.SwapCommitment == nil {
+ m.SwapCommitment = &v1alpha11.StateCommitment{}
+ }
+ if err := m.SwapCommitment.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipView(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthView
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *TransactionPlannerRequest_Delegate) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Delegate: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Delegate: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Amount", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Amount == nil {
+ m.Amount = &v1alpha11.Amount{}
+ }
+ if err := m.Amount.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field RateData", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.RateData == nil {
+ m.RateData = &v1alpha13.RateData{}
+ }
+ if err := m.RateData.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipView(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthView
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *TransactionPlannerRequest_Undelegate) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: Undelegate: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: Undelegate: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Value", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Value == nil {
+ m.Value = &v1alpha11.Value{}
+ }
+ if err := m.Value.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field RateData", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.RateData == nil {
+ m.RateData = &v1alpha13.RateData{}
+ }
+ if err := m.RateData.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipView(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthView
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *TransactionPlannerResponse) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: TransactionPlannerResponse: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: TransactionPlannerResponse: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Plan", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Plan == nil {
+ m.Plan = &v1alpha1.TransactionPlan{}
+ }
+ if err := m.Plan.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipView(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthView
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *AddressByIndexRequest) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: AddressByIndexRequest: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: AddressByIndexRequest: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field AddressIndex", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.AddressIndex == nil {
+ m.AddressIndex = &v1alpha11.AddressIndex{}
+ }
+ if err := m.AddressIndex.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field DisplayConfirm", wireType)
+ }
+ var v int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ v |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ m.DisplayConfirm = bool(v != 0)
+ default:
+ iNdEx = preIndex
+ skippy, err := skipView(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthView
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *AddressByIndexResponse) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: AddressByIndexResponse: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: AddressByIndexResponse: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Address", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Address == nil {
+ m.Address = &v1alpha11.Address{}
+ }
+ if err := m.Address.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipView(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthView
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *IndexByAddressRequest) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: IndexByAddressRequest: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: IndexByAddressRequest: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Address", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Address == nil {
+ m.Address = &v1alpha11.Address{}
+ }
+ if err := m.Address.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipView(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthView
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *IndexByAddressResponse) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: IndexByAddressResponse: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: IndexByAddressResponse: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field AddressIndex", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha11.AddressIndex{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.XAddressIndex = &IndexByAddressResponse_AddressIndex{v}
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipView(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthView
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *EphemeralAddressRequest) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: EphemeralAddressRequest: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: EphemeralAddressRequest: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field AddressIndex", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.AddressIndex == nil {
+ m.AddressIndex = &v1alpha11.AddressIndex{}
+ }
+ if err := m.AddressIndex.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field DisplayConfirm", wireType)
+ }
+ var v int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ v |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ m.DisplayConfirm = bool(v != 0)
+ default:
+ iNdEx = preIndex
+ skippy, err := skipView(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthView
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *EphemeralAddressResponse) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: EphemeralAddressResponse: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: EphemeralAddressResponse: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Address", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Address == nil {
+ m.Address = &v1alpha11.Address{}
+ }
+ if err := m.Address.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipView(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthView
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *BalancesRequest) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: BalancesRequest: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: BalancesRequest: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field AccountFilter", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.AccountFilter == nil {
+ m.AccountFilter = &v1alpha11.AddressIndex{}
+ }
+ if err := m.AccountFilter.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field AssetIdFilter", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.AssetIdFilter == nil {
+ m.AssetIdFilter = &v1alpha11.AssetId{}
+ }
+ if err := m.AssetIdFilter.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipView(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthView
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *BalancesResponse) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: BalancesResponse: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: BalancesResponse: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Account", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Account == nil {
+ m.Account = &v1alpha11.AddressIndex{}
+ }
+ if err := m.Account.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Balance", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Balance == nil {
+ m.Balance = &v1alpha11.Value{}
+ }
+ if err := m.Balance.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipView(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthView
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *ViewAuthToken) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: ViewAuthToken: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: ViewAuthToken: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Inner", wireType)
+ }
+ var byteLen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ byteLen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if byteLen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + byteLen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.Inner = append(m.Inner[:0], dAtA[iNdEx:postIndex]...)
+ if m.Inner == nil {
+ m.Inner = []byte{}
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipView(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthView
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *ViewAuthRequest) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: ViewAuthRequest: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: ViewAuthRequest: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Fvk", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Fvk == nil {
+ m.Fvk = &v1alpha11.FullViewingKey{}
+ }
+ if err := m.Fvk.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipView(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthView
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *ViewAuthResponse) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: ViewAuthResponse: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: ViewAuthResponse: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Token", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Token == nil {
+ m.Token = &ViewAuthToken{}
+ }
+ if err := m.Token.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipView(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthView
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *StatusRequest) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: StatusRequest: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: StatusRequest: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 14:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field AccountGroupId", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha11.AccountGroupId{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.XAccountGroupId = &StatusRequest_AccountGroupId{v}
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipView(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthView
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *StatusResponse) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: StatusResponse: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: StatusResponse: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field SyncHeight", wireType)
+ }
+ m.SyncHeight = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.SyncHeight |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 2:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field CatchingUp", wireType)
+ }
+ var v int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ v |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ m.CatchingUp = bool(v != 0)
+ default:
+ iNdEx = preIndex
+ skippy, err := skipView(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthView
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *StatusStreamRequest) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: StatusStreamRequest: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: StatusStreamRequest: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 14:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field AccountGroupId", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha11.AccountGroupId{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.XAccountGroupId = &StatusStreamRequest_AccountGroupId{v}
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipView(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthView
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *StatusStreamResponse) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: StatusStreamResponse: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: StatusStreamResponse: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field LatestKnownBlockHeight", wireType)
+ }
+ m.LatestKnownBlockHeight = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.LatestKnownBlockHeight |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 2:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field SyncHeight", wireType)
+ }
+ m.SyncHeight = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.SyncHeight |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ default:
+ iNdEx = preIndex
+ skippy, err := skipView(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthView
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *NotesRequest) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: NotesRequest: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: NotesRequest: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 2:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field IncludeSpent", wireType)
+ }
+ var v int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ v |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ m.IncludeSpent = bool(v != 0)
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field AssetId", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.AssetId == nil {
+ m.AssetId = &v1alpha11.AssetId{}
+ }
+ if err := m.AssetId.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 4:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field AddressIndex", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.AddressIndex == nil {
+ m.AddressIndex = &v1alpha11.AddressIndex{}
+ }
+ if err := m.AddressIndex.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 6:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field AmountToSpend", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.AmountToSpend == nil {
+ m.AmountToSpend = &v1alpha11.Amount{}
+ }
+ if err := m.AmountToSpend.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 14:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field AccountGroupId", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha11.AccountGroupId{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.XAccountGroupId = &NotesRequest_AccountGroupId{v}
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipView(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthView
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *NotesForVotingRequest) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: NotesForVotingRequest: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: NotesForVotingRequest: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field VotableAtHeight", wireType)
+ }
+ m.VotableAtHeight = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.VotableAtHeight |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field AddressIndex", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.AddressIndex == nil {
+ m.AddressIndex = &v1alpha11.AddressIndex{}
+ }
+ if err := m.AddressIndex.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 14:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field AccountGroupId", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha11.AccountGroupId{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.XAccountGroupId = &NotesForVotingRequest_AccountGroupId{v}
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipView(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthView
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *WitnessRequest) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: WitnessRequest: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: WitnessRequest: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field NoteCommitments", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.NoteCommitments = append(m.NoteCommitments, &v1alpha11.StateCommitment{})
+ if err := m.NoteCommitments[len(m.NoteCommitments)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field TransactionPlan", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.TransactionPlan == nil {
+ m.TransactionPlan = &v1alpha1.TransactionPlan{}
+ }
+ if err := m.TransactionPlan.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 14:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field AccountGroupId", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha11.AccountGroupId{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.XAccountGroupId = &WitnessRequest_AccountGroupId{v}
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipView(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthView
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *WitnessResponse) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: WitnessResponse: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: WitnessResponse: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field WitnessData", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.WitnessData == nil {
+ m.WitnessData = &v1alpha1.WitnessData{}
+ }
+ if err := m.WitnessData.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipView(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthView
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *WitnessAndBuildRequest) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: WitnessAndBuildRequest: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: WitnessAndBuildRequest: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field TransactionPlan", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.TransactionPlan == nil {
+ m.TransactionPlan = &v1alpha1.TransactionPlan{}
+ }
+ if err := m.TransactionPlan.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field AuthorizationData", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.AuthorizationData == nil {
+ m.AuthorizationData = &v1alpha1.AuthorizationData{}
+ }
+ if err := m.AuthorizationData.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipView(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthView
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *WitnessAndBuildResponse) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: WitnessAndBuildResponse: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: WitnessAndBuildResponse: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Transaction", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Transaction == nil {
+ m.Transaction = &v1alpha1.Transaction{}
+ }
+ if err := m.Transaction.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipView(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthView
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *AssetsRequest) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: AssetsRequest: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: AssetsRequest: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Filtered", wireType)
+ }
+ var v int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ v |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ m.Filtered = bool(v != 0)
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field IncludeSpecificDenominations", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ m.IncludeSpecificDenominations = append(m.IncludeSpecificDenominations, &v1alpha11.Denom{})
+ if err := m.IncludeSpecificDenominations[len(m.IncludeSpecificDenominations)-1].Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 3:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field IncludeDelegationTokens", wireType)
+ }
+ var v int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ v |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ m.IncludeDelegationTokens = bool(v != 0)
+ case 4:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field IncludeUnbondingTokens", wireType)
+ }
+ var v int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ v |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ m.IncludeUnbondingTokens = bool(v != 0)
+ case 5:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field IncludeLpNfts", wireType)
+ }
+ var v int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ v |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ m.IncludeLpNfts = bool(v != 0)
+ case 6:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field IncludeProposalNfts", wireType)
+ }
+ var v int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ v |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ m.IncludeProposalNfts = bool(v != 0)
+ case 7:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field IncludeVotingReceiptTokens", wireType)
+ }
+ var v int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ v |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ m.IncludeVotingReceiptTokens = bool(v != 0)
+ default:
+ iNdEx = preIndex
+ skippy, err := skipView(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthView
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *AssetsResponse) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: AssetsResponse: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: AssetsResponse: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field DenomMetadata", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.DenomMetadata == nil {
+ m.DenomMetadata = &v1alpha11.DenomMetadata{}
+ }
+ if err := m.DenomMetadata.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipView(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthView
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *ChainParametersRequest) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: ChainParametersRequest: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: ChainParametersRequest: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ default:
+ iNdEx = preIndex
+ skippy, err := skipView(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthView
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *ChainParametersResponse) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: ChainParametersResponse: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: ChainParametersResponse: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Parameters", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Parameters == nil {
+ m.Parameters = &v1alpha14.ChainParameters{}
+ }
+ if err := m.Parameters.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipView(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthView
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *FMDParametersRequest) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: FMDParametersRequest: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: FMDParametersRequest: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ default:
+ iNdEx = preIndex
+ skippy, err := skipView(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthView
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *FMDParametersResponse) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: FMDParametersResponse: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: FMDParametersResponse: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Parameters", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Parameters == nil {
+ m.Parameters = &v1alpha14.FmdParameters{}
+ }
+ if err := m.Parameters.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipView(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthView
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *NoteByCommitmentRequest) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: NoteByCommitmentRequest: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: NoteByCommitmentRequest: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field NoteCommitment", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.NoteCommitment == nil {
+ m.NoteCommitment = &v1alpha11.StateCommitment{}
+ }
+ if err := m.NoteCommitment.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 3:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field AwaitDetection", wireType)
+ }
+ var v int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ v |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ m.AwaitDetection = bool(v != 0)
+ case 14:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field AccountGroupId", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha11.AccountGroupId{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.XAccountGroupId = &NoteByCommitmentRequest_AccountGroupId{v}
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipView(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthView
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *NoteByCommitmentResponse) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: NoteByCommitmentResponse: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: NoteByCommitmentResponse: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field SpendableNote", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.SpendableNote == nil {
+ m.SpendableNote = &SpendableNoteRecord{}
+ }
+ if err := m.SpendableNote.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipView(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthView
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *SwapByCommitmentRequest) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: SwapByCommitmentRequest: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: SwapByCommitmentRequest: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field SwapCommitment", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.SwapCommitment == nil {
+ m.SwapCommitment = &v1alpha11.StateCommitment{}
+ }
+ if err := m.SwapCommitment.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 3:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field AwaitDetection", wireType)
+ }
+ var v int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ v |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ m.AwaitDetection = bool(v != 0)
+ case 14:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field AccountGroupId", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha11.AccountGroupId{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.XAccountGroupId = &SwapByCommitmentRequest_AccountGroupId{v}
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipView(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthView
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *SwapByCommitmentResponse) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: SwapByCommitmentResponse: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: SwapByCommitmentResponse: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Swap", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Swap == nil {
+ m.Swap = &SwapRecord{}
+ }
+ if err := m.Swap.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipView(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthView
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *NullifierStatusRequest) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: NullifierStatusRequest: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: NullifierStatusRequest: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Nullifier", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Nullifier == nil {
+ m.Nullifier = &v1alpha11.Nullifier{}
+ }
+ if err := m.Nullifier.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 3:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field AwaitDetection", wireType)
+ }
+ var v int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ v |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ m.AwaitDetection = bool(v != 0)
+ case 14:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field AccountGroupId", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha11.AccountGroupId{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.XAccountGroupId = &NullifierStatusRequest_AccountGroupId{v}
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipView(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthView
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *NullifierStatusResponse) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: NullifierStatusResponse: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: NullifierStatusResponse: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Spent", wireType)
+ }
+ var v int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ v |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ m.Spent = bool(v != 0)
+ default:
+ iNdEx = preIndex
+ skippy, err := skipView(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthView
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *TransactionInfoByHashRequest) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: TransactionInfoByHashRequest: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: TransactionInfoByHashRequest: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Id", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Id == nil {
+ m.Id = &v1alpha1.Id{}
+ }
+ if err := m.Id.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipView(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthView
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *TransactionInfoRequest) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: TransactionInfoRequest: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: TransactionInfoRequest: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field StartHeight", wireType)
+ }
+ var v uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ v |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ m.XStartHeight = &TransactionInfoRequest_StartHeight{v}
+ case 2:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field EndHeight", wireType)
+ }
+ var v uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ v |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ m.XEndHeight = &TransactionInfoRequest_EndHeight{v}
+ default:
+ iNdEx = preIndex
+ skippy, err := skipView(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthView
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *TransactionInfo) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: TransactionInfo: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: TransactionInfo: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Height", wireType)
+ }
+ var v uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ v |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ m.XHeight = &TransactionInfo_Height{v}
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Id", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Id == nil {
+ m.Id = &v1alpha1.Id{}
+ }
+ if err := m.Id.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Transaction", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Transaction == nil {
+ m.Transaction = &v1alpha1.Transaction{}
+ }
+ if err := m.Transaction.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 4:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Perspective", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Perspective == nil {
+ m.Perspective = &v1alpha1.TransactionPerspective{}
+ }
+ if err := m.Perspective.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 5:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field View", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.View == nil {
+ m.View = &v1alpha1.TransactionView{}
+ }
+ if err := m.View.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipView(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthView
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *TransactionInfoResponse) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: TransactionInfoResponse: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: TransactionInfoResponse: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field TxInfo", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.TxInfo == nil {
+ m.TxInfo = &TransactionInfo{}
+ }
+ if err := m.TxInfo.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipView(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthView
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *TransactionInfoByHashResponse) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: TransactionInfoByHashResponse: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: TransactionInfoByHashResponse: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field TxInfo", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.TxInfo == nil {
+ m.TxInfo = &TransactionInfo{}
+ }
+ if err := m.TxInfo.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipView(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthView
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *NotesResponse) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: NotesResponse: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: NotesResponse: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field NoteRecord", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.NoteRecord == nil {
+ m.NoteRecord = &SpendableNoteRecord{}
+ }
+ if err := m.NoteRecord.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipView(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthView
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *NotesForVotingResponse) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: NotesForVotingResponse: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: NotesForVotingResponse: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field NoteRecord", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.NoteRecord == nil {
+ m.NoteRecord = &SpendableNoteRecord{}
+ }
+ if err := m.NoteRecord.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field IdentityKey", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.IdentityKey == nil {
+ m.IdentityKey = &v1alpha11.IdentityKey{}
+ }
+ if err := m.IdentityKey.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipView(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthView
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *SpendableNoteRecord) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: SpendableNoteRecord: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: SpendableNoteRecord: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field NoteCommitment", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.NoteCommitment == nil {
+ m.NoteCommitment = &v1alpha11.StateCommitment{}
+ }
+ if err := m.NoteCommitment.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Note", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Note == nil {
+ m.Note = &v1alpha11.Note{}
+ }
+ if err := m.Note.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 3:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field AddressIndex", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.AddressIndex == nil {
+ m.AddressIndex = &v1alpha11.AddressIndex{}
+ }
+ if err := m.AddressIndex.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 4:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Nullifier", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Nullifier == nil {
+ m.Nullifier = &v1alpha11.Nullifier{}
+ }
+ if err := m.Nullifier.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 5:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field HeightCreated", wireType)
+ }
+ m.HeightCreated = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.HeightCreated |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 6:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field HeightSpent", wireType)
+ }
+ var v uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ v |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ m.XHeightSpent = &SpendableNoteRecord_HeightSpent{v}
+ case 7:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Position", wireType)
+ }
+ m.Position = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.Position |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 8:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Source", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Source == nil {
+ m.Source = &v1alpha14.NoteSource{}
+ }
+ if err := m.Source.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipView(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthView
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *SwapRecord) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: SwapRecord: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: SwapRecord: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field SwapCommitment", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.SwapCommitment == nil {
+ m.SwapCommitment = &v1alpha11.StateCommitment{}
+ }
+ if err := m.SwapCommitment.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Swap", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Swap == nil {
+ m.Swap = &v1alpha15.SwapPlaintext{}
+ }
+ if err := m.Swap.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 3:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Position", wireType)
+ }
+ m.Position = 0
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ m.Position |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ case 4:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Nullifier", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Nullifier == nil {
+ m.Nullifier = &v1alpha11.Nullifier{}
+ }
+ if err := m.Nullifier.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 5:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field OutputData", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.OutputData == nil {
+ m.OutputData = &v1alpha15.BatchSwapOutputData{}
+ }
+ if err := m.OutputData.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ case 6:
+ if wireType != 0 {
+ return fmt.Errorf("proto: wrong wireType = %d for field HeightClaimed", wireType)
+ }
+ var v uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ v |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ m.XHeightClaimed = &SwapRecord_HeightClaimed{v}
+ case 7:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field Source", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.Source == nil {
+ m.Source = &v1alpha14.NoteSource{}
+ }
+ if err := m.Source.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipView(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthView
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *OwnedPositionIdsRequest) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: OwnedPositionIdsRequest: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: OwnedPositionIdsRequest: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field PositionState", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha15.PositionState{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.XPositionState = &OwnedPositionIdsRequest_PositionState{v}
+ iNdEx = postIndex
+ case 2:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field TradingPair", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ v := &v1alpha15.TradingPair{}
+ if err := v.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ m.XTradingPair = &OwnedPositionIdsRequest_TradingPair{v}
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipView(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthView
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func (m *OwnedPositionIdsResponse) Unmarshal(dAtA []byte) error {
+ l := len(dAtA)
+ iNdEx := 0
+ for iNdEx < l {
+ preIndex := iNdEx
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= uint64(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ fieldNum := int32(wire >> 3)
+ wireType := int(wire & 0x7)
+ if wireType == 4 {
+ return fmt.Errorf("proto: OwnedPositionIdsResponse: wiretype end group for non-group")
+ }
+ if fieldNum <= 0 {
+ return fmt.Errorf("proto: OwnedPositionIdsResponse: illegal tag %d (wire type %d)", fieldNum, wire)
+ }
+ switch fieldNum {
+ case 1:
+ if wireType != 2 {
+ return fmt.Errorf("proto: wrong wireType = %d for field PositionId", wireType)
+ }
+ var msglen int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ msglen |= int(b&0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if msglen < 0 {
+ return ErrInvalidLengthView
+ }
+ postIndex := iNdEx + msglen
+ if postIndex < 0 {
+ return ErrInvalidLengthView
+ }
+ if postIndex > l {
+ return io.ErrUnexpectedEOF
+ }
+ if m.PositionId == nil {
+ m.PositionId = &v1alpha15.PositionId{}
+ }
+ if err := m.PositionId.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
+ return err
+ }
+ iNdEx = postIndex
+ default:
+ iNdEx = preIndex
+ skippy, err := skipView(dAtA[iNdEx:])
+ if err != nil {
+ return err
+ }
+ if (skippy < 0) || (iNdEx+skippy) < 0 {
+ return ErrInvalidLengthView
+ }
+ if (iNdEx + skippy) > l {
+ return io.ErrUnexpectedEOF
+ }
+ iNdEx += skippy
+ }
+ }
+
+ if iNdEx > l {
+ return io.ErrUnexpectedEOF
+ }
+ return nil
+}
+func skipView(dAtA []byte) (n int, err error) {
+ l := len(dAtA)
+ iNdEx := 0
+ depth := 0
+ for iNdEx < l {
+ var wire uint64
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return 0, ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return 0, io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ wire |= (uint64(b) & 0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ wireType := int(wire & 0x7)
+ switch wireType {
+ case 0:
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return 0, ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return 0, io.ErrUnexpectedEOF
+ }
+ iNdEx++
+ if dAtA[iNdEx-1] < 0x80 {
+ break
+ }
+ }
+ case 1:
+ iNdEx += 8
+ case 2:
+ var length int
+ for shift := uint(0); ; shift += 7 {
+ if shift >= 64 {
+ return 0, ErrIntOverflowView
+ }
+ if iNdEx >= l {
+ return 0, io.ErrUnexpectedEOF
+ }
+ b := dAtA[iNdEx]
+ iNdEx++
+ length |= (int(b) & 0x7F) << shift
+ if b < 0x80 {
+ break
+ }
+ }
+ if length < 0 {
+ return 0, ErrInvalidLengthView
+ }
+ iNdEx += length
+ case 3:
+ depth++
+ case 4:
+ if depth == 0 {
+ return 0, ErrUnexpectedEndOfGroupView
+ }
+ depth--
+ case 5:
+ iNdEx += 4
+ default:
+ return 0, fmt.Errorf("proto: illegal wireType %d", wireType)
+ }
+ if iNdEx < 0 {
+ return 0, ErrInvalidLengthView
+ }
+ if depth == 0 {
+ return iNdEx, nil
+ }
+ }
+ return 0, io.ErrUnexpectedEOF
+}
+
+var (
+ ErrInvalidLengthView = fmt.Errorf("proto: negative length found during unmarshaling")
+ ErrIntOverflowView = fmt.Errorf("proto: integer overflow")
+ ErrUnexpectedEndOfGroupView = fmt.Errorf("proto: unexpected end of group")
+)
diff --git a/relayer/chains/wasm/accounts.go b/relayer/chains/wasm/accounts.go
new file mode 100644
index 000000000..85a910fa9
--- /dev/null
+++ b/relayer/chains/wasm/accounts.go
@@ -0,0 +1,75 @@
+package wasm
+
+import (
+ "context"
+ "fmt"
+ "strconv"
+
+ "github.com/cosmos/cosmos-sdk/client"
+ sdk "github.com/cosmos/cosmos-sdk/types"
+ grpctypes "github.com/cosmos/cosmos-sdk/types/grpc"
+ authtypes "github.com/cosmos/cosmos-sdk/x/auth/types"
+ "google.golang.org/grpc"
+ "google.golang.org/grpc/metadata"
+)
+
+var _ client.AccountRetriever = &WasmProvider{}
+
+// GetAccount queries for an account given an address and a block height. An
+// error is returned if the query or decoding fails.
+func (cc *WasmProvider) GetAccount(clientCtx client.Context, addr sdk.AccAddress) (client.Account, error) {
+ account, _, err := cc.GetAccountWithHeight(clientCtx, addr)
+ return account, err
+}
+
+// GetAccountWithHeight queries for an account given an address. Returns the
+// height of the query with the account. An error is returned if the query
+// or decoding fails.
+func (cc *WasmProvider) GetAccountWithHeight(clientCtx client.Context, addr sdk.AccAddress) (client.Account, int64, error) {
+ var header metadata.MD
+ address, err := cc.EncodeBech32AccAddr(addr)
+ if err != nil {
+ return nil, 0, err
+ }
+
+ queryClient := authtypes.NewQueryClient(cc)
+ res, err := queryClient.Account(context.Background(), &authtypes.QueryAccountRequest{Address: address}, grpc.Header(&header))
+ if err != nil {
+ return nil, 0, err
+ }
+
+ blockHeight := header.Get(grpctypes.GRPCBlockHeightHeader)
+ if l := len(blockHeight); l != 1 {
+ return nil, 0, fmt.Errorf("unexpected '%s' header length; got %d, expected: %d", grpctypes.GRPCBlockHeightHeader, l, 1)
+ }
+
+ nBlockHeight, err := strconv.Atoi(blockHeight[0])
+ if err != nil {
+ return nil, 0, fmt.Errorf("failed to parse block height: %w", err)
+ }
+
+ var acc authtypes.AccountI
+ if err := cc.Cdc.InterfaceRegistry.UnpackAny(res.Account, &acc); err != nil {
+ return nil, 0, err
+ }
+
+ return acc, int64(nBlockHeight), nil
+}
+
+// EnsureExists returns an error if no account exists for the given address else nil.
+func (cc *WasmProvider) EnsureExists(clientCtx client.Context, addr sdk.AccAddress) error {
+ if _, err := cc.GetAccount(clientCtx, addr); err != nil {
+ return err
+ }
+ return nil
+}
+
+// GetAccountNumberSequence returns sequence and account number for the given address.
+// It returns an error if the account couldn't be retrieved from the state.
+func (cc *WasmProvider) GetAccountNumberSequence(clientCtx client.Context, addr sdk.AccAddress) (uint64, uint64, error) {
+ acc, err := cc.GetAccount(clientCtx, addr)
+ if err != nil {
+ return 0, 0, err
+ }
+ return acc.GetAccountNumber(), acc.GetSequence(), nil
+}
diff --git a/relayer/chains/wasm/codec.go b/relayer/chains/wasm/codec.go
new file mode 100644
index 000000000..dc96060b9
--- /dev/null
+++ b/relayer/chains/wasm/codec.go
@@ -0,0 +1,49 @@
+package wasm
+
+import (
+ "github.com/CosmWasm/wasmd/x/wasm"
+ "github.com/cosmos/cosmos-sdk/client"
+ "github.com/cosmos/cosmos-sdk/codec"
+ "github.com/cosmos/cosmos-sdk/codec/types"
+ "github.com/cosmos/cosmos-sdk/std"
+ "github.com/cosmos/cosmos-sdk/types/module"
+ "github.com/cosmos/cosmos-sdk/x/auth"
+ "github.com/cosmos/cosmos-sdk/x/auth/tx"
+ ibc "github.com/cosmos/ibc-go/v7/modules/core"
+ icon_module "github.com/cosmos/relayer/v2/relayer/chains/icon/module"
+ wasm_module "github.com/cosmos/relayer/v2/relayer/chains/wasm/module"
+)
+
+var ModuleBasics = []module.AppModuleBasic{
+ auth.AppModuleBasic{},
+ ibc.AppModuleBasic{},
+ wasm_module.AppModuleBasic{},
+ wasm.AppModuleBasic{},
+ icon_module.AppModuleBasic{},
+}
+
+type Codec struct {
+ InterfaceRegistry types.InterfaceRegistry
+ Marshaler codec.Codec
+ TxConfig client.TxConfig
+ Amino *codec.LegacyAmino
+}
+
+func MakeCodec(moduleBasics []module.AppModuleBasic, extraCodecs []string) Codec {
+ modBasic := module.NewBasicManager(moduleBasics...)
+ encodingConfig := MakeCodecConfig()
+ std.RegisterInterfaces(encodingConfig.InterfaceRegistry)
+ modBasic.RegisterInterfaces(encodingConfig.InterfaceRegistry)
+ return encodingConfig
+}
+
+func MakeCodecConfig() Codec {
+ interfaceRegistry := types.NewInterfaceRegistry()
+ marshaler := codec.NewProtoCodec(interfaceRegistry)
+ return Codec{
+ InterfaceRegistry: interfaceRegistry,
+ Marshaler: marshaler,
+ TxConfig: tx.NewTxConfig(marshaler, tx.DefaultSignModes),
+ Amino: codec.NewLegacyAmino(),
+ }
+}
diff --git a/relayer/chains/wasm/consts.go b/relayer/chains/wasm/consts.go
new file mode 100644
index 000000000..e68b1bd1e
--- /dev/null
+++ b/relayer/chains/wasm/consts.go
@@ -0,0 +1,36 @@
+package wasm
+
+const (
+ // External methods
+ MethodCreateClient = "create_client"
+ MethodUpdateClient = "update_client"
+ MethodConnectionOpenInit = "connection_open_init"
+ MethodConnectionOpenTry = "connection_open_try"
+ MethodConnectionOpenAck = "connection_open_ack"
+ MethodConnectionOpenConfirm = "connection_open_confirm"
+ MethodChannelOpenInit = "channel_open_init"
+ MethodChannelOpenTry = "channel_open_try"
+ MethodChannelOpenAck = "channel_open_ack"
+ MethodChannelOpenConfirm = "channel_open_confirm"
+ MethodChannelCloseInit = "channel_close_init"
+ MethodChannelCloseConfirm = "channel_close_confirm"
+ MethodSendPacket = "send_packet"
+ MethodRecvPacket = "receive_packet"
+ MethodWriteAcknowledgement = "write_acknowledgement"
+ MethodAcknowledgePacket = "acknowledgement_packet"
+ MethodTimeoutPacket = "timeout_packet"
+
+ MethodGetNextClientSequence = "get_next_client_sequence"
+ MethodGetNextChannelSequence = "get_next_channel_sequence"
+ MethodGetNextConnectionSequence = "get_next_connection_sequence"
+)
+
+const (
+ ClientPrefix = "iconclient"
+ ConnectionPrefix = "connection"
+ ChannelPrefix = "channel"
+)
+
+const (
+ ContractAddressSizeMinusPrefix = 59
+)
diff --git a/relayer/chains/wasm/event_parser.go b/relayer/chains/wasm/event_parser.go
new file mode 100644
index 000000000..bfdf3313b
--- /dev/null
+++ b/relayer/chains/wasm/event_parser.go
@@ -0,0 +1,532 @@
+package wasm
+
+import (
+ "encoding/base64"
+ "encoding/hex"
+ "fmt"
+ "strconv"
+ "strings"
+ "time"
+
+ abci "github.com/cometbft/cometbft/abci/types"
+ "github.com/cosmos/cosmos-sdk/types"
+ sdk "github.com/cosmos/cosmos-sdk/types"
+ clienttypes "github.com/cosmos/ibc-go/v7/modules/core/02-client/types"
+ conntypes "github.com/cosmos/ibc-go/v7/modules/core/03-connection/types"
+ chantypes "github.com/cosmos/ibc-go/v7/modules/core/04-channel/types"
+ "github.com/cosmos/relayer/v2/relayer/processor"
+ "github.com/cosmos/relayer/v2/relayer/provider"
+ "go.uber.org/zap"
+ "go.uber.org/zap/zapcore"
+)
+
+const (
+ wasmPrefix = "wasm-"
+ contractAddressName = "_contract_address"
+)
+
+// ibcMessage is the type used for parsing all possible properties of IBC messages
+type ibcMessage struct {
+ eventType string
+ info ibcMessageInfo
+}
+
+type ibcMessageInfo interface {
+ parseAttrs(log *zap.Logger, attrs []sdk.Attribute)
+ MarshalLogObject(enc zapcore.ObjectEncoder) error
+}
+
+// func (ccp *WasmChainProcessor) ibcMessagesFromBlockEvents(
+// beginBlockEvents, endBlockEvents []abci.Event,
+// height uint64, base64Encoded bool,
+// ) (res []ibcMessage) {
+// chainID := ccp.chainProvider.ChainId()
+// res = append(res, ibcMessagesFromEvents(ccp.log, beginBlockEvents, chainID, height, base64Encoded)...)
+// res = append(res, ibcMessagesFromEvents(ccp.log, endBlockEvents, chainID, height, base64Encoded)...)
+// return res
+// }
+
+func parseBase64Event(log *zap.Logger, event abci.Event) sdk.StringEvent {
+ evt := sdk.StringEvent{Type: event.Type}
+ for _, attr := range event.Attributes {
+ key, err := base64.StdEncoding.DecodeString(string(attr.Key))
+ if err != nil {
+ log.Error("Failed to decode legacy key as base64", zap.String("base64", string(attr.Key)), zap.Error(err))
+ continue
+ }
+ value, err := base64.StdEncoding.DecodeString(string(attr.Value))
+ if err != nil {
+ log.Error("Failed to decode legacy value as base64", zap.String("base64", string(attr.Value)), zap.Error(err))
+ continue
+ }
+ evt.Attributes = append(evt.Attributes, sdk.Attribute{
+ Key: string(key),
+ Value: string(value),
+ })
+ }
+ return evt
+}
+
+// ibcMessagesFromTransaction parses all events within a transaction to find IBC messages
+func ibcMessagesFromEvents(
+ log *zap.Logger,
+ events []abci.Event,
+ chainID string,
+ height uint64,
+ contractAddress string,
+ base64Encoded bool,
+) (messages []ibcMessage) {
+ for _, event := range events {
+ var evt sdk.StringEvent
+ if base64Encoded {
+ evt = parseBase64Event(log, event)
+ } else {
+ evt = sdk.StringifyEvent(event)
+
+ }
+ m := parseIBCMessageFromEvent(log, evt, chainID, height, contractAddress)
+ if m == nil || m.info == nil {
+ // Not an IBC message, don't need to log here
+ continue
+ }
+ messages = append(messages, *m)
+ }
+ return messages
+}
+
+func parseIBCMessageFromEvent(
+ log *zap.Logger,
+ event sdk.StringEvent,
+ chainID string,
+ height uint64,
+ contractAddress string,
+) *ibcMessage {
+
+ if len(event.Attributes) == 0 {
+ return nil
+ }
+
+ if !eventFromIBCContractAddress(event.Attributes[0], contractAddress) {
+ return nil
+ }
+
+ eventType := findEventType(event.Type)
+ attrs := event.Attributes[1:]
+ switch eventType {
+ case chantypes.EventTypeSendPacket, chantypes.EventTypeRecvPacket, chantypes.EventTypeWriteAck,
+ chantypes.EventTypeAcknowledgePacket, chantypes.EventTypeTimeoutPacket,
+ chantypes.EventTypeTimeoutPacketOnClose:
+ pi := &packetInfo{Height: height}
+ pi.parseAttrs(log, attrs)
+ return &ibcMessage{
+ eventType: eventType,
+ info: pi,
+ }
+ case chantypes.EventTypeChannelOpenInit, chantypes.EventTypeChannelOpenTry,
+ chantypes.EventTypeChannelOpenAck, chantypes.EventTypeChannelOpenConfirm,
+ chantypes.EventTypeChannelCloseInit, chantypes.EventTypeChannelCloseConfirm:
+ ci := &channelInfo{Height: height}
+ ci.parseAttrs(log, attrs)
+ return &ibcMessage{
+ eventType: eventType,
+ info: ci,
+ }
+
+ case conntypes.EventTypeConnectionOpenInit, conntypes.EventTypeConnectionOpenTry,
+ conntypes.EventTypeConnectionOpenAck, conntypes.EventTypeConnectionOpenConfirm:
+ ci := &connectionInfo{Height: height}
+ ci.parseAttrs(log, attrs)
+ return &ibcMessage{
+ eventType: eventType,
+ info: ci,
+ }
+
+ case clienttypes.EventTypeCreateClient, clienttypes.EventTypeUpdateClient,
+ clienttypes.EventTypeUpgradeClient, clienttypes.EventTypeSubmitMisbehaviour,
+ clienttypes.EventTypeUpdateClientProposal:
+ ci := new(clientInfo)
+ ci.parseAttrs(log, attrs)
+ return &ibcMessage{
+ eventType: eventType,
+ info: ci,
+ }
+
+ case string(processor.ClientICQTypeRequest), string(processor.ClientICQTypeResponse):
+ ci := &clientICQInfo{
+ Height: height,
+ Source: chainID,
+ }
+ ci.parseAttrs(log, attrs)
+ return &ibcMessage{
+ eventType: eventType,
+ info: ci,
+ }
+ }
+ return nil
+}
+
+func (msg *ibcMessage) parseIBCPacketReceiveMessageFromEvent(
+ log *zap.Logger,
+ event sdk.StringEvent,
+ chainID string,
+ height uint64,
+) *ibcMessage {
+ var pi *packetInfo
+ if msg.info == nil {
+ pi = &packetInfo{Height: height}
+ msg.info = pi
+ } else {
+ pi = msg.info.(*packetInfo)
+ }
+ pi.parseAttrs(log, event.Attributes)
+ if event.Type != chantypes.EventTypeWriteAck {
+ msg.eventType = event.Type
+ }
+ return msg
+}
+
+// clientInfo contains the consensus height of the counterparty chain for a client.
+type clientInfo struct {
+ clientID string
+ consensusHeight clienttypes.Height
+ header []byte
+}
+
+func (c clientInfo) ClientState(trustingPeriod time.Duration) provider.ClientState {
+ return provider.ClientState{
+ ClientID: c.clientID,
+ ConsensusHeight: c.consensusHeight,
+ TrustingPeriod: trustingPeriod,
+ Header: c.header,
+ }
+}
+
+func (res *clientInfo) MarshalLogObject(enc zapcore.ObjectEncoder) error {
+ enc.AddString("client_id", res.clientID)
+ enc.AddUint64("consensus_height", res.consensusHeight.RevisionHeight)
+ enc.AddUint64("consensus_height_revision", res.consensusHeight.RevisionNumber)
+ return nil
+}
+
+func (res *clientInfo) parseAttrs(log *zap.Logger, attributes []sdk.Attribute) {
+ for _, attr := range attributes {
+ res.parseClientAttribute(log, attr)
+ }
+}
+
+func (res *clientInfo) parseClientAttribute(log *zap.Logger, attr sdk.Attribute) {
+ switch attr.Key {
+ case clienttypes.AttributeKeyClientID:
+ res.clientID = attr.Value
+ case clienttypes.AttributeKeyConsensusHeight:
+ revisionSplit := strings.Split(attr.Value, "-")
+ if len(revisionSplit) != 2 {
+ log.Error("Error parsing client consensus height",
+ zap.String("client_id", res.clientID),
+ zap.String("value", attr.Value),
+ )
+ return
+ }
+ revisionNumberString := revisionSplit[0]
+ revisionNumber, err := strconv.ParseUint(revisionNumberString, 10, 64)
+ if err != nil {
+ log.Error("Error parsing client consensus height revision number",
+ zap.Error(err),
+ )
+ return
+ }
+ revisionHeightString := revisionSplit[1]
+ revisionHeight, err := strconv.ParseUint(revisionHeightString, 10, 64)
+ if err != nil {
+ log.Error("Error parsing client consensus height revision height",
+ zap.Error(err),
+ )
+ return
+ }
+ res.consensusHeight = clienttypes.Height{
+ RevisionNumber: revisionNumber,
+ RevisionHeight: revisionHeight,
+ }
+ case clienttypes.AttributeKeyHeader:
+ data, err := hex.DecodeString(attr.Value)
+ if err != nil {
+ log.Error("Error parsing client header",
+ zap.String("header", attr.Value),
+ zap.Error(err),
+ )
+ return
+ }
+ res.header = data
+ }
+}
+
+// alias type to the provider types, used for adding parser methods
+type packetInfo provider.PacketInfo
+
+func (res *packetInfo) MarshalLogObject(enc zapcore.ObjectEncoder) error {
+ enc.AddUint64("sequence", res.Sequence)
+ enc.AddString("src_channel", res.SourceChannel)
+ enc.AddString("src_port", res.SourcePort)
+ enc.AddString("dst_channel", res.DestChannel)
+ enc.AddString("dst_port", res.DestPort)
+ return nil
+}
+
+// parsePacketInfo is treated differently from the others since it can be constructed from the accumulation of multiple events
+func (res *packetInfo) parseAttrs(log *zap.Logger, attrs []sdk.Attribute) {
+ for _, attr := range attrs {
+ res.parsePacketAttribute(log, attr)
+ }
+}
+
+func (res *packetInfo) parsePacketAttribute(log *zap.Logger, attr sdk.Attribute) {
+ var err error
+ switch attr.Key {
+ case chantypes.AttributeKeySequence:
+ res.Sequence, err = strconv.ParseUint(attr.Value, 10, 64)
+ if err != nil {
+ log.Error("Error parsing packet sequence",
+ zap.String("value", attr.Value),
+ zap.Error(err),
+ )
+ return
+ }
+ case chantypes.AttributeKeyTimeoutTimestamp:
+ res.TimeoutTimestamp, err = strconv.ParseUint(attr.Value, 10, 64)
+ if err != nil {
+ log.Error("Error parsing packet timestamp",
+ zap.Uint64("sequence", res.Sequence),
+ zap.String("value", attr.Value),
+ zap.Error(err),
+ )
+ return
+ }
+ // NOTE: deprecated per IBC spec
+ case chantypes.AttributeKeyData:
+ res.Data = []byte(attr.Value)
+ case chantypes.AttributeKeyDataHex:
+ data, err := hex.DecodeString(attr.Value)
+ if err != nil {
+ log.Error("Error parsing packet data",
+ zap.Uint64("sequence", res.Sequence),
+ zap.Error(err),
+ )
+ return
+ }
+ res.Data = data
+ // NOTE: deprecated per IBC spec
+ case chantypes.AttributeKeyAck:
+ res.Ack = []byte(attr.Value)
+ case chantypes.AttributeKeyAckHex:
+ data, err := hex.DecodeString(attr.Value)
+ if err != nil {
+ log.Error("Error parsing packet ack",
+ zap.Uint64("sequence", res.Sequence),
+ zap.String("value", attr.Value),
+ zap.Error(err),
+ )
+ return
+ }
+ res.Ack = data
+ case chantypes.AttributeKeyTimeoutHeight:
+ timeoutSplit := strings.Split(attr.Value, "-")
+ if len(timeoutSplit) != 2 {
+ log.Error("Error parsing packet height timeout",
+ zap.Uint64("sequence", res.Sequence),
+ zap.String("value", attr.Value),
+ )
+ return
+ }
+ revisionNumber, err := strconv.ParseUint(timeoutSplit[0], 10, 64)
+ if err != nil {
+ log.Error("Error parsing packet timeout height revision number",
+ zap.Uint64("sequence", res.Sequence),
+ zap.String("value", timeoutSplit[0]),
+ zap.Error(err),
+ )
+ return
+ }
+ revisionHeight, err := strconv.ParseUint(timeoutSplit[1], 10, 64)
+ if err != nil {
+ log.Error("Error parsing packet timeout height revision height",
+ zap.Uint64("sequence", res.Sequence),
+ zap.String("value", timeoutSplit[1]),
+ zap.Error(err),
+ )
+ return
+ }
+ res.TimeoutHeight = clienttypes.Height{
+ RevisionNumber: revisionNumber,
+ RevisionHeight: revisionHeight,
+ }
+ case chantypes.AttributeKeySrcPort:
+ res.SourcePort = attr.Value
+ case chantypes.AttributeKeySrcChannel:
+ res.SourceChannel = attr.Value
+ case chantypes.AttributeKeyDstPort:
+ res.DestPort = attr.Value
+ case chantypes.AttributeKeyDstChannel:
+ res.DestChannel = attr.Value
+ case chantypes.AttributeKeyChannelOrdering:
+ res.ChannelOrder = attr.Value
+ }
+}
+
+// alias type to the provider types, used for adding parser methods
+type channelInfo provider.ChannelInfo
+
+func (res *channelInfo) MarshalLogObject(enc zapcore.ObjectEncoder) error {
+ enc.AddString("channel_id", res.ChannelID)
+ enc.AddString("port_id", res.PortID)
+ enc.AddString("counterparty_channel_id", res.CounterpartyChannelID)
+ enc.AddString("counterparty_port_id", res.CounterpartyPortID)
+ return nil
+}
+
+func (res *channelInfo) parseAttrs(log *zap.Logger, attrs []sdk.Attribute) {
+ for _, attr := range attrs {
+ res.parseChannelAttribute(attr)
+ }
+}
+
+// parseChannelAttribute parses channel attributes from an event.
+// If the attribute has already been parsed into the channelInfo,
+// it will not overwrite, and return true to inform the caller that
+// the attribute already exists.
+func (res *channelInfo) parseChannelAttribute(attr sdk.Attribute) {
+ switch attr.Key {
+ case chantypes.AttributeKeyPortID:
+ res.PortID = attr.Value
+ case chantypes.AttributeKeyChannelID:
+ res.ChannelID = attr.Value
+ case chantypes.AttributeCounterpartyPortID:
+ res.CounterpartyPortID = attr.Value
+ case chantypes.AttributeCounterpartyChannelID:
+ res.CounterpartyChannelID = attr.Value
+ case chantypes.AttributeKeyConnectionID:
+ res.ConnID = attr.Value
+ case chantypes.AttributeVersion:
+ res.Version = attr.Value
+ }
+}
+
+// alias type to the provider types, used for adding parser methods
+type connectionInfo provider.ConnectionInfo
+
+func (res *connectionInfo) MarshalLogObject(enc zapcore.ObjectEncoder) error {
+ enc.AddString("connection_id", res.ConnID)
+ enc.AddString("client_id", res.ClientID)
+ enc.AddString("counterparty_connection_id", res.CounterpartyConnID)
+ enc.AddString("counterparty_client_id", res.CounterpartyClientID)
+ return nil
+}
+
+func (res *connectionInfo) parseAttrs(log *zap.Logger, attrs []sdk.Attribute) {
+ for _, attr := range attrs {
+ res.parseConnectionAttribute(attr)
+ }
+}
+
+func (res *connectionInfo) parseConnectionAttribute(attr sdk.Attribute) {
+ switch attr.Key {
+ case conntypes.AttributeKeyConnectionID:
+ res.ConnID = attr.Value
+ case conntypes.AttributeKeyClientID:
+ res.ClientID = attr.Value
+ case conntypes.AttributeKeyCounterpartyConnectionID:
+ res.CounterpartyConnID = attr.Value
+ case conntypes.AttributeKeyCounterpartyClientID:
+ res.CounterpartyClientID = attr.Value
+ }
+}
+
+type clientICQInfo struct {
+ Source string
+ Connection string
+ Chain string
+ QueryID provider.ClientICQQueryID
+ Type string
+ Request []byte
+ Height uint64
+}
+
+func (res *clientICQInfo) MarshalLogObject(enc zapcore.ObjectEncoder) error {
+ enc.AddString("connection_id", res.Connection)
+ enc.AddString("chain_id", res.Chain)
+ enc.AddString("query_id", string(res.QueryID))
+ enc.AddString("type", res.Type)
+ enc.AddString("request", hex.EncodeToString(res.Request))
+ enc.AddUint64("height", res.Height)
+
+ return nil
+}
+
+func (res *clientICQInfo) parseAttrs(log *zap.Logger, attrs []sdk.Attribute) {
+ for _, attr := range attrs {
+ if err := res.parseAttribute(attr); err != nil {
+ panic(fmt.Errorf("failed to parse attributes from client ICQ message: %w", err))
+ }
+ }
+}
+
+func (res *clientICQInfo) parseAttribute(attr sdk.Attribute) (err error) {
+ switch attr.Key {
+ case "connection_id":
+ res.Connection = attr.Value
+ case "chain_id":
+ res.Chain = attr.Value
+ case "query_id":
+ res.QueryID = provider.ClientICQQueryID(attr.Value)
+ case "type":
+ res.Type = attr.Value
+ case "request":
+ res.Request, err = hex.DecodeString(attr.Value)
+ if err != nil {
+ return err
+ }
+ case "height":
+ res.Height, err = strconv.ParseUint(attr.Value, 10, 64)
+ if err != nil {
+ return err
+ }
+ }
+ return nil
+}
+
+func StringifyEvent(e abci.Event) types.StringEvent {
+ res := types.StringEvent{Type: e.Type}
+
+ for _, attr := range e.Attributes {
+ res.Attributes = append(
+ res.Attributes,
+ types.Attribute{Key: string(attr.Key), Value: string(attr.Value)},
+ )
+ }
+
+ return res
+}
+
+func findEventType(t string) string {
+ return strings.TrimPrefix(t, wasmPrefix)
+}
+
+func appendWasm(t string) string {
+ return fmt.Sprintf("%s%s", wasmPrefix, t)
+}
+
+func startsWithWasm(s string) bool {
+ if len(s) <= 5 {
+ return false
+ }
+ return s[:5] == wasmPrefix
+}
+
+func eventFromIBCContractAddress(attr types.Attribute, contractAddress string) bool {
+ if attr.Key != contractAddressName {
+ return false
+ }
+ if attr.Value == contractAddress {
+ return true
+ }
+ return false
+}
diff --git a/relayer/chains/wasm/event_parser_test.go b/relayer/chains/wasm/event_parser_test.go
new file mode 100644
index 000000000..f805816a1
--- /dev/null
+++ b/relayer/chains/wasm/event_parser_test.go
@@ -0,0 +1,52 @@
+package wasm
+
+import (
+ "testing"
+
+ "github.com/stretchr/testify/assert"
+)
+
+func TestWasmPrefix(t *testing.T) {
+ string := "wasm-create_client"
+ assert.Equal(t, wasmPrefix, string[:5])
+}
+
+// func TestEventParser(t *testing.T) {
+
+// addr := "https://rpc.constantine-2.archway.tech:443"
+// contract_address := "archway1w28yk5n5pjk8mjshxycu2lhhlcr8lzqnfc23mgtcsuzdwlv5cx2qemlcsd"
+// client, err := NewRPCClient(addr, 5*time.Second)
+// assert.NoError(t, err)
+// ctx := context.Background()
+// var h int64 = 1713974
+// rs, err := client.BlockResults(ctx, &h)
+// assert.NoError(t, err)
+
+// var m []ibcMessage
+// for _, tx := range rs.TxsResults {
+// if tx.Code != 0 {
+// // tx was not successful
+// continue
+// }
+// m = append(m, ibcMessagesFromEvents(&zap.Logger{}, tx.Events, "archway", 1711515, contract_address, true)...)
+// }
+
+// assert.Equal(t, len(m), 1)
+// ibcPacket := m[0]
+// assert.Equal(t, ibcPacket.eventType, chantypes.EventTypeSendPacket)
+// dummyInfo := &packetInfo{
+// Height: 1711515,
+// Sequence: 1811435,
+// SourcePort: "port-1",
+// SourceChannel: "channel-0",
+// DestPort: "port-1",
+// DestChannel: "channel-0",
+// ChannelOrder: "ORDER_UNORDERED",
+// Data: []byte{123, 34, 97, 109, 111, 117, 110, 116, 34, 58, 34, 49, 54, 49, 50, 55, 52, 34, 44, 34, 100, 101, 110, 111, 109, 34, 58, 34, 117, 97, 116, 111, 109, 34, 44, 34, 114, 101, 99, 101, 105, 118, 101, 114, 34, 58, 34, 111, 115, 109, 111, 49, 120, 52, 54, 102, 102, 52, 53, 99, 116, 107, 97, 107, 54, 114, 106, 113, 107, 97, 57, 117, 113, 118, 119, 113, 116, 52, 118, 104, 100, 114, 52, 53, 114, 112, 99, 55, 102, 51, 34, 44, 34, 115, 101, 110, 100, 101, 114, 34, 58, 34, 99, 111, 115, 109, 111, 115, 49, 120, 52, 54, 102, 102, 52, 53, 99, 116, 107, 97, 107, 54, 114, 106, 113, 107, 97, 57, 117, 113, 118, 119, 113, 116, 52, 118, 104, 100, 114, 52, 53, 116, 54, 116, 119, 108, 114, 34, 125},
+// TimeoutHeight: clienttypes.Height{RevisionHeight: 9454229, RevisionNumber: 1},
+// TimeoutTimestamp: 0,
+// Ack: nil,
+// }
+// assert.Equal(t, dummyInfo, ibcPacket.info)
+
+// }
diff --git a/relayer/chains/wasm/grpc_query.go b/relayer/chains/wasm/grpc_query.go
new file mode 100644
index 000000000..b81ac2b69
--- /dev/null
+++ b/relayer/chains/wasm/grpc_query.go
@@ -0,0 +1,215 @@
+package wasm
+
+import (
+ "context"
+ "fmt"
+ "reflect"
+ "strconv"
+ "sync"
+ "time"
+
+ abci "github.com/cometbft/cometbft/abci/types"
+ gogogrpc "github.com/cosmos/gogoproto/grpc"
+ "github.com/cosmos/relayer/v2/relayer/provider"
+ "google.golang.org/grpc"
+ "google.golang.org/grpc/codes"
+ "google.golang.org/grpc/encoding"
+ "google.golang.org/grpc/encoding/proto"
+ "google.golang.org/grpc/metadata"
+ "google.golang.org/grpc/status"
+
+ "github.com/cosmos/cosmos-sdk/codec/types"
+ sdk "github.com/cosmos/cosmos-sdk/types"
+ sdkerrors "github.com/cosmos/cosmos-sdk/types/errors"
+ grpctypes "github.com/cosmos/cosmos-sdk/types/grpc"
+ "github.com/cosmos/cosmos-sdk/types/tx"
+)
+
+var _ gogogrpc.ClientConn = &WasmProvider{}
+
+var protoCodec = encoding.GetCodec(proto.Name)
+
+// Invoke implements the grpc ClientConn.Invoke method
+func (ap *WasmProvider) Invoke(ctx context.Context, method string, req, reply interface{}, opts ...grpc.CallOption) (err error) {
+ // Two things can happen here:
+ // 1. either we're broadcasting a Tx, in which call we call Tendermint's broadcast endpoint directly,
+ // 2. or we are querying for state, in which case we call ABCI's Querier.
+
+ // In both cases, we don't allow empty request req (it will panic unexpectedly).
+ if reflect.ValueOf(req).IsNil() {
+ return sdkerrors.Wrap(sdkerrors.ErrInvalidRequest, "request cannot be nil")
+ }
+
+ // Case 1. Broadcasting a Tx.
+ if reqProto, ok := req.(*tx.BroadcastTxRequest); ok {
+ if !ok {
+ return sdkerrors.Wrapf(sdkerrors.ErrInvalidRequest, "expected %T, got %T", (*tx.BroadcastTxRequest)(nil), req)
+ }
+ resProto, ok := reply.(*tx.BroadcastTxResponse)
+ if !ok {
+ return sdkerrors.Wrapf(sdkerrors.ErrInvalidRequest, "expected %T, got %T", (*tx.BroadcastTxResponse)(nil), req)
+ }
+
+ broadcastRes, err := ap.TxServiceBroadcast(ctx, reqProto)
+ if err != nil {
+ return err
+ }
+ *resProto = *broadcastRes
+ return err
+ }
+
+ // Case 2. Querying state.
+ inMd, _ := metadata.FromOutgoingContext(ctx)
+ abciRes, outMd, err := ap.RunGRPCQuery(ctx, method, req, inMd)
+ if err != nil {
+ return err
+ }
+
+ if err = protoCodec.Unmarshal(abciRes.Value, reply); err != nil {
+ return err
+ }
+
+ for _, callOpt := range opts {
+ header, ok := callOpt.(grpc.HeaderCallOption)
+ if !ok {
+ continue
+ }
+
+ *header.HeaderAddr = outMd
+ }
+
+ if ap.Cdc.InterfaceRegistry != nil {
+ return types.UnpackInterfaces(reply, ap.Cdc.Marshaler)
+ }
+
+ return nil
+}
+
+// NewStream implements the grpc ClientConn.NewStream method
+func (ap *WasmProvider) NewStream(context.Context, *grpc.StreamDesc, string, ...grpc.CallOption) (grpc.ClientStream, error) {
+ return nil, fmt.Errorf("streaming rpc not supported")
+}
+
+// RunGRPCQuery runs a gRPC query from the clientCtx, given all necessary
+// arguments for the gRPC method, and returns the ABCI response. It is used
+// to factorize code between client (Invoke) and server (RegisterGRPCServer)
+// gRPC handlers.
+func (ap *WasmProvider) RunGRPCQuery(ctx context.Context, method string, req interface{}, md metadata.MD) (abci.ResponseQuery, metadata.MD, error) {
+ reqBz, err := protoCodec.Marshal(req)
+ if err != nil {
+ return abci.ResponseQuery{}, nil, err
+ }
+
+ // parse height header
+ if heights := md.Get(grpctypes.GRPCBlockHeightHeader); len(heights) > 0 {
+ height, err := strconv.ParseInt(heights[0], 10, 64)
+ if err != nil {
+ return abci.ResponseQuery{}, nil, err
+ }
+ if height < 0 {
+ return abci.ResponseQuery{}, nil, sdkerrors.Wrapf(
+ sdkerrors.ErrInvalidRequest,
+ "client.Context.Invoke: height (%d) from %q must be >= 0", height, grpctypes.GRPCBlockHeightHeader)
+ }
+
+ }
+
+ height, err := GetHeightFromMetadata(md)
+ if err != nil {
+ return abci.ResponseQuery{}, nil, err
+ }
+
+ prove, err := GetProveFromMetadata(md)
+ if err != nil {
+ return abci.ResponseQuery{}, nil, err
+ }
+
+ abciReq := abci.RequestQuery{
+ Path: method,
+ Data: reqBz,
+ Height: height,
+ Prove: prove,
+ }
+
+ abciRes, err := ap.QueryABCI(ctx, abciReq)
+ if err != nil {
+ return abci.ResponseQuery{}, nil, err
+ }
+
+ // Create header metadata. For now the headers contain:
+ // - block height
+ // We then parse all the call options, if the call option is a
+ // HeaderCallOption, then we manually set the value of that header to the
+ // metadata.
+ md = metadata.Pairs(grpctypes.GRPCBlockHeightHeader, strconv.FormatInt(abciRes.Height, 10))
+ return abciRes, md, nil
+}
+
+// TxServiceBroadcast is a helper function to broadcast a Tx with the correct gRPC types
+// from the tx service. Calls `clientCtx.BroadcastTx` under the hood.
+func (ap *WasmProvider) TxServiceBroadcast(ctx context.Context, req *tx.BroadcastTxRequest) (*tx.BroadcastTxResponse, error) {
+ if req == nil || req.TxBytes == nil {
+ return nil, status.Error(codes.InvalidArgument, "invalid empty tx")
+ }
+
+ var (
+ blockTimeout = defaultBroadcastWaitTimeout
+ err error
+ rlyResp *provider.RelayerTxResponse
+ callbackErr error
+ wg sync.WaitGroup
+ )
+
+ if ap.PCfg.BlockTimeout != "" {
+ blockTimeout, err = time.ParseDuration(ap.PCfg.BlockTimeout)
+ if err != nil {
+ // Did you call Validate() method on WasmProviderConfig struct
+ // before coming here?
+ return nil, err
+ }
+ }
+
+ callback := func(rtr *provider.RelayerTxResponse, err error) {
+ rlyResp = rtr
+ callbackErr = err
+ wg.Done()
+ }
+
+ wg.Add(1)
+
+ if err := ap.broadcastTx(ctx, req.TxBytes, nil, nil, ctx, blockTimeout, callback); err != nil {
+ return nil, err
+ }
+
+ wg.Wait()
+
+ if callbackErr != nil {
+ return nil, callbackErr
+ }
+
+ return &tx.BroadcastTxResponse{
+ TxResponse: &sdk.TxResponse{
+ Height: rlyResp.Height,
+ TxHash: rlyResp.TxHash,
+ Codespace: rlyResp.Codespace,
+ Code: rlyResp.Code,
+ Data: rlyResp.Data,
+ },
+ }, nil
+}
+
+func GetHeightFromMetadata(md metadata.MD) (int64, error) {
+ height := md.Get(grpctypes.GRPCBlockHeightHeader)
+ if len(height) == 1 {
+ return strconv.ParseInt(height[0], 10, 64)
+ }
+ return 0, nil
+}
+
+func GetProveFromMetadata(md metadata.MD) (bool, error) {
+ prove := md.Get("x-cosmos-query-prove")
+ if len(prove) == 1 {
+ return strconv.ParseBool(prove[0])
+ }
+ return false, nil
+}
diff --git a/relayer/chains/wasm/helper_debug_msg.go b/relayer/chains/wasm/helper_debug_msg.go
new file mode 100644
index 000000000..5ab3f0b8d
--- /dev/null
+++ b/relayer/chains/wasm/helper_debug_msg.go
@@ -0,0 +1,85 @@
+package wasm
+
+import (
+ "encoding/json"
+ "fmt"
+ "io/ioutil"
+ "os"
+ "path/filepath"
+
+ "github.com/cosmos/relayer/v2/relayer/chains/icon/types"
+ "github.com/cosmos/relayer/v2/relayer/provider"
+)
+
+var WasmDebugMessagePath = filepath.Join(os.Getenv("HOME"), ".relayer", "debug_wasm_msg_data.json")
+
+// for saving data in particular format
+func jsonDumpDataFile(filename string, bufs interface{}) {
+ // Marshal the slice of structs to JSON format
+ jsonData, err := json.MarshalIndent(bufs, "", " ")
+ if err != nil {
+ fmt.Println("Error marshaling slice of structs to JSON:", err)
+ os.Exit(1)
+ }
+
+ // Write JSON data to file
+ err = ioutil.WriteFile(filename, jsonData, 0644)
+ if err != nil {
+ fmt.Println("Error writing JSON to file:", err)
+ os.Exit(1)
+ }
+
+}
+
+func readExistingData(filename string, opPointer interface{}) error {
+
+ // Check if the JSON file exists
+ if _, err := os.Stat(filename); !os.IsNotExist(err) {
+ // Read existing JSON data from file
+ jsonData, err := ioutil.ReadFile(filename)
+ if err != nil {
+ return fmt.Errorf("Error reading JSON from file: %v", err)
+ }
+
+ if jsonData == nil {
+ return nil
+ }
+
+ // Unmarshal JSON data into a slice of structs
+ err = json.Unmarshal(jsonData, opPointer)
+ if err != nil {
+ return fmt.Errorf("Error unmarshaling JSON data: %v", err)
+ }
+ }
+
+ return nil
+}
+
+func SaveMsgToFile(filename string, msgs []provider.RelayerMessage) {
+ type DataFormat struct {
+ Step string `json:"step"`
+ Message types.HexBytes `json:"message"`
+ }
+
+ if len(msgs) == 0 {
+ return
+ }
+
+ var d []DataFormat
+ err := readExistingData(filename, &d)
+ if err != nil {
+ fmt.Println("error savingtoFile ", err)
+ return
+ }
+
+ // update on msg n will be added to n+1 message
+ for _, m := range msgs {
+ if m == nil {
+ continue
+ }
+ b, _ := m.MsgBytes()
+ d = append(d, DataFormat{Step: m.Type(), Message: types.NewHexBytes(b)})
+ // resetting update
+ }
+ jsonDumpDataFile(filename, d)
+}
diff --git a/relayer/chains/wasm/keys.go b/relayer/chains/wasm/keys.go
new file mode 100644
index 000000000..c7b8e2991
--- /dev/null
+++ b/relayer/chains/wasm/keys.go
@@ -0,0 +1,201 @@
+package wasm
+
+import (
+ "errors"
+ "os"
+
+ ckeys "github.com/cosmos/cosmos-sdk/client/keys"
+ "github.com/cosmos/cosmos-sdk/crypto/hd"
+ "github.com/cosmos/cosmos-sdk/crypto/keyring"
+ sdk "github.com/cosmos/cosmos-sdk/types"
+ "github.com/cosmos/go-bip39"
+ "github.com/cosmos/relayer/v2/relayer/codecs/ethermint"
+ "github.com/cosmos/relayer/v2/relayer/codecs/injective"
+ "github.com/cosmos/relayer/v2/relayer/provider"
+)
+
+const ethereumCoinType = uint32(60)
+
+var (
+ // SupportedAlgorithms defines the list of signing algorithms used on Evmos:
+ // - secp256k1 (Cosmos)
+ // - eth_secp256k1 (Ethereum)
+ SupportedAlgorithms = keyring.SigningAlgoList{hd.Secp256k1, ethermint.EthSecp256k1, injective.EthSecp256k1}
+ // SupportedAlgorithmsLedger defines the list of signing algorithms used on Evmos for the Ledger device:
+ // - secp256k1 (Cosmos)
+ // - eth_secp256k1 (Ethereum)
+ SupportedAlgorithmsLedger = keyring.SigningAlgoList{hd.Secp256k1, ethermint.EthSecp256k1, injective.EthSecp256k1}
+)
+
+// KeyringAlgoOptions defines a function keys options for the ethereum Secp256k1 curve.
+// It supports secp256k1 and eth_secp256k1 keys for accounts.
+func KeyringAlgoOptions() keyring.Option {
+ return func(options *keyring.Options) {
+ options.SupportedAlgos = SupportedAlgorithms
+ options.SupportedAlgosLedger = SupportedAlgorithmsLedger
+ }
+}
+
+// CreateKeystore initializes a new instance of a keyring at the specified path in the local filesystem.
+func (cc *WasmProvider) CreateKeystore(path string) error {
+ keybase, err := keyring.New(cc.PCfg.ChainID, cc.PCfg.KeyringBackend, cc.PCfg.KeyDirectory, cc.Input, cc.Cdc.Marshaler, KeyringAlgoOptions())
+ if err != nil {
+ return err
+ }
+ cc.Keybase = keybase
+ return nil
+}
+
+// KeystoreCreated returns true if there is an existing keystore instance at the specified path, it returns false otherwise.
+func (cc *WasmProvider) KeystoreCreated(path string) bool {
+ if _, err := os.Stat(cc.PCfg.KeyDirectory); errors.Is(err, os.ErrNotExist) {
+ return false
+ } else if cc.Keybase == nil {
+ return false
+ }
+ return true
+}
+
+// AddKey generates a new mnemonic which is then converted to a private key and BIP-39 HD Path and persists it to the keystore.
+// It fails if there is an existing key with the same address.
+func (cc *WasmProvider) AddKey(name string, coinType uint32, signingAlgorithm string, password string) (output *provider.KeyOutput, err error) {
+ ko, err := cc.KeyAddOrRestore(name, coinType)
+ if err != nil {
+ return nil, err
+ }
+ return ko, nil
+}
+
+// RestoreKey converts a mnemonic to a private key and BIP-39 HD Path and persists it to the keystore.
+// It fails if there is an existing key with the same address.
+func (cc *WasmProvider) RestoreKey(name, mnemonic string, coinType uint32, signingAlgorithm string) (address string, err error) {
+ ko, err := cc.KeyAddOrRestore(name, coinType, mnemonic)
+ if err != nil {
+ return "", err
+ }
+ return ko.Address, nil
+}
+
+// KeyAddOrRestore either generates a new mnemonic or uses the specified mnemonic and converts it to a private key
+// and BIP-39 HD Path which is then persisted to the keystore. It fails if there is an existing key with the same address.
+func (cc *WasmProvider) KeyAddOrRestore(keyName string, coinType uint32, mnemonic ...string) (*provider.KeyOutput, error) {
+ var mnemonicStr string
+ var err error
+ algo := keyring.SignatureAlgo(hd.Secp256k1)
+
+ if len(mnemonic) > 0 {
+ mnemonicStr = mnemonic[0]
+ } else {
+ mnemonicStr, err = CreateMnemonic()
+ if err != nil {
+ return nil, err
+ }
+ }
+
+ info, err := cc.Keybase.NewAccount(keyName, mnemonicStr, "", hd.CreateHDPath(coinType, 0, 0).String(), algo)
+ if err != nil {
+ return nil, err
+ }
+
+ acc, err := info.GetAddress()
+ if err != nil {
+ return nil, err
+ }
+
+ out, err := cc.EncodeBech32AccAddr(acc)
+ if err != nil {
+ return nil, err
+ }
+ return &provider.KeyOutput{Mnemonic: mnemonicStr, Address: out}, nil
+}
+
+// ShowAddress retrieves a key by name from the keystore and returns the bech32 encoded string representation of that key.
+func (cc *WasmProvider) ShowAddress(name string) (address string, err error) {
+ info, err := cc.Keybase.Key(name)
+ if err != nil {
+ return "", err
+ }
+ acc, err := info.GetAddress()
+ if err != nil {
+ return "", nil
+ }
+ out, err := cc.EncodeBech32AccAddr(acc)
+ if err != nil {
+ return "", err
+ }
+ return out, nil
+}
+
+// // ListAddresses returns a map of bech32 encoded strings representing all keys currently in the keystore.
+func (cc *WasmProvider) ListAddresses() (map[string]string, error) {
+ out := map[string]string{}
+ info, err := cc.Keybase.List()
+ if err != nil {
+ return nil, err
+ }
+ for _, k := range info {
+ acc, err := k.GetAddress()
+ if err != nil {
+ return nil, err
+ }
+ addr, err := cc.EncodeBech32AccAddr(acc)
+ if err != nil {
+ return nil, err
+ }
+ out[k.Name] = addr
+ }
+ return out, nil
+}
+
+// DeleteKey removes a key from the keystore for the specified name.
+func (cc *WasmProvider) DeleteKey(name string) error {
+ if err := cc.Keybase.Delete(name); err != nil {
+ return err
+ }
+ return nil
+}
+
+// KeyExists returns true if a key with the specified name exists in the keystore, it returns false otherwise.
+func (cc *WasmProvider) KeyExists(name string) bool {
+ k, err := cc.Keybase.Key(name)
+ if err != nil {
+ return false
+ }
+
+ return k.Name == name
+}
+
+// ExportPrivKeyArmor returns a private key in ASCII armored format.
+// It returns an error if the key does not exist or a wrong encryption passphrase is supplied.
+func (cc *WasmProvider) ExportPrivKeyArmor(keyName string) (armor string, err error) {
+ return cc.Keybase.ExportPrivKeyArmor(keyName, ckeys.DefaultKeyPass)
+}
+
+// GetKeyAddress returns the account address representation for the currently configured key.
+func (cc *WasmProvider) GetKeyAddress() (sdk.AccAddress, error) {
+ info, err := cc.Keybase.Key(cc.PCfg.Key)
+ if err != nil {
+ return nil, err
+ }
+ return info.GetAddress()
+}
+
+// CreateMnemonic generates a new mnemonic.
+func CreateMnemonic() (string, error) {
+ entropySeed, err := bip39.NewEntropy(256)
+ if err != nil {
+ return "", err
+ }
+ mnemonic, err := bip39.NewMnemonic(entropySeed)
+ if err != nil {
+ return "", err
+ }
+ return mnemonic, nil
+}
+
+// EncodeBech32AccAddr returns the string bech32 representation for the specified account address.
+// It returns an empty sting if the byte slice is 0-length.
+// It returns an error if the bech32 conversion fails or the prefix is empty.
+func (cc *WasmProvider) EncodeBech32AccAddr(addr sdk.AccAddress) (string, error) {
+ return sdk.Bech32ifyAddressBytes(cc.PCfg.AccountPrefix, addr)
+}
diff --git a/relayer/chains/wasm/message_handler.go b/relayer/chains/wasm/message_handler.go
new file mode 100644
index 000000000..716e0aa1b
--- /dev/null
+++ b/relayer/chains/wasm/message_handler.go
@@ -0,0 +1,203 @@
+package wasm
+
+import (
+ "context"
+ "encoding/hex"
+
+ conntypes "github.com/cosmos/ibc-go/v7/modules/core/03-connection/types"
+ chantypes "github.com/cosmos/ibc-go/v7/modules/core/04-channel/types"
+ "github.com/cosmos/relayer/v2/relayer/processor"
+ "github.com/cosmos/relayer/v2/relayer/provider"
+ "go.uber.org/zap"
+ "go.uber.org/zap/zapcore"
+)
+
+func (ccp *WasmChainProcessor) handleMessage(ctx context.Context, m ibcMessage, c processor.IBCMessagesCache) {
+ switch t := m.info.(type) {
+ case *packetInfo:
+ ccp.handlePacketMessage(m.eventType, provider.PacketInfo(*t), c)
+ case *channelInfo:
+ ccp.handleChannelMessage(m.eventType, provider.ChannelInfo(*t), c)
+ case *connectionInfo:
+ ccp.handleConnectionMessage(m.eventType, provider.ConnectionInfo(*t), c)
+ case *clientInfo:
+ ccp.handleClientMessage(ctx, m.eventType, *t)
+ case *clientICQInfo:
+ ccp.handleClientICQMessage(m.eventType, provider.ClientICQInfo(*t), c)
+ }
+}
+
+func (ccp *WasmChainProcessor) handlePacketMessage(eventType string, pi provider.PacketInfo, c processor.IBCMessagesCache) {
+ k, err := processor.PacketInfoChannelKey(eventType, pi)
+ if err != nil {
+ ccp.log.Error("Unexpected error handling packet message",
+ zap.String("event_type", eventType),
+ zap.Uint64("sequence", pi.Sequence),
+ zap.Inline(k),
+ zap.Error(err),
+ )
+ return
+ }
+
+ if eventType == chantypes.EventTypeTimeoutPacket && pi.ChannelOrder == chantypes.ORDERED.String() {
+ ccp.channelStateCache.SetOpen(k, false, chantypes.ORDERED)
+ }
+
+ if !c.PacketFlow.ShouldRetainSequence(ccp.pathProcessors, k, ccp.chainProvider.ChainId(), eventType, pi.Sequence) {
+ ccp.log.Debug("Not retaining packet message",
+ zap.String("event_type", eventType),
+ zap.Uint64("sequence", pi.Sequence),
+ zap.Inline(k),
+ )
+ return
+ }
+
+ ccp.log.Debug("Retaining packet message",
+ zap.String("event_type", eventType),
+ zap.Uint64("sequence", pi.Sequence),
+ zap.Inline(k),
+ )
+
+ c.PacketFlow.Retain(k, eventType, pi)
+ ccp.logPacketMessage(eventType, pi)
+}
+
+func (ccp *WasmChainProcessor) handleChannelMessage(eventType string, ci provider.ChannelInfo, ibcMessagesCache processor.IBCMessagesCache) {
+ ccp.channelConnections[ci.ChannelID] = ci.ConnID
+ channelKey := processor.ChannelInfoChannelKey(ci)
+
+ if eventType == chantypes.EventTypeChannelOpenInit {
+ found := false
+ for k := range ccp.channelStateCache {
+ // Don't add a channelKey to the channelStateCache without counterparty channel ID
+ // since we already have the channelKey in the channelStateCache which includes the
+ // counterparty channel ID.
+ if k.MsgInitKey() == channelKey {
+ found = true
+ break
+ }
+ }
+ if !found {
+ ccp.channelStateCache.SetOpen(channelKey, false, ci.Order)
+ }
+ } else {
+ switch eventType {
+ case chantypes.EventTypeChannelOpenTry:
+ ccp.channelStateCache.SetOpen(channelKey, false, ci.Order)
+ case chantypes.EventTypeChannelOpenAck, chantypes.EventTypeChannelOpenConfirm:
+ ccp.channelStateCache.SetOpen(channelKey, true, ci.Order)
+ case chantypes.EventTypeChannelCloseConfirm:
+ for k := range ccp.channelStateCache {
+ if k.PortID == ci.PortID && k.ChannelID == ci.ChannelID {
+ ccp.channelStateCache.SetOpen(k, false, ci.Order)
+ break
+ }
+ }
+ }
+ // Clear out MsgInitKeys once we have the counterparty channel ID
+ delete(ccp.channelStateCache, channelKey.MsgInitKey())
+ }
+
+ ibcMessagesCache.ChannelHandshake.Retain(channelKey, eventType, ci)
+
+ ccp.logChannelMessage(eventType, ci)
+}
+
+func (ccp *WasmChainProcessor) handleConnectionMessage(eventType string, ci provider.ConnectionInfo, ibcMessagesCache processor.IBCMessagesCache) {
+ ccp.connectionClients[ci.ConnID] = ci.ClientID
+ connectionKey := processor.ConnectionInfoConnectionKey(ci)
+ if eventType == conntypes.EventTypeConnectionOpenInit {
+ found := false
+ for k := range ccp.connectionStateCache {
+ // Don't add a connectionKey to the connectionStateCache without counterparty connection ID
+ // since we already have the connectionKey in the connectionStateCache which includes the
+ // counterparty connection ID.
+ if k.MsgInitKey() == connectionKey {
+ found = true
+ break
+ }
+ }
+ if !found {
+ ccp.connectionStateCache[connectionKey] = false
+ }
+ } else {
+ // Clear out MsgInitKeys once we have the counterparty connection ID
+ delete(ccp.connectionStateCache, connectionKey.MsgInitKey())
+ open := (eventType == conntypes.EventTypeConnectionOpenAck || eventType == conntypes.EventTypeConnectionOpenConfirm)
+ ccp.connectionStateCache[connectionKey] = open
+ }
+ ibcMessagesCache.ConnectionHandshake.Retain(connectionKey, eventType, ci)
+
+ ccp.logConnectionMessage(eventType, ci)
+}
+
+func (ccp *WasmChainProcessor) handleClientMessage(ctx context.Context, eventType string, ci clientInfo) {
+ ccp.latestClientState.update(ctx, ci, ccp)
+ ccp.logObservedIBCMessage(eventType, zap.String("client_id", ci.clientID))
+}
+
+func (ccp *WasmChainProcessor) handleClientICQMessage(
+ eventType string,
+ ci provider.ClientICQInfo,
+ c processor.IBCMessagesCache,
+) {
+ c.ClientICQ.Retain(processor.ClientICQType(eventType), ci)
+ ccp.logClientICQMessage(eventType, ci)
+}
+
+func (ccp *WasmChainProcessor) logObservedIBCMessage(m string, fields ...zap.Field) {
+ ccp.log.With(zap.String("event_type", m)).Debug("Observed IBC message", fields...)
+}
+
+func (ccp *WasmChainProcessor) logPacketMessage(message string, pi provider.PacketInfo) {
+ if !ccp.log.Core().Enabled(zapcore.DebugLevel) {
+ return
+ }
+ fields := []zap.Field{
+ zap.Uint64("sequence", pi.Sequence),
+ zap.String("src_channel", pi.SourceChannel),
+ zap.String("src_port", pi.SourcePort),
+ zap.String("dst_channel", pi.DestChannel),
+ zap.String("dst_port", pi.DestPort),
+ }
+ if pi.TimeoutHeight.RevisionHeight > 0 {
+ fields = append(fields, zap.Uint64("timeout_height", pi.TimeoutHeight.RevisionHeight))
+ }
+ if pi.TimeoutHeight.RevisionNumber > 0 {
+ fields = append(fields, zap.Uint64("timeout_height_revision", pi.TimeoutHeight.RevisionNumber))
+ }
+ if pi.TimeoutTimestamp > 0 {
+ fields = append(fields, zap.Uint64("timeout_timestamp", pi.TimeoutTimestamp))
+ }
+ ccp.logObservedIBCMessage(message, fields...)
+}
+
+func (ccp *WasmChainProcessor) logChannelMessage(message string, ci provider.ChannelInfo) {
+ ccp.logObservedIBCMessage(message,
+ zap.String("channel_id", ci.ChannelID),
+ zap.String("port_id", ci.PortID),
+ zap.String("counterparty_channel_id", ci.CounterpartyChannelID),
+ zap.String("counterparty_port_id", ci.CounterpartyPortID),
+ zap.String("connection_id", ci.ConnID),
+ )
+}
+
+func (ccp *WasmChainProcessor) logConnectionMessage(message string, ci provider.ConnectionInfo) {
+ ccp.logObservedIBCMessage(message,
+ zap.String("client_id", ci.ClientID),
+ zap.String("connection_id", ci.ConnID),
+ zap.String("counterparty_client_id", ci.CounterpartyClientID),
+ zap.String("counterparty_connection_id", ci.CounterpartyConnID),
+ )
+}
+
+func (ccp *WasmChainProcessor) logClientICQMessage(icqType string, ci provider.ClientICQInfo) {
+ ccp.logObservedIBCMessage(icqType,
+ zap.String("type", ci.Type),
+ zap.String("query_id", string(ci.QueryID)),
+ zap.String("request", hex.EncodeToString(ci.Request)),
+ zap.String("chain_id", ci.Chain),
+ zap.String("connection_id", ci.Connection),
+ zap.Uint64("height", ci.Height),
+ )
+}
diff --git a/relayer/chains/wasm/module/app_module.go b/relayer/chains/wasm/module/app_module.go
new file mode 100644
index 000000000..375e20b8c
--- /dev/null
+++ b/relayer/chains/wasm/module/app_module.go
@@ -0,0 +1,45 @@
+package module
+
+import (
+ "github.com/cosmos/cosmos-sdk/client"
+ "github.com/cosmos/cosmos-sdk/codec"
+ codectypes "github.com/cosmos/cosmos-sdk/codec/types"
+ "github.com/cosmos/ibc-go/v7/modules/core/exported"
+ "github.com/grpc-ecosystem/grpc-gateway/runtime"
+ "github.com/icon-project/IBC-Integration/libraries/go/common/tendermint"
+ "github.com/spf13/cobra"
+)
+
+// AppModuleBasic defines the basic application module used by the module.
+type AppModuleBasic struct{}
+
+// Name returns the module's name.
+func (AppModuleBasic) Name() string {
+ return "wasm_chain_provider"
+}
+
+// RegisterLegacyAminoCodec does nothing. IBC does not support amino.
+func (AppModuleBasic) RegisterLegacyAminoCodec(*codec.LegacyAmino) {}
+
+// RegisterInterfaces registers module concrete types into protobuf Any.
+func (AppModuleBasic) RegisterInterfaces(registry codectypes.InterfaceRegistry) {
+ registry.RegisterImplementations(
+ (*exported.ClientState)(nil),
+ &tendermint.ClientState{},
+ )
+}
+
+// RegisterGRPCGatewayRoutes registers the gRPC Gateway routes for the ibc module.
+func (AppModuleBasic) RegisterGRPCGatewayRoutes(clientCtx client.Context, mux *runtime.ServeMux) {
+ panic("not implemented")
+}
+
+// GetTxCmd returns the root tx command for the ibc module.
+func (AppModuleBasic) GetTxCmd() *cobra.Command {
+ panic("not implemented")
+}
+
+// GetQueryCmd returns no root query command for the ibc module.
+func (AppModuleBasic) GetQueryCmd() *cobra.Command {
+ panic("not implemented")
+}
diff --git a/relayer/chains/wasm/msg.go b/relayer/chains/wasm/msg.go
new file mode 100644
index 000000000..eb9ae8c5c
--- /dev/null
+++ b/relayer/chains/wasm/msg.go
@@ -0,0 +1,80 @@
+package wasm
+
+import (
+ "fmt"
+
+ wasmtypes "github.com/CosmWasm/wasmd/x/wasm/types"
+ "github.com/cosmos/cosmos-sdk/codec"
+ sdk "github.com/cosmos/cosmos-sdk/types"
+ "github.com/cosmos/gogoproto/proto"
+ "github.com/cosmos/relayer/v2/relayer/chains/wasm/types"
+ "github.com/cosmos/relayer/v2/relayer/provider"
+)
+
+type WasmContractMessage struct {
+ Msg *wasmtypes.MsgExecuteContract
+ Method string
+ MessageBytes []byte
+}
+
+func (w *WasmContractMessage) Type() string {
+ return w.Method
+}
+
+func (w *WasmContractMessage) MsgBytes() ([]byte, error) {
+ if w.MessageBytes != nil {
+ return w.MessageBytes, nil
+ }
+ return nil, fmt.Errorf("Invalid format")
+}
+
+func (ap *WasmProvider) NewWasmContractMessage(method string, m codec.ProtoMarshaler) (provider.RelayerMessage, error) {
+ signer, _ := ap.Address()
+ contract := ap.PCfg.IbcHandlerAddress
+
+ protoMsg, err := ap.Cdc.Marshaler.Marshal(m)
+ if err != nil {
+ return nil, err
+ }
+ // ap.log.Debug("Wasm Constructed message ", zap.String("MethodName", method), zap.Any("Message", types.NewHexBytes(protoMsg)))
+
+ msgParam, err := types.GenerateTxnParams(method, types.NewHexBytes(protoMsg))
+
+ if err != nil {
+ return nil, err
+ }
+
+ return &WasmContractMessage{
+ Method: method,
+ Msg: &wasmtypes.MsgExecuteContract{
+ Sender: signer,
+ Contract: contract,
+ Msg: msgParam,
+ },
+ MessageBytes: protoMsg,
+ }, nil
+}
+
+type WasmMessage struct {
+ Msg sdk.Msg
+}
+
+func (am WasmMessage) Type() string {
+ return sdk.MsgTypeURL(am.Msg)
+}
+
+func (am WasmMessage) MsgBytes() ([]byte, error) {
+ return proto.Marshal(am.Msg)
+}
+
+func WasmMsgs(rm ...provider.RelayerMessage) []sdk.Msg {
+ sdkMsgs := make([]sdk.Msg, 0)
+ for _, rMsg := range rm {
+ if val, ok := rMsg.(WasmMessage); !ok {
+ return nil
+ } else {
+ sdkMsgs = append(sdkMsgs, val.Msg)
+ }
+ }
+ return sdkMsgs
+}
diff --git a/relayer/chains/wasm/provider.go b/relayer/chains/wasm/provider.go
new file mode 100644
index 000000000..c3ad74207
--- /dev/null
+++ b/relayer/chains/wasm/provider.go
@@ -0,0 +1,505 @@
+package wasm
+
+import (
+ "context"
+ "fmt"
+ "io"
+ "os"
+ "path"
+ "sync"
+ "time"
+
+ "github.com/CosmWasm/wasmd/app"
+ provtypes "github.com/cometbft/cometbft/light/provider"
+ comettypes "github.com/cometbft/cometbft/types"
+
+ "github.com/cosmos/cosmos-sdk/client"
+ itm "github.com/icon-project/IBC-Integration/libraries/go/common/tendermint"
+
+ wasmtypes "github.com/CosmWasm/wasmd/x/wasm/types"
+ authtypes "github.com/cosmos/cosmos-sdk/x/auth/types"
+
+ prov "github.com/cometbft/cometbft/light/provider/http"
+
+ "github.com/cosmos/cosmos-sdk/crypto/keyring"
+ "github.com/cosmos/cosmos-sdk/types/bech32"
+ "github.com/cosmos/cosmos-sdk/types/module"
+ "github.com/cosmos/gogoproto/proto"
+ commitmenttypes "github.com/cosmos/ibc-go/v7/modules/core/23-commitment/types"
+ ibcexported "github.com/cosmos/ibc-go/v7/modules/core/exported"
+ "github.com/cosmos/relayer/v2/relayer/codecs/ethermint"
+ "github.com/cosmos/relayer/v2/relayer/processor"
+ "github.com/cosmos/relayer/v2/relayer/provider"
+
+ rpcclient "github.com/cometbft/cometbft/rpc/client"
+ rpchttp "github.com/cometbft/cometbft/rpc/client/http"
+ ctypes "github.com/cometbft/cometbft/rpc/core/types"
+
+ "go.uber.org/zap"
+)
+
+var (
+ _ provider.ChainProvider = &WasmProvider{}
+ _ provider.KeyProvider = &WasmProvider{}
+ _ provider.ProviderConfig = &WasmProviderConfig{}
+)
+
+type WasmProviderConfig struct {
+ KeyDirectory string `json:"key-directory" yaml:"key-directory"`
+ Key string `json:"key" yaml:"key"`
+ ChainName string `json:"-" yaml:"-"`
+ ChainID string `json:"chain-id" yaml:"chain-id"`
+ RPCAddr string `json:"rpc-addr" yaml:"rpc-addr"`
+ AccountPrefix string `json:"account-prefix" yaml:"account-prefix"`
+ KeyringBackend string `json:"keyring-backend" yaml:"keyring-backend"`
+ GasAdjustment float64 `json:"gas-adjustment" yaml:"gas-adjustment"`
+ GasPrices string `json:"gas-prices" yaml:"gas-prices"`
+ MinGasAmount uint64 `json:"min-gas-amount" yaml:"min-gas-amount"`
+ Debug bool `json:"debug" yaml:"debug"`
+ Timeout string `json:"timeout" yaml:"timeout"`
+ BlockTimeout string `json:"block-timeout" yaml:"block-timeout"`
+ OutputFormat string `json:"output-format" yaml:"output-format"`
+ SignModeStr string `json:"sign-mode" yaml:"sign-mode"`
+ ExtraCodecs []string `json:"extra-codecs" yaml:"extra-codecs"`
+ Modules []module.AppModuleBasic `json:"-" yaml:"-"`
+ Slip44 int `json:"coin-type" yaml:"coin-type"`
+ Broadcast provider.BroadcastMode `json:"broadcast-mode" yaml:"broadcast-mode"`
+ IbcHandlerAddress string `json:"ibc-handler-address" yaml:"ibc-handler-address"`
+ FirstRetryBlockAfter uint64 `json:"first-retry-block-after" yaml:"first-retry-block-after"`
+ StartHeight uint64 `json:"start-height" yaml:"start-height"`
+ BlockInterval uint64 `json:"block-interval" yaml:"block-interval"`
+}
+
+type WasmIBCHeader struct {
+ SignedHeader *itm.SignedHeader
+ ValidatorSet *itm.ValidatorSet
+}
+
+func NewWasmIBCHeader(header *itm.SignedHeader, validators *itm.ValidatorSet) WasmIBCHeader {
+ return WasmIBCHeader{
+ SignedHeader: header,
+ ValidatorSet: validators,
+ }
+}
+
+func NewWasmIBCHeaderFromLightBlock(lightBlock *comettypes.LightBlock) WasmIBCHeader {
+ vSets := make([]*itm.Validator, 0)
+ for _, v := range lightBlock.ValidatorSet.Validators {
+ _v := &itm.Validator{
+ Address: v.Address,
+ PubKey: &itm.PublicKey{
+ Sum: itm.GetPubKeyFromTx(v.PubKey.Type(), v.PubKey.Bytes()),
+ },
+ VotingPower: v.VotingPower,
+ ProposerPriority: v.ProposerPriority,
+ }
+
+ vSets = append(vSets, _v)
+ }
+
+ signatures := make([]*itm.CommitSig, 0)
+ for _, d := range lightBlock.Commit.Signatures {
+
+ _d := &itm.CommitSig{
+ BlockIdFlag: itm.BlockIDFlag(d.BlockIDFlag),
+ ValidatorAddress: d.ValidatorAddress,
+ Timestamp: &itm.Timestamp{
+ Seconds: int64(d.Timestamp.Unix()),
+ Nanos: int32(d.Timestamp.Nanosecond()),
+ },
+ Signature: d.Signature,
+ }
+ signatures = append(signatures, _d)
+ }
+
+ return WasmIBCHeader{
+ SignedHeader: &itm.SignedHeader{
+ Header: &itm.LightHeader{
+ Version: &itm.Consensus{
+ Block: lightBlock.Version.Block,
+ App: lightBlock.Version.App,
+ },
+ ChainId: lightBlock.ChainID,
+
+ Height: lightBlock.Height,
+ Time: &itm.Timestamp{
+ Seconds: int64(lightBlock.Time.Unix()),
+ Nanos: int32(lightBlock.Time.Nanosecond()), // this is the offset after the nanosecond
+ },
+ LastBlockId: &itm.BlockID{
+ Hash: lightBlock.LastBlockID.Hash,
+ PartSetHeader: &itm.PartSetHeader{
+ Total: lightBlock.LastBlockID.PartSetHeader.Total,
+ Hash: lightBlock.LastBlockID.PartSetHeader.Hash,
+ },
+ },
+ LastCommitHash: lightBlock.LastCommitHash,
+ DataHash: lightBlock.DataHash,
+ ValidatorsHash: lightBlock.ValidatorsHash,
+ NextValidatorsHash: lightBlock.NextValidatorsHash,
+ ConsensusHash: lightBlock.ConsensusHash,
+ AppHash: lightBlock.AppHash,
+ LastResultsHash: lightBlock.LastResultsHash,
+ EvidenceHash: lightBlock.EvidenceHash,
+ ProposerAddress: lightBlock.ProposerAddress,
+ },
+ Commit: &itm.Commit{
+ Height: lightBlock.Commit.Height,
+ Round: lightBlock.Commit.Round,
+ BlockId: &itm.BlockID{
+ Hash: lightBlock.Commit.BlockID.Hash,
+ PartSetHeader: &itm.PartSetHeader{
+ Total: lightBlock.Commit.BlockID.PartSetHeader.Total,
+ Hash: lightBlock.Commit.BlockID.PartSetHeader.Hash,
+ },
+ },
+ Signatures: signatures,
+ },
+ },
+ ValidatorSet: &itm.ValidatorSet{
+ Validators: vSets,
+ },
+ }
+}
+
+func (h WasmIBCHeader) ConsensusState() ibcexported.ConsensusState {
+ return &itm.ConsensusState{
+ Timestamp: h.SignedHeader.Header.Time,
+ Root: &itm.MerkleRoot{Hash: h.SignedHeader.Header.AppHash},
+ NextValidatorsHash: h.SignedHeader.Header.NextValidatorsHash,
+ }
+}
+
+func (a WasmIBCHeader) Height() uint64 {
+ return uint64(a.SignedHeader.Header.Height)
+}
+
+func (a WasmIBCHeader) IsCompleteBlock() bool {
+ return true
+}
+
+func (a WasmIBCHeader) NextValidatorsHash() []byte {
+ return a.SignedHeader.Header.NextValidatorsHash
+}
+
+func (a WasmIBCHeader) ShouldUpdateWithZeroMessage() bool {
+ return false
+}
+
+func (pp *WasmProviderConfig) ValidateContractAddress(addr string) bool {
+ prefix, _, err := bech32.DecodeAndConvert(addr)
+ if err != nil {
+ return false
+ }
+ if pp.AccountPrefix != prefix {
+ return false
+ }
+
+ // TODO: Is this needed?
+ // Confirmed working for neutron, archway, osmosis
+ prefixLen := len(pp.AccountPrefix)
+ if len(addr) != prefixLen+ContractAddressSizeMinusPrefix {
+ return false
+ }
+
+ return true
+}
+
+func (pp *WasmProviderConfig) Validate() error {
+ if _, err := time.ParseDuration(pp.Timeout); err != nil {
+ return fmt.Errorf("invalid Timeout: %w", err)
+ }
+
+ if !pp.ValidateContractAddress(pp.IbcHandlerAddress) {
+ return fmt.Errorf("Invalid contract address")
+ }
+
+ if pp.BlockInterval == 0 {
+ return fmt.Errorf("Block interval cannot be zero")
+ }
+
+ return nil
+}
+
+func (pp *WasmProviderConfig) getRPCAddr() string {
+ return pp.RPCAddr
+}
+
+func (pp *WasmProviderConfig) BroadcastMode() provider.BroadcastMode {
+ return pp.Broadcast
+}
+
+func (pp *WasmProviderConfig) GetBlockInterval() uint64 {
+ return pp.BlockInterval
+}
+
+func (pp *WasmProviderConfig) GetFirstRetryBlockAfter() uint64 {
+ if pp.FirstRetryBlockAfter != 0 {
+ return pp.FirstRetryBlockAfter
+ }
+ return 3
+}
+
+func (pc *WasmProviderConfig) NewProvider(log *zap.Logger, homepath string, debug bool, chainName string) (provider.ChainProvider, error) {
+ if err := pc.Validate(); err != nil {
+ return nil, err
+ }
+
+ pc.KeyDirectory = keysDir(homepath, pc.ChainID)
+
+ pc.ChainName = chainName
+ pc.Modules = append([]module.AppModuleBasic{}, ModuleBasics...)
+
+ if pc.Broadcast == "" {
+ pc.Broadcast = provider.BroadcastModeBatch
+ }
+
+ cp := &WasmProvider{
+ log: log,
+ PCfg: pc,
+ KeyringOptions: []keyring.Option{ethermint.EthSecp256k1Option()},
+ Input: os.Stdin,
+ Output: os.Stdout,
+
+ // TODO: this is a bit of a hack, we should probably have a better way to inject modules
+ Cdc: MakeCodec(pc.Modules, pc.ExtraCodecs),
+ }
+
+ return cp, nil
+}
+
+type WasmProvider struct {
+ log *zap.Logger
+
+ PCfg *WasmProviderConfig
+ Keybase keyring.Keyring
+ KeyringOptions []keyring.Option
+ RPCClient rpcclient.Client
+ QueryClient wasmtypes.QueryClient
+ LightProvider provtypes.Provider
+ Cdc Codec
+ Input io.Reader
+ Output io.Writer
+ ClientCtx client.Context
+
+ nextAccountSeq uint64
+ txMu sync.Mutex
+
+ metrics *processor.PrometheusMetrics
+
+ // for comet < v0.37, decode tm events as base64
+ cometLegacyEncoding bool
+}
+
+func (ap *WasmProvider) ProviderConfig() provider.ProviderConfig {
+ return ap.PCfg
+}
+
+func (ap *WasmProvider) ChainId() string {
+ return ap.PCfg.ChainID
+}
+
+func (ap *WasmProvider) ChainName() string {
+ return ap.PCfg.ChainName
+}
+
+func (ap *WasmProvider) Type() string {
+ return "wasm"
+}
+
+func (ap *WasmProvider) Key() string {
+ return ap.PCfg.Key
+}
+
+func (ap *WasmProvider) Timeout() string {
+ return ap.PCfg.Timeout
+}
+
+// CommitmentPrefix returns the commitment prefix for Cosmos
+func (ap *WasmProvider) CommitmentPrefix() commitmenttypes.MerklePrefix {
+ ctx := context.Background()
+ b, _ := ap.GetCommitmentPrefixFromContract(ctx)
+ return commitmenttypes.NewMerklePrefix(b)
+}
+
+func (ap *WasmProvider) Init(ctx context.Context) error {
+ keybase, err := keyring.New(ap.PCfg.ChainID, ap.PCfg.KeyringBackend, ap.PCfg.KeyDirectory, ap.Input, ap.Cdc.Marshaler, ap.KeyringOptions...)
+ if err != nil {
+ return err
+ }
+ ap.Keybase = keybase
+
+ timeout, err := time.ParseDuration(ap.PCfg.Timeout)
+ if err != nil {
+ return err
+ }
+
+ rpcClient, err := NewRPCClient(ap.PCfg.RPCAddr, timeout)
+ if err != nil {
+ return err
+ }
+ ap.RPCClient = rpcClient
+
+ lightprovider, err := prov.New(ap.PCfg.ChainID, ap.PCfg.RPCAddr)
+ if err != nil {
+ return err
+ }
+ ap.LightProvider = lightprovider
+
+ clientCtx := client.Context{}.
+ WithClient(rpcClient).
+ WithFromName(ap.PCfg.Key).
+ WithTxConfig(app.MakeEncodingConfig().TxConfig).
+ WithSkipConfirmation(true).
+ WithBroadcastMode("sync").
+ WithCodec(ap.Cdc.Marshaler).
+ WithInterfaceRegistry(ap.Cdc.InterfaceRegistry).
+ WithAccountRetriever(authtypes.AccountRetriever{})
+
+ addr, _ := ap.GetKeyAddress()
+ if addr != nil {
+ clientCtx = clientCtx.
+ WithFromAddress(addr)
+
+ }
+
+ ap.QueryClient = wasmtypes.NewQueryClient(clientCtx)
+ ap.ClientCtx = clientCtx
+ return nil
+}
+
+func (ap *WasmProvider) Address() (string, error) {
+ info, err := ap.Keybase.Key(ap.PCfg.Key)
+ if err != nil {
+ return "", err
+ }
+
+ acc, err := info.GetAddress()
+ if err != nil {
+ return "", err
+ }
+
+ out, err := ap.EncodeBech32AccAddr(acc)
+ if err != nil {
+ return "", err
+ }
+
+ return out, err
+}
+
+// TODO: CHECK AGAIN
+func (cc *WasmProvider) TrustingPeriod(ctx context.Context) (time.Duration, error) {
+ panic(fmt.Sprintf("%s%s", cc.ChainName(), NOT_IMPLEMENTED))
+ // res, err := cc.QueryStakingParams(ctx)
+
+ // TODO: check and rewrite
+ // var unbondingTime time.Duration
+ // if err != nil {
+ // // Attempt ICS query
+ // consumerUnbondingPeriod, consumerErr := cc.queryConsumerUnbondingPeriod(ctx)
+ // if consumerErr != nil {
+ // return 0,
+ // fmt.Errorf("failed to query unbonding period as both standard and consumer chain: %s: %w", err.Error(), consumerErr)
+ // }
+ // unbondingTime = consumerUnbondingPeriod
+ // } else {
+ // unbondingTime = res.UnbondingTime
+ // }
+
+ // // We want the trusting period to be 85% of the unbonding time.
+ // // Go mentions that the time.Duration type can track approximately 290 years.
+ // // We don't want to lose precision if the duration is a very long duration
+ // // by converting int64 to float64.
+ // // Use integer math the whole time, first reducing by a factor of 100
+ // // and then re-growing by 85x.
+ // tp := unbondingTime / 100 * 85
+
+ // // And we only want the trusting period to be whole hours.
+ // // But avoid rounding if the time is less than 1 hour
+ // // (otherwise the trusting period will go to 0)
+ // if tp > time.Hour {
+ // tp = tp.Truncate(time.Hour)
+ // }
+ // return tp, nil
+}
+
+func (cc *WasmProvider) Sprint(toPrint proto.Message) (string, error) {
+ out, err := cc.Cdc.Marshaler.MarshalJSON(toPrint)
+ if err != nil {
+ return "", err
+ }
+ return string(out), nil
+}
+
+func (cc *WasmProvider) QueryStatus(ctx context.Context) (*ctypes.ResultStatus, error) {
+ status, err := cc.RPCClient.Status(ctx)
+ if err != nil {
+ return nil, fmt.Errorf("failed to query node status: %w", err)
+ }
+ return status, nil
+}
+
+// WaitForNBlocks blocks until the next block on a given chain
+func (cc *WasmProvider) WaitForNBlocks(ctx context.Context, n int64) error {
+ panic(fmt.Sprintf("%s%s", cc.ChainName(), NOT_IMPLEMENTED))
+ // var initial int64
+ // h, err := cc.RPCClient.Status(ctx)
+ // if err != nil {
+ // return err
+ // }
+ // if h.SyncInfo.CatchingUp {
+ // return fmt.Errorf("chain catching up")
+ // }
+ // initial = h.SyncInfo.LatestBlockHeight
+ // for {
+ // h, err = cc.RPCClient.Status(ctx)
+ // if err != nil {
+ // return err
+ // }
+ // if h.SyncInfo.LatestBlockHeight > initial+n {
+ // return nil
+ // }
+ // select {
+ // case <-time.After(10 * time.Millisecond):
+ // // Nothing to do.
+ // case <-ctx.Done():
+ // return ctx.Err()
+ // }
+ // }
+}
+
+func (ac *WasmProvider) BlockTime(ctx context.Context, height int64) (time.Time, error) {
+ resultBlock, err := ac.RPCClient.Block(ctx, &height)
+ if err != nil {
+ return time.Time{}, err
+ }
+ return resultBlock.Block.Time, nil
+}
+
+func (ac *WasmProvider) Codec() Codec {
+ return ac.Cdc
+}
+
+func (ap *WasmProvider) ClientContext() client.Context {
+ return ap.ClientCtx
+}
+
+func (ap *WasmProvider) updateNextAccountSequence(seq uint64) {
+ if seq > ap.nextAccountSeq {
+ ap.nextAccountSeq = seq
+ }
+}
+
+func (ap *WasmProvider) MsgRegisterCounterpartyPayee(portID, channelID, relayerAddr, counterpartyPayeeAddr string) (provider.RelayerMessage, error) {
+ panic(fmt.Sprintf("%s%s", ap.ChainName(), NOT_IMPLEMENTED))
+}
+
+// keysDir returns a string representing the path on the local filesystem where the keystore will be initialized.
+func keysDir(home, chainID string) string {
+ return path.Join(home, "keys", chainID)
+}
+
+// NewRPCClient initializes a new tendermint RPC client connected to the specified address.
+func NewRPCClient(addr string, timeout time.Duration) (*rpchttp.HTTP, error) {
+ return client.NewClientFromNode(addr)
+}
diff --git a/relayer/chains/wasm/provider_test.go b/relayer/chains/wasm/provider_test.go
new file mode 100644
index 000000000..58bd1f74a
--- /dev/null
+++ b/relayer/chains/wasm/provider_test.go
@@ -0,0 +1,844 @@
+package wasm
+
+import (
+ "context"
+ "encoding/hex"
+ "encoding/json"
+ "fmt"
+ "path/filepath"
+ "testing"
+
+ codectypes "github.com/cosmos/cosmos-sdk/codec/types"
+ "github.com/cosmos/gogoproto/proto"
+ itm "github.com/icon-project/IBC-Integration/libraries/go/common/tendermint"
+
+ clienttypes "github.com/cosmos/ibc-go/v7/modules/core/02-client/types"
+ chantypes "github.com/cosmos/ibc-go/v7/modules/core/04-channel/types"
+ commitmenttypes "github.com/cosmos/ibc-go/v7/modules/core/23-commitment/types"
+
+ // tendermint "github.com/cosmos/ibc-go/v7/modules/light-clients/07-tendermint"
+
+ "github.com/cosmos/relayer/v2/relayer/chains/icon"
+ "github.com/cosmos/relayer/v2/relayer/provider"
+ "github.com/stretchr/testify/assert"
+ "go.uber.org/zap"
+ "go.uber.org/zap/zaptest"
+)
+
+type mockAccountSequenceMismatchError struct {
+ Expected uint64
+ Actual uint64
+}
+
+func (err mockAccountSequenceMismatchError) Error() string {
+ return fmt.Sprintf("account sequence mismatch, expected %d, got %d: incorrect account sequence", err.Expected, err.Actual)
+}
+
+func GetProvider(ctx context.Context, handlerAddr string, local bool) (provider.ChainProvider, error) {
+
+ absPath, _ := filepath.Abs("../../../env/archway/keys")
+ var config = WasmProviderConfig{
+ KeyDirectory: absPath,
+ Key: "testWallet",
+ ChainName: "archway",
+ ChainID: "localnet",
+ RPCAddr: "http://localhost:26657",
+ AccountPrefix: "archway",
+ KeyringBackend: "test",
+ GasAdjustment: 1.5,
+ GasPrices: "0.02stake",
+ Debug: true,
+ Timeout: "20s",
+ SignModeStr: "direct",
+ MinGasAmount: 1000_000,
+ IbcHandlerAddress: handlerAddr,
+ BlockInterval: 6000,
+ }
+ if !local {
+ config.RPCAddr = "https://rpc.constantine.archway.tech:443"
+ config.ChainID = "constantine-3"
+ config.GasPrices = "0.02uconst"
+ }
+
+ p, err := config.NewProvider(zaptest.NewLogger(&testing.T{}), "../../../env/archway", true, "archway")
+ if err != nil {
+ return nil, err
+ }
+ err = p.Init(ctx)
+ if err != nil {
+ return nil, err
+ }
+ return p, err
+
+}
+
+func TestGetAddress(t *testing.T) {
+ ctx := context.Background()
+ p, err := GetProvider(ctx, "archway14hj2tavq8fpesdwxxcu44rty3hh90vhujrvcmstl4zr3txmfvw9sy85n2u", false)
+ assert.NoError(t, err)
+ pArch := p.(*WasmProvider)
+ assert.NoError(t, err)
+ // prefix will be setup when querying a contract or doing a txn, not when provider is initialized
+ a := "cosmos1jpdcgkwv7wmwaqc6lyvd82dwhkxxfvpl53qrze"
+ addr, err := pArch.GetKeyAddress()
+ assert.NoError(t, err)
+ assert.Equal(t, a, addr.String())
+
+ // op, err := pArch.QueryBalance(ctx, "default")
+ // assert.NoError(t, err)
+
+ // fmt.Println("balance", op)
+ // opx, err := pArch.ShowAddress("testWallet")
+ // assert.NoError(t, err)
+ // assert.Equal(t, addr, opx)
+}
+
+type HexBytes string
+
+func (hs HexBytes) Value() ([]byte, error) {
+ if hs == "" {
+ return nil, nil
+ }
+ return hex.DecodeString(string(hs[2:]))
+}
+func NewHexBytes(b []byte) HexBytes {
+ return HexBytes(hex.EncodeToString(b))
+}
+
+type SendPacket struct {
+ Pkt struct {
+ Packet HexBytes `json:"packet"`
+ Id string `json:"id"`
+ } `json:"send_packet"`
+}
+
+func (m *SendPacket) Type() string {
+ return "sendPacket"
+}
+
+func (m *SendPacket) MsgBytes() ([]byte, error) {
+ return json.Marshal(m)
+}
+
+// func TestTransaction(t *testing.T) {
+// ctx := context.Background()
+// contract := "archway1j2zsnnv7qpd6hqhrkg96c57wv9yff4y6amarcvsp5lkta2e4k5vstvt9j3"
+// p, _ := GetProvider(ctx, contract)
+// pArch := p.(*WasmProvider)
+// pArch.Init(ctx)
+
+// key := "jptKey"
+
+// msg := &SendPacket{
+// Pkt: struct {
+// Packet HexBytes "json:\"packet\""
+// Id string "json:\"id\""
+// }{
+// Packet: NewHexBytes([]byte("Hello")),
+// Id: key,
+// },
+// }
+
+// // msg, err := pArch.MsgSendPacketTemp(key)
+// // assert.NoError(t, err)
+
+// callback := func(rtr *provider.RelayerTxResponse, err error) {
+// if err != nil {
+// return
+// }
+// }
+
+// err := pArch.SendMessagesToMempool(ctx, []provider.RelayerMessage{msg}, "memo", nil, callback)
+// assert.NoError(t, err)
+
+// storageKey := fmt.Sprintf("0007%x%s", []byte("packets"), key)
+// _, err = pArch.QueryWasmProof(ctx, []byte(storageKey), 1932589)
+// assert.NoError(t, err)
+
+// }
+
+// func TestTxnResult(t *testing.T) {
+// hash := "A7FAA098E4671ABDB9C3557B4E94F5C208939804B4CE64BF066669EC75313151"
+// b, e := hex.DecodeString(hash)
+// assert.NoError(t, e)
+
+// ctx := context.Background()
+// p, err := GetProvider(ctx, "archway21", true)
+// assert.NoError(t, err)
+// pArch, ok := p.(*WasmProvider)
+// assert.True(t, ok)
+
+// a := make(chan provider.RelayerTxResponse, 10)
+
+// callback := func(rtr *provider.RelayerTxResponse, err error) {
+// fmt.Printf("Tx Response:: %+v\n ", rtr)
+// if err == nil {
+// a <- *rtr
+// }
+// return
+// }
+
+// pArch.waitForTx(ctx, b, nil, time.Minute*10, callback)
+// brakHere:
+// for {
+// select {
+// case <-a:
+// {
+// fmt.Println("response received")
+// break brakHere
+// }
+// }
+
+// }
+
+// }
+
+// func TestClientState(t *testing.T) {
+
+// ctx := context.Background()
+// contractAddr := "archway1vguuxez2h5ekltfj9gjd62fs5k4rl2zy5hfrncasykzw08rezpfsa4aasz"
+// p, err := GetProvider(ctx, contractAddr, true)
+// assert.NoError(t, err)
+
+// archP := p.(*WasmProvider)
+
+// clientId := "iconclient-0"
+
+// iconM, err := archP.QueryClientStateContract(ctx, clientId)
+// assert.NoError(t, err)
+// fmt.Printf("%+v", iconM)
+// }
+
+// func TestTxCall(t *testing.T) {
+
+// ctx := context.Background()
+
+// p, _ := GetProvider(ctx, "", false)
+// pArch := p.(*WasmProvider)
+
+// // cl, _ := client.NewClientFromNode("http://localhost:26657")
+// cl, _ := client.NewClientFromNode("https://rpc.constantine-2.archway.tech:443")
+
+// addr, err := pArch.GetKeyAddress()
+// assert.NoError(t, err)
+
+// encodingConfig := app.MakeEncodingConfig()
+// cliCtx := client.Context{}.
+// WithClient(cl).
+// WithFromName(pArch.PCfg.Key).
+// WithFromAddress(addr).
+// WithTxConfig(encodingConfig.TxConfig).
+// WithSkipConfirmation(true).
+// WithBroadcastMode("sync")
+
+// /////////////////////////////////////////////////
+// ///////////////////// EXECUTION /////////////////
+// /////////////////////////////////////////////////
+
+// // pktData := []byte("hello_world")
+
+// // type SendPacketParams struct {
+// // Packet HexBytes `json:"packet"`
+// // Id string `json:"id"`
+// // }
+// // type SendPacket struct {
+// // Pkt SendPacketParams `json:"send_packet"`
+// // }
+
+// // sendPkt := SendPacket{
+// // Pkt: SendPacketParams{
+// // Packet: NewHexBytes(pktData),
+// // Id: "345",
+// // },
+// // }
+
+// // dB, err := json.Marshal(sendPkt)
+// // assert.NoError(t, err)
+
+// // msg := &wasmtypes.MsgExecuteContract{
+// // Sender: addr.String(),
+// // Contract: contract,
+// // Msg: dB,
+// // }
+
+// // a := pArch.TxFactory()
+// // factory, err := pArch.PrepareFactory(a)
+// // assert.NoError(t, err)
+
+// // tx.GenerateOrBroadcastTxWithFactory(cliCtx, factory, msg)
+
+// /////////////////////////////////////////////////
+// /////////////////////// QUERY ///////////////////
+// /////////////////////////////////////////////////
+
+// type GetPacket struct {
+// GetPacket struct {
+// Id string `json:"id"`
+// } `json:"get_packet"`
+// }
+
+// type PacketOutput struct {
+// Packet []byte `json:"packet"`
+// }
+
+// // _param := GetPacket{
+// // GetPacket: struct {
+// // Id string "json:\"id\""
+// // }{
+// // Id: "100",
+// // },
+// // }
+
+// // type GetAllPacket struct {
+// // GetAllPacket interface{} `json:"get_packet"`
+// // }
+
+// cs := types.GetClientState{
+// ClientState: struct {
+// ClientId string "json:\"client_id\""
+// }{
+// ClientId: "iconclient-0",
+// },
+// }
+
+// param, _ := json.Marshal(cs)
+
+// queryCLient := wasmtypes.NewQueryClient(cliCtx)
+// contractState, err := queryCLient.SmartContractState(ctx, &wasmtypes.QuerySmartContractStateRequest{
+// Address: archway_mock_address,
+// QueryData: param,
+// })
+
+// assert.NoError(t, err)
+// e := contractState.Data
+// var i icon_types.ClientState
+// err = json.Unmarshal(e, &i)
+// fmt.Printf("data is %s \n", e)
+// assert.NoError(t, err)
+// fmt.Printf("data is %+v \n", i)
+
+// }
+
+// func TestCreateClient(t *testing.T) {
+
+// ctx := context.Background()
+// ap, err := GetProvider(ctx, "archway1hpufl3l8g44aaz3qsqw886sjanhhu73ul6tllxuw3pqlhxzq9e4sqcz9uv", true) //"archway1g4w5f2l25dav7h4mc0mzeute5859wa9hgmavancmprfldqun6ppqsn0zma")
+// assert.NoError(t, err)
+
+// networkId := 1
+// height := 59
+// ip := GetIconProvider(networkId)
+
+// btpHeader, err := ip.GetBtpHeader(int64(height))
+// assert.NoError(t, err)
+
+// header := icon.NewIconIBCHeader(btpHeader, nil, int64(height))
+
+// clS, err := ip.NewClientState("07-tendermint", header, 100, 100, true, true)
+// assert.NoError(t, err)
+
+// msg, err := ap.MsgCreateClient(clS, header.ConsensusState())
+// assert.NoError(t, err)
+
+// call := make(chan bool)
+
+// callback := func(rtr *provider.RelayerTxResponse, err error) {
+// assert.NoError(t, err)
+// fmt.Printf("Tx Response:: %+v\n ", rtr)
+// call <- true
+// }
+
+// err = ap.SendMessagesToMempool(ctx, []provider.RelayerMessage{msg}, "memo", nil, callback)
+// assert.NoError(t, err)
+// namedLoop:
+// for {
+// select {
+// case <-call:
+// break namedLoop
+// }
+// }
+// }
+
+func TestSerializeAny(t *testing.T) {
+
+ d := clienttypes.Height{
+ RevisionNumber: 0,
+ RevisionHeight: 20000,
+ }
+ anyValue, err := codectypes.NewAnyWithValue(&d)
+ assert.NoError(t, err)
+ clt := clienttypes.MsgCreateClient{
+ ClientState: anyValue,
+ ConsensusState: anyValue,
+ Signer: "acbdef",
+ }
+ cdc := MakeCodec(ModuleBasics, []string{})
+ actual, err := cdc.Marshaler.MarshalJSON(&clt)
+ assert.NoError(t, err)
+ expected, _ := hex.DecodeString("7b22636c69656e745f7374617465223a7b224074797065223a222f6962632e636f72652e636c69656e742e76312e486569676874222c227265766973696f6e5f6e756d626572223a2230222c227265766973696f6e5f686569676874223a223230303030227d2c22636f6e73656e7375735f7374617465223a7b224074797065223a222f6962632e636f72652e636c69656e742e76312e486569676874222c227265766973696f6e5f6e756d626572223a2230222c227265766973696f6e5f686569676874223a223230303030227d2c227369676e6572223a22616362646566227d")
+ assert.Equal(t, actual, expected)
+
+}
+
+func GetIconProvider(network_id int) *icon.IconProvider {
+
+ pcfg := icon.IconProviderConfig{
+ Keystore: "godWallet",
+ KeyDirectory: "../../../env",
+ ChainID: "ibc-icon",
+ Password: "gochain",
+ ICONNetworkID: 3,
+ BTPNetworkID: int64(network_id),
+ BTPNetworkTypeID: 1,
+ IbcHandlerAddress: "cxff5fce97254f26dee5a5d35496743f61169b6db6",
+ RPCAddr: "http://localhost:9082/api/v3",
+ // RPCAddr: "http://localhost:9999",
+ Timeout: "20s",
+ }
+ log, _ := zap.NewProduction()
+ p, _ := pcfg.NewProvider(log, "", false, "icon")
+
+ iconProvider, _ := p.(*icon.IconProvider)
+ return iconProvider
+}
+
+// func TestCreateClient(t *testing.T) {
+
+// ctx := context.Background()
+// ap, err := GetProvider(ctx, "archway1maqs3qvslrjaq8xz9402shucnr4wzdujty8lr7ux5z5rnj989lwsmssrzk", true)
+// assert.NoError(t, err)
+
+// archwayP, ok := ap.(*WasmProvider)
+// if !ok {
+// assert.Fail(t, "failed to convert to archwayP")
+// }
+
+// networkId := 2
+// height := 307
+// ip := GetIconProvider(networkId)
+
+// btpHeader, err := ip.GetBtpHeader(int64(height))
+// assert.NoError(t, err)
+
+// header := icon.NewIconIBCHeader(btpHeader, nil, int64(height))
+// fmt.Println(header.Height())
+
+// clS, err := ip.NewClientState("07-tendermint", header, 100, 100, true, true)
+// assert.NoError(t, err)
+
+// msg, err := archwayP.MsgCreateClient(clS, header.ConsensusState())
+// if err != nil {
+// assert.Fail(t, err.Error())
+// fmt.Println("error in unexpected place ")
+// return
+// }
+
+// fmt.Printf("the value is %s \n", msg)
+
+// callback := func(rtr *provider.RelayerTxResponse, err error) {
+// if err != nil {
+// return
+// }
+// }
+
+// err = archwayP.SendMessagesToMempool(ctx, []provider.RelayerMessage{msg}, "memo", nil, callback)
+// time.Sleep(2 * 1000)
+// assert.NoError(t, err)
+
+// }
+
+// func TestGetClientState(t *testing.T) {
+// ctx := context.Background()
+// ap, err := GetProvider(ctx, "", false)
+// assert.NoError(t, err)
+
+// archwayP, ok := ap.(*WasmProvider)
+// if !ok {
+// assert.Fail(t, "failed to convert to archwayP")
+// }
+
+// state, err := archwayP.QueryClientStateContract(ctx, "iconclient-0")
+// assert.NoError(t, err)
+// fmt.Printf("ClentState %+v \n", state)
+
+// }
+
+// func TestDataDecode(t *testing.T) {
+
+// d := []byte{10, 32, 47, 105, 99, 111, 110, 46, 108, 105, 103, 104, 116, 99, 108, 105, 101, 110, 116, 46, 118, 49, 46, 67, 108, 105, 101, 110, 116, 83, 116, 97, 116, 101, 18, 32, 127, 98, 36, 134, 45, 9, 198, 30, 199, 185, 205, 28, 128, 214, 203, 138, 15, 65, 45, 70, 134, 139, 202, 40, 61, 44, 97, 169, 50, 7, 225, 18}
+// // d := "103247105991111104610810510310411699108105101110116461184946671081051011101168311697116101183212798361344591983019918520528128214203138156545701341392024061449716950722518"
+// // b, err := hex.DecodeString(d)
+// // assert.NoError(t, err)
+
+// ctx := context.Background()
+// ap, err := GetProvider(ctx, "archway123", false)
+// assert.NoError(t, err)
+// archwayP, _ := ap.(*WasmProvider)
+
+// var iconee exported.ClientState
+// err = archwayP.Cdc.Marshaler.UnmarshalInterface(d, &iconee)
+// assert.NoError(t, err)
+// fmt.Println(iconee.GetLatestHeight())
+// }
+
+// func TestArchwayLightHeader(t *testing.T) {
+// ctx := context.Background()
+// apx, err := GetProvider(ctx, "abcd", true)
+// assert.NoError(t, err)
+
+// ap := apx.(*WasmProvider)
+
+// tsHeight := 34055
+// cl := "07-tendermint-0"
+
+// trustedIbcHeader, err := ap.QueryIBCHeader(ctx, int64(tsHeight))
+
+// latestBlockHeader, err := ap.QueryIBCHeader(ctx, 34060)
+
+// trustedHeight := clienttypes.Height{
+// RevisionHeight: uint64(tsHeight),
+// RevisionNumber: 0,
+// }
+
+// msg, err := ap.MsgUpdateClientHeader(latestBlockHeader, trustedHeight, trustedIbcHeader)
+// assert.NoError(t, err)
+
+// iconP := GetIconProvider(2)
+
+// updateMessage, err := iconP.MsgUpdateClient(cl, msg)
+// assert.NoError(t, err)
+// fmt.Printf("%x \n ", updateMessage)
+
+// // err = iconP.SendMessagesToMempool(ctx, []provider.RelayerMessage{updateMessage}, "", ctx, nil)
+// // assert.Error(t, err)
+// }
+
+// func TestGetConsensusState(t *testing.T) {
+// iconP := GetIconProvider(2)
+
+// ctx := context.Background()
+
+// op, err := iconP.QueryClientConsensusState(ctx, 200, "07-tendermint-34", clienttypes.NewHeight(0, 31600))
+// assert.NoError(t, err)
+// fmt.Println(op)
+// }
+
+func TestProtoMarshal(t *testing.T) {
+
+ codec := MakeCodec(ModuleBasics, []string{})
+ height := clienttypes.Height{
+ RevisionHeight: 32318,
+ RevisionNumber: 0,
+ }
+ expected, _ := hex.DecodeString("10befc01")
+ b, err := codec.Marshaler.Marshal(&height)
+ assert.NoError(t, err)
+ assert.Equal(t, b, expected)
+
+}
+
+func TestDecodeProto(t *testing.T) {
+ b := "0a086c6f63616c6e65741204080110031a0408c0a90722003898800140014801"
+ by, _ := hex.DecodeString(b)
+
+ var cl itm.ClientState
+ codec := MakeCodec(ModuleBasics, []string{})
+ err := codec.Marshaler.Unmarshal(by, &cl)
+ assert.NoError(t, err)
+
+}
+
+// goloop rpc sendtx call \
+// --uri http://localhost:9082/api/v3 \
+// --nid 3 \
+// --step_limit 1000000000\
+// --to cxc327ce659d52f63f727c8d9e9503b8b9cced75f2 \
+// --method updateClient \
+// --raw "{\"params\":{\"msg\":{\"clientId\":\"07-tendermint-0\",\"clientMessage\":\"0x0acc040a8f030a02080b12086c6f63616c6e6574188c8a02220b08bbdbb6a30610fcabd1512a480a20c50b8ec7e3a350b8f4952a23f98e94ca97960d969397625584b33ab2cf2ea45612240801122019bc479a78d29fe86494b54203583cabe3e01edf199f191dfa8f5ea8518b4add3220a7edff3caabb2dd4bfe9ac7c9dd2cd9049ec4332e0e7cf72ed8a78f6e5ea790a3a20e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b8554220d299a92ba9789927c2f4e6bf0db8be41300d33aec0b3d53a37c0d7cf6035e3204a20d299a92ba9789927c2f4e6bf0db8be41300d33aec0b3d53a37c0d7cf6035e3205220048091bc7ddc283f77bfbf91d73c44da58c3df8a9cbc867405d8b7f3daada22f5a206e24d5124a854616c3689c32b2bd77278f45e7b12de588c712d4937f03106b156220e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b8556a20e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b85572146e5f3463982f10e154de349f627857b7acf5218912b701088c8a021a480a20a068896ce65463eb64ff67db82244d084fda128dc09bb2033d78ed3ee636f224122408011220ffc44c3d4d8af8084358d13e3e3174ef0c22b13be985e9fe00f929231929b4892267080212146e5f3463982f10e154de349f627857b7acf521891a0b08c0dbb6a30610f7b2c56722404bef8bdcbf7863684d589abe2af674ff3d418ce4516a4b209e1b1011f6124b0c2eaa15a22ee848e9b609f3357876f50170c9692a59ac4b0fca12311ef373a502123e0a3c0a146e5f3463982f10e154de349f627857b7acf5218912220a208636f208b278b8527a22c7bad921c39ece0594dc95ad213435140be2beaf380e180a18878a02223e0a3c0a146e5f3463982f10e154de349f627857b7acf5218912220a208636f208b278b8527a22c7bad921c39ece0594dc95ad213435140be2beaf380e180a\"}}}"\ \
+// --key_store /Users/viveksharmapoudel/keystore/godWallet.json\
+// --key_password gochain
+
+// func TestBtpHeader(t *testing.T) {
+// a := GetIconProvider(2)
+// h, err := a.GetBtpHeader(1125)
+// assert.NoError(t, err)
+// fmt.Printf("%x \n ", h.PrevNetworkSectionHash)
+// }
+
+// func TestArchwayEvent(t *testing.T) {
+
+// ctx := context.Background()
+// pro, err := GetProvider(ctx, "archway17ymdtz48qey0lpha8erch8hghj37ag4dn0qqyyrtseymvgw6lfnqgmtsrj", true)
+// assert.NoError(t, err)
+
+// archwayP := pro.(*WasmProvider)
+
+// height := int64(6343)
+// blockRes, err := archwayP.RPCClient.BlockResults(ctx, &height)
+// assert.NoError(t, err)
+
+// for _, tx := range blockRes.TxsResults {
+// if tx.Code != 0 {
+// // tx was not successful
+// continue
+// }
+
+// // fmt.Println(tx.Events)
+// messages := ibcMessagesFromEvents(archwayP.log, tx.Events, archwayP.ChainId(), uint64(height), archwayP.PCfg.IbcHandlerAddress, true)
+
+// assert.Equal(t, len(messages), 2)
+
+// for _, m := range messages {
+
+// fmt.Println(m.eventType)
+// fmt.Printf("message is %+v \n", m.info)
+
+// }
+// }
+
+// }
+
+// func TestDecodeMerkleProof(t *testing.T) {
+
+// v := common.MustHexStrToBytes("0x0ac90612c6060a7b03ade4a5f5803a439835c636395a8d648dee57b2fc90d98dc17fa887159b69638b30303062363336663665366536353633373436393666366537336230326433663334643963373863663565353734396637373131373861386361663034653731303432636366336636396165656430356230383066333336373712f5020a4503ade4a5f5803a439835c636395a8d648dee57b2fc90d98dc17fa887159b69638b0016636c69656e745f696d706c656d656e746174696f6e7369636f6e636c69656e742d3012442261726368776179316e633574617461667636657971376c6c6b7232677635306666396532326d6e66373071676a6c763733376b746d74346573777271676a33336736221a0b0801180120012a03000238222b0801120402043e201a2120a30ef45adecacce36447237e218f8cf3ad48357e82cae6aeea7df465573854cb22290801122504083e20fd6187d3aeb814e2a15d3987fd093b63aae12f9a04ba1c871e8a06c9f85a710b2022290801122508163e2064cfaa6db5902310f5d7255b7e8733f455699291f73d3988a17dc47348d63323202229080112250a2a3e2090d36297ce6f62cdb1110921e2482c20cd630e2817648bb0b95a42ce9fe081a420222b080112040c403e201a2120a8753c7dfe3f41e2bb9936721c8e0547e2c74a46a6d25c3f144d784204ceb86e1ace020a2e03ade4a5f5803a439835c636395a8d648dee57b2fc90d98dc17fa887159b69638b636f6e74726163745f696e666f12367b22636f6e7472616374223a226372617465732e696f3a63772d6962632d636f7265222c2276657273696f6e223a22302e312e30227d1a0b0801180120012a0300021422290801122502043e205a76cca2d1f3103d95080d98bf27abb862829151eb227f6be56d3dc8990d47182022290801122504083e20fd6187d3aeb814e2a15d3987fd093b63aae12f9a04ba1c871e8a06c9f85a710b2022290801122508163e2064cfaa6db5902310f5d7255b7e8733f455699291f73d3988a17dc47348d63323202229080112250a2a3e2090d36297ce6f62cdb1110921e2482c20cd630e2817648bb0b95a42ce9fe081a420222b080112040c403e201a2120a8753c7dfe3f41e2bb9936721c8e0547e2c74a46a6d25c3f144d784204ceb86e0a84010a81010a047761736d122031710a6b9c07bb7f1d7816f5b76f65d48e53ea30ad6d8138322f31374e8733321a090801180120012a0100222508011221011107704879ce264af2b8ca54a7ad461538067d296f22b7de0482e4fdf43314b922250801122101efb0c2cf8ed06dea231b3f0f26942e24623f13012e6297b343e7e1afc3863d6d")
+
+// var op commitmenttypes.MerkleProof
+// err := proto.Unmarshal(v, &op)
+// assert.NoError(t, err)
+
+// for i, v := range op.Proofs {
+// fmt.Printf("index %d \n ", i)
+// fmt.Printf("existence proof %x : \n ", v.GetExist())
+// fmt.Printf("Non-existence proof %x : \n", v.GetNonexist())
+
+// }
+
+// // err = op.VerifyMembership([]*ics23.ProofSpec{ics23.IavlSpec, ics23.TendermintSpec}, root, path, result.Response.Value)
+// assert.NoError(t, err)
+
+// }
+
+// func TestCommitmentKey(t *testing.T) {
+// fmt.Printf("%x \n ", common.GetConnectionCommitmentKey("connection-0"))
+
+// }
+
+// func TestGetProofTendermint(t *testing.T) {
+
+// ctx := context.Background()
+// contractAddr := "archway17p9rzwnnfxcjp32un9ug7yhhzgtkhvl9jfksztgw5uh69wac2pgssf05p7"
+// pro, err := GetProvider(ctx, contractAddr, true)
+// assert.NoError(t, err)
+
+// archwayP := pro.(*WasmProvider)
+
+// connectionKey := common.GetConnectionCommitmentKey("connection-3")
+
+// connStorageKey := fmt.Sprintf("%s%x", getKey(STORAGEKEY__Commitments), connectionKey)
+// hexStrkey, err := hex.DecodeString(connStorageKey)
+// assert.NoError(t, err)
+// fmt.Printf("the main key is %x \n ", hexStrkey)
+
+// proofConnBytes, err := archwayP.QueryWasmProof(ctx, hexStrkey, int64(2273))
+
+// var op icn.MerkleProof
+// err = proto.Unmarshal(proofConnBytes, &op)
+// assert.NoError(t, err)
+// for ind, xx := range op.Proofs {
+// fmt.Println("index ", ind)
+// fmt.Printf("Get Exist %x \n", xx.GetExist())
+// fmt.Printf("non ExistP %x \n", xx.GetNonexist())
+// }
+
+// }
+
+// func TestVerifyMembership(t *testing.T) {
+
+// ctx := context.Background()
+// contractAddr := "archway10qt8wg0n7z740ssvf3urmvgtjhxpyp74hxqvqt7z226gykuus7eqzla6h5"
+// pro, err := GetProvider(ctx, contractAddr, true)
+// assert.NoError(t, err)
+// archwayP := pro.(*WasmProvider)
+// height := 410
+
+// ibcAddr, err := sdk.AccAddressFromBech32(archwayP.PCfg.IbcHandlerAddress)
+// assert.NoError(t, err)
+
+// connectionKey := common.GetConnectionCommitmentKey("connection-0")
+// fmt.Printf("commitment key is %x \n ", connectionKey)
+
+// // map_key := []byte("state")
+// map_key := []byte("commitments")
+// keyV := fmt.Sprintf("03%x000b%x%x", ibcAddr.Bytes(), map_key, connectionKey)
+// // keyV := fmt.Sprintf("03%x00077374617465", ibcAddr.Bytes())
+// key, _ := hex.DecodeString(keyV)
+// fmt.Printf("contract Address %x \n ", ibcAddr.Bytes())
+
+// key1, err := hex.DecodeString(fmt.Sprintf("%s%x", archwayP.CommitmentPrefix().KeyPrefix, common.GetConnectionCommitmentKey("connection-0")))
+// assert.NoError(t, err)
+
+// fmt.Printf("%x", key1)
+// assert.Equal(t, key, key1)
+
+// req := abci.RequestQuery{
+// Path: fmt.Sprintf("store/wasm/key"),
+// Data: key,
+// Prove: true,
+// Height: int64(height),
+// }
+
+// ibcH, err := archwayP.QueryIBCHeader(ctx, req.Height+1)
+// assert.NoError(t, err)
+// header := ibcH.(WasmIBCHeader)
+
+// path := commitmenttypes.MerklePath{KeyPath: []string{
+// "wasm",
+// string(key),
+// }}
+
+// fmt.Println("path is ", string(key))
+
+// opts := rpcclient.ABCIQueryOptions{
+// Height: req.Height,
+// Prove: req.Prove,
+// }
+// result, err := archwayP.RPCClient.ABCIQueryWithOptions(ctx, req.Path, req.Data, opts)
+// assert.NoError(t, err)
+
+// root := commitmenttypes.MerkleRoot{Hash: header.SignedHeader.Header.AppHash}
+
+// rootMarshalled, _ := proto.Marshal(&root)
+
+// fmt.Printf("proto marshalled root %x \n", rootMarshalled)
+
+// proof, err := commitmenttypes.ConvertProofs(result.Response.ProofOps)
+// assert.NoError(t, err)
+
+// fmt.Printf("value %x \n ", result.Response.Value)
+// proofProtoMarshal, err := proto.Marshal(&proof)
+// fmt.Printf("proof %x \n ", proofProtoMarshal)
+
+// err = proof.VerifyMembership([]*ics23.ProofSpec{ics23.IavlSpec, ics23.TendermintSpec}, root, path, result.Response.Value)
+// assert.NoError(t, err)
+// if err != nil {
+// fmt.Println("failed to verify Memebership ", err)
+// }
+// }
+
+// func TestVerifyMembershipTestCC(t *testing.T) {
+
+// ctx := context.Background()
+// contractAddr := "archway1999u8suptza3rtxwk7lspve02m406xe7l622erg3np3aq05gawxsk8g4pd" //START CONTRACT
+// // contractAddr := "archway10qt8wg0n7z740ssvf3urmvgtjhxpyp74hxqvqt7z226gykuus7eqzla6h5"
+// pro, err := GetProvider(ctx, contractAddr, true)
+// assert.NoError(t, err)
+// archwayP := pro.(*WasmProvider)
+
+// ibcAddr, err := sdk.AccAddressFromBech32(archwayP.PCfg.IbcHandlerAddress)
+// assert.NoError(t, err)
+
+// // map_key := []byte("state")
+// map_key := []byte("test_maphello")
+// keyV := fmt.Sprintf("03%x0008%x", ibcAddr.Bytes(), map_key)
+// // keyV := fmt.Sprintf("03%x00077374617465", ibcAddr.Bytes())
+// key, _ := hex.DecodeString(keyV)
+// fmt.Printf("contract Address %x \n ", ibcAddr.Bytes())
+
+// fmt.Printf("the main key is : %x \n", map_key)
+
+// req := abci.RequestQuery{
+// Path: fmt.Sprintf("store/wasm/key"),
+// Data: key,
+// Prove: true,
+// Height: 17084,
+// }
+
+// path := commitmenttypes.MerklePath{KeyPath: []string{
+// "wasm",
+// string(key),
+// }}
+
+// opts := rpcclient.ABCIQueryOptions{
+// Height: req.Height,
+// Prove: req.Prove,
+// }
+// result, err := archwayP.RPCClient.ABCIQueryWithOptions(ctx, req.Path, req.Data, opts)
+// assert.NoError(t, err)
+
+// rootB, _ := hex.DecodeString("7526C2B51C1FDCCD86BD4FAB4F0AF762242C50B321829B11D04E81B52DB83BBF")
+// root := commitmenttypes.MerkleRoot{Hash: rootB}
+
+// rootMarshalled, _ := proto.Marshal(&root)
+
+// fmt.Printf("proto marshalled root %x \n", rootMarshalled)
+
+// proof, err := commitmenttypes.ConvertProofs(result.Response.ProofOps)
+// assert.NoError(t, err)
+
+// fmt.Println("value \n ", result.Response.Value)
+// proofProtoMarshal, err := proto.Marshal(&proof)
+// fmt.Printf("proof %x \n ", proofProtoMarshal)
+
+// err = proof.VerifyMembership([]*ics23.ProofSpec{ics23.IavlSpec, ics23.TendermintSpec}, root, path, result.Response.Value)
+// assert.NoError(t, err)
+// if err != nil {
+// fmt.Println("failed to verify Memebership ", err)
+// }
+// }
+
+func TestGenRoot(t *testing.T) {
+
+ rootB, _ := hex.DecodeString("99306EBA529FB6416B0984146B97C9C76386F226E9541A47197FA7ADA530EDA3")
+ root := commitmenttypes.MerkleRoot{Hash: rootB}
+
+ rootMarshalled, _ := proto.Marshal(&root)
+
+ fmt.Printf("proto marshalled root %x \n", rootMarshalled)
+
+}
+
+func TestStringToHex(t *testing.T) {
+
+ // type YY struct {
+ // Req []byte
+ // }
+
+ // b := "5b332c3234322c3232362c3136322c38322c3231392c3131382c3231302c3130302c3139352c35312c3130382c33302c35382c3130372c37362c3130312c3232332c332c37322c3231312c32372c302c31302c3135372c3135362c3235312c3234312c3235342c38382c3233332c3230375d"
+ // y, _ := hex.DecodeString(b)
+
+ // x := []byte(fmt.Sprintf(`{"req":%s}`, y))
+ // var a YY
+ // err := json.Unmarshal(x, &a)
+ // assert.NoError(t, err)
+ // fmt.Printf("%x", a.Req)
+
+ var byteArray []byte
+ str := "[3,242,226,162,82,219,118,210,100,195,51,108,30,58,107,76,101,223,3,72,211,27,0,10,157,156,251,241,254,88,233,207]"
+
+ err := json.Unmarshal([]byte(str), &byteArray)
+ if err != nil {
+ fmt.Println(err)
+ }
+
+ fmt.Printf("%x \n", byteArray)
+
+}
+
+func TestProtoUnmarshal(t *testing.T) {
+ val, _ := hex.DecodeString("080210021a110a046d6f636b12096368616e6e656c2d30220c636f6e6e656374696f6e2d302a0769637332302d31")
+ var channelS chantypes.Channel
+ err := proto.Unmarshal(val, &channelS)
+ assert.NoError(t, err)
+ assert.Equal(t, channelS.State, chantypes.State(2))
+}
+
+// func TestCommitmentPrefix(t *testing.T) {
+
+// ctx := context.Background()
+// p, _ := GetProvider(ctx, "archway13we0myxwzlpx8l5ark8elw5gj5d59dl6cjkzmt80c5q5cv5rt54quagxpp", true)
+
+// archwayP := p.(*WasmProvider)
+
+// _, err := archwayP.GetCommitmentPrefixFromContract(ctx)
+// assert.NoError(t, err)
+// }
diff --git a/relayer/chains/wasm/query.go b/relayer/chains/wasm/query.go
new file mode 100644
index 000000000..41299c862
--- /dev/null
+++ b/relayer/chains/wasm/query.go
@@ -0,0 +1,885 @@
+package wasm
+
+import (
+ "context"
+ "encoding/hex"
+ "encoding/json"
+ "errors"
+ "fmt"
+ "math/big"
+ "strings"
+ "time"
+
+ wasmtypes "github.com/CosmWasm/wasmd/x/wasm/types"
+ "github.com/avast/retry-go/v4"
+ abci "github.com/cometbft/cometbft/abci/types"
+ rpcclient "github.com/cometbft/cometbft/rpc/client"
+ tmtypes "github.com/cometbft/cometbft/types"
+ "github.com/cosmos/cosmos-sdk/codec"
+ sdk "github.com/cosmos/cosmos-sdk/types"
+ "github.com/cosmos/gogoproto/proto"
+ tmclient "github.com/cosmos/ibc-go/v7/modules/light-clients/07-tendermint"
+ "github.com/icon-project/IBC-Integration/libraries/go/common/icon"
+ "go.uber.org/zap"
+
+ querytypes "github.com/cosmos/cosmos-sdk/types/query"
+ bankTypes "github.com/cosmos/cosmos-sdk/x/bank/types"
+ transfertypes "github.com/cosmos/ibc-go/v7/modules/apps/transfer/types"
+ clienttypes "github.com/cosmos/ibc-go/v7/modules/core/02-client/types"
+ conntypes "github.com/cosmos/ibc-go/v7/modules/core/03-connection/types"
+ chantypes "github.com/cosmos/ibc-go/v7/modules/core/04-channel/types"
+ commitmenttypes "github.com/cosmos/ibc-go/v7/modules/core/23-commitment/types"
+ "github.com/cosmos/ibc-go/v7/modules/core/exported"
+
+ ibcexported "github.com/cosmos/ibc-go/v7/modules/core/exported"
+ "github.com/cosmos/relayer/v2/relayer/chains/wasm/types"
+ "github.com/cosmos/relayer/v2/relayer/common"
+ "github.com/cosmos/relayer/v2/relayer/provider"
+)
+
+const (
+ PaginationDelay = 10 * time.Millisecond
+ NOT_IMPLEMENTED = " :: Not implemented for WASM"
+)
+
+func (ap *WasmProvider) QueryTx(ctx context.Context, hashHex string) (*provider.RelayerTxResponse, error) {
+ hash, err := hex.DecodeString(hashHex)
+ if err != nil {
+ return nil, err
+ }
+
+ resp, err := ap.RPCClient.Tx(ctx, hash, true)
+ if err != nil {
+ return nil, err
+ }
+
+ events := parseEventsFromResponseDeliverTx(resp.TxResult)
+
+ return &provider.RelayerTxResponse{
+ Height: resp.Height,
+ TxHash: string(hash),
+ Code: resp.TxResult.Code,
+ Data: string(resp.TxResult.Data),
+ Events: events,
+ }, nil
+
+}
+func (ap *WasmProvider) QueryTxs(ctx context.Context, page, limit int, events []string) ([]*provider.RelayerTxResponse, error) {
+ if len(events) == 0 {
+ return nil, errors.New("must declare at least one event to search")
+ }
+
+ if page <= 0 {
+ return nil, errors.New("page must greater than 0")
+ }
+
+ if limit <= 0 {
+ return nil, errors.New("limit must greater than 0")
+ }
+
+ res, err := ap.RPCClient.TxSearch(ctx, strings.Join(events, " AND "), true, &page, &limit, "")
+ if err != nil {
+ return nil, err
+ }
+
+ // Currently, we only call QueryTxs() in two spots and in both of them we are expecting there to only be,
+ // at most, one tx in the response. Because of this we don't want to initialize the slice with an initial size.
+ var txResps []*provider.RelayerTxResponse
+ for _, tx := range res.Txs {
+ relayerEvents := parseEventsFromResponseDeliverTx(tx.TxResult)
+ txResps = append(txResps, &provider.RelayerTxResponse{
+ Height: tx.Height,
+ TxHash: string(tx.Hash),
+ Code: tx.TxResult.Code,
+ Data: string(tx.TxResult.Data),
+ Events: relayerEvents,
+ })
+ }
+ return txResps, nil
+
+}
+
+// parseEventsFromResponseDeliverTx parses the events from a ResponseDeliverTx and builds a slice
+// of provider.RelayerEvent's.
+// TODO: Comet check needed?
+func parseEventsFromResponseDeliverTx(resp abci.ResponseDeliverTx) []provider.RelayerEvent {
+ var events []provider.RelayerEvent
+
+ for _, event := range resp.Events {
+ attributes := make(map[string]string)
+ for _, attribute := range event.Attributes {
+ attributes[string(attribute.Key)] = string(attribute.Value)
+ }
+ events = append(events, provider.RelayerEvent{
+ EventType: event.Type,
+ Attributes: attributes,
+ })
+ }
+ return events
+}
+
+func (ap *WasmProvider) QueryLatestHeight(ctx context.Context) (int64, error) {
+
+ stat, err := ap.RPCClient.Status(ctx)
+ if err != nil {
+ return -1, err
+ } else if stat.SyncInfo.CatchingUp {
+ return -1, fmt.Errorf("node at %s running chain %s not caught up", ap.PCfg.RPCAddr, ap.PCfg.ChainID)
+ }
+ return stat.SyncInfo.LatestBlockHeight, nil
+}
+
+// QueryIBCHeader returns the IBC compatible block header at a specific height.
+func (ap *WasmProvider) QueryIBCHeader(ctx context.Context, h int64) (provider.IBCHeader, error) {
+ if h == 0 {
+ return nil, fmt.Errorf("No header at height 0")
+ }
+ lightBlock, err := ap.LightProvider.LightBlock(ctx, h)
+ if err != nil {
+ return nil, err
+ }
+
+ return NewWasmIBCHeaderFromLightBlock(lightBlock), nil
+}
+
+func (ap *WasmProvider) QueryLightBlock(ctx context.Context, h int64) (provider.IBCHeader, *tmtypes.LightBlock, error) {
+ if h == 0 {
+ return nil, nil, fmt.Errorf("No header at height 0")
+ }
+ lightBlock, err := ap.LightProvider.LightBlock(ctx, h)
+ if err != nil {
+ return nil, nil, err
+ }
+
+ return NewWasmIBCHeaderFromLightBlock(lightBlock), lightBlock, nil
+}
+
+// query packet info for sequence
+func (ap *WasmProvider) QuerySendPacket(ctx context.Context, srcChanID, srcPortID string, sequence uint64) (provider.PacketInfo, error) {
+ return provider.PacketInfo{}, fmt.Errorf("Not implemented for Wasm")
+}
+func (ap *WasmProvider) QueryRecvPacket(ctx context.Context, dstChanID, dstPortID string, sequence uint64) (provider.PacketInfo, error) {
+ return provider.PacketInfo{}, fmt.Errorf("Not implemented for Wasm")
+}
+
+// bank
+func (ap *WasmProvider) QueryBalance(ctx context.Context, keyName string) (sdk.Coins, error) {
+ addr, err := ap.ShowAddress(keyName)
+ if err != nil {
+ return nil, err
+ }
+
+ return ap.QueryBalanceWithAddress(ctx, addr)
+}
+
+func (ap *WasmProvider) QueryBalanceWithAddress(ctx context.Context, address string) (sdk.Coins, error) {
+ qc := bankTypes.NewQueryClient(ap)
+ p := DefaultPageRequest()
+ coins := sdk.Coins{}
+
+ for {
+ res, err := qc.AllBalances(ctx, &bankTypes.QueryAllBalancesRequest{
+ Address: address,
+ Pagination: p,
+ })
+ if err != nil {
+ return nil, err
+ }
+
+ coins = append(coins, res.Balances...)
+ next := res.GetPagination().GetNextKey()
+ if len(next) == 0 {
+ break
+ }
+
+ time.Sleep(PaginationDelay)
+ p.Key = next
+ }
+ return coins, nil
+}
+
+func DefaultPageRequest() *querytypes.PageRequest {
+ return &querytypes.PageRequest{
+ Key: []byte(""),
+ Offset: 0,
+ Limit: 1000,
+ CountTotal: false,
+ }
+}
+
+// staking
+func (ap *WasmProvider) QueryUnbondingPeriod(context.Context) (time.Duration, error) {
+ // move to provider, panic
+ return 0, nil
+}
+
+// ics 02 - client
+func (ap *WasmProvider) QueryClientState(ctx context.Context, height int64, clientid string) (ibcexported.ClientState, error) {
+ clientStateRes, err := ap.QueryClientStateResponse(ctx, height, clientid)
+ if err != nil {
+ return nil, err
+ }
+
+ clientStateExported, err := clienttypes.UnpackClientState(clientStateRes.ClientState)
+ if err != nil {
+ return nil, err
+ }
+ return clientStateExported, nil
+}
+
+// TODO: Check revision number
+func (ap *WasmProvider) QueryClientStateResponse(ctx context.Context, height int64, srcClientId string) (*clienttypes.QueryClientStateResponse, error) {
+
+ clS, err := ap.QueryClientStateContract(ctx, srcClientId)
+ if err != nil {
+ return nil, err
+ }
+ anyClientState, err := clienttypes.PackClientState(clS)
+ if err != nil {
+ return nil, err
+ }
+
+ storageKey := getStorageKeyFromPath(common.GetClientStateCommitmentKey(srcClientId))
+ proof, err := ap.QueryWasmProof(ctx, storageKey, height)
+ if err != nil {
+ return nil, err
+ }
+
+ return &clienttypes.QueryClientStateResponse{
+ ClientState: anyClientState,
+ Proof: proof,
+ ProofHeight: clienttypes.NewHeight(0, uint64(height)),
+ }, nil
+}
+
+func (ap *WasmProvider) QueryClientStateContract(ctx context.Context, clientId string) (*icon.ClientState, error) {
+ clientStateParam, err := types.NewClientState(clientId).Bytes()
+ if err != nil {
+ return nil, err
+ }
+
+ clientState, err := ap.QueryIBCHandlerContractProcessed(ctx, clientStateParam)
+ if err != nil {
+ return nil, err
+ }
+
+ cdc := codec.NewProtoCodec(ap.Cdc.InterfaceRegistry)
+
+ clientS, err := clienttypes.UnmarshalClientState(cdc, clientState)
+ if err != nil {
+ return nil, err
+ }
+
+ iconClientState, ok := clientS.(*icon.ClientState)
+ if !ok {
+ return nil, fmt.Errorf("Error casting to icon.ClientState")
+ }
+
+ return iconClientState, nil
+}
+
+func (ap *WasmProvider) QueryConnectionContract(ctx context.Context, connId string) (*conntypes.ConnectionEnd, error) {
+ connStateParam, err := types.NewConnection(connId).Bytes()
+ if err != nil {
+ return nil, err
+ }
+
+ connState, err := ap.QueryIBCHandlerContractProcessed(ctx, connStateParam)
+ if err != nil {
+ return nil, err
+ }
+
+ var connS conntypes.ConnectionEnd
+ if err := proto.Unmarshal(connState, &connS); err != nil {
+ return nil, err
+ }
+
+ return &connS, nil
+}
+
+func (ap *WasmProvider) QueryChannelContract(ctx context.Context, portId, channelId string) (*chantypes.Channel, error) {
+ channelStateParam, err := types.NewChannel(portId, channelId).Bytes()
+ if err != nil {
+ return nil, err
+ }
+
+ channelState, err := ap.QueryIBCHandlerContractProcessed(ctx, channelStateParam)
+ if err != nil {
+ return nil, err
+ }
+
+ var channelS chantypes.Channel
+ if err = proto.Unmarshal(channelState, &channelS); err != nil {
+ return nil, err
+ }
+ return &channelS, nil
+}
+
+func (ap *WasmProvider) QueryClientConsensusState(ctx context.Context, chainHeight int64, clientid string, clientHeight ibcexported.Height) (*clienttypes.QueryConsensusStateResponse, error) {
+
+ consensusStateParam, err := types.NewConsensusStateByHeight(clientid, uint64(clientHeight.GetRevisionHeight())).Bytes()
+ consensusState, err := ap.QueryIBCHandlerContractProcessed(ctx, consensusStateParam)
+ if err != nil {
+ return nil, err
+ }
+
+ cdc := codec.NewProtoCodec(ap.Cdc.InterfaceRegistry)
+ csState, err := clienttypes.UnmarshalConsensusState(cdc, consensusState)
+ if err != nil {
+ return nil, err
+ }
+
+ anyConsensusState, err := clienttypes.PackConsensusState(csState)
+ if err != nil {
+ return nil, err
+ }
+ return clienttypes.NewQueryConsensusStateResponse(anyConsensusState, nil, clienttypes.NewHeight(0, uint64(chainHeight))), nil
+}
+
+func (ap *WasmProvider) QueryIBCHandlerContract(ctx context.Context, param wasmtypes.RawContractMessage) (op *wasmtypes.QuerySmartContractStateResponse, err error) {
+ return op, retry.Do(func() error {
+ done := ap.SetSDKContext()
+ defer done()
+ op, err = ap.QueryClient.SmartContractState(ctx, &wasmtypes.QuerySmartContractStateRequest{
+ Address: ap.PCfg.IbcHandlerAddress,
+ QueryData: param,
+ })
+ return err
+ }, retry.Context(ctx), retry.Attempts(latestHeightQueryRetries), retry.Delay(50*time.Millisecond), retry.LastErrorOnly(true), retry.OnRetry(func(n uint, err error) {
+ ap.log.Error(
+ "Failed to query",
+ zap.Uint("attempt", n+1),
+ zap.Uint("max_attempts", latestHeightQueryRetries),
+ zap.Any("Param", param),
+ zap.Error(err),
+ )
+ }))
+}
+
+func (ap *WasmProvider) QueryIBCHandlerContractProcessed(ctx context.Context, param wasmtypes.RawContractMessage) ([]byte, error) {
+ res, err := ap.QueryIBCHandlerContract(ctx, param)
+ if err != nil {
+ return nil, err
+ }
+ return ProcessContractResponse(res)
+}
+
+func (ap *WasmProvider) QueryUpgradedClient(ctx context.Context, height int64) (*clienttypes.QueryClientStateResponse, error) {
+ panic(fmt.Sprintf("%s%s", ap.ChainName(), NOT_IMPLEMENTED))
+}
+
+func (ap *WasmProvider) QueryUpgradedConsState(ctx context.Context, height int64) (*clienttypes.QueryConsensusStateResponse, error) {
+ panic(fmt.Sprintf("%s%s", ap.ChainName(), NOT_IMPLEMENTED))
+}
+
+func (ap *WasmProvider) QueryConsensusState(ctx context.Context, height int64) (ibcexported.ConsensusState, int64, error) {
+
+ commit, err := ap.RPCClient.Commit(ctx, &height)
+ if err != nil {
+ return &tmclient.ConsensusState{}, 0, err
+ }
+
+ page := 1
+ count := 10_000
+
+ nextHeight := height + 1
+ nextVals, err := ap.RPCClient.Validators(ctx, &nextHeight, &page, &count)
+ if err != nil {
+ return &tmclient.ConsensusState{}, 0, err
+ }
+
+ state := &tmclient.ConsensusState{
+ Timestamp: commit.Time,
+ Root: commitmenttypes.NewMerkleRoot(commit.AppHash),
+ NextValidatorsHash: tmtypes.NewValidatorSet(nextVals.Validators).Hash(),
+ }
+
+ return state, height, nil
+}
+
+func (ap *WasmProvider) getAllPorts(ctx context.Context) ([]string, error) {
+ param, err := types.NewGetAllPorts().Bytes()
+ if err != nil {
+ return make([]string, 0), err
+ }
+ op, err := ap.QueryIBCHandlerContract(ctx, param)
+ if err != nil {
+ return make([]string, 0), err
+ }
+ resp := op.Data.Bytes()
+ var ports []string
+ err = json.Unmarshal(resp, &ports)
+ if err != nil {
+ return make([]string, 0), nil
+ }
+ return ports, nil
+}
+
+func (ap *WasmProvider) getNextSequence(ctx context.Context, methodName string) (int, error) {
+ switch methodName {
+ case MethodGetNextClientSequence:
+ param, err := types.NewNextClientSequence().Bytes()
+ if err != nil {
+ return 0, err
+ }
+
+ op, err := ap.QueryIBCHandlerContract(ctx, param)
+ if err != nil {
+ return 0, err
+ }
+
+ return byteToInt(op.Data.Bytes())
+
+ case MethodGetNextChannelSequence:
+ param, err := types.NewNextChannelSequence().Bytes()
+ if err != nil {
+ return 0, err
+ }
+ op, err := ap.QueryIBCHandlerContract(ctx, param)
+ if err != nil {
+ return 0, err
+ }
+ return byteToInt(op.Data.Bytes())
+
+ case MethodGetNextConnectionSequence:
+ param, err := types.NewNextConnectionSequence().Bytes()
+ if err != nil {
+ return 0, err
+ }
+ op, err := ap.QueryIBCHandlerContract(ctx, param)
+ if err != nil {
+ return 0, err
+ }
+ return byteToInt(op.Data.Bytes())
+
+ default:
+ return 0, errors.New("Invalid method name")
+ }
+}
+
+func (ap *WasmProvider) QueryClients(ctx context.Context) (clienttypes.IdentifiedClientStates, error) {
+
+ seq, err := ap.getNextSequence(ctx, MethodGetNextClientSequence)
+ if err != nil {
+ return nil, err
+ }
+
+ if seq == 0 {
+ return nil, nil
+ }
+
+ identifiedClientStates := make(clienttypes.IdentifiedClientStates, 0)
+ for i := 0; i <= int(seq)-1; i++ {
+ clientIdentifier := common.GetIdentifier(common.IconLightClient, i)
+ clientState, err := ap.QueryClientStateContract(ctx, clientIdentifier)
+ if err != nil {
+ return nil, err
+ }
+ identifiedClientStates = append(identifiedClientStates, clienttypes.NewIdentifiedClientState(clientIdentifier, clientState))
+
+ }
+ return identifiedClientStates, nil
+}
+
+// ics 03 - connection
+func (ap *WasmProvider) QueryConnection(ctx context.Context, height int64, connectionid string) (*conntypes.QueryConnectionResponse, error) {
+ connectionStateParams, err := types.NewConnection(connectionid).Bytes()
+ if err != nil {
+ return nil, err
+ }
+
+ connState, err := ap.QueryIBCHandlerContractProcessed(ctx, connectionStateParams)
+ if err != nil {
+ return nil, err
+ }
+
+ var conn conntypes.ConnectionEnd
+ err = proto.Unmarshal(connState, &conn)
+ if err != nil {
+ return nil, err
+ }
+
+ storageKey := getStorageKeyFromPath(common.GetConnectionCommitmentKey(connectionid))
+ connProof, err := ap.QueryWasmProof(ctx, storageKey, height)
+
+ return conntypes.NewQueryConnectionResponse(conn, connProof, clienttypes.NewHeight(0, uint64(height))), nil
+}
+
+func (ap *WasmProvider) QueryWasmProof(ctx context.Context, storageKey []byte, height int64) ([]byte, error) {
+ done := ap.SetSDKContext()
+ defer done()
+ ibcAddr, err := sdk.AccAddressFromBech32(ap.PCfg.IbcHandlerAddress)
+ if err != nil {
+ return nil, err
+ }
+ key, err := hex.DecodeString(fmt.Sprintf("%s%x%x", WASM_CONTRACT_PREFIX, ibcAddr.Bytes(), storageKey))
+ if err != nil {
+ return nil, err
+ }
+
+ if height > 2 {
+ height--
+ }
+
+ req := abci.RequestQuery{
+ Path: fmt.Sprintf("store/wasm/key"),
+ Data: key,
+ Prove: true,
+ Height: height,
+ }
+
+ opts := rpcclient.ABCIQueryOptions{
+ Height: req.Height,
+ Prove: req.Prove,
+ }
+ result, err := ap.RPCClient.ABCIQueryWithOptions(ctx, req.Path, req.Data, opts)
+ if err != nil {
+ return nil, err
+ }
+
+ proof, err := commitmenttypes.ConvertProofs(result.Response.ProofOps)
+ if err != nil {
+ return nil, err
+ }
+
+ proofBytes, err := proto.Marshal(&proof)
+ if err != nil {
+ return nil, err
+ }
+
+ return proofBytes, nil
+
+}
+
+func (ap *WasmProvider) QueryConnections(ctx context.Context) (conns []*conntypes.IdentifiedConnection, err error) {
+
+ seq, err := ap.getNextSequence(ctx, MethodGetNextConnectionSequence)
+ if err != nil {
+ return nil, err
+ }
+
+ if seq == 0 {
+ return nil, nil
+ }
+
+ for i := 0; i <= int(seq)-1; i++ {
+ connectionId := common.GetIdentifier(common.ConnectionKey, i)
+ conn, err := ap.QueryConnectionContract(ctx, connectionId)
+ if err != nil {
+ continue
+ }
+
+ // Only return open conenctions
+ if conn.State == conntypes.OPEN {
+ identifiedConn := conntypes.IdentifiedConnection{
+ Id: connectionId,
+ ClientId: conn.ClientId,
+ Versions: conn.Versions,
+ State: conn.State,
+ Counterparty: conn.Counterparty,
+ DelayPeriod: conn.DelayPeriod,
+ }
+ conns = append(conns, &identifiedConn)
+ }
+ }
+
+ return conns, nil
+}
+
+func (ap *WasmProvider) QueryConnectionsUsingClient(ctx context.Context, height int64, clientid string) (*conntypes.QueryConnectionsResponse, error) {
+ panic(fmt.Sprintf("%s%s", ap.ChainName(), NOT_IMPLEMENTED))
+}
+
+func (ap *WasmProvider) GenerateConnHandshakeProof(ctx context.Context, height int64, clientId, connId string) (clientState ibcexported.ClientState,
+ clientStateProof []byte, consensusProof []byte, connectionProof []byte,
+ connectionProofHeight ibcexported.Height, err error) {
+
+ clientResponse, err := ap.QueryClientStateResponse(ctx, height, clientId)
+ if err != nil {
+ return nil, nil, nil, nil, clienttypes.Height{}, err
+ }
+
+ anyClientState := clientResponse.ClientState
+ clientState_, err := clienttypes.UnpackClientState(anyClientState)
+ if err != nil {
+ return nil, nil, nil, nil, clienttypes.Height{}, err
+ }
+
+ connStorageKey := getStorageKeyFromPath(common.GetConnectionCommitmentKey(connId))
+ proofConnBytes, err := ap.QueryWasmProof(ctx, connStorageKey, height)
+ if err != nil {
+ return nil, nil, nil, nil, nil, err
+
+ }
+
+ consStorageKey := getStorageKeyFromPath(common.GetConsensusStateCommitmentKey(clientId, big.NewInt(0), big.NewInt(height)))
+ proofConsensusBytes, err := ap.QueryWasmProof(ctx, consStorageKey, height)
+ if err != nil {
+ return nil, nil, nil, nil, nil, err
+ }
+ return clientState_, clientResponse.GetProof(), proofConsensusBytes, proofConnBytes, clienttypes.NewHeight(0, uint64(height)), nil
+}
+
+// ics 04 - channel
+func (ap *WasmProvider) QueryChannel(ctx context.Context, height int64, channelid, portid string) (chanRes *chantypes.QueryChannelResponse, err error) {
+ channelParams, err := types.NewChannel(portid, channelid).Bytes()
+ if err != nil {
+ return nil, err
+ }
+
+ channelState, err := ap.QueryIBCHandlerContractProcessed(ctx, channelParams)
+ if err != nil {
+ return nil, err
+ }
+
+ if channelState == nil {
+ return nil, err
+ }
+
+ var channelS chantypes.Channel
+ if err := proto.Unmarshal(channelState, &channelS); err != nil {
+ return nil, err
+ }
+
+ storageKey := getStorageKeyFromPath(common.GetChannelCommitmentKey(portid, channelid))
+ proof, err := ap.QueryWasmProof(ctx, storageKey, height)
+
+ return chantypes.NewQueryChannelResponse(channelS, proof, clienttypes.NewHeight(0, uint64(height))), nil
+}
+
+func (ap *WasmProvider) QueryChannelClient(ctx context.Context, height int64, channelid, portid string) (*clienttypes.IdentifiedClientState, error) {
+ panic(fmt.Sprintf("%s%s", ap.ChainName(), NOT_IMPLEMENTED))
+}
+
+func (ap *WasmProvider) QueryConnectionChannels(ctx context.Context, height int64, connectionid string) ([]*chantypes.IdentifiedChannel, error) {
+ allChannel, err := ap.QueryChannels(ctx)
+ if err != nil {
+ return nil, fmt.Errorf("error querying Channels %v", err)
+ }
+ var identifiedChannels []*chantypes.IdentifiedChannel
+ for _, c := range allChannel {
+ if c.ConnectionHops[0] == connectionid {
+ identifiedChannels = append(identifiedChannels, c)
+ }
+ }
+ return identifiedChannels, nil
+}
+
+func (ap *WasmProvider) QueryChannels(ctx context.Context) ([]*chantypes.IdentifiedChannel, error) {
+ nextSeq, err := ap.getNextSequence(ctx, MethodGetNextChannelSequence)
+ if err != nil {
+ return nil, err
+ }
+ var channels []*chantypes.IdentifiedChannel
+
+ allPorts, err := ap.getAllPorts(ctx)
+ if err != nil {
+ return nil, err
+ }
+ if allPorts == nil || len(allPorts) <= 0 {
+ return channels, nil
+ }
+
+ for i := 0; i <= int(nextSeq)-1; i++ {
+ for _, portId := range allPorts {
+ channelId := common.GetIdentifier(common.ChannelKey, i)
+ channel, err := ap.QueryChannelContract(ctx, portId, channelId)
+ if err != nil {
+ continue
+ }
+
+ // check if the channel is open
+ if channel.State == chantypes.OPEN {
+ identifiedChannel := chantypes.IdentifiedChannel{
+ State: channel.State,
+ Ordering: channel.Ordering,
+ Counterparty: channel.Counterparty,
+ ConnectionHops: channel.ConnectionHops,
+ Version: channel.Version,
+ PortId: portId,
+ ChannelId: channelId,
+ }
+ channels = append(channels, &identifiedChannel)
+ }
+ }
+ }
+
+ return channels, nil
+}
+
+func (ap *WasmProvider) QueryPacketCommitments(ctx context.Context, height uint64, channelid, portid string) (commitments *chantypes.QueryPacketCommitmentsResponse, err error) {
+ panic(fmt.Sprintf("%s%s", ap.ChainName(), NOT_IMPLEMENTED))
+}
+
+func (ap *WasmProvider) QueryPacketAcknowledgements(ctx context.Context, height uint64, channelid, portid string) (acknowledgements []*chantypes.PacketState, err error) {
+ panic(fmt.Sprintf("%s%s", ap.ChainName(), NOT_IMPLEMENTED))
+}
+
+func (ap *WasmProvider) QueryUnreceivedPackets(ctx context.Context, height uint64, channelid, portid string, seqs []uint64) ([]uint64, error) {
+ panic(fmt.Sprintf("%s%s", ap.ChainName(), NOT_IMPLEMENTED))
+}
+
+func (ap *WasmProvider) QueryUnreceivedAcknowledgements(ctx context.Context, height uint64, channelid, portid string, seqs []uint64) ([]uint64, error) {
+ panic(fmt.Sprintf("%s%s", ap.ChainName(), NOT_IMPLEMENTED))
+}
+
+func (ap *WasmProvider) QueryNextSeqAck(ctx context.Context, height int64, channelid, portid string) (recvRes *chantypes.QueryNextSequenceReceiveResponse, err error) {
+ panic(fmt.Sprintf("%s%s", ap.ChainName(), NOT_IMPLEMENTED))
+}
+
+func (ap *WasmProvider) QueryNextSeqRecv(ctx context.Context, height int64, channelid, portid string) (recvRes *chantypes.QueryNextSequenceReceiveResponse, err error) {
+ nextSeqRecvParams, err := types.NewNextSequenceReceive(portid, channelid).Bytes()
+ if err != nil {
+ return nil, err
+ }
+ nextSeqRecv, err := ap.QueryIBCHandlerContract(ctx, nextSeqRecvParams)
+ if err != nil {
+ return nil, err
+ }
+
+ proof, err := ap.QueryWasmProof(ctx, common.MustHexStrToBytes(STORAGEKEY__NextSequenceReceive), height)
+ if err != nil {
+ return nil, err
+ }
+
+ return &chantypes.QueryNextSequenceReceiveResponse{
+ NextSequenceReceive: sdk.BigEndianToUint64(nextSeqRecv.Data.Bytes()),
+ Proof: proof,
+ ProofHeight: clienttypes.NewHeight(0, uint64(height)),
+ }, nil
+}
+
+func (ap *WasmProvider) QueryPacketCommitment(ctx context.Context, height int64, channelid, portid string, seq uint64) (comRes *chantypes.QueryPacketCommitmentResponse, err error) {
+ pktCommitmentParams, err := types.NewPacketCommitment(portid, channelid, seq).Bytes()
+ if err != nil {
+ return nil, err
+ }
+ pktCommitment, err := ap.QueryIBCHandlerContract(ctx, pktCommitmentParams)
+ if err != nil {
+ return nil, err
+ }
+ storageKey := getStorageKeyFromPath(common.GetPacketCommitmentKey(portid, channelid, big.NewInt(int64(seq))))
+ proof, err := ap.QueryWasmProof(ctx, storageKey, height)
+
+ if err != nil {
+ return nil, err
+ }
+ return &chantypes.QueryPacketCommitmentResponse{
+ Commitment: pktCommitment.Data.Bytes(),
+ Proof: proof,
+ ProofHeight: clienttypes.NewHeight(0, uint64(height)),
+ }, nil
+
+}
+
+func (ap *WasmProvider) QueryPacketAcknowledgement(ctx context.Context, height int64, channelid, portid string, seq uint64) (ackRes *chantypes.QueryPacketAcknowledgementResponse, err error) {
+ pktAcknowledgementParams, err := types.NewPacketAcknowledgementCommitment(portid, channelid, seq).Bytes()
+ if err != nil {
+ return nil, err
+ }
+ pktAcknowledgement, err := ap.QueryIBCHandlerContract(ctx, pktAcknowledgementParams)
+ if err != nil {
+ return nil, err
+ }
+ storageKey := getStorageKeyFromPath(common.GetPacketAcknowledgementCommitmentKey(portid, channelid, big.NewInt(int64(seq))))
+ proof, err := ap.QueryWasmProof(ctx, storageKey, height)
+
+ return &chantypes.QueryPacketAcknowledgementResponse{
+ Acknowledgement: pktAcknowledgement.Data.Bytes(),
+ Proof: proof,
+ ProofHeight: clienttypes.NewHeight(0, uint64(height)),
+ }, nil
+}
+
+func (ap *WasmProvider) QueryPacketReceipt(ctx context.Context, height int64, channelid, portid string, seq uint64) (recRes *chantypes.QueryPacketReceiptResponse, err error) {
+
+ // getting proof from commitment map in contract
+ storageKey := getStorageKeyFromPath(common.GetPacketReceiptCommitmentKey(portid, channelid, big.NewInt(int64(seq))))
+ proof, err := ap.QueryWasmProof(ctx, storageKey, height)
+ if err != nil {
+ return nil, err
+ }
+
+ pktReceiptParams, err := types.NewPacketReceipt(portid, channelid, seq).Bytes()
+ if err != nil {
+ return nil, err
+ }
+
+ pktReceipt, err := ap.QueryIBCHandlerContract(ctx, pktReceiptParams)
+ if err != nil && !strings.Contains(err.Error(), "PacketReceiptNotFound") {
+ return nil, err
+ }
+
+ return &chantypes.QueryPacketReceiptResponse{
+ Received: pktReceipt != nil, // TODO: Bytes to boolean
+ Proof: proof,
+ ProofHeight: clienttypes.NewHeight(0, uint64(height)),
+ }, nil
+}
+
+func (ap *WasmProvider) GetCommitmentPrefixFromContract(ctx context.Context) ([]byte, error) {
+
+ pktCommitmentParams, err := types.NewCommitmentPrefix().Bytes()
+ if err != nil {
+ return nil, err
+ }
+ return ap.QueryIBCHandlerContractProcessed(ctx, pktCommitmentParams)
+
+}
+
+// ics 20 - transfer
+func (ap *WasmProvider) QueryDenomTrace(ctx context.Context, denom string) (*transfertypes.DenomTrace, error) {
+ transfers, err := transfertypes.NewQueryClient(ap).DenomTrace(ctx,
+ &transfertypes.QueryDenomTraceRequest{
+ Hash: denom,
+ })
+ if err != nil {
+ return nil, err
+ }
+ return transfers.DenomTrace, nil
+}
+func (ap *WasmProvider) QueryDenomTraces(ctx context.Context, offset, limit uint64, height int64) ([]transfertypes.DenomTrace, error) {
+ qc := transfertypes.NewQueryClient(ap)
+ p := DefaultPageRequest()
+ transfers := []transfertypes.DenomTrace{}
+ for {
+ res, err := qc.DenomTraces(ctx,
+ &transfertypes.QueryDenomTracesRequest{
+ Pagination: p,
+ })
+
+ if err != nil || res == nil {
+ return nil, err
+ }
+
+ transfers = append(transfers, res.DenomTraces...)
+ next := res.GetPagination().GetNextKey()
+ if len(next) == 0 {
+ break
+ }
+
+ time.Sleep(PaginationDelay)
+ p.Key = next
+ }
+ return transfers, nil
+}
+
+func (ap *WasmProvider) QueryClientPrevConsensusStateHeight(ctx context.Context, chainHeight int64, clientId string, clientHeight int64) (exported.Height, error) {
+ param, err := types.NewPrevConsensusStateHeight(clientId, uint64(clientHeight)).Bytes()
+ res, err := ap.QueryIBCHandlerContract(ctx, param)
+ if err != nil {
+ return nil, err
+ }
+
+ var heights []int64
+ err = json.Unmarshal(res.Data.Bytes(), &heights)
+
+ if err != nil {
+ return nil, err
+ }
+
+ if len(heights) == 0 {
+ return nil, fmt.Errorf("consensus state of client %s before %d", clientId, clientHeight)
+ }
+ return clienttypes.Height{RevisionNumber: 0, RevisionHeight: uint64(heights[0])}, nil
+}
diff --git a/relayer/chains/wasm/storage_key.go b/relayer/chains/wasm/storage_key.go
new file mode 100644
index 000000000..969418375
--- /dev/null
+++ b/relayer/chains/wasm/storage_key.go
@@ -0,0 +1,26 @@
+package wasm
+
+const WASM_CONTRACT_PREFIX = "03"
+
+const (
+ STORAGEKEY__ClientRegistry = "client_registry"
+ STORAGEKEY__ClientTypes = "client_types"
+ STORAGEKEY__ClientImplementations = "client_implementations"
+ STORAGEKEY__NextSequenceSend = "next_sequence_send"
+ STORAGEKEY__NextSequenceReceive = "next_sequence_recv"
+ STORAGEKEY__NextSequenceAcknowledgement = "next_sequence_ack"
+ STORAGEKEY__NextClientSequence = "next_client_sequence"
+ STORAGEKEY__NextConnectionSequence = "next_connection_sequence"
+ STORAGEKEY__NextChannelSequence = "next_channel_sequence"
+ STORAGEKEY__Connections = "connections"
+ STORAGEKEY__ClientConnection = "client_connections"
+ STORAGEKEY__Channels = "channels"
+ STORAGEKEY__Router = "router"
+ STORAGEKEY__PortToModule = "port_to_module"
+ STORAGEKEY__Commitments = "commitments"
+ STORAGEKEY__BlockTime = "block_time"
+ STORAGEKEY__BlockHeight = "block_height"
+ STORAGEKEY__Capabilities = "capabilities"
+ STORAGEKEY__PacketReceipts = "packet_receipts"
+ STORAGEKEY__Owner = "owner"
+)
diff --git a/relayer/chains/wasm/storage_key_test.go b/relayer/chains/wasm/storage_key_test.go
new file mode 100644
index 000000000..c4bacca9a
--- /dev/null
+++ b/relayer/chains/wasm/storage_key_test.go
@@ -0,0 +1,14 @@
+package wasm
+
+import (
+ "fmt"
+ "testing"
+
+ "github.com/stretchr/testify/assert"
+)
+
+func TestStorageKey(t *testing.T) {
+ s := getKey(STORAGEKEY__Commitments)
+ expected := fmt.Sprintf("000b%x", STORAGEKEY__Commitments)
+ assert.Equal(t, expected, s)
+}
diff --git a/relayer/chains/wasm/tx.go b/relayer/chains/wasm/tx.go
new file mode 100644
index 000000000..594308260
--- /dev/null
+++ b/relayer/chains/wasm/tx.go
@@ -0,0 +1,1319 @@
+package wasm
+
+import (
+ "bufio"
+ "context"
+ "encoding/hex"
+ "encoding/json"
+ "errors"
+ "fmt"
+ "os"
+ "reflect"
+ "regexp"
+ "strings"
+ "sync"
+ "time"
+
+ "github.com/cosmos/cosmos-sdk/codec/types"
+ codectypes "github.com/cosmos/cosmos-sdk/codec/types"
+
+ coretypes "github.com/cometbft/cometbft/rpc/core/types"
+
+ sdkerrors "github.com/cosmos/cosmos-sdk/types/errors"
+ txtypes "github.com/cosmos/cosmos-sdk/types/tx"
+ "go.uber.org/zap"
+ "go.uber.org/zap/zapcore"
+
+ "github.com/cosmos/cosmos-sdk/store/rootmulti"
+ "google.golang.org/grpc/codes"
+ "google.golang.org/grpc/status"
+
+ "github.com/avast/retry-go/v4"
+ abci "github.com/cometbft/cometbft/abci/types"
+ "github.com/cometbft/cometbft/light"
+ rpcclient "github.com/cometbft/cometbft/rpc/client"
+ conntypes "github.com/cosmos/ibc-go/v7/modules/core/03-connection/types"
+ commitmenttypes "github.com/cosmos/ibc-go/v7/modules/core/23-commitment/types"
+ "github.com/cosmos/relayer/v2/relayer/provider"
+ itm "github.com/icon-project/IBC-Integration/libraries/go/common/tendermint"
+
+ "github.com/cosmos/cosmos-sdk/client"
+ "github.com/cosmos/cosmos-sdk/client/input"
+ "github.com/cosmos/cosmos-sdk/client/tx"
+ sdk "github.com/cosmos/cosmos-sdk/types"
+ "github.com/cosmos/cosmos-sdk/types/tx/signing"
+ clienttypes "github.com/cosmos/ibc-go/v7/modules/core/02-client/types"
+ chantypes "github.com/cosmos/ibc-go/v7/modules/core/04-channel/types"
+ ibcexported "github.com/cosmos/ibc-go/v7/modules/core/exported"
+)
+
+var (
+ rtyAttNum = uint(5)
+ rtyAtt = retry.Attempts(rtyAttNum)
+ rtyDel = retry.Delay(time.Millisecond * 400)
+ rtyErr = retry.LastErrorOnly(true)
+ numRegex = regexp.MustCompile("[0-9]+")
+ defaultBroadcastWaitTimeout = 10 * time.Minute
+ errUnknown = "unknown"
+)
+
+// Default IBC settings
+var (
+ defaultChainPrefix = commitmenttypes.NewMerklePrefix([]byte("commitments"))
+ defaultDelayPeriod = uint64(0)
+)
+
+func (ap *WasmProvider) TxFactory() tx.Factory {
+ return tx.Factory{}.
+ WithAccountRetriever(ap).
+ WithChainID(ap.PCfg.ChainID).
+ WithTxConfig(ap.Cdc.TxConfig).
+ WithGasAdjustment(ap.PCfg.GasAdjustment).
+ WithGasPrices(ap.PCfg.GasPrices).
+ WithKeybase(ap.Keybase).
+ WithSignMode(ap.PCfg.SignMode()).
+ WithSimulateAndExecute(true)
+}
+
+// PrepareFactory mutates the tx factory with the appropriate account number, sequence number, and min gas settings.
+func (ap *WasmProvider) PrepareFactory(txf tx.Factory) (tx.Factory, error) {
+ var (
+ err error
+ from sdk.AccAddress
+ num, seq uint64
+ )
+
+ // Get key address and retry if fail
+ if err = retry.Do(func() error {
+ from, err = ap.GetKeyAddress()
+ if err != nil {
+ return err
+ }
+ return err
+ }, rtyAtt, rtyDel, rtyErr); err != nil {
+ return tx.Factory{}, err
+ }
+
+ cliCtx := client.Context{}.WithClient(ap.RPCClient).
+ WithInterfaceRegistry(ap.Cdc.InterfaceRegistry).
+ WithChainID(ap.PCfg.ChainID).
+ WithCodec(ap.Cdc.Marshaler)
+
+ // Set the account number and sequence on the transaction factory and retry if fail
+ if err = retry.Do(func() error {
+ if err = txf.AccountRetriever().EnsureExists(cliCtx, from); err != nil {
+ return err
+ }
+ return err
+ }, rtyAtt, rtyDel, rtyErr); err != nil {
+ return txf, err
+ }
+
+ // TODO: why this code? this may potentially require another query when we don't want one
+ initNum, initSeq := txf.AccountNumber(), txf.Sequence()
+ if initNum == 0 || initSeq == 0 {
+ if err = retry.Do(func() error {
+ num, seq, err = txf.AccountRetriever().GetAccountNumberSequence(cliCtx, from)
+ if err != nil {
+ return err
+ }
+ return err
+ }, rtyAtt, rtyDel, rtyErr); err != nil {
+ return txf, err
+ }
+
+ if initNum == 0 {
+ txf = txf.WithAccountNumber(num)
+ }
+
+ if initSeq == 0 {
+ txf = txf.WithSequence(seq)
+ }
+ }
+
+ if ap.PCfg.MinGasAmount != 0 {
+ txf = txf.WithGas(ap.PCfg.MinGasAmount)
+ }
+
+ return txf, nil
+}
+
+func (pc *WasmProviderConfig) SignMode() signing.SignMode {
+ signMode := signing.SignMode_SIGN_MODE_UNSPECIFIED
+ switch pc.SignModeStr {
+ case "direct":
+ signMode = signing.SignMode_SIGN_MODE_DIRECT
+ case "amino-json":
+ signMode = signing.SignMode_SIGN_MODE_LEGACY_AMINO_JSON
+ }
+ return signMode
+}
+
+func (ap *WasmProvider) NewClientState(dstChainID string, dstIBCHeader provider.IBCHeader, dstTrustingPeriod, dstUbdPeriod time.Duration, allowUpdateAfterExpiry, allowUpdateAfterMisbehaviour bool) (ibcexported.ClientState, error) {
+
+ return &itm.ClientState{
+ ChainId: dstChainID,
+ TrustLevel: &itm.Fraction{Numerator: light.DefaultTrustLevel.Numerator, Denominator: light.DefaultTrustLevel.Denominator},
+ TrustingPeriod: &itm.Duration{Seconds: int64(dstTrustingPeriod.Seconds())},
+ UnbondingPeriod: &itm.Duration{Seconds: int64(dstUbdPeriod.Seconds())},
+ FrozenHeight: 0,
+ LatestHeight: int64(dstIBCHeader.Height()),
+ AllowUpdateAfterExpiry: allowUpdateAfterExpiry,
+ AllowUpdateAfterMisbehaviour: allowUpdateAfterMisbehaviour,
+ }, nil
+}
+
+func (ap *WasmProvider) MsgCreateClient(clientState ibcexported.ClientState, consensusState ibcexported.ConsensusState) (provider.RelayerMessage, error) {
+ signer, err := ap.Address()
+ if err != nil {
+ return nil, err
+ }
+
+ anyClientState, err := clienttypes.PackClientState(clientState)
+ if err != nil {
+ return nil, err
+ }
+
+ anyConsensusState, err := clienttypes.PackConsensusState(consensusState)
+ if err != nil {
+ return nil, err
+ }
+
+ params := &clienttypes.MsgCreateClient{
+ ClientState: anyClientState,
+ ConsensusState: anyConsensusState,
+ Signer: signer,
+ }
+
+ return ap.NewWasmContractMessage(MethodCreateClient, params)
+}
+
+func (ap *WasmProvider) MsgUpgradeClient(srcClientId string, consRes *clienttypes.QueryConsensusStateResponse, clientRes *clienttypes.QueryClientStateResponse) (provider.RelayerMessage, error) {
+ panic(fmt.Sprintf("%s%s", ap.ChainName(), NOT_IMPLEMENTED))
+}
+
+func (ap *WasmProvider) MsgSubmitMisbehaviour(clientID string, misbehaviour ibcexported.ClientMessage) (provider.RelayerMessage, error) {
+ panic(fmt.Sprintf("%s%s", ap.ChainName(), NOT_IMPLEMENTED))
+}
+
+func (ap *WasmProvider) ValidatePacket(msgTransfer provider.PacketInfo, latest provider.LatestBlock) error {
+
+ if msgTransfer.Sequence == 0 {
+ return errors.New("refusing to relay packet with sequence: 0")
+ }
+
+ if len(msgTransfer.Data) == 0 {
+ return errors.New("refusing to relay packet with empty data")
+ }
+
+ // This should not be possible, as it violates IBC spec
+ if msgTransfer.TimeoutHeight.IsZero() {
+ return errors.New("refusing to relay packet without a timeout (height or timestamp must be set)")
+ }
+
+ revisionNumber := 0
+ latestClientTypesHeight := clienttypes.NewHeight(uint64(revisionNumber), latest.Height)
+ if !msgTransfer.TimeoutHeight.IsZero() && latestClientTypesHeight.GTE(msgTransfer.TimeoutHeight) {
+
+ return provider.NewTimeoutHeightError(latest.Height, msgTransfer.TimeoutHeight.RevisionHeight)
+ }
+ // latestTimestamp := uint64(latest.Time.UnixNano())
+ // if msgTransfer.TimeoutTimestamp > 0 && latestTimestamp > msgTransfer.TimeoutTimestamp {
+ // return provider.NewTimeoutTimestampError(latestTimestamp, msgTransfer.TimeoutTimestamp)
+ // }
+
+ return nil
+}
+
+func (ap *WasmProvider) PacketCommitment(ctx context.Context, msgTransfer provider.PacketInfo, height uint64) (provider.PacketProof, error) {
+ packetCommitmentResponse, err := ap.QueryPacketCommitment(
+ ctx, int64(height), msgTransfer.SourceChannel, msgTransfer.SourcePort, msgTransfer.Sequence,
+ )
+
+ if err != nil {
+ return provider.PacketProof{}, err
+ }
+ return provider.PacketProof{
+ Proof: packetCommitmentResponse.Proof,
+ ProofHeight: packetCommitmentResponse.ProofHeight,
+ }, nil
+}
+
+func (ap *WasmProvider) PacketAcknowledgement(ctx context.Context, msgRecvPacket provider.PacketInfo, height uint64) (provider.PacketProof, error) {
+ packetAckResponse, err := ap.QueryPacketAcknowledgement(ctx, int64(height), msgRecvPacket.DestChannel, msgRecvPacket.DestPort, msgRecvPacket.Sequence)
+ if err != nil {
+ return provider.PacketProof{}, err
+ }
+ return provider.PacketProof{
+ Proof: packetAckResponse.Proof,
+ ProofHeight: packetAckResponse.GetProofHeight(),
+ }, nil
+}
+
+func (ap *WasmProvider) PacketReceipt(ctx context.Context, msgTransfer provider.PacketInfo, height uint64) (provider.PacketProof, error) {
+
+ packetReceiptResponse, err := ap.QueryPacketReceipt(ctx, int64(height), msgTransfer.DestChannel, msgTransfer.DestPort, msgTransfer.Sequence)
+
+ if err != nil {
+ return provider.PacketProof{}, err
+ }
+ return provider.PacketProof{
+ Proof: packetReceiptResponse.Proof,
+ ProofHeight: packetReceiptResponse.ProofHeight,
+ }, nil
+}
+
+func (ap *WasmProvider) NextSeqRecv(ctx context.Context, msgTransfer provider.PacketInfo, height uint64) (provider.PacketProof, error) {
+ nextSeqRecvResponse, err := ap.QueryNextSeqRecv(ctx, int64(height), msgTransfer.DestChannel, msgTransfer.DestPort)
+ if err != nil {
+ return provider.PacketProof{}, err
+ }
+ return provider.PacketProof{
+ Proof: nextSeqRecvResponse.Proof,
+ ProofHeight: nextSeqRecvResponse.ProofHeight,
+ }, nil
+}
+
+func (ap *WasmProvider) MsgTransfer(dstAddr string, amount sdk.Coin, info provider.PacketInfo) (provider.RelayerMessage, error) {
+ panic(fmt.Sprintf("%s%s", ap.ChainName(), NOT_IMPLEMENTED))
+}
+
+func (ap *WasmProvider) MsgRecvPacket(msgTransfer provider.PacketInfo, proof provider.PacketProof) (provider.RelayerMessage, error) {
+ signer, err := ap.Address()
+ if err != nil {
+ return nil, err
+ }
+
+ params := &chantypes.MsgRecvPacket{
+ Packet: msgTransfer.Packet(),
+ ProofCommitment: proof.Proof,
+ ProofHeight: proof.ProofHeight,
+ Signer: signer,
+ }
+ return ap.NewWasmContractMessage(MethodRecvPacket, params)
+}
+
+func (ap *WasmProvider) MsgAcknowledgement(msgRecvPacket provider.PacketInfo, proof provider.PacketProof) (provider.RelayerMessage, error) {
+ signer, err := ap.Address()
+ if err != nil {
+ return nil, err
+ }
+
+ params := &chantypes.MsgAcknowledgement{
+ Packet: msgRecvPacket.Packet(),
+ Acknowledgement: msgRecvPacket.Ack,
+ ProofAcked: proof.Proof,
+ ProofHeight: proof.ProofHeight,
+ Signer: signer,
+ }
+ return ap.NewWasmContractMessage(MethodAcknowledgePacket, params)
+
+}
+
+func (ap *WasmProvider) MsgTimeout(msgTransfer provider.PacketInfo, proof provider.PacketProof) (provider.RelayerMessage, error) {
+ signer, err := ap.Address()
+ if err != nil {
+ return nil, err
+ }
+
+ params := &chantypes.MsgTimeout{
+ Packet: msgTransfer.Packet(),
+ ProofUnreceived: proof.Proof,
+ ProofHeight: proof.ProofHeight,
+ NextSequenceRecv: msgTransfer.Sequence,
+ Signer: signer,
+ }
+
+ return ap.NewWasmContractMessage(MethodTimeoutPacket, params)
+}
+
+func (ap *WasmProvider) MsgTimeoutRequest(msgTransfer provider.PacketInfo, proof provider.PacketProof) (provider.RelayerMessage, error) {
+ panic(fmt.Sprintf("%s%s", ap.ChainName(), NOT_IMPLEMENTED))
+}
+
+// panic
+func (ap *WasmProvider) MsgTimeoutOnClose(msgTransfer provider.PacketInfo, proofUnreceived provider.PacketProof) (provider.RelayerMessage, error) {
+ panic(fmt.Sprintf("%s%s", ap.ChainName(), NOT_IMPLEMENTED))
+}
+
+func (ap *WasmProvider) ConnectionHandshakeProof(ctx context.Context, msgOpenInit provider.ConnectionInfo, height uint64) (provider.ConnectionProof, error) {
+ clientState, clientStateProof, consensusStateProof, connStateProof, proofHeight, err := ap.GenerateConnHandshakeProof(ctx, int64(height), msgOpenInit.ClientID, msgOpenInit.ConnID)
+ if err != nil {
+ return provider.ConnectionProof{}, err
+ }
+
+ return provider.ConnectionProof{
+ ClientState: clientState,
+ ClientStateProof: clientStateProof,
+ ConsensusStateProof: consensusStateProof,
+ ConnectionStateProof: connStateProof,
+ ProofHeight: proofHeight.(clienttypes.Height),
+ }, nil
+}
+
+func (ap *WasmProvider) ConnectionProof(ctx context.Context, msgOpenAck provider.ConnectionInfo, height uint64) (provider.ConnectionProof, error) {
+ connState, err := ap.QueryConnection(ctx, int64(height), msgOpenAck.ConnID)
+ if err != nil {
+ return provider.ConnectionProof{}, err
+ }
+ return provider.ConnectionProof{
+ ConnectionStateProof: connState.Proof,
+ ProofHeight: connState.ProofHeight,
+ }, nil
+}
+
+func (ap *WasmProvider) MsgConnectionOpenInit(info provider.ConnectionInfo, proof provider.ConnectionProof) (provider.RelayerMessage, error) {
+ signer, err := ap.Address()
+ if err != nil {
+ return nil, err
+ }
+ params := &conntypes.MsgConnectionOpenInit{
+ ClientId: info.ClientID,
+ Counterparty: conntypes.Counterparty{
+ ClientId: info.CounterpartyClientID,
+ ConnectionId: "",
+ Prefix: info.CounterpartyCommitmentPrefix,
+ },
+ Version: nil,
+ DelayPeriod: defaultDelayPeriod,
+ Signer: signer,
+ }
+
+ return ap.NewWasmContractMessage(MethodConnectionOpenInit, params)
+
+}
+
+func (ap *WasmProvider) MsgConnectionOpenTry(msgOpenInit provider.ConnectionInfo, proof provider.ConnectionProof) (provider.RelayerMessage, error) {
+ signer, err := ap.Address()
+ if err != nil {
+ return nil, err
+ }
+ csAny, err := clienttypes.PackClientState(proof.ClientState)
+ if err != nil {
+ return nil, err
+ }
+
+ counterparty := conntypes.Counterparty{
+ ClientId: msgOpenInit.ClientID,
+ ConnectionId: msgOpenInit.ConnID,
+ Prefix: msgOpenInit.CommitmentPrefix,
+ }
+
+ params := &conntypes.MsgConnectionOpenTry{
+ ClientId: msgOpenInit.CounterpartyClientID,
+ PreviousConnectionId: msgOpenInit.CounterpartyConnID,
+ ClientState: csAny,
+ Counterparty: counterparty,
+ DelayPeriod: defaultDelayPeriod,
+ CounterpartyVersions: conntypes.ExportedVersionsToProto(conntypes.GetCompatibleVersions()),
+ ProofHeight: proof.ProofHeight,
+ ProofInit: proof.ConnectionStateProof,
+ ProofClient: proof.ClientStateProof,
+ ProofConsensus: proof.ConsensusStateProof,
+ ConsensusHeight: proof.ClientState.GetLatestHeight().(clienttypes.Height),
+ Signer: signer,
+ }
+
+ return ap.NewWasmContractMessage(MethodConnectionOpenTry, params)
+
+}
+
+func (ap *WasmProvider) MsgConnectionOpenAck(msgOpenTry provider.ConnectionInfo, proof provider.ConnectionProof) (provider.RelayerMessage, error) {
+ signer, err := ap.Address()
+ if err != nil {
+ return nil, err
+ }
+
+ csAny, err := clienttypes.PackClientState(proof.ClientState)
+ if err != nil {
+ return nil, err
+ }
+
+ params := &conntypes.MsgConnectionOpenAck{
+ ConnectionId: msgOpenTry.CounterpartyConnID,
+ CounterpartyConnectionId: msgOpenTry.ConnID,
+ Version: conntypes.DefaultIBCVersion,
+ ClientState: csAny,
+ ProofHeight: clienttypes.Height{
+ RevisionNumber: proof.ProofHeight.GetRevisionNumber(),
+ RevisionHeight: proof.ProofHeight.GetRevisionHeight(),
+ },
+ ProofTry: proof.ConnectionStateProof,
+ ProofClient: proof.ClientStateProof,
+ ProofConsensus: proof.ConsensusStateProof,
+ ConsensusHeight: proof.ClientState.GetLatestHeight().(clienttypes.Height),
+ Signer: signer,
+ }
+
+ return ap.NewWasmContractMessage(MethodConnectionOpenAck, params)
+}
+
+func (ap *WasmProvider) MsgConnectionOpenConfirm(msgOpenAck provider.ConnectionInfo, proof provider.ConnectionProof) (provider.RelayerMessage, error) {
+ signer, err := ap.Address()
+ if err != nil {
+ return nil, err
+ }
+ params := &conntypes.MsgConnectionOpenConfirm{
+ ConnectionId: msgOpenAck.CounterpartyConnID,
+ ProofAck: proof.ConnectionStateProof,
+ ProofHeight: proof.ProofHeight,
+ Signer: signer,
+ }
+ return ap.NewWasmContractMessage(MethodConnectionOpenConfirm, params)
+}
+
+func (ap *WasmProvider) ChannelProof(ctx context.Context, msg provider.ChannelInfo, height uint64) (provider.ChannelProof, error) {
+ channelResult, err := ap.QueryChannel(ctx, int64(height), msg.ChannelID, msg.PortID)
+ if err != nil {
+ return provider.ChannelProof{}, nil
+ }
+ return provider.ChannelProof{
+ Proof: channelResult.Proof,
+ ProofHeight: clienttypes.Height{
+ RevisionNumber: 0,
+ RevisionHeight: height,
+ },
+ Ordering: chantypes.Order(channelResult.Channel.GetOrdering()),
+ Version: channelResult.Channel.Version,
+ }, nil
+}
+
+func (ap *WasmProvider) MsgChannelOpenInit(info provider.ChannelInfo, proof provider.ChannelProof) (provider.RelayerMessage, error) {
+ signer, err := ap.Address()
+ if err != nil {
+ return nil, err
+ }
+ params := &chantypes.MsgChannelOpenInit{
+ PortId: info.PortID,
+ Channel: chantypes.Channel{
+ State: chantypes.INIT,
+ Ordering: info.Order,
+ Counterparty: chantypes.Counterparty{
+ PortId: info.CounterpartyPortID,
+ ChannelId: "",
+ },
+ ConnectionHops: []string{info.ConnID},
+ Version: info.Version,
+ },
+ Signer: signer,
+ }
+ return ap.NewWasmContractMessage(MethodChannelOpenInit, params)
+}
+
+func (ap *WasmProvider) MsgChannelOpenTry(msgOpenInit provider.ChannelInfo, proof provider.ChannelProof) (provider.RelayerMessage, error) {
+ signer, err := ap.Address()
+ if err != nil {
+ return nil, err
+ }
+
+ params := &chantypes.MsgChannelOpenTry{
+ PortId: msgOpenInit.CounterpartyPortID,
+ PreviousChannelId: msgOpenInit.CounterpartyChannelID,
+ Channel: chantypes.Channel{
+ State: chantypes.TRYOPEN,
+ Ordering: proof.Ordering,
+ Counterparty: chantypes.Counterparty{
+ PortId: msgOpenInit.PortID,
+ ChannelId: msgOpenInit.ChannelID,
+ },
+ ConnectionHops: []string{msgOpenInit.CounterpartyConnID},
+ // In the future, may need to separate this from the CounterpartyVersion.
+ // https://github.com/cosmos/ibc/tree/master/spec/core/ics-004-channel-and-packet-semantics#definitions
+ // Using same version as counterparty for now.
+ Version: proof.Version,
+ },
+ CounterpartyVersion: proof.Version,
+ ProofInit: proof.Proof,
+ ProofHeight: proof.ProofHeight,
+ Signer: signer,
+ }
+ return ap.NewWasmContractMessage(MethodChannelOpenTry, params)
+}
+
+func (ap *WasmProvider) MsgChannelOpenAck(msgOpenTry provider.ChannelInfo, proof provider.ChannelProof) (provider.RelayerMessage, error) {
+ signer, err := ap.Address()
+ if err != nil {
+ return nil, err
+ }
+
+ params := &chantypes.MsgChannelOpenAck{
+ PortId: msgOpenTry.CounterpartyPortID,
+ ChannelId: msgOpenTry.CounterpartyChannelID,
+ CounterpartyChannelId: msgOpenTry.ChannelID,
+ CounterpartyVersion: proof.Version,
+ ProofTry: proof.Proof,
+ ProofHeight: proof.ProofHeight,
+ Signer: signer,
+ }
+ return ap.NewWasmContractMessage(MethodChannelOpenAck, params)
+}
+
+func (ap *WasmProvider) MsgChannelOpenConfirm(msgOpenAck provider.ChannelInfo, proof provider.ChannelProof) (provider.RelayerMessage, error) {
+ signer, err := ap.Address()
+ if err != nil {
+ return nil, err
+ }
+
+ params := &chantypes.MsgChannelOpenConfirm{
+ PortId: msgOpenAck.CounterpartyPortID,
+ ChannelId: msgOpenAck.CounterpartyChannelID,
+ ProofAck: proof.Proof,
+ ProofHeight: proof.ProofHeight,
+ Signer: signer,
+ }
+ return ap.NewWasmContractMessage(MethodChannelOpenConfirm, params)
+}
+
+func (ap *WasmProvider) MsgChannelCloseInit(info provider.ChannelInfo, proof provider.ChannelProof) (provider.RelayerMessage, error) {
+ signer, err := ap.Address()
+ if err != nil {
+ return nil, err
+ }
+
+ params := &chantypes.MsgChannelCloseInit{
+ PortId: info.PortID,
+ ChannelId: info.ChannelID,
+ Signer: signer,
+ }
+
+ return ap.NewWasmContractMessage(MethodChannelCloseInit, params)
+}
+
+func (ap *WasmProvider) MsgChannelCloseConfirm(msgCloseInit provider.ChannelInfo, proof provider.ChannelProof) (provider.RelayerMessage, error) {
+ signer, err := ap.Address()
+ if err != nil {
+ return nil, err
+ }
+
+ params := &chantypes.MsgChannelCloseConfirm{
+ PortId: msgCloseInit.CounterpartyPortID,
+ ChannelId: msgCloseInit.CounterpartyChannelID,
+ ProofInit: proof.Proof,
+ ProofHeight: proof.ProofHeight,
+ Signer: signer,
+ }
+
+ return ap.NewWasmContractMessage(MethodChannelCloseConfirm, params)
+}
+
+func (ap *WasmProvider) MsgUpdateClientHeader(latestHeader provider.IBCHeader, trustedHeight clienttypes.Height, trustedHeader provider.IBCHeader) (ibcexported.ClientMessage, error) {
+ trustedWasmHeader, ok := trustedHeader.(WasmIBCHeader)
+ if !ok {
+ return nil, fmt.Errorf("unsupported IBC trusted header type, expected: TendermintIBCHeader, actual: %T", trustedHeader)
+ }
+
+ latestWasmHeader, ok := latestHeader.(WasmIBCHeader)
+ if !ok {
+ return nil, fmt.Errorf("unsupported IBC header type, expected: TendermintIBCHeader, actual: %T", latestHeader)
+ }
+
+ return &itm.TmHeader{
+ SignedHeader: latestWasmHeader.SignedHeader,
+ ValidatorSet: latestWasmHeader.ValidatorSet,
+ TrustedValidators: trustedWasmHeader.ValidatorSet,
+ TrustedHeight: int64(trustedHeight.RevisionHeight),
+ }, nil
+}
+
+func (ap *WasmProvider) MsgUpdateClient(clientID string, dstHeader ibcexported.ClientMessage) (provider.RelayerMessage, error) {
+ signer, err := ap.Address()
+ if err != nil {
+ return nil, err
+ }
+ clientMsg, err := clienttypes.PackClientMessage(dstHeader)
+ if err != nil {
+ return nil, err
+ }
+
+ params := &clienttypes.MsgUpdateClient{
+ ClientId: clientID,
+ ClientMessage: clientMsg,
+ Signer: signer,
+ }
+
+ return ap.NewWasmContractMessage(MethodUpdateClient, params)
+
+}
+
+func (ap *WasmProvider) QueryICQWithProof(ctx context.Context, msgType string, request []byte, height uint64) (provider.ICQProof, error) {
+ panic(fmt.Sprintf("%s%s", ap.ChainName(), NOT_IMPLEMENTED))
+}
+
+func (ap *WasmProvider) MsgSubmitQueryResponse(chainID string, queryID provider.ClientICQQueryID, proof provider.ICQProof) (provider.RelayerMessage, error) {
+ panic(fmt.Sprintf("%s%s", ap.ChainName(), NOT_IMPLEMENTED))
+}
+
+func (ap *WasmProvider) RelayPacketFromSequence(ctx context.Context, src provider.ChainProvider, srch, dsth, seq uint64, srcChanID, srcPortID string, order chantypes.Order) (provider.RelayerMessage, provider.RelayerMessage, error) {
+ panic(fmt.Sprintf("%s%s", ap.ChainName(), NOT_IMPLEMENTED))
+}
+
+func (ap *WasmProvider) AcknowledgementFromSequence(ctx context.Context, dst provider.ChainProvider, dsth, seq uint64, dstChanID, dstPortID, srcChanID, srcPortID string) (provider.RelayerMessage, error) {
+ panic(fmt.Sprintf("%s%s", ap.ChainName(), NOT_IMPLEMENTED))
+}
+
+func (ap *WasmProvider) SendMessage(ctx context.Context, msg provider.RelayerMessage, memo string) (*provider.RelayerTxResponse, bool, error) {
+ return ap.SendMessages(ctx, []provider.RelayerMessage{msg}, memo)
+}
+
+func (ap *WasmProvider) SendMessages(ctx context.Context, msgs []provider.RelayerMessage, memo string) (*provider.RelayerTxResponse, bool, error) {
+ var (
+ rlyResp *provider.RelayerTxResponse
+ callbackErr error
+ wg sync.WaitGroup
+ )
+
+ callback := func(rtr *provider.RelayerTxResponse, err error) {
+ callbackErr = err
+
+ if err != nil {
+ wg.Done()
+ return
+ }
+
+ for i, e := range rtr.Events {
+ if startsWithWasm(e.EventType) {
+ rtr.Events[i].EventType = findEventType(e.EventType)
+ }
+ }
+ rlyResp = rtr
+ wg.Done()
+ }
+
+ wg.Add(1)
+
+ if err := retry.Do(func() error {
+ return ap.SendMessagesToMempool(ctx, msgs, memo, ctx, []func(*provider.RelayerTxResponse, error){callback})
+ }, retry.Context(ctx), rtyAtt, rtyDel, rtyErr, retry.OnRetry(func(n uint, err error) {
+ ap.log.Info(
+ "Error building or broadcasting transaction",
+ zap.String("chain_id", ap.PCfg.ChainID),
+ zap.Uint("attempt", n+1),
+ zap.Uint("max_attempts", rtyAttNum),
+ zap.Error(err),
+ )
+ })); err != nil {
+ return nil, false, err
+ }
+
+ wg.Wait()
+
+ if callbackErr != nil {
+ return rlyResp, false, callbackErr
+ }
+
+ if rlyResp.Code != 0 {
+ return rlyResp, false, fmt.Errorf("transaction failed with code: %d", rlyResp.Code)
+ }
+
+ return rlyResp, true, callbackErr
+}
+
+func (ap *WasmProvider) SendMessagesToMempool(
+ ctx context.Context,
+ msgs []provider.RelayerMessage,
+ memo string,
+
+ asyncCtx context.Context,
+ asyncCallback []func(*provider.RelayerTxResponse, error),
+) error {
+ ap.txMu.Lock()
+ defer ap.txMu.Unlock()
+
+ cliCtx := ap.ClientContext()
+ factory, err := ap.PrepareFactory(ap.TxFactory())
+ if err != nil {
+ return err
+ }
+
+ // uncomment for saving msg
+ // SaveMsgToFile(WasmDebugMessagePath, msgs)
+
+ for _, msg := range msgs {
+ if msg == nil {
+ ap.log.Debug("One of the message of is nil ")
+ continue
+ }
+
+ wasmMsg, ok := msg.(*WasmContractMessage)
+ if !ok {
+ return fmt.Errorf("Wasm Message is not valid %s", wasmMsg.Type())
+ }
+
+ txBytes, sequence, err := ap.buildMessages(cliCtx, factory, wasmMsg.Msg)
+ if err != nil {
+ return err
+ }
+
+ // if msg.Type() == MethodUpdateClient {
+ // if err := retry.Do(func() error {
+ // if err := ap.BroadcastTx(cliCtx, txBytes, []provider.RelayerMessage{msg}, asyncCtx, defaultBroadcastWaitTimeout, asyncCallback, true); err != nil {
+ // if strings.Contains(err.Error(), sdkerrors.ErrWrongSequence.Error()) {
+ // ap.handleAccountSequenceMismatchError(err)
+ // }
+ // }
+ // return err
+ // }, retry.Context(ctx), rtyAtt, retry.Delay(time.Millisecond*time.Duration(ap.PCfg.BlockInterval)), rtyErr); err != nil {
+ // ap.log.Error("Failed to update client", zap.Any("Message", msg))
+ // return err
+ // }
+ // continue
+ // }
+ if err := ap.BroadcastTx(cliCtx, txBytes, []provider.RelayerMessage{msg}, asyncCtx, defaultBroadcastWaitTimeout, asyncCallback, false); err != nil {
+ if strings.Contains(err.Error(), sdkerrors.ErrWrongSequence.Error()) {
+ ap.handleAccountSequenceMismatchError(err)
+ }
+ }
+ ap.updateNextAccountSequence(sequence + 1)
+ }
+
+ return nil
+
+}
+
+func (ap *WasmProvider) LogFailedTx(res *provider.RelayerTxResponse, err error, msgs []provider.RelayerMessage) {
+
+ fields := []zapcore.Field{zap.String("chain_id", ap.ChainId())}
+ // if res != nil {
+ // channels := getChannelsIfPresent(res.Events)
+ // fields = append(fields, channels...)
+ // }
+ fields = append(fields, msgTypesField(msgs))
+
+ if err != nil {
+ // Make a copy since we may continue to the warning
+ errorFields := append(fields, zap.Error(err))
+ ap.log.Error(
+ "Failed sending wasm transaction",
+ errorFields...,
+ )
+
+ if res == nil {
+ return
+ }
+ }
+ if res.Code != 0 {
+ if sdkErr := ap.sdkError(res.Codespace, res.Code); err != nil {
+ fields = append(fields, zap.NamedError("sdk_error", sdkErr))
+ }
+ fields = append(fields, zap.Object("response", res))
+ ap.log.Warn(
+ "Sent transaction but received failure response",
+ fields...,
+ )
+ }
+}
+
+// LogSuccessTx take the transaction and the messages to create it and logs the appropriate data
+func (ap *WasmProvider) LogSuccessTx(res *sdk.TxResponse, msgs []provider.RelayerMessage) {
+ // Include the chain_id
+ fields := []zapcore.Field{zap.String("chain_id", ap.ChainId())}
+ done := ap.SetSDKContext()
+ defer done()
+
+ // Include the gas used
+ fields = append(fields, zap.Int64("gas_used", res.GasUsed))
+
+ // Extract fees and fee_payer if present
+ ir := types.NewInterfaceRegistry()
+ var m sdk.Msg
+ if err := ir.UnpackAny(res.Tx, &m); err == nil {
+ if tx, ok := m.(*txtypes.Tx); ok {
+ fields = append(fields, zap.Stringer("fees", tx.GetFee()))
+ if feePayer := getFeePayer(tx); feePayer != "" {
+ fields = append(fields, zap.String("fee_payer", feePayer))
+ }
+ } else {
+ ap.log.Debug(
+ "Failed to convert message to Tx type",
+ zap.Stringer("type", reflect.TypeOf(m)),
+ )
+ }
+ } else {
+ ap.log.Debug("Failed to unpack response Tx into sdk.Msg", zap.Error(err))
+ }
+
+ // Include the height, msgType, and tx_hash
+ fields = append(fields,
+ zap.Int64("height", res.Height),
+ msgTypesField(msgs),
+ zap.String("tx_hash", res.TxHash),
+ )
+
+ // Log the succesful transaction with fields
+ ap.log.Info(
+ "Successful transaction",
+ fields...,
+ )
+
+}
+
+// getFeePayer returns the bech32 address of the fee payer of a transaction.
+// This uses the fee payer field if set,
+// otherwise falls back to the address of whoever signed the first message.
+func getFeePayer(tx *txtypes.Tx) string {
+ payer := tx.AuthInfo.Fee.Payer
+ if payer != "" {
+ return payer
+ }
+ switch firstMsg := tx.GetMsgs()[0].(type) {
+
+ case *clienttypes.MsgCreateClient:
+ // Without this particular special case, there is a panic in ibc-go
+ // due to the sdk config singleton expecting one bech32 prefix but seeing another.
+ return firstMsg.Signer
+ case *clienttypes.MsgUpdateClient:
+ // Same failure mode as MsgCreateClient.
+ return firstMsg.Signer
+ default:
+ return firstMsg.GetSigners()[0].String()
+ }
+
+}
+
+func (ap *WasmProvider) sdkError(codespace string, code uint32) error {
+ // ABCIError will return an error other than "unknown" if syncRes.Code is a registered error in syncRes.Codespace
+ // This catches all of the sdk errors https://github.com/cosmos/cosmos-sdk/blob/f10f5e5974d2ecbf9efc05bc0bfe1c99fdeed4b6/types/errors/errors.go
+ err := errors.Unwrap(sdkerrors.ABCIError(codespace, code, "error broadcasting transaction"))
+ if err.Error() != errUnknown {
+ return err
+ }
+ return nil
+}
+
+func (ap *WasmProvider) buildMessages(clientCtx client.Context, txf tx.Factory, msgs ...sdk.Msg) ([]byte, uint64, error) {
+ done := ap.SetSDKContext()
+ defer done()
+
+ for _, msg := range msgs {
+ if err := msg.ValidateBasic(); err != nil {
+ return nil, 0, err
+ }
+ }
+
+ // If the --aux flag is set, we simply generate and print the AuxSignerData.
+ // tf is aux? do we need it? prolly not
+ if clientCtx.IsAux {
+ auxSignerData, err := makeAuxSignerData(clientCtx, txf, msgs...)
+ if err != nil {
+ return nil, 0, err
+ }
+
+ return nil, 0, clientCtx.PrintProto(&auxSignerData)
+ }
+
+ if clientCtx.GenerateOnly {
+ return nil, 0, txf.PrintUnsignedTx(clientCtx, msgs...)
+ }
+
+ txf, err := txf.Prepare(clientCtx)
+ if err != nil {
+ return nil, 0, err
+ }
+
+ sequence := txf.Sequence()
+ ap.updateNextAccountSequence(sequence)
+ if sequence < ap.nextAccountSeq {
+ sequence = ap.nextAccountSeq
+ txf = txf.WithSequence(sequence)
+ }
+
+ if txf.SimulateAndExecute() || clientCtx.Simulate {
+ if clientCtx.Offline {
+ return nil, 0, errors.New("cannot estimate gas in offline mode")
+ }
+
+ _, adjusted, err := tx.CalculateGas(clientCtx, txf, msgs...)
+ if err != nil {
+ return nil, 0, err
+ }
+
+ txf = txf.WithGas(adjusted)
+ // _, _ = fmt.Fprintf(os.Stderr, "%s\n", tx.GasEstimateResponse{GasEstimate: txf.Gas()})
+ }
+
+ if clientCtx.Simulate {
+ return nil, 0, nil
+ }
+
+ txn, err := txf.BuildUnsignedTx(msgs...)
+ if err != nil {
+ return nil, 0, err
+ }
+
+ if !clientCtx.SkipConfirm {
+ txBytes, err := clientCtx.TxConfig.TxJSONEncoder()(txn.GetTx())
+ if err != nil {
+ return nil, 0, err
+ }
+
+ if err := clientCtx.PrintRaw(json.RawMessage(txBytes)); err != nil {
+ _, _ = fmt.Fprintf(os.Stderr, "%s\n", txBytes)
+ }
+
+ buf := bufio.NewReader(os.Stdin)
+ ok, err := input.GetConfirmation("confirm transaction before signing and broadcasting", buf, os.Stderr)
+
+ if err != nil || !ok {
+ _, _ = fmt.Fprintf(os.Stderr, "%s\n", "cancelled transaction")
+ return nil, 0, err
+ }
+ }
+
+ err = tx.Sign(txf, clientCtx.GetFromName(), txn, true)
+ if err != nil {
+ return nil, 0, err
+ }
+
+ res, err := clientCtx.TxConfig.TxEncoder()(txn.GetTx())
+ return res, sequence, nil
+}
+
+func (ap *WasmProvider) BroadcastTx(
+ clientCtx client.Context,
+ txBytes []byte,
+ msgs []provider.RelayerMessage,
+ asyncCtx context.Context, // context for async wait for block inclusion after successful tx broadcast
+ asyncTimeout time.Duration, // timeout for waiting for block inclusion
+ asyncCallback []func(*provider.RelayerTxResponse, error), // callback for success/fail of the wait for block inclusion
+ shouldWait bool,
+) error {
+ res, err := clientCtx.BroadcastTx(txBytes)
+ // log submitted txn
+
+ isErr := err != nil
+ isFailed := res != nil && res.Code != 0
+ if isErr || isFailed {
+ if isErr && res == nil {
+ // There are some cases where BroadcastTxSync will return an error but the associated
+ // ResultBroadcastTx will be nil.
+ return err
+ }
+ rlyResp := &provider.RelayerTxResponse{
+ TxHash: res.TxHash,
+ Codespace: res.Codespace,
+ Code: res.Code,
+ Data: res.Data,
+ }
+ if isFailed {
+ err = ap.sdkError(res.Codespace, res.Code)
+ if err == nil {
+ err = fmt.Errorf("transaction failed to execute")
+ }
+ }
+ ap.LogFailedTx(rlyResp, err, msgs)
+ return err
+ }
+
+ hexTx, err := hex.DecodeString(res.TxHash)
+ if err != nil {
+ return err
+ }
+
+ ap.log.Info("Submitted transaction",
+ zap.String("chain_id", ap.PCfg.ChainID),
+ zap.String("tx_hash", res.TxHash),
+ msgTypesField(msgs),
+ )
+
+ if shouldWait {
+ return ap.waitForTx(asyncCtx, hexTx, msgs, asyncTimeout, asyncCallback)
+ }
+ go ap.waitForTx(asyncCtx, hexTx, msgs, asyncTimeout, asyncCallback)
+ return nil
+}
+
+// BroadcastTx attempts to generate, sign and broadcast a transaction with the
+// given set of messages. It will also simulate gas requirements if necessary.
+// It will return an error upon failure.
+// UNUSED: PANIC
+func (ap *WasmProvider) broadcastTx(
+ ctx context.Context, // context for tx broadcast
+ tx []byte, // raw tx to be broadcasted
+ msgs []provider.RelayerMessage, // used for logging only
+ fees sdk.Coins, // used for metrics
+
+ asyncCtx context.Context, // context for async wait for block inclusion after successful tx broadcast
+ asyncTimeout time.Duration, // timeout for waiting for block inclusion
+ asyncCallback func(*provider.RelayerTxResponse, error), // callback for success/fail of the wait for block inclusion
+) error {
+ panic(fmt.Sprintf("%s%s", ap.ChainName(), NOT_IMPLEMENTED))
+}
+
+func (ap *WasmProvider) waitForTx(
+ ctx context.Context,
+ txHash []byte,
+ msgs []provider.RelayerMessage, // used for logging only
+ waitTimeout time.Duration,
+ callbacks []func(*provider.RelayerTxResponse, error),
+) error {
+ res, err := ap.waitForTxResult(ctx, txHash, waitTimeout)
+ if err != nil {
+ ap.log.Error("Failed to wait for block inclusion", zap.Error(err))
+ if len(callbacks) > 0 {
+ for _, cb := range callbacks {
+ cb(nil, err)
+ }
+ }
+ return err
+ }
+
+ rlyResp := &provider.RelayerTxResponse{
+ Height: res.Height,
+ TxHash: res.TxHash,
+ Codespace: res.Codespace,
+ Code: res.Code,
+ Data: res.Data,
+ Events: parseEventsFromTxResponse(res),
+ }
+
+ // transaction was executed, log the success or failure using the tx response code
+ // NOTE: error is nil, logic should use the returned error to determine if the
+ // transaction was successfully executed.
+
+ if res.Code != 0 {
+ // Check for any registered SDK errors
+ err := ap.sdkError(res.Codespace, res.Code)
+ if err == nil {
+ err = fmt.Errorf("transaction failed to execute")
+ }
+ if len(callbacks) > 0 {
+ for _, cb := range callbacks {
+ cb(nil, err)
+ }
+ }
+ ap.LogFailedTx(rlyResp, nil, msgs)
+ return err
+ }
+
+ if len(callbacks) > 0 {
+ for _, cb := range callbacks {
+ // Call each callback in order since waitForTx is already invoked asyncronously
+ cb(rlyResp, err)
+ }
+ }
+
+ ap.LogSuccessTx(res, msgs)
+ return nil
+}
+
+func (ap *WasmProvider) waitForTxResult(
+ ctx context.Context,
+ txHash []byte,
+ waitTimeout time.Duration,
+) (*sdk.TxResponse, error) {
+ exitAfter := time.After(waitTimeout)
+ for {
+ select {
+ case <-exitAfter:
+ return nil, fmt.Errorf("timed out after: %d; %s", waitTimeout, ErrTimeoutAfterWaitingForTxBroadcast)
+ case <-time.After(time.Millisecond * 100):
+ res, err := ap.RPCClient.Tx(ctx, txHash, false)
+ if err == nil && res == nil {
+ continue
+ }
+ if err == nil {
+ return ap.mkTxResult(res)
+ }
+ if strings.Contains(err.Error(), "transaction indexing is disabled") {
+ return nil, fmt.Errorf("cannot determine success/failure of tx because transaction indexing is disabled on rpc url")
+ }
+ case <-ctx.Done():
+ return nil, ctx.Err()
+ }
+ }
+}
+
+func msgTypesField(msgs []provider.RelayerMessage) zap.Field {
+ msgTypes := make([]string, len(msgs))
+ for i, m := range msgs {
+ if m == nil {
+ continue
+ }
+ msgTypes[i] = m.Type()
+ }
+ return zap.Strings("msg_types", msgTypes)
+}
+
+const (
+ ErrTimeoutAfterWaitingForTxBroadcast string = "timed out after waiting for tx to get included in the block"
+)
+
+type intoAny interface {
+ AsAny() *codectypes.Any
+}
+
+func (ap *WasmProvider) mkTxResult(resTx *coretypes.ResultTx) (*sdk.TxResponse, error) {
+ txbz, err := ap.Cdc.TxConfig.TxDecoder()(resTx.Tx)
+ if err != nil {
+ return nil, err
+ }
+ p, ok := txbz.(intoAny)
+ if !ok {
+ return nil, fmt.Errorf("expecting a type implementing intoAny, got: %T", txbz)
+ }
+ any := p.AsAny()
+ return sdk.NewResponseResultTx(resTx, any, ""), nil
+}
+
+func makeAuxSignerData(clientCtx client.Context, f tx.Factory, msgs ...sdk.Msg) (txtypes.AuxSignerData, error) {
+ b := tx.NewAuxTxBuilder()
+ fromAddress, name, _, err := client.GetFromFields(clientCtx, clientCtx.Keyring, clientCtx.From)
+ if err != nil {
+ return txtypes.AuxSignerData{}, err
+ }
+
+ b.SetAddress(fromAddress.String())
+ if clientCtx.Offline {
+ b.SetAccountNumber(f.AccountNumber())
+ b.SetSequence(f.Sequence())
+ } else {
+ accNum, seq, err := clientCtx.AccountRetriever.GetAccountNumberSequence(clientCtx, fromAddress)
+ if err != nil {
+ return txtypes.AuxSignerData{}, err
+ }
+ b.SetAccountNumber(accNum)
+ b.SetSequence(seq)
+ }
+
+ err = b.SetMsgs(msgs...)
+ if err != nil {
+ return txtypes.AuxSignerData{}, err
+ }
+
+ // if f.tip != nil {
+ // if _, err := sdk.AccAddressFromBech32(f.tip.Tipper); err != nil {
+ // return txtypes.AuxSignerData{}, sdkerrors.ErrInvalidAddress.Wrap("tipper must be a bech32 address")
+ // }
+ // b.SetTip(f.tip)
+ // }
+
+ err = b.SetSignMode(f.SignMode())
+ if err != nil {
+ return txtypes.AuxSignerData{}, err
+ }
+
+ key, err := clientCtx.Keyring.Key(name)
+ if err != nil {
+ return txtypes.AuxSignerData{}, err
+ }
+
+ pub, err := key.GetPubKey()
+ if err != nil {
+ return txtypes.AuxSignerData{}, err
+ }
+
+ err = b.SetPubKey(pub)
+ if err != nil {
+ return txtypes.AuxSignerData{}, err
+ }
+
+ b.SetChainID(clientCtx.ChainID)
+ signBz, err := b.GetSignBytes()
+ if err != nil {
+ return txtypes.AuxSignerData{}, err
+ }
+
+ sig, _, err := clientCtx.Keyring.Sign(name, signBz)
+ if err != nil {
+ return txtypes.AuxSignerData{}, err
+ }
+ b.SetSignature(sig)
+
+ return b.GetAuxSignerData()
+}
+
+func parseEventsFromTxResponse(resp *sdk.TxResponse) []provider.RelayerEvent {
+ var events []provider.RelayerEvent
+
+ if resp == nil {
+ return events
+ }
+
+ for _, logs := range resp.Logs {
+ for _, event := range logs.Events {
+ attributes := make(map[string]string)
+ for _, attribute := range event.Attributes {
+ attributes[attribute.Key] = attribute.Value
+ }
+ events = append(events, provider.RelayerEvent{
+ EventType: event.Type,
+ Attributes: attributes,
+ })
+ }
+ }
+ return events
+}
+
+// QueryABCI performs an ABCI query and returns the appropriate response and error sdk error code.
+func (cc *WasmProvider) QueryABCI(ctx context.Context, req abci.RequestQuery) (abci.ResponseQuery, error) {
+ opts := rpcclient.ABCIQueryOptions{
+ Height: req.Height,
+ Prove: req.Prove,
+ }
+ result, err := cc.RPCClient.ABCIQueryWithOptions(ctx, req.Path, req.Data, opts)
+ if err != nil {
+ return abci.ResponseQuery{}, err
+ }
+
+ if !result.Response.IsOK() {
+ return abci.ResponseQuery{}, sdkErrorToGRPCError(result.Response)
+ }
+
+ // data from trusted node or subspace query doesn't need verification
+ if !opts.Prove || !isQueryStoreWithProof(req.Path) {
+ return result.Response, nil
+ }
+
+ return result.Response, nil
+}
+
+func (cc *WasmProvider) handleAccountSequenceMismatchError(err error) {
+
+ clientCtx := cc.ClientContext()
+ _, seq, err := cc.ClientCtx.AccountRetriever.GetAccountNumberSequence(clientCtx, clientCtx.GetFromAddress())
+
+ // sequences := numRegex.FindAllString(err.Error(), -1)
+ // if len(sequences) != 2 {
+ // return
+ // }
+ // nextSeq, err := strconv.ParseUint(sequences[0], 10, 64)
+ if err != nil {
+ return
+ }
+
+ cc.nextAccountSeq = seq
+}
+
+func sdkErrorToGRPCError(resp abci.ResponseQuery) error {
+ switch resp.Code {
+ case sdkerrors.ErrInvalidRequest.ABCICode():
+ return status.Error(codes.InvalidArgument, resp.Log)
+ case sdkerrors.ErrUnauthorized.ABCICode():
+ return status.Error(codes.Unauthenticated, resp.Log)
+ case sdkerrors.ErrKeyNotFound.ABCICode():
+ return status.Error(codes.NotFound, resp.Log)
+ default:
+ return status.Error(codes.Unknown, resp.Log)
+ }
+}
+
+// isQueryStoreWithProof expects a format like ///
+// queryType must be "store" and subpath must be "key" to require a proof.
+func isQueryStoreWithProof(path string) bool {
+ if !strings.HasPrefix(path, "/") {
+ return false
+ }
+
+ paths := strings.SplitN(path[1:], "/", 3)
+
+ switch {
+ case len(paths) != 3:
+ return false
+ case paths[0] != "store":
+ return false
+ case rootmulti.RequireProof("/" + paths[2]):
+ return true
+ }
+
+ return false
+}
diff --git a/relayer/chains/wasm/types/types.go b/relayer/chains/wasm/types/types.go
new file mode 100644
index 000000000..f6085a42c
--- /dev/null
+++ b/relayer/chains/wasm/types/types.go
@@ -0,0 +1,371 @@
+package types
+
+import (
+ "encoding/hex"
+ "encoding/json"
+ "fmt"
+)
+
+type HexBytes string
+
+func (hs HexBytes) Value() ([]byte, error) {
+ if hs == "" {
+ return nil, nil
+ }
+ return hex.DecodeString(string(hs[2:]))
+}
+
+func NewHexBytes(b []byte) HexBytes {
+ return HexBytes("0x" + hex.EncodeToString(b))
+}
+
+// / IBC Handler Contract Methods and Parameters
+
+// / EXTERNAL METHODS
+
+type ContractCall struct {
+ Msg HexBytes `json:"msg"`
+}
+
+type CreateClientMsg struct {
+ CreateClient ContractCall `json:"create_client"`
+}
+
+func (c *CreateClientMsg) Bytes() ([]byte, error) {
+ return json.Marshal(c)
+}
+
+func GenerateTxnParams(methodName string, value HexBytes) ([]byte, error) {
+ if len(methodName) <= 0 {
+ return nil, fmt.Errorf("Empty Method Name")
+ }
+ if len(value) <= 0 {
+ return nil, fmt.Errorf("Empty value for %s", methodName)
+ }
+ m := map[string]interface{}{
+ methodName: map[string]HexBytes{
+ "msg": value,
+ },
+ }
+ return json.Marshal(m)
+}
+
+// / READONLY METHODS
+type GetClientState struct {
+ ClientState struct {
+ ClientId string `json:"client_id"`
+ } `json:"get_client_state"`
+}
+
+func (x *GetClientState) Bytes() ([]byte, error) {
+ return json.Marshal(x)
+}
+
+func NewClientState(clientId string) *GetClientState {
+ return &GetClientState{
+ struct {
+ ClientId string `json:"client_id"`
+ }{
+ ClientId: clientId,
+ },
+ }
+}
+
+type ConsensusStateByHeight struct {
+ ClientId string "json:\"client_id\""
+ Height uint64 "json:\"height\""
+}
+
+type GetConsensusStateByHeight struct {
+ ConsensusStateByHeight ConsensusStateByHeight `json:"get_consensus_state_by_height"`
+}
+
+func (x *GetConsensusStateByHeight) Bytes() ([]byte, error) {
+ return json.Marshal(x)
+}
+
+func NewConsensusStateByHeight(clientId string, height uint64) *GetConsensusStateByHeight {
+ return &GetConsensusStateByHeight{
+ ConsensusStateByHeight: ConsensusStateByHeight{
+ ClientId: clientId,
+ Height: height,
+ },
+ }
+}
+
+type GetConnection struct {
+ Connection struct {
+ ConnectionId string `json:"connection_id"`
+ } `json:"get_connection"`
+}
+
+func (x *GetConnection) Bytes() ([]byte, error) {
+ return json.Marshal(x)
+}
+
+func NewConnection(connId string) *GetConnection {
+ return &GetConnection{
+ Connection: struct {
+ ConnectionId string "json:\"connection_id\""
+ }{
+ ConnectionId: connId,
+ },
+ }
+}
+
+type GetChannel struct {
+ Channel struct {
+ PortId string `json:"port_id"`
+ ChannelId string `json:"channel_id"`
+ } `json:"get_channel"`
+}
+
+func (x *GetChannel) Bytes() ([]byte, error) {
+ return json.Marshal(x)
+}
+
+func NewChannel(portId, channelId string) *GetChannel {
+ return &GetChannel{
+ Channel: struct {
+ PortId string "json:\"port_id\""
+ ChannelId string "json:\"channel_id\""
+ }{
+ PortId: portId,
+ ChannelId: channelId,
+ },
+ }
+}
+
+type GetPacketCommitment struct {
+ PacketCommitment struct {
+ PortId string `json:"port_id"`
+ ChannelId string `json:"channel_id"`
+ Sequence uint64 `json:"sequence"`
+ } `json:"get_packet_commitment"`
+}
+
+func (x *GetPacketCommitment) Bytes() ([]byte, error) {
+ return json.Marshal(x)
+}
+
+func NewPacketCommitment(portId, channelId string, sequence uint64) *GetPacketCommitment {
+ return &GetPacketCommitment{
+ PacketCommitment: struct {
+ PortId string "json:\"port_id\""
+ ChannelId string "json:\"channel_id\""
+ Sequence uint64 "json:\"sequence\""
+ }{
+ PortId: portId,
+ ChannelId: channelId,
+ Sequence: sequence,
+ },
+ }
+}
+
+type GetPacketAcknowledgementCommitment struct {
+ PacketCommitment struct {
+ PortId string `json:"port_id"`
+ ChannelId string `json:"channel_id"`
+ Sequence uint64 `json:"sequence"`
+ } `json:"get_packet_acknowledgement_commitment"`
+}
+
+func (x *GetPacketAcknowledgementCommitment) Bytes() ([]byte, error) {
+ return json.Marshal(x)
+}
+
+func NewPacketAcknowledgementCommitment(portId, channelId string, sequence uint64) *GetPacketAcknowledgementCommitment {
+ return &GetPacketAcknowledgementCommitment{
+ PacketCommitment: struct {
+ PortId string "json:\"port_id\""
+ ChannelId string "json:\"channel_id\""
+ Sequence uint64 "json:\"sequence\""
+ }{
+ PortId: portId,
+ ChannelId: channelId,
+ Sequence: sequence,
+ },
+ }
+}
+
+type GetNextSequenceSend struct {
+ NextSequenceSend struct {
+ PortId string `json:"port_id"`
+ ChannelId string `json:"channel_id"`
+ } `json:"get_next_sequence_send"`
+}
+
+func (x *GetNextSequenceSend) Bytes() ([]byte, error) {
+ return json.Marshal(x)
+}
+
+func NewNextSequenceSend(portId, channelId string) *GetNextSequenceSend {
+ return &GetNextSequenceSend{
+ NextSequenceSend: struct {
+ PortId string "json:\"port_id\""
+ ChannelId string "json:\"channel_id\""
+ }{
+ PortId: portId,
+ ChannelId: channelId,
+ },
+ }
+}
+
+type GetNextSequenceReceive struct {
+ NextSequenceReceive struct {
+ PortId string `json:"port_id"`
+ ChannelId string `json:"channel_id"`
+ } `json:"get_next_sequence_receive"`
+}
+
+func (x *GetNextSequenceReceive) Bytes() ([]byte, error) {
+ return json.Marshal(x)
+}
+
+func NewNextSequenceReceive(portId, channelId string) *GetNextSequenceReceive {
+ return &GetNextSequenceReceive{
+ NextSequenceReceive: struct {
+ PortId string "json:\"port_id\""
+ ChannelId string "json:\"channel_id\""
+ }{
+ PortId: portId,
+ ChannelId: channelId,
+ },
+ }
+}
+
+type GetNextSequenceAcknowledgement struct {
+ NextSequenceAck struct {
+ PortId string `json:"port_id"`
+ ChannelId string `json:"channel_id"`
+ } `json:"get_next_sequence_acknowledgement"`
+}
+
+func (x *GetNextSequenceAcknowledgement) Bytes() ([]byte, error) {
+ return json.Marshal(x)
+}
+
+func NewNextSequenceAcknowledgement(portId, channelId string) *GetNextSequenceAcknowledgement {
+ return &GetNextSequenceAcknowledgement{
+ NextSequenceAck: struct {
+ PortId string "json:\"port_id\""
+ ChannelId string "json:\"channel_id\""
+ }{
+ PortId: portId,
+ ChannelId: channelId,
+ },
+ }
+}
+
+type GetPacketReceipt struct {
+ PacketReceipt struct {
+ PortId string `json:"port_id"`
+ ChannelId string `json:"channel_id"`
+ Sequence uint64 `json:"sequence"`
+ } `json:"get_packet_receipt"`
+}
+
+func (x *GetPacketReceipt) Bytes() ([]byte, error) {
+ return json.Marshal(x)
+}
+
+func NewPacketReceipt(portId, channelId string, sequence uint64) *GetPacketReceipt {
+ return &GetPacketReceipt{
+ PacketReceipt: struct {
+ PortId string "json:\"port_id\""
+ ChannelId string "json:\"channel_id\""
+ Sequence uint64 "json:\"sequence\""
+ }{
+ PortId: portId,
+ ChannelId: channelId,
+ Sequence: sequence,
+ },
+ }
+}
+
+type GetNextClientSequence struct {
+ Sequence struct{} `json:"get_next_client_sequence"`
+}
+
+func (x *GetNextClientSequence) Bytes() ([]byte, error) {
+ return json.Marshal(x)
+}
+
+func NewNextClientSequence() *GetNextClientSequence {
+ return &GetNextClientSequence{
+ Sequence: struct{}{},
+ }
+}
+
+type GetNextConnectionSequence struct {
+ Sequence struct{} `json:"get_next_connection_sequence"`
+}
+
+func (x *GetNextConnectionSequence) Bytes() ([]byte, error) {
+ return json.Marshal(x)
+}
+
+func NewNextConnectionSequence() *GetNextConnectionSequence {
+ return &GetNextConnectionSequence{
+ Sequence: struct{}{},
+ }
+}
+
+type GetNextChannelSequence struct {
+ Sequence struct{} `json:"get_next_channel_sequence"`
+}
+
+func (x *GetNextChannelSequence) Bytes() ([]byte, error) {
+ return json.Marshal(x)
+}
+
+func NewNextChannelSequence() *GetNextChannelSequence {
+ return &GetNextChannelSequence{
+ Sequence: struct{}{},
+ }
+}
+
+type GetAllPorts struct {
+ AllPorts struct{} `json:"get_all_ports"`
+}
+
+func (x *GetAllPorts) Bytes() ([]byte, error) {
+ return json.Marshal(x)
+}
+
+func NewGetAllPorts() *GetAllPorts {
+ return &GetAllPorts{
+ AllPorts: struct{}{},
+ }
+}
+
+type GetCommitmentPrefix struct {
+ GetCommitment struct{} `json:"get_commitment_prefix"`
+}
+
+func (x *GetCommitmentPrefix) Bytes() ([]byte, error) {
+ return json.Marshal(x)
+}
+
+func NewCommitmentPrefix() *GetCommitmentPrefix {
+ return &GetCommitmentPrefix{
+ GetCommitment: struct{}{},
+ }
+}
+
+type GetPrevConsensusStateHeight struct {
+ ConsensusStateByHeight ConsensusStateByHeight `json:"get_previous_consensus_state_height"`
+}
+
+func (x *GetPrevConsensusStateHeight) Bytes() ([]byte, error) {
+ return json.Marshal(x)
+}
+
+func NewPrevConsensusStateHeight(clientId string, height uint64) *GetPrevConsensusStateHeight {
+ return &GetPrevConsensusStateHeight{
+ ConsensusStateByHeight: ConsensusStateByHeight{
+ ClientId: clientId,
+ Height: height,
+ },
+ }
+}
diff --git a/relayer/chains/wasm/utils.go b/relayer/chains/wasm/utils.go
new file mode 100644
index 000000000..6b49cc1aa
--- /dev/null
+++ b/relayer/chains/wasm/utils.go
@@ -0,0 +1,40 @@
+package wasm
+
+import (
+ "encoding/binary"
+ "encoding/hex"
+ "fmt"
+ "strconv"
+ "strings"
+
+ wasmtypes "github.com/CosmWasm/wasmd/x/wasm/types"
+ "github.com/cosmos/relayer/v2/relayer/common"
+)
+
+func getKey(data string) string {
+ return fmt.Sprintf("%s%x", getKeyLength(data), []byte(data))
+}
+
+func getKeyLength(data string) string {
+ length := uint16(len(data)) // Assuming the string length fits within 32 bits
+
+ // Convert the length to big endian format
+ buf := make([]byte, 2)
+ binary.BigEndian.PutUint16(buf, length)
+ return fmt.Sprintf("%x", buf)
+}
+
+func byteToInt(b []byte) (int, error) {
+ return strconv.Atoi(string(b))
+
+}
+
+func ProcessContractResponse(p *wasmtypes.QuerySmartContractStateResponse) ([]byte, error) {
+ data := string(p.Data.Bytes())
+ trimmedData := strings.ReplaceAll(data, `"`, "")
+ return hex.DecodeString(trimmedData)
+}
+
+func getStorageKeyFromPath(path []byte) []byte {
+ return common.MustHexStrToBytes(fmt.Sprintf("%s%x", getKey(STORAGEKEY__Commitments), path))
+}
diff --git a/relayer/chains/wasm/wasm_chain_processor.go b/relayer/chains/wasm/wasm_chain_processor.go
new file mode 100644
index 000000000..7b6f372a4
--- /dev/null
+++ b/relayer/chains/wasm/wasm_chain_processor.go
@@ -0,0 +1,664 @@
+package wasm
+
+import (
+ "bytes"
+ "context"
+ "errors"
+ "fmt"
+ "time"
+
+ "github.com/avast/retry-go/v4"
+ sdk "github.com/cosmos/cosmos-sdk/types"
+
+ clienttypes "github.com/cosmos/ibc-go/v7/modules/core/02-client/types"
+ conntypes "github.com/cosmos/ibc-go/v7/modules/core/03-connection/types"
+ chantypes "github.com/cosmos/ibc-go/v7/modules/core/04-channel/types"
+ "github.com/cosmos/relayer/v2/relayer/common"
+ "github.com/cosmos/relayer/v2/relayer/processor"
+ "github.com/cosmos/relayer/v2/relayer/provider"
+
+ ctypes "github.com/cometbft/cometbft/rpc/core/types"
+ "github.com/cometbft/cometbft/types"
+ "go.uber.org/zap"
+ "golang.org/x/sync/errgroup"
+)
+
+type WasmChainProcessor struct {
+ log *zap.Logger
+
+ chainProvider *WasmProvider
+
+ pathProcessors processor.PathProcessors
+
+ // indicates whether queries are in sync with latest height of the chain
+ inSync bool
+
+ // highest block
+ latestBlock provider.LatestBlock
+
+ // holds highest consensus height and header for all clients
+ latestClientState
+
+ // holds open state for known connections
+ connectionStateCache processor.ConnectionStateCache
+
+ // holds open state for known channels
+ channelStateCache processor.ChannelStateCache
+
+ // map of connection ID to client ID
+ connectionClients map[string]string
+
+ // map of channel ID to connection ID
+ channelConnections map[string]string
+
+ // metrics to monitor lifetime of processor
+ metrics *processor.PrometheusMetrics
+
+ // parsed gas prices accepted by the chain (only used for metrics)
+ parsedGasPrices *sdk.DecCoins
+
+ verifier *Verifier
+
+ heightSnapshotChan chan struct{}
+}
+
+type Verifier struct {
+ Header *types.LightBlock
+}
+
+func NewWasmChainProcessor(log *zap.Logger, provider *WasmProvider, metrics *processor.PrometheusMetrics, heightSnapshot chan struct{}) *WasmChainProcessor {
+ return &WasmChainProcessor{
+ log: log.With(zap.String("chain_name", provider.ChainName()), zap.String("chain_id", provider.ChainId())),
+ chainProvider: provider,
+ latestClientState: make(latestClientState),
+ connectionStateCache: make(processor.ConnectionStateCache),
+ channelStateCache: make(processor.ChannelStateCache),
+ connectionClients: make(map[string]string),
+ channelConnections: make(map[string]string),
+ metrics: metrics,
+ heightSnapshotChan: heightSnapshot,
+ }
+}
+
+const (
+ queryTimeout = 5 * time.Second
+ blockResultsQueryTimeout = 2 * time.Minute
+ latestHeightQueryRetryDelay = 1 * time.Second
+ latestHeightQueryRetries = 5
+
+ // TODO: review transfer to providerConfig
+ defaultMinQueryLoopDuration = 1 * time.Second
+ defaultBalanceUpdateWaitDuration = 60 * time.Second
+ inSyncNumBlocksThreshold = 2
+ MaxBlockFetch = 100
+)
+
+// latestClientState is a map of clientID to the latest clientInfo for that client.
+type latestClientState map[string]provider.ClientState
+
+func (l latestClientState) update(ctx context.Context, clientInfo clientInfo, ccp *WasmChainProcessor) {
+ existingClientInfo, ok := l[clientInfo.clientID]
+ var trustingPeriod time.Duration
+ if ok {
+ if clientInfo.consensusHeight.LT(existingClientInfo.ConsensusHeight) {
+ // height is less than latest, so no-op
+ return
+ }
+ trustingPeriod = existingClientInfo.TrustingPeriod
+ }
+ // TODO
+ // if trustingPeriod == 0 {
+ // cs, err := ccp.chainProvider.QueryClientState(ctx, 0, clientInfo.clientID)
+ // if err != nil {
+ // ccp.log.Error(
+ // "Failed to query client state to get trusting period",
+ // zap.String("client_id", clientInfo.clientID),
+ // zap.Error(err),
+ // )
+ // return
+ // }
+ // // trustingPeriod = cs.TrustingPeriod
+ // }
+ clientState := clientInfo.ClientState(trustingPeriod)
+
+ // update latest if no existing state or provided consensus height is newer
+ l[clientInfo.clientID] = clientState
+
+}
+
+// Provider returns the ChainProvider, which provides the methods for querying, assembling IBC messages, and sending transactions.
+func (ccp *WasmChainProcessor) Provider() provider.ChainProvider {
+ return ccp.chainProvider
+}
+
+// Set the PathProcessors that this ChainProcessor should publish relevant IBC events to.
+// ChainProcessors need reference to their PathProcessors and vice-versa, handled by EventProcessorBuilder.Build().
+func (ccp *WasmChainProcessor) SetPathProcessors(pathProcessors processor.PathProcessors) {
+ ccp.pathProcessors = pathProcessors
+}
+
+// latestHeightWithRetry will query for the latest height, retrying in case of failure.
+// It will delay by latestHeightQueryRetryDelay between attempts, up to latestHeightQueryRetries.
+func (ccp *WasmChainProcessor) latestHeightWithRetry(ctx context.Context) (latestHeight int64, err error) {
+ return latestHeight, retry.Do(func() error {
+ latestHeightQueryCtx, cancelLatestHeightQueryCtx := context.WithTimeout(ctx, queryTimeout)
+ defer cancelLatestHeightQueryCtx()
+ var err error
+ latestHeight, err = ccp.chainProvider.QueryLatestHeight(latestHeightQueryCtx)
+ return err
+ }, retry.Context(ctx), retry.Attempts(latestHeightQueryRetries), retry.Delay(latestHeightQueryRetryDelay), retry.LastErrorOnly(true), retry.OnRetry(func(n uint, err error) {
+ ccp.log.Error(
+ "Failed to query latest height",
+ zap.Uint("attempt", n+1),
+ zap.Uint("max_attempts", latestHeightQueryRetries),
+ zap.Error(err),
+ )
+ }))
+}
+
+// nodeStatusWithRetry will query for the latest node status, retrying in case of failure.
+// It will delay by latestHeightQueryRetryDelay between attempts, up to latestHeightQueryRetries.
+func (ccp *WasmChainProcessor) nodeStatusWithRetry(ctx context.Context) (status *ctypes.ResultStatus, err error) {
+ return status, retry.Do(func() error {
+ latestHeightQueryCtx, cancelLatestHeightQueryCtx := context.WithTimeout(ctx, queryTimeout)
+ defer cancelLatestHeightQueryCtx()
+ var err error
+ status, err = ccp.chainProvider.QueryStatus(latestHeightQueryCtx)
+ return err
+ }, retry.Context(ctx), retry.Attempts(latestHeightQueryRetries), retry.Delay(latestHeightQueryRetryDelay), retry.LastErrorOnly(true), retry.OnRetry(func(n uint, err error) {
+ ccp.log.Error(
+ "Failed to query node status",
+ zap.Uint("attempt", n+1),
+ zap.Uint("max_attempts", latestHeightQueryRetries),
+ zap.Error(err),
+ )
+ }))
+}
+
+// clientState will return the most recent client state if client messages
+// have already been observed for the clientID, otherwise it will query for it.
+func (ccp *WasmChainProcessor) clientState(ctx context.Context, clientID string) (provider.ClientState, error) {
+ if state, ok := ccp.latestClientState[clientID]; ok {
+ return state, nil
+ }
+ cs, err := ccp.chainProvider.QueryClientState(ctx, int64(ccp.latestBlock.Height), clientID)
+ if err != nil {
+ return provider.ClientState{}, err
+ }
+ clientState := provider.ClientState{
+ ClientID: clientID,
+ ConsensusHeight: cs.GetLatestHeight().(clienttypes.Height),
+ // TrustingPeriod: cs.TrustingPeriod,
+ }
+ ccp.latestClientState[clientID] = clientState
+ return clientState, nil
+}
+
+// queryCyclePersistence hold the variables that should be retained across queryCycles.
+type queryCyclePersistence struct {
+ latestHeight int64
+ latestQueriedBlock int64
+ minQueryLoopDuration time.Duration
+ lastBalanceUpdate time.Time
+ balanceUpdateWaitDuration time.Duration
+}
+
+func (ccp *WasmChainProcessor) StartFromHeight(ctx context.Context) int64 {
+ cfg := ccp.Provider().ProviderConfig().(*WasmProviderConfig)
+ if cfg.StartHeight != 0 {
+ return int64(cfg.StartHeight)
+ }
+ snapshotHeight, err := common.LoadSnapshotHeight(ccp.Provider().ChainId())
+ if err != nil {
+ ccp.log.Warn("Failed to load height from snapshot", zap.Error(err))
+ } else {
+ ccp.log.Info("Obtained start height from config", zap.Int64("height", snapshotHeight))
+ }
+ return snapshotHeight
+}
+
+// Run starts the query loop for the chain which will gather applicable ibc messages and push events out to the relevant PathProcessors.
+// The initialBlockHistory parameter determines how many historical blocks should be fetched and processed before continuing with current blocks.
+// ChainProcessors should obey the context and return upon context cancellation.
+func (ccp *WasmChainProcessor) Run(ctx context.Context, initialBlockHistory uint64) error {
+ // this will be used for persistence across query cycle loop executions
+ persistence := queryCyclePersistence{
+ minQueryLoopDuration: defaultMinQueryLoopDuration,
+ lastBalanceUpdate: time.Unix(0, 0),
+ balanceUpdateWaitDuration: defaultBalanceUpdateWaitDuration,
+ }
+
+ // Infinite retry to get initial latest height
+ for {
+ status, err := ccp.nodeStatusWithRetry(ctx)
+ if err != nil {
+ ccp.log.Error(
+ "Failed to query latest height after max attempts",
+ zap.Uint("attempts", latestHeightQueryRetries),
+ zap.Error(err),
+ )
+ if errors.Is(err, context.Canceled) || errors.Is(err, context.DeadlineExceeded) {
+ return nil
+ }
+ continue
+ }
+ persistence.latestHeight = status.SyncInfo.LatestBlockHeight
+ break
+ }
+
+ // this will make initial QueryLoop iteration look back initialBlockHistory blocks in history
+ latestQueriedBlock := ccp.StartFromHeight(ctx)
+ if latestQueriedBlock <= 0 || latestQueriedBlock > persistence.latestHeight {
+ latestQueriedBlock = persistence.latestHeight
+ }
+
+ persistence.latestQueriedBlock = int64(latestQueriedBlock)
+
+ ccp.log.Info("Start to query from height ", zap.Int64("height", latestQueriedBlock))
+
+ _, lightBlock, err := ccp.chainProvider.QueryLightBlock(ctx, persistence.latestQueriedBlock)
+ if err != nil {
+ ccp.log.Error("Failed to get ibcHeader",
+ zap.Int64("height", persistence.latestQueriedBlock),
+ zap.Any("error", err),
+ )
+ return err
+ }
+
+ ccp.verifier = &Verifier{
+ Header: lightBlock,
+ }
+
+ var eg errgroup.Group
+ eg.Go(func() error {
+ return ccp.initializeConnectionState(ctx)
+ })
+ eg.Go(func() error {
+ return ccp.initializeChannelState(ctx)
+ })
+ if err := eg.Wait(); err != nil {
+ return err
+ }
+
+ ccp.log.Debug("Entering Wasm main query loop")
+
+ ticker := time.NewTicker(persistence.minQueryLoopDuration)
+ defer ticker.Stop()
+
+ for {
+ if err := ccp.queryCycle(ctx, &persistence); err != nil {
+ return err
+ }
+ select {
+ case <-ctx.Done():
+ return nil
+ case <-ccp.heightSnapshotChan:
+ ccp.SnapshotHeight(ccp.getHeightToSave(persistence.latestHeight))
+ case <-ticker.C:
+ ticker.Reset(persistence.minQueryLoopDuration)
+ }
+ }
+}
+
+// initializeConnectionState will bootstrap the connectionStateCache with the open connection state.
+func (ccp *WasmChainProcessor) initializeConnectionState(ctx context.Context) error {
+ ctx, cancel := context.WithTimeout(ctx, queryTimeout)
+ defer cancel()
+ connections, err := ccp.chainProvider.QueryConnections(ctx)
+ if err != nil {
+ return fmt.Errorf("error querying connections: %w", err)
+ }
+ for _, c := range connections {
+ ccp.connectionClients[c.Id] = c.ClientId
+ ccp.connectionStateCache[processor.ConnectionKey{
+ ConnectionID: c.Id,
+ ClientID: c.ClientId,
+ CounterpartyConnID: c.Counterparty.ConnectionId,
+ CounterpartyClientID: c.Counterparty.ClientId,
+ }] = c.State == conntypes.OPEN
+
+ ccp.log.Debug("Found open connection",
+ zap.String("client-id ", c.ClientId),
+ zap.String("connection-id ", c.Id),
+ )
+ }
+ return nil
+}
+
+// initializeChannelState will bootstrap the channelStateCache with the open channel state.
+func (ccp *WasmChainProcessor) initializeChannelState(ctx context.Context) error {
+ ctx, cancel := context.WithTimeout(ctx, queryTimeout)
+ defer cancel()
+ channels, err := ccp.chainProvider.QueryChannels(ctx)
+ if err != nil {
+ return fmt.Errorf("error querying channels: %w", err)
+ }
+ for _, ch := range channels {
+ if len(ch.ConnectionHops) != 1 {
+ ccp.log.Error("Found channel using multiple connection hops. Not currently supported, ignoring.",
+ zap.String("channel_id", ch.ChannelId),
+ zap.String("port_id", ch.PortId),
+ zap.Strings("connection_hops", ch.ConnectionHops),
+ )
+ continue
+ }
+ ccp.channelConnections[ch.ChannelId] = ch.ConnectionHops[0]
+ channelKey := processor.ChannelKey{
+ ChannelID: ch.ChannelId,
+ PortID: ch.PortId,
+ CounterpartyChannelID: ch.Counterparty.ChannelId,
+ CounterpartyPortID: ch.Counterparty.PortId,
+ }
+ ccp.channelStateCache.SetOpen(channelKey, ch.State == chantypes.OPEN, ch.Ordering)
+ ccp.log.Debug("Found open channel",
+ zap.String("channel-id", ch.ChannelId),
+ zap.String("port-id ", ch.PortId),
+ zap.String("counterparty-channel-id", ch.Counterparty.ChannelId),
+ zap.String("counterparty-port-id", ch.Counterparty.PortId))
+ }
+ return nil
+}
+
+func (ccp *WasmChainProcessor) queryCycle(ctx context.Context, persistence *queryCyclePersistence) error {
+ status, err := ccp.nodeStatusWithRetry(ctx)
+ if err != nil {
+ // don't want to cause WasmChainProcessor to quit here, can retry again next cycle.
+ ccp.log.Error(
+ "Failed to query node status after max attempts",
+ zap.Uint("attempts", latestHeightQueryRetries),
+ zap.Error(err),
+ )
+
+ // TODO: Save height when node status is false?
+ // ccp.SnapshotHeight(ccp.getHeightToSave(status.SyncInfo.LatestBlockHeight))
+ return nil
+ }
+
+ persistence.latestHeight = status.SyncInfo.LatestBlockHeight
+ // ccp.chainProvider.setCometVersion(ccp.log, status.NodeInfo.Version)
+
+ ccp.log.Debug("Queried latest height",
+ zap.Int64("latest_height", persistence.latestHeight),
+ )
+
+ if ccp.metrics != nil {
+ ccp.CollectMetrics(ctx, persistence)
+ }
+
+ // used at the end of the cycle to send signal to path processors to start processing if both chains are in sync and no new messages came in this cycle
+ firstTimeInSync := false
+
+ if !ccp.inSync {
+ if (persistence.latestHeight - persistence.latestQueriedBlock) < inSyncNumBlocksThreshold {
+ ccp.inSync = true
+ firstTimeInSync = true
+ ccp.log.Info("Chain is in sync")
+ } else {
+ ccp.log.Info("Chain is not yet in sync",
+ zap.Int64("latest_queried_block", persistence.latestQueriedBlock),
+ zap.Int64("latest_height", persistence.latestHeight),
+ )
+ }
+ }
+
+ ibcMessagesCache := processor.NewIBCMessagesCache()
+ ibcHeaderCache := make(processor.IBCHeaderCache)
+
+ ppChanged := false
+
+ newLatestQueriedBlock := persistence.latestQueriedBlock
+ chainID := ccp.chainProvider.ChainId()
+ var latestHeader provider.IBCHeader
+
+ syncUpHeight := func() int64 {
+ if persistence.latestHeight-persistence.latestQueriedBlock > MaxBlockFetch {
+ return persistence.latestQueriedBlock + MaxBlockFetch
+ }
+ return persistence.latestHeight
+ }
+
+ for i := persistence.latestQueriedBlock + 1; i <= syncUpHeight(); i++ {
+ var eg errgroup.Group
+ var blockRes *ctypes.ResultBlockResults
+ var lightBlock *types.LightBlock
+ i := i
+ eg.Go(func() (err error) {
+ queryCtx, cancelQueryCtx := context.WithTimeout(ctx, blockResultsQueryTimeout)
+ defer cancelQueryCtx()
+ blockRes, err = ccp.chainProvider.RPCClient.BlockResults(queryCtx, &i)
+ return err
+ })
+ eg.Go(func() (err error) {
+ queryCtx, cancelQueryCtx := context.WithTimeout(ctx, queryTimeout)
+ defer cancelQueryCtx()
+ latestHeader, lightBlock, err = ccp.chainProvider.QueryLightBlock(queryCtx, i)
+ return err
+ })
+
+ if err := eg.Wait(); err != nil {
+ ccp.log.Warn("Error querying block data", zap.Error(err))
+ break
+ }
+
+ if err := ccp.Verify(ctx, lightBlock); err != nil {
+ ccp.log.Warn("Failed to verify block", zap.Int64("height", blockRes.Height), zap.Error(err))
+ return err
+ }
+
+ ccp.log.Debug("Verified block ",
+ zap.Int64("height", lightBlock.Header.Height))
+
+ heightUint64 := uint64(i)
+
+ ccp.latestBlock = provider.LatestBlock{
+ Height: heightUint64,
+ }
+
+ ibcHeaderCache[heightUint64] = latestHeader
+ ppChanged = true
+
+ base64Encoded := true
+
+ for _, tx := range blockRes.TxsResults {
+ if tx.Code != 0 {
+ // tx was not successful
+ continue
+ }
+ messages := ibcMessagesFromEvents(ccp.log, tx.Events, chainID, heightUint64, ccp.chainProvider.PCfg.IbcHandlerAddress, base64Encoded)
+
+ for _, m := range messages {
+ ccp.log.Info("Detected eventlog", zap.String("eventlog", m.eventType), zap.Uint64("height", heightUint64))
+ ccp.handleMessage(ctx, m, ibcMessagesCache)
+ }
+ }
+
+ newLatestQueriedBlock = i
+ }
+
+ if newLatestQueriedBlock == persistence.latestQueriedBlock {
+ return nil
+ }
+
+ if !ppChanged {
+ if firstTimeInSync {
+ for _, pp := range ccp.pathProcessors {
+ pp.ProcessBacklogIfReady()
+ }
+ }
+
+ return nil
+ }
+
+ for _, pp := range ccp.pathProcessors {
+ clientID := pp.RelevantClientID(chainID)
+ clientState, err := ccp.clientState(ctx, clientID)
+ if err != nil {
+ ccp.log.Error("Error fetching client state",
+ zap.String("client_id", clientID),
+ zap.Error(err),
+ )
+ continue
+ }
+
+ pp.HandleNewData(chainID, processor.ChainProcessorCacheData{
+ LatestBlock: ccp.latestBlock,
+ LatestHeader: latestHeader,
+ IBCMessagesCache: ibcMessagesCache.Clone(),
+ InSync: ccp.inSync,
+ ClientState: clientState,
+ ConnectionStateCache: ccp.connectionStateCache.FilterForClient(clientID),
+ ChannelStateCache: ccp.channelStateCache.FilterForClient(clientID, ccp.channelConnections, ccp.connectionClients),
+ IBCHeaderCache: ibcHeaderCache.Clone(),
+ })
+ }
+
+ persistence.latestQueriedBlock = newLatestQueriedBlock
+
+ return nil
+}
+
+func (ccp *WasmChainProcessor) getHeightToSave(height int64) int64 {
+ retryAfter := ccp.Provider().ProviderConfig().GetFirstRetryBlockAfter()
+ ht := height - int64(retryAfter)
+ if ht < 0 {
+ return 0
+ }
+ return ht
+}
+
+func (ccp *WasmChainProcessor) SnapshotHeight(height int64) {
+ ccp.log.Info("Save height for snapshot", zap.Int64("height", height))
+ err := common.SnapshotHeight(ccp.Provider().ChainId(), height)
+ if err != nil {
+ ccp.log.Warn("Failed saving height snapshot for height", zap.Int64("height", height))
+ }
+}
+
+func (ccp *WasmChainProcessor) CollectMetrics(ctx context.Context, persistence *queryCyclePersistence) {
+ ccp.CurrentBlockHeight(ctx, persistence)
+
+ // Wait a while before updating the balance
+ if time.Since(persistence.lastBalanceUpdate) > persistence.balanceUpdateWaitDuration {
+ // ccp.CurrentRelayerBalance(ctx)
+ persistence.lastBalanceUpdate = time.Now()
+ }
+}
+
+func (ccp *WasmChainProcessor) CurrentBlockHeight(ctx context.Context, persistence *queryCyclePersistence) {
+ ccp.metrics.SetLatestHeight(ccp.chainProvider.ChainId(), persistence.latestHeight)
+}
+
+func (ccp *WasmChainProcessor) Verify(ctx context.Context, untrusted *types.LightBlock) error {
+
+ if untrusted.Height != ccp.verifier.Header.Height+1 {
+ return errors.New("headers must be adjacent in height")
+ }
+
+ if err := verifyNewHeaderAndVals(untrusted.SignedHeader,
+ untrusted.ValidatorSet,
+ ccp.verifier.Header.SignedHeader,
+ time.Now(), 0); err != nil {
+ return fmt.Errorf("Failed to verify Header: %v", err)
+ }
+
+ if !bytes.Equal(untrusted.Header.ValidatorsHash, ccp.verifier.Header.NextValidatorsHash) {
+ err := fmt.Errorf("expected old header next validators (%X) to match those from new header (%X)",
+ ccp.verifier.Header.NextValidatorsHash,
+ untrusted.Header.ValidatorsHash,
+ )
+ return err
+ }
+
+ if !bytes.Equal(untrusted.Header.LastBlockID.Hash.Bytes(), ccp.verifier.Header.Commit.BlockID.Hash.Bytes()) {
+ err := fmt.Errorf("expected LastBlockId Hash (%X) of current header to match those from trusted Header BlockID hash (%X)",
+ ccp.verifier.Header.NextValidatorsHash,
+ untrusted.Header.ValidatorsHash,
+ )
+ return err
+ }
+
+ // Ensure that +2/3 of new validators signed correctly.
+ if err := untrusted.ValidatorSet.VerifyCommitLight(ccp.verifier.Header.ChainID, untrusted.Commit.BlockID,
+ untrusted.Header.Height, untrusted.Commit); err != nil {
+ return fmt.Errorf("invalid header: %v", err)
+ }
+
+ ccp.verifier.Header = untrusted
+ return nil
+
+}
+
+func verifyNewHeaderAndVals(
+ untrustedHeader *types.SignedHeader,
+ untrustedVals *types.ValidatorSet,
+ trustedHeader *types.SignedHeader,
+ now time.Time,
+ maxClockDrift time.Duration) error {
+
+ if err := untrustedHeader.ValidateBasic(trustedHeader.ChainID); err != nil {
+ return fmt.Errorf("untrustedHeader.ValidateBasic failed: %w", err)
+ }
+
+ if untrustedHeader.Height <= trustedHeader.Height {
+ return fmt.Errorf("expected new header height %d to be greater than one of old header %d",
+ untrustedHeader.Height,
+ trustedHeader.Height)
+ }
+
+ if !untrustedHeader.Time.After(trustedHeader.Time) {
+ return fmt.Errorf("expected new header time %v to be after old header time %v",
+ untrustedHeader.Time,
+ trustedHeader.Time)
+ }
+
+ if !untrustedHeader.Time.Before(now.Add(maxClockDrift)) {
+ return fmt.Errorf("new header has a time from the future %v (now: %v; max clock drift: %v)",
+ untrustedHeader.Time,
+ now,
+ maxClockDrift)
+ }
+
+ if !bytes.Equal(untrustedHeader.ValidatorsHash, untrustedVals.Hash()) {
+ return fmt.Errorf("expected new header validators (%X) to match those that were supplied (%X) at height %d",
+ untrustedHeader.ValidatorsHash,
+ untrustedVals.Hash(),
+ untrustedHeader.Height,
+ )
+ }
+
+ return nil
+}
+
+// func (ccp *WasmChainProcessor) CurrentRelayerBalance(ctx context.Context) {
+// // memoize the current gas prices to only show metrics for "interesting" denoms
+// if ccp.parsedGasPrices == nil {
+// gp, err := sdk.ParseDecCoins(ccp.chainProvider.PCfg.GasPrices)
+// if err != nil {
+// ccp.log.Error(
+// "Failed to parse gas prices",
+// zap.Error(err),
+// )
+// }
+// ccp.parsedGasPrices = &gp
+// }
+
+// // Get the balance for the chain provider's key
+// relayerWalletBalance, err := ccp.chainProvider.QueryBalance(ctx, ccp.chainProvider.Key())
+// if err != nil {
+// ccp.log.Error(
+// "Failed to query relayer balance",
+// zap.Error(err),
+// )
+// }
+
+// // Print the relevant gas prices
+// for _, gasDenom := range *ccp.parsedGasPrices {
+// for _, balance := range relayerWalletBalance {
+// if balance.Denom == gasDenom.Denom {
+// // Convert to a big float to get a float64 for metrics
+// f, _ := big.NewFloat(0.0).SetInt(balance.Amount.BigInt()).Float64()
+// ccp.metrics.SetWalletBalance(ccp.chainProvider.ChainId(), ccp.chainProvider.Key(), balance.Denom, f)
+// }
+// }
+// }
+// }
diff --git a/relayer/chains/wasm/wasm_prefix.go b/relayer/chains/wasm/wasm_prefix.go
new file mode 100644
index 000000000..1a77d255f
--- /dev/null
+++ b/relayer/chains/wasm/wasm_prefix.go
@@ -0,0 +1,28 @@
+package wasm
+
+import (
+ "sync"
+
+ "github.com/CosmWasm/wasmd/app"
+ wasmtypes "github.com/CosmWasm/wasmd/x/wasm/types"
+ sdk "github.com/cosmos/cosmos-sdk/types"
+)
+
+// This file is cursed and this mutex is too
+// you don't want none of this dewey cox.
+var sdkConfigMutex sync.Mutex
+
+// Based on cosmos bech32_hack.go
+// SetSDKContext sets the SDK config to the proper bech32 prefixes for wasm.
+// Don't use this unless you know what you're doing.
+// TODO: :dagger: :knife: :chainsaw: remove this function
+func (ap *WasmProvider) SetSDKContext() func() {
+
+ sdkConfigMutex.Lock()
+ cfg_update := sdk.GetConfig()
+ cfg_update.SetBech32PrefixForAccount(ap.PCfg.AccountPrefix, app.Bech32PrefixAccPub)
+ cfg_update.SetBech32PrefixForValidator(ap.PCfg.AccountPrefix, app.Bech32PrefixValPub)
+ cfg_update.SetBech32PrefixForConsensusNode(app.Bech32PrefixConsAddr, app.Bech32PrefixConsPub)
+ cfg_update.SetAddressVerifier(wasmtypes.VerifyAddressLen())
+ return sdkConfigMutex.Unlock
+}
diff --git a/relayer/channel.go b/relayer/channel.go
index f5aa9dc0e..184ed599c 100644
--- a/relayer/channel.go
+++ b/relayer/channel.go
@@ -59,6 +59,7 @@ func (c *Chain) CreateOpenChannels(
memo,
DefaultClientUpdateThreshold,
DefaultFlushInterval,
+ DefaultMaxMsgLength,
)
c.log.Info("Starting event processor for channel handshake",
@@ -70,8 +71,8 @@ func (c *Chain) CreateOpenChannels(
return processor.NewEventProcessor().
WithChainProcessors(
- c.chainProcessor(c.log, nil),
- dst.chainProcessor(c.log, nil),
+ c.chainProcessor(c.log, nil, nil),
+ dst.chainProcessor(c.log, nil, nil),
).
WithPathProcessors(pp).
WithInitialBlockHistory(0).
@@ -114,13 +115,52 @@ func (c *Chain) CloseChannel(
// Timeout is per message. Two close channel handshake messages, allowing maxRetries for each.
processorTimeout := timeout * 2 * time.Duration(maxRetries)
+ // Perform a flush first so that any timeouts are cleared.
+ flushCtx, flushCancel := context.WithTimeout(ctx, processorTimeout)
+ defer flushCancel()
+
+ flushProcessor := processor.NewEventProcessor().
+ WithChainProcessors(
+ c.chainProcessor(c.log, nil, nil),
+ dst.chainProcessor(c.log, nil, nil),
+ ).
+ WithPathProcessors(processor.NewPathProcessor(
+ c.log,
+ processor.NewPathEnd(pathName, c.PathEnd.ChainID, c.PathEnd.ClientID, "", []processor.ChainChannelKey{}),
+ processor.NewPathEnd(pathName, dst.PathEnd.ChainID, dst.PathEnd.ClientID, "", []processor.ChainChannelKey{}),
+ nil,
+ memo,
+ DefaultClientUpdateThreshold,
+ DefaultFlushInterval,
+ DefaultMaxMsgLength,
+ )).
+ WithInitialBlockHistory(0).
+ WithMessageLifecycle(&processor.FlushLifecycle{}).
+ Build()
+
+ c.log.Info("Starting event processor for flush before channel close",
+ zap.String("src_chain_id", c.PathEnd.ChainID),
+ zap.String("src_port_id", srcPortID),
+ zap.String("dst_chain_id", dst.PathEnd.ChainID),
+ )
+
+ if err := flushProcessor.Run(flushCtx); err != nil {
+ return err
+ }
+
ctx, cancel := context.WithTimeout(ctx, processorTimeout)
defer cancel()
+ c.log.Info("Starting event processor for channel close",
+ zap.String("src_chain_id", c.PathEnd.ChainID),
+ zap.String("src_port_id", srcPortID),
+ zap.String("dst_chain_id", dst.PathEnd.ChainID),
+ )
+
return processor.NewEventProcessor().
WithChainProcessors(
- c.chainProcessor(c.log, nil),
- dst.chainProcessor(c.log, nil),
+ c.chainProcessor(c.log, nil, nil),
+ dst.chainProcessor(c.log, nil, nil),
).
WithPathProcessors(processor.NewPathProcessor(
c.log,
@@ -130,25 +170,15 @@ func (c *Chain) CloseChannel(
memo,
DefaultClientUpdateThreshold,
DefaultFlushInterval,
+ DefaultMaxMsgLength,
)).
WithInitialBlockHistory(0).
- WithMessageLifecycle(&processor.ChannelMessageLifecycle{
- Initial: &processor.ChannelMessage{
- ChainID: c.PathEnd.ChainID,
- EventType: chantypes.EventTypeChannelCloseInit,
- Info: provider.ChannelInfo{
- PortID: srcPortID,
- ChannelID: srcChanID,
- },
- },
- Termination: &processor.ChannelMessage{
- ChainID: dst.PathEnd.ChainID,
- EventType: chantypes.EventTypeChannelCloseConfirm,
- Info: provider.ChannelInfo{
- CounterpartyPortID: srcPortID,
- CounterpartyChannelID: srcChanID,
- },
- },
+ WithMessageLifecycle(&processor.ChannelCloseLifecycle{
+ SrcChainID: c.PathEnd.ChainID,
+ SrcChannelID: srcChanID,
+ SrcPortID: srcPortID,
+ SrcConnID: c.PathEnd.ConnectionID,
+ DstConnID: dst.PathEnd.ConnectionID,
}).
Build().
Run(ctx)
diff --git a/relayer/client.go b/relayer/client.go
index 2330b262b..1972885bf 100644
--- a/relayer/client.go
+++ b/relayer/client.go
@@ -10,13 +10,15 @@ import (
clienttypes "github.com/cosmos/ibc-go/v7/modules/core/02-client/types"
ibcexported "github.com/cosmos/ibc-go/v7/modules/core/exported"
tmclient "github.com/cosmos/ibc-go/v7/modules/light-clients/07-tendermint"
+ "github.com/cosmos/relayer/v2/relayer/chains/icon"
+ "github.com/cosmos/relayer/v2/relayer/common"
"github.com/cosmos/relayer/v2/relayer/provider"
"go.uber.org/zap"
"golang.org/x/sync/errgroup"
)
// CreateClients creates clients for src on dst and dst on src if the client ids are unspecified.
-func (c *Chain) CreateClients(ctx context.Context, dst *Chain, allowUpdateAfterExpiry, allowUpdateAfterMisbehaviour, override bool, customClientTrustingPeriod time.Duration, memo string) (string, string, error) {
+func (c *Chain) CreateClients(ctx context.Context, dst *Chain, allowUpdateAfterExpiry, allowUpdateAfterMisbehaviour, override bool, customClientTrustingPeriod time.Duration, memo string, iconStartHeight int64) (string, string, error) {
// Query the latest heights on src and dst and retry if the query fails
var srch, dsth int64
if err := retry.Do(func() error {
@@ -60,7 +62,7 @@ func (c *Chain) CreateClients(ctx context.Context, dst *Chain, allowUpdateAfterE
eg.Go(func() error {
var err error
// Create client on src for dst if the client id is unspecified
- clientSrc, err = CreateClient(egCtx, c, dst, srcUpdateHeader, dstUpdateHeader, allowUpdateAfterExpiry, allowUpdateAfterMisbehaviour, override, customClientTrustingPeriod, memo)
+ clientSrc, err = CreateClient(egCtx, c, dst, srcUpdateHeader, dstUpdateHeader, allowUpdateAfterExpiry, allowUpdateAfterMisbehaviour, override, customClientTrustingPeriod, memo, iconStartHeight)
if err != nil {
return fmt.Errorf("failed to create client on src chain{%s}: %w", c.ChainID(), err)
}
@@ -70,7 +72,7 @@ func (c *Chain) CreateClients(ctx context.Context, dst *Chain, allowUpdateAfterE
eg.Go(func() error {
var err error
// Create client on dst for src if the client id is unspecified
- clientDst, err = CreateClient(egCtx, dst, c, dstUpdateHeader, srcUpdateHeader, allowUpdateAfterExpiry, allowUpdateAfterMisbehaviour, override, customClientTrustingPeriod, memo)
+ clientDst, err = CreateClient(egCtx, dst, c, dstUpdateHeader, srcUpdateHeader, allowUpdateAfterExpiry, allowUpdateAfterMisbehaviour, override, customClientTrustingPeriod, memo, iconStartHeight)
if err != nil {
return fmt.Errorf("failed to create client on dst chain{%s}: %w", dst.ChainID(), err)
}
@@ -102,10 +104,12 @@ func CreateClient(
allowUpdateAfterMisbehaviour bool,
override bool,
customClientTrustingPeriod time.Duration,
- memo string) (string, error) {
+ memo string,
+ iconStartHeight int64,
+) (string, error) {
+ var err error
// If a client ID was specified in the path and override is not set, ensure the client exists.
if !override && src.PathEnd.ClientID != "" {
- // TODO: check client is not expired
_, err := src.ChainProvider.QueryClientStateResponse(ctx, int64(srcUpdateHeader.Height()), src.ClientID())
if err != nil {
return "", fmt.Errorf("please ensure provided on-chain client (%s) exists on the chain (%s): %w",
@@ -156,6 +160,32 @@ func CreateClient(
return "", err
}
+ // if the dst chainProvider is ICON
+ if dst.ChainProvider.Type() == common.IconModule {
+ if iconStartHeight != 0 {
+ dstUpdateHeader, err = dst.ChainProvider.QueryIBCHeader(ctx, iconStartHeight)
+ if err != nil {
+ return "", fmt.Errorf("Error while creating client, failed to fetch ibcHeader for height %d due to %v", iconStartHeight, dstUpdateHeader)
+ }
+ } else {
+ if !dstUpdateHeader.IsCompleteBlock() {
+ iconProvider, ok := dst.ChainProvider.(*icon.IconProvider)
+ if !ok {
+ return "", fmt.Errorf("Error while creating client icon chain type %s mismatched with chain name %s", dst.ChainProvider.Type(), dst.ChainID())
+ }
+ h, err := iconProvider.GetCurrentBtpNetworkStartHeight()
+ if err != nil {
+ return "", fmt.Errorf("Error while creating client, failed to fetch btpnetwork for chain iD %s ", dst.ChainProvider.Type())
+ }
+ dstUpdateHeader, err = dst.ChainProvider.QueryIBCHeader(ctx, h+1)
+ if err != nil {
+ return "", fmt.Errorf("Error while creating client, failed to fetch ibcHeader for height %d due to %v", h, err)
+ }
+
+ }
+ }
+ }
+
// We want to create a light client on the src chain which tracks the state of the dst chain.
// So we build a new client state from dst and attempt to use this for creating the light client on src.
clientState, err := dst.ChainProvider.NewClientState(dst.ChainID(), dstUpdateHeader, tp, ubdPeriod, allowUpdateAfterExpiry, allowUpdateAfterMisbehaviour)
diff --git a/relayer/codecs/ethermint/account.pb.go b/relayer/codecs/ethermint/account.pb.go
index 6d275445f..de39dc307 100644
--- a/relayer/codecs/ethermint/account.pb.go
+++ b/relayer/codecs/ethermint/account.pb.go
@@ -6,8 +6,8 @@ package ethermint
import (
fmt "fmt"
types "github.com/cosmos/cosmos-sdk/x/auth/types"
+ _ "github.com/cosmos/gogoproto/gogoproto"
proto "github.com/cosmos/gogoproto/proto"
- _ "github.com/gogo/protobuf/gogoproto"
io "io"
math "math"
math_bits "math/bits"
diff --git a/relayer/codecs/ethermint/algorithm.go b/relayer/codecs/ethermint/algorithm.go
index 121af6e61..510b18542 100644
--- a/relayer/codecs/ethermint/algorithm.go
+++ b/relayer/codecs/ethermint/algorithm.go
@@ -1,8 +1,8 @@
package ethermint
import (
+ "github.com/btcsuite/btcd/btcutil/hdkeychain"
"github.com/btcsuite/btcd/chaincfg"
- "github.com/btcsuite/btcutil/hdkeychain"
"github.com/tyler-smith/go-bip39"
"github.com/ethereum/go-ethereum/accounts"
diff --git a/relayer/codecs/ethermint/codec.go b/relayer/codecs/ethermint/codec.go
index df398a823..4da95a495 100644
--- a/relayer/codecs/ethermint/codec.go
+++ b/relayer/codecs/ethermint/codec.go
@@ -5,6 +5,7 @@ import (
cryptotypes "github.com/cosmos/cosmos-sdk/crypto/types"
"github.com/cosmos/cosmos-sdk/types/tx"
authtypes "github.com/cosmos/cosmos-sdk/x/auth/types"
+ "github.com/cosmos/relayer/v2/relayer/ethermint"
)
// RegisterInterfaces register the Ethermint key concrete types.
@@ -20,9 +21,10 @@ func RegisterInterfaces(registry codectypes.InterfaceRegistry) {
(*authtypes.GenesisAccount)(nil),
&EthAccount{},
)
+
registry.RegisterImplementations(
- (*tx.ExtensionOptionI)(nil),
+ (*tx.TxExtensionOptionI)(nil),
&ExtensionOptionsWeb3Tx{},
- &ExtensionOptionDynamicFeeTx{},
+ ðermint.ExtensionOptionDynamicFeeTx{},
)
}
diff --git a/relayer/codecs/ethermint/dynamic_fee.pb.go b/relayer/codecs/ethermint/dynamic_fee.pb.go
deleted file mode 100644
index 721600b94..000000000
--- a/relayer/codecs/ethermint/dynamic_fee.pb.go
+++ /dev/null
@@ -1,325 +0,0 @@
-// Code generated by protoc-gen-gogo. DO NOT EDIT.
-// source: ethermint/types/v1/dynamic_fee.proto
-
-package ethermint
-
-import (
- fmt "fmt"
- github_com_cosmos_cosmos_sdk_types "github.com/cosmos/cosmos-sdk/types"
- proto "github.com/cosmos/gogoproto/proto"
- _ "github.com/gogo/protobuf/gogoproto"
- io "io"
- math "math"
- math_bits "math/bits"
-)
-
-// Reference imports to suppress errors if they are not otherwise used.
-var _ = proto.Marshal
-var _ = fmt.Errorf
-var _ = math.Inf
-
-// This is a compile-time assertion to ensure that this generated file
-// is compatible with the proto package it is being compiled against.
-// A compilation error at this line likely means your copy of the
-// proto package needs to be updated.
-const _ = proto.GoGoProtoPackageIsVersion3 // please upgrade the proto package
-
-// ExtensionOptionDynamicFeeTx is an extension option that specifies the
-// maxPrioPrice for cosmos tx
-type ExtensionOptionDynamicFeeTx struct {
- // max_priority_price is the same as `max_priority_fee_per_gas` in eip-1559
- // spec
- MaxPriorityPrice github_com_cosmos_cosmos_sdk_types.Int `protobuf:"bytes,1,opt,name=max_priority_price,json=maxPriorityPrice,proto3,customtype=github.com/cosmos/cosmos-sdk/types.Int" json:"max_priority_price"`
-}
-
-func (m *ExtensionOptionDynamicFeeTx) Reset() { *m = ExtensionOptionDynamicFeeTx{} }
-func (m *ExtensionOptionDynamicFeeTx) String() string { return proto.CompactTextString(m) }
-func (*ExtensionOptionDynamicFeeTx) ProtoMessage() {}
-func (*ExtensionOptionDynamicFeeTx) Descriptor() ([]byte, []int) {
- return fileDescriptor_9d7cf05c9992c480, []int{0}
-}
-func (m *ExtensionOptionDynamicFeeTx) XXX_Unmarshal(b []byte) error {
- return m.Unmarshal(b)
-}
-func (m *ExtensionOptionDynamicFeeTx) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
- if deterministic {
- return xxx_messageInfo_ExtensionOptionDynamicFeeTx.Marshal(b, m, deterministic)
- } else {
- b = b[:cap(b)]
- n, err := m.MarshalToSizedBuffer(b)
- if err != nil {
- return nil, err
- }
- return b[:n], nil
- }
-}
-func (m *ExtensionOptionDynamicFeeTx) XXX_Merge(src proto.Message) {
- xxx_messageInfo_ExtensionOptionDynamicFeeTx.Merge(m, src)
-}
-func (m *ExtensionOptionDynamicFeeTx) XXX_Size() int {
- return m.Size()
-}
-func (m *ExtensionOptionDynamicFeeTx) XXX_DiscardUnknown() {
- xxx_messageInfo_ExtensionOptionDynamicFeeTx.DiscardUnknown(m)
-}
-
-var xxx_messageInfo_ExtensionOptionDynamicFeeTx proto.InternalMessageInfo
-
-func init() {
- proto.RegisterType((*ExtensionOptionDynamicFeeTx)(nil), "ethermint.types.v1.ExtensionOptionDynamicFeeTx")
-}
-
-func init() {
- proto.RegisterFile("ethermint/types/v1/dynamic_fee.proto", fileDescriptor_9d7cf05c9992c480)
-}
-
-var fileDescriptor_9d7cf05c9992c480 = []byte{
- // 263 bytes of a gzipped FileDescriptorProto
- 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x4c, 0x8f, 0x41, 0x4b, 0xf3, 0x40,
- 0x10, 0x86, 0x93, 0xcb, 0x07, 0x5f, 0x4e, 0x12, 0x3c, 0x88, 0xc2, 0x56, 0x44, 0xc4, 0x4b, 0x77,
- 0x29, 0x5e, 0x3d, 0x15, 0x15, 0x3c, 0x59, 0x44, 0x3c, 0x88, 0x50, 0xd2, 0xcd, 0x98, 0x2e, 0x66,
- 0x67, 0xc2, 0xee, 0x34, 0x24, 0xf8, 0x27, 0xfc, 0x59, 0x3d, 0xf6, 0x28, 0x1e, 0x8a, 0x24, 0x7f,
- 0x44, 0x92, 0x94, 0xe2, 0x69, 0x5e, 0x98, 0x87, 0x87, 0xf7, 0x8d, 0xce, 0x81, 0x97, 0xe0, 0xac,
- 0x41, 0x56, 0x5c, 0x17, 0xe0, 0x55, 0x39, 0x51, 0x69, 0x8d, 0x89, 0x35, 0x7a, 0xfe, 0x06, 0x20,
- 0x0b, 0x47, 0x4c, 0x71, 0xbc, 0xa7, 0x64, 0x4f, 0xc9, 0x72, 0x72, 0x7c, 0x98, 0x51, 0x46, 0xfd,
- 0x5b, 0x75, 0x69, 0x20, 0xcf, 0x3e, 0xa2, 0x93, 0xdb, 0x8a, 0x01, 0xbd, 0x21, 0x7c, 0x28, 0xd8,
- 0x10, 0xde, 0x0c, 0xb6, 0x3b, 0x80, 0xa7, 0x2a, 0x7e, 0x8d, 0x62, 0x9b, 0x54, 0xf3, 0xc2, 0x19,
- 0x72, 0x86, 0xeb, 0x2e, 0x68, 0x38, 0x0a, 0x4f, 0xc3, 0xcb, 0xff, 0x53, 0xb9, 0xde, 0x8e, 0x82,
- 0xef, 0xed, 0xe8, 0x22, 0x33, 0xbc, 0x5c, 0x2d, 0xa4, 0x26, 0xab, 0x34, 0x79, 0x4b, 0x7e, 0x77,
- 0xc6, 0x3e, 0x7d, 0x1f, 0x5a, 0xca, 0x7b, 0xe4, 0xc7, 0x03, 0x9b, 0x54, 0xb3, 0x9d, 0x68, 0xd6,
- 0x79, 0xa6, 0xcf, 0xeb, 0x46, 0x84, 0x9b, 0x46, 0x84, 0x3f, 0x8d, 0x08, 0x3f, 0x5b, 0x11, 0x6c,
- 0x5a, 0x11, 0x7c, 0xb5, 0x22, 0x78, 0xb9, 0xfe, 0xe3, 0xf4, 0xec, 0x12, 0xcc, 0x20, 0xa7, 0x12,
- 0xc6, 0x25, 0x20, 0xaf, 0x1c, 0x78, 0x95, 0x03, 0x7a, 0xa5, 0x73, 0x03, 0xc8, 0x4a, 0x53, 0x0a,
- 0xda, 0xab, 0xfd, 0xe6, 0xc5, 0xbf, 0x7e, 0xdb, 0xd5, 0x6f, 0x00, 0x00, 0x00, 0xff, 0xff, 0x7e,
- 0x31, 0x52, 0x1f, 0x2d, 0x01, 0x00, 0x00,
-}
-
-func (m *ExtensionOptionDynamicFeeTx) Marshal() (dAtA []byte, err error) {
- size := m.Size()
- dAtA = make([]byte, size)
- n, err := m.MarshalToSizedBuffer(dAtA[:size])
- if err != nil {
- return nil, err
- }
- return dAtA[:n], nil
-}
-
-func (m *ExtensionOptionDynamicFeeTx) MarshalTo(dAtA []byte) (int, error) {
- size := m.Size()
- return m.MarshalToSizedBuffer(dAtA[:size])
-}
-
-func (m *ExtensionOptionDynamicFeeTx) MarshalToSizedBuffer(dAtA []byte) (int, error) {
- i := len(dAtA)
- _ = i
- var l int
- _ = l
- {
- size := m.MaxPriorityPrice.Size()
- i -= size
- if _, err := m.MaxPriorityPrice.MarshalTo(dAtA[i:]); err != nil {
- return 0, err
- }
- i = encodeVarintDynamicFee(dAtA, i, uint64(size))
- }
- i--
- dAtA[i] = 0xa
- return len(dAtA) - i, nil
-}
-
-func encodeVarintDynamicFee(dAtA []byte, offset int, v uint64) int {
- offset -= sovDynamicFee(v)
- base := offset
- for v >= 1<<7 {
- dAtA[offset] = uint8(v&0x7f | 0x80)
- v >>= 7
- offset++
- }
- dAtA[offset] = uint8(v)
- return base
-}
-func (m *ExtensionOptionDynamicFeeTx) Size() (n int) {
- if m == nil {
- return 0
- }
- var l int
- _ = l
- l = m.MaxPriorityPrice.Size()
- n += 1 + l + sovDynamicFee(uint64(l))
- return n
-}
-
-func sovDynamicFee(x uint64) (n int) {
- return (math_bits.Len64(x|1) + 6) / 7
-}
-func sozDynamicFee(x uint64) (n int) {
- return sovDynamicFee(uint64((x << 1) ^ uint64((int64(x) >> 63))))
-}
-func (m *ExtensionOptionDynamicFeeTx) Unmarshal(dAtA []byte) error {
- l := len(dAtA)
- iNdEx := 0
- for iNdEx < l {
- preIndex := iNdEx
- var wire uint64
- for shift := uint(0); ; shift += 7 {
- if shift >= 64 {
- return ErrIntOverflowDynamicFee
- }
- if iNdEx >= l {
- return io.ErrUnexpectedEOF
- }
- b := dAtA[iNdEx]
- iNdEx++
- wire |= uint64(b&0x7F) << shift
- if b < 0x80 {
- break
- }
- }
- fieldNum := int32(wire >> 3)
- wireType := int(wire & 0x7)
- if wireType == 4 {
- return fmt.Errorf("proto: ExtensionOptionDynamicFeeTx: wiretype end group for non-group")
- }
- if fieldNum <= 0 {
- return fmt.Errorf("proto: ExtensionOptionDynamicFeeTx: illegal tag %d (wire type %d)", fieldNum, wire)
- }
- switch fieldNum {
- case 1:
- if wireType != 2 {
- return fmt.Errorf("proto: wrong wireType = %d for field MaxPriorityPrice", wireType)
- }
- var stringLen uint64
- for shift := uint(0); ; shift += 7 {
- if shift >= 64 {
- return ErrIntOverflowDynamicFee
- }
- if iNdEx >= l {
- return io.ErrUnexpectedEOF
- }
- b := dAtA[iNdEx]
- iNdEx++
- stringLen |= uint64(b&0x7F) << shift
- if b < 0x80 {
- break
- }
- }
- intStringLen := int(stringLen)
- if intStringLen < 0 {
- return ErrInvalidLengthDynamicFee
- }
- postIndex := iNdEx + intStringLen
- if postIndex < 0 {
- return ErrInvalidLengthDynamicFee
- }
- if postIndex > l {
- return io.ErrUnexpectedEOF
- }
- if err := m.MaxPriorityPrice.Unmarshal(dAtA[iNdEx:postIndex]); err != nil {
- return err
- }
- iNdEx = postIndex
- default:
- iNdEx = preIndex
- skippy, err := skipDynamicFee(dAtA[iNdEx:])
- if err != nil {
- return err
- }
- if (skippy < 0) || (iNdEx+skippy) < 0 {
- return ErrInvalidLengthDynamicFee
- }
- if (iNdEx + skippy) > l {
- return io.ErrUnexpectedEOF
- }
- iNdEx += skippy
- }
- }
-
- if iNdEx > l {
- return io.ErrUnexpectedEOF
- }
- return nil
-}
-func skipDynamicFee(dAtA []byte) (n int, err error) {
- l := len(dAtA)
- iNdEx := 0
- depth := 0
- for iNdEx < l {
- var wire uint64
- for shift := uint(0); ; shift += 7 {
- if shift >= 64 {
- return 0, ErrIntOverflowDynamicFee
- }
- if iNdEx >= l {
- return 0, io.ErrUnexpectedEOF
- }
- b := dAtA[iNdEx]
- iNdEx++
- wire |= (uint64(b) & 0x7F) << shift
- if b < 0x80 {
- break
- }
- }
- wireType := int(wire & 0x7)
- switch wireType {
- case 0:
- for shift := uint(0); ; shift += 7 {
- if shift >= 64 {
- return 0, ErrIntOverflowDynamicFee
- }
- if iNdEx >= l {
- return 0, io.ErrUnexpectedEOF
- }
- iNdEx++
- if dAtA[iNdEx-1] < 0x80 {
- break
- }
- }
- case 1:
- iNdEx += 8
- case 2:
- var length int
- for shift := uint(0); ; shift += 7 {
- if shift >= 64 {
- return 0, ErrIntOverflowDynamicFee
- }
- if iNdEx >= l {
- return 0, io.ErrUnexpectedEOF
- }
- b := dAtA[iNdEx]
- iNdEx++
- length |= (int(b) & 0x7F) << shift
- if b < 0x80 {
- break
- }
- }
- if length < 0 {
- return 0, ErrInvalidLengthDynamicFee
- }
- iNdEx += length
- case 3:
- depth++
- case 4:
- if depth == 0 {
- return 0, ErrUnexpectedEndOfGroupDynamicFee
- }
- depth--
- case 5:
- iNdEx += 4
- default:
- return 0, fmt.Errorf("proto: illegal wireType %d", wireType)
- }
- if iNdEx < 0 {
- return 0, ErrInvalidLengthDynamicFee
- }
- if depth == 0 {
- return iNdEx, nil
- }
- }
- return 0, io.ErrUnexpectedEOF
-}
-
-var (
- ErrInvalidLengthDynamicFee = fmt.Errorf("proto: negative length found during unmarshaling")
- ErrIntOverflowDynamicFee = fmt.Errorf("proto: integer overflow")
- ErrUnexpectedEndOfGroupDynamicFee = fmt.Errorf("proto: unexpected end of group")
-)
diff --git a/relayer/codecs/ethermint/keys.pb.go b/relayer/codecs/ethermint/keys.pb.go
index 9b94bf2d0..d29638520 100644
--- a/relayer/codecs/ethermint/keys.pb.go
+++ b/relayer/codecs/ethermint/keys.pb.go
@@ -7,8 +7,8 @@ package ethermint
import (
fmt "fmt"
+ _ "github.com/cosmos/gogoproto/gogoproto"
proto "github.com/cosmos/gogoproto/proto"
- _ "github.com/gogo/protobuf/gogoproto"
io "io"
math "math"
math_bits "math/bits"
diff --git a/relayer/codecs/injective/account.pb.go b/relayer/codecs/injective/account.pb.go
index 2f5d1ced9..3b7d6a22e 100644
--- a/relayer/codecs/injective/account.pb.go
+++ b/relayer/codecs/injective/account.pb.go
@@ -6,8 +6,8 @@ package injective
import (
fmt "fmt"
types "github.com/cosmos/cosmos-sdk/x/auth/types"
+ _ "github.com/cosmos/gogoproto/gogoproto"
proto "github.com/cosmos/gogoproto/proto"
- _ "github.com/gogo/protobuf/gogoproto"
io "io"
math "math"
math_bits "math/bits"
diff --git a/relayer/codecs/injective/algorithm.go b/relayer/codecs/injective/algorithm.go
index 4b6edd110..187a387f6 100644
--- a/relayer/codecs/injective/algorithm.go
+++ b/relayer/codecs/injective/algorithm.go
@@ -1,8 +1,8 @@
package injective
import (
+ "github.com/btcsuite/btcd/btcutil/hdkeychain"
"github.com/btcsuite/btcd/chaincfg"
- "github.com/btcsuite/btcutil/hdkeychain"
"github.com/cosmos/cosmos-sdk/crypto/hd"
cryptotypes "github.com/cosmos/cosmos-sdk/crypto/types"
ethaccounts "github.com/ethereum/go-ethereum/accounts"
diff --git a/relayer/codecs/injective/keys.pb.go b/relayer/codecs/injective/keys.pb.go
index c799acd04..25c30f0c1 100644
--- a/relayer/codecs/injective/keys.pb.go
+++ b/relayer/codecs/injective/keys.pb.go
@@ -7,8 +7,8 @@ package injective
import (
fmt "fmt"
+ _ "github.com/cosmos/gogoproto/gogoproto"
proto "github.com/cosmos/gogoproto/proto"
- _ "github.com/gogo/protobuf/gogoproto"
io "io"
math "math"
math_bits "math/bits"
diff --git a/relayer/common/commitment_path.go b/relayer/common/commitment_path.go
new file mode 100644
index 000000000..9da953adc
--- /dev/null
+++ b/relayer/common/commitment_path.go
@@ -0,0 +1,85 @@
+package common
+
+import (
+ "fmt"
+ "math/big"
+)
+
+func encodePacked(parts ...interface{}) []byte {
+ var result string
+ for _, part := range parts {
+ switch v := part.(type) {
+ case string:
+ result += v
+ case *big.Int:
+ result += v.String()
+ default:
+ panic(fmt.Errorf("unsupported type: %T", v))
+ }
+ }
+ return []byte(result)
+}
+
+func GetClientStatePath(clientId string) []byte {
+ return encodePacked("clients/", clientId, "/clientState")
+}
+
+func GetConsensusStatePath(clientId string, revisionNumber, revisionHeight *big.Int) []byte {
+ return encodePacked("clients/", clientId, "/consensusStates/", revisionNumber, "-", revisionHeight)
+}
+
+func GetConnectionPath(connectionId string) []byte {
+ return encodePacked("connections/", connectionId)
+}
+
+func GetChannelPath(portId, channelId string) []byte {
+ return encodePacked("channelEnds/ports/", portId, "/channels/", channelId)
+}
+
+func GetPacketCommitmentPath(portId, channelId string, sequence *big.Int) []byte {
+ return encodePacked("commitments/ports/", portId, "/channels/", channelId, "/sequences/", sequence)
+}
+
+func GetPacketAcknowledgementCommitmentPath(portId, channelId string, sequence *big.Int) []byte {
+ return encodePacked("acks/ports/", portId, "/channels/", channelId, "/sequences/", sequence)
+}
+
+func GetPacketReceiptCommitmentPath(portId, channelId string, sequence *big.Int) []byte {
+ return encodePacked("receipts/ports/", portId, "/channels/", channelId, "/sequences/", sequence)
+}
+
+func GetNextSequenceRecvCommitmentPath(portId, channelId string) []byte {
+ return encodePacked("nextSequenceRecv/ports/", portId, "/channels/", channelId)
+}
+
+func GetClientStateCommitmentKey(clientId string) []byte {
+ return Sha3keccak256(GetClientStatePath(clientId))
+}
+
+func GetConsensusStateCommitmentKey(clientId string, revisionNumber, revisionHeight *big.Int) []byte {
+ return Sha3keccak256(GetConsensusStatePath(clientId, revisionNumber, revisionHeight))
+}
+
+func GetConnectionCommitmentKey(connectionId string) []byte {
+ return Sha3keccak256(GetConnectionPath(connectionId))
+}
+
+func GetChannelCommitmentKey(portId, channelId string) []byte {
+ return Sha3keccak256(GetChannelPath(portId, channelId))
+}
+
+func GetPacketCommitmentKey(portId, channelId string, sequence *big.Int) []byte {
+ return Sha3keccak256(GetPacketCommitmentPath(portId, channelId, sequence))
+}
+
+func GetPacketAcknowledgementCommitmentKey(portId, channelId string, sequence *big.Int) []byte {
+ return Sha3keccak256(GetPacketAcknowledgementCommitmentPath(portId, channelId, sequence))
+}
+
+func GetPacketReceiptCommitmentKey(portId, channelId string, sequence *big.Int) []byte {
+ return Sha3keccak256(GetPacketReceiptCommitmentPath(portId, channelId, sequence))
+}
+
+func GetNextSequenceRecvCommitmentKey(portId, channelId string) []byte {
+ return Sha3keccak256(GetNextSequenceRecvCommitmentPath(portId, channelId))
+}
diff --git a/relayer/common/const.go b/relayer/common/const.go
new file mode 100644
index 000000000..55dee1afc
--- /dev/null
+++ b/relayer/common/const.go
@@ -0,0 +1,36 @@
+package common
+
+import (
+ conntypes "github.com/cosmos/ibc-go/v7/modules/core/03-connection/types"
+ chantypes "github.com/cosmos/ibc-go/v7/modules/core/04-channel/types"
+)
+
+var (
+ EventTimeoutRequest = "TimeoutRequest(bytes)"
+ IconModule = "icon"
+ WasmModule = "wasm"
+ ArchwayModule = "archway"
+ TendermintLightClient = "07-tendermint"
+ IconLightClient = "iconclient"
+ ConnectionKey = "connection"
+ ChannelKey = "channel"
+ ONE_HOUR = 60 * 60 * 1000
+ NanoToMilliRatio = 1000_000
+)
+
+var (
+ EventRequiresClientUpdate = map[string]bool{
+ chantypes.EventTypeRecvPacket: true,
+ chantypes.EventTypeAcknowledgePacket: true,
+ chantypes.EventTypeTimeoutPacket: true,
+
+ conntypes.EventTypeConnectionOpenTry: true,
+ conntypes.EventTypeConnectionOpenAck: true,
+ conntypes.EventTypeConnectionOpenConfirm: true,
+
+ chantypes.EventTypeChannelOpenTry: true,
+ chantypes.EventTypeChannelOpenAck: true,
+ chantypes.EventTypeChannelOpenConfirm: true,
+ chantypes.EventTypeChannelCloseConfirm: true,
+ }
+)
diff --git a/relayer/common/hash_function.go b/relayer/common/hash_function.go
new file mode 100644
index 000000000..63d8e6fde
--- /dev/null
+++ b/relayer/common/hash_function.go
@@ -0,0 +1,17 @@
+package common
+
+import (
+ "golang.org/x/crypto/sha3"
+)
+
+func AppendKeccak256(out []byte, data ...[]byte) []byte {
+ d := sha3.NewLegacyKeccak256()
+ for _, b := range data {
+ d.Write(b)
+ }
+ return d.Sum(out)
+}
+
+func Sha3keccak256(data ...[]byte) []byte {
+ return AppendKeccak256(nil, data...)
+}
diff --git a/relayer/common/identifier.go b/relayer/common/identifier.go
new file mode 100644
index 000000000..810653844
--- /dev/null
+++ b/relayer/common/identifier.go
@@ -0,0 +1,7 @@
+package common
+
+import "fmt"
+
+func GetIdentifier(name string, i int) string {
+ return fmt.Sprintf("%s-%d", name, i)
+}
diff --git a/relayer/common/utils.go b/relayer/common/utils.go
new file mode 100644
index 000000000..47b4ee60c
--- /dev/null
+++ b/relayer/common/utils.go
@@ -0,0 +1,60 @@
+package common
+
+import (
+ "encoding/hex"
+ "fmt"
+ "os"
+ "path"
+ "strconv"
+ "strings"
+)
+
+func MustHexStrToBytes(hex_string string) []byte {
+ enc, _ := hex.DecodeString(strings.TrimPrefix(hex_string, "0x"))
+ return enc
+}
+
+// Ensures ~/.relayer/chain_name exists and returns that if no error
+func getSnapshotPath(chain_name string) (string, error) {
+ home, err := os.UserHomeDir()
+ if err != nil {
+ return "", fmt.Errorf("Failed to get home directory")
+ }
+ snapshot := path.Join(home, ".relayer", chain_name)
+ if _, err := os.Stat(snapshot); err != nil {
+ if err := os.MkdirAll(snapshot, os.ModePerm); err != nil {
+ return "", err
+ }
+ }
+ return snapshot, nil
+}
+
+func SnapshotHeight(chain_id string, height int64) error {
+ snapshot, err := getSnapshotPath(chain_id)
+ if err != nil {
+ return fmt.Errorf("Failed to find snapshot path, %w", err)
+ }
+ f, err := os.Create(fmt.Sprintf("%s/latest_height", snapshot))
+ defer f.Close()
+ if err != nil {
+ return fmt.Errorf("Failed to create file: %w", err)
+ }
+ _, err = f.WriteString(fmt.Sprintf("%d", height))
+ if err != nil {
+ return fmt.Errorf("Failed to write to file: %w", err)
+ }
+ return nil
+}
+
+func LoadSnapshotHeight(chain_id string) (int64, error) {
+ snapshot, err := getSnapshotPath(chain_id)
+ if err != nil {
+ return -1, fmt.Errorf("Failed to find snapshot path, %w", err)
+ }
+ fileName := fmt.Sprintf("%s/latest_height", snapshot)
+ content, err := os.ReadFile(fileName)
+ if err != nil {
+ return -1, fmt.Errorf("Failed reading file, %w", err)
+ }
+ return strconv.ParseInt(strings.TrimSuffix(string(content), "\n"), 10, 64)
+}
diff --git a/relayer/connection.go b/relayer/connection.go
index 1f818eff7..9c64619cc 100644
--- a/relayer/connection.go
+++ b/relayer/connection.go
@@ -40,6 +40,7 @@ func (c *Chain) CreateOpenConnections(
memo,
DefaultClientUpdateThreshold,
DefaultFlushInterval,
+ DefaultMaxMsgLength,
)
var connectionSrc, connectionDst string
@@ -60,8 +61,8 @@ func (c *Chain) CreateOpenConnections(
return connectionSrc, connectionDst, processor.NewEventProcessor().
WithChainProcessors(
- c.chainProcessor(c.log, nil),
- dst.chainProcessor(c.log, nil),
+ c.chainProcessor(c.log, nil, nil),
+ dst.chainProcessor(c.log, nil, nil),
).
WithPathProcessors(pp).
WithInitialBlockHistory(initialBlockHistory).
diff --git a/relayer/ethermint/dynamic_fee.pb.go b/relayer/ethermint/dynamic_fee.pb.go
index fa2e28c60..3238cd863 100644
--- a/relayer/ethermint/dynamic_fee.pb.go
+++ b/relayer/ethermint/dynamic_fee.pb.go
@@ -6,8 +6,8 @@ package ethermint
import (
fmt "fmt"
github_com_cosmos_cosmos_sdk_types "github.com/cosmos/cosmos-sdk/types"
+ _ "github.com/cosmos/gogoproto/gogoproto"
proto "github.com/cosmos/gogoproto/proto"
- _ "github.com/gogo/protobuf/gogoproto"
io "io"
math "math"
math_bits "math/bits"
diff --git a/relayer/events.go b/relayer/events.go
new file mode 100644
index 000000000..799844e89
--- /dev/null
+++ b/relayer/events.go
@@ -0,0 +1,55 @@
+package relayer
+
+import (
+ "fmt"
+
+ clienttypes "github.com/cosmos/ibc-go/v7/modules/core/02-client/types"
+ connectiontypes "github.com/cosmos/ibc-go/v7/modules/core/03-connection/types"
+ channeltypes "github.com/cosmos/ibc-go/v7/modules/core/04-channel/types"
+ "github.com/cosmos/relayer/v2/relayer/provider"
+)
+
+// ParseClientIDFromEvents parses events emitted from a MsgCreateClient and returns the
+// client identifier.
+func ParseClientIDFromEvents(events []provider.RelayerEvent) (string, error) {
+ for _, event := range events {
+ if event.EventType == clienttypes.EventTypeCreateClient {
+ for attributeKey, attributeValue := range event.Attributes {
+ if attributeKey == clienttypes.AttributeKeyClientID {
+ return attributeValue, nil
+ }
+ }
+ }
+ }
+ return "", fmt.Errorf("client identifier event attribute not found")
+}
+
+// ParseConnectionIDFromEvents parses events emitted from a MsgConnectionOpenInit or
+// MsgConnectionOpenTry and returns the connection identifier.
+func ParseConnectionIDFromEvents(events []provider.RelayerEvent) (string, error) {
+ for _, event := range events {
+ if event.EventType == connectiontypes.EventTypeConnectionOpenInit || event.EventType == connectiontypes.EventTypeConnectionOpenTry {
+ for attributeKey, attributeValue := range event.Attributes {
+ if attributeKey == connectiontypes.AttributeKeyConnectionID {
+ return attributeValue, nil
+ }
+ }
+ }
+ }
+ return "", fmt.Errorf("connection identifier event attribute not found")
+}
+
+// ParseChannelIDFromEvents parses events emitted from a MsgChannelOpenInit or
+// MsgChannelOpenTry and returns the channel identifier.
+func ParseChannelIDFromEvents(events []provider.RelayerEvent) (string, error) {
+ for _, event := range events {
+ if event.EventType == channeltypes.EventTypeChannelOpenInit || event.EventType == channeltypes.EventTypeChannelOpenTry {
+ for attributeKey, attributeValue := range event.Attributes {
+ if attributeKey == channeltypes.AttributeKeyChannelID {
+ return attributeValue, nil
+ }
+ }
+ }
+ }
+ return "", fmt.Errorf("channel identifier event attribute not found")
+}
diff --git a/relayer/packet-tx.go b/relayer/packet-tx.go
index ecc2146e0..1cb38c7b3 100644
--- a/relayer/packet-tx.go
+++ b/relayer/packet-tx.go
@@ -113,7 +113,15 @@ func (c *Chain) SendTransferMsg(ctx context.Context, log *zap.Logger, dst *Chain
)
}
return err
+ } else {
+ if result.SuccessfullySent() {
+ c.log.Info(
+ "Successfully sent a transfer",
+ zap.String("src_chain_id", c.ChainID()),
+ zap.String("dst_chain_id", dst.ChainID()),
+ zap.Object("send_result", result),
+ )
+ }
}
-
return nil
}
diff --git a/relayer/processor/chain_processor.go b/relayer/processor/chain_processor.go
index cb13b589e..5637a47ce 100644
--- a/relayer/processor/chain_processor.go
+++ b/relayer/processor/chain_processor.go
@@ -20,6 +20,14 @@ type ChainProcessor interface {
// Set the PathProcessors that this ChainProcessor should publish relevant IBC events to.
// ChainProcessors need reference to their PathProcessors and vice-versa, handled by EventProcessorBuilder.Build().
SetPathProcessors(pathProcessors PathProcessors)
+
+ // Take snapshot of height every N blocks or when the chain processor fails, so that the relayer
+ // can restart from that height
+ SnapshotHeight(height int64)
+
+ // If the relay goes down, start chain processor from height returned by this function
+ // CAN return max(snapshotHeight, latestHeightFromClient)
+ StartFromHeight(ctx context.Context) int64
}
// ChainProcessors is a slice of ChainProcessor instances.
diff --git a/relayer/processor/message_processor.go b/relayer/processor/message_processor.go
index 776c66303..36c6d664f 100644
--- a/relayer/processor/message_processor.go
+++ b/relayer/processor/message_processor.go
@@ -8,7 +8,10 @@ import (
"sync"
"time"
+ sdkerrors "github.com/cosmos/cosmos-sdk/types/errors"
+ "github.com/cosmos/ibc-go/v7/modules/core/02-client/types"
chantypes "github.com/cosmos/ibc-go/v7/modules/core/04-channel/types"
+ ibcexported "github.com/cosmos/ibc-go/v7/modules/core/exported"
"github.com/cosmos/relayer/v2/relayer/provider"
"go.uber.org/zap"
"go.uber.org/zap/zapcore"
@@ -28,8 +31,13 @@ type messageProcessor struct {
connMsgs []connectionMessageToTrack
chanMsgs []channelMessageToTrack
clientICQMsgs []clientICQMessageToTrack
+
+ isLocalhost bool
}
+// catagories of tx errors for a Prometheus counter. If the error doesnt fall into one of the below categories, it is labeled as "Tx Failure"
+var promErrorCatagories = []error{chantypes.ErrRedundantTx, sdkerrors.ErrInsufficientFunds, sdkerrors.ErrInvalidCoins, sdkerrors.ErrOutOfGas, sdkerrors.ErrWrongSequence}
+
// trackMessage stores the message tracker in the correct slice and index based on the type.
func (mp *messageProcessor) trackMessage(tracker messageToTrack, i int) {
switch t := tracker.(type) {
@@ -66,12 +74,14 @@ func newMessageProcessor(
metrics *PrometheusMetrics,
memo string,
clientUpdateThresholdTime time.Duration,
+ isLocalhost bool,
) *messageProcessor {
return &messageProcessor{
log: log,
metrics: metrics,
memo: memo,
clientUpdateThresholdTime: clientUpdateThresholdTime,
+ isLocalhost: isLocalhost,
}
}
@@ -82,13 +92,20 @@ func (mp *messageProcessor) processMessages(
messages pathEndMessages,
src, dst *pathEndRuntime,
) error {
- needsClientUpdate, err := mp.shouldUpdateClientNow(ctx, src, dst)
- if err != nil {
- return err
- }
+ var needsClientUpdate bool
- if err := mp.assembleMsgUpdateClient(ctx, src, dst); err != nil {
- return err
+ // Localhost IBC does not permit client updates
+ if src.clientState.ClientID != ibcexported.LocalhostClientID && dst.clientState.ClientID != ibcexported.LocalhostConnectionID {
+ var err error
+ // 2/3 rule enough_time_pass && Valid BTP Block
+ needsClientUpdate, err = mp.shouldUpdateClientNow(ctx, src, dst)
+ if err != nil {
+ return err
+ }
+
+ if err := mp.assembleMsgUpdateClient(ctx, src, dst, needsClientUpdate); err != nil {
+ return err
+ }
}
mp.assembleMessages(ctx, messages, src, dst)
@@ -102,6 +119,23 @@ func (mp *messageProcessor) processMessages(
// Otherwise, it will be attempted if either 2/3 of the trusting period
// or the configured client update threshold duration has passed.
func (mp *messageProcessor) shouldUpdateClientNow(ctx context.Context, src, dst *pathEndRuntime) (bool, error) {
+ // handle if dst is IconLightClient
+ if IsBTPLightClient(dst.clientState) {
+ if src.BTPHeightQueue.Size() == 0 {
+ return false, nil
+ }
+ btpHeightInfo, err := src.BTPHeightQueue.GetQueue()
+ if err != nil {
+ return false, nil
+ }
+
+ if btpHeightInfo.IsProcessing {
+ return false, nil
+ }
+ return true, nil
+ }
+
+ // for lightClient other than ICON this will be helpful
var consensusHeightTime time.Time
if dst.clientState.ConsensusTime.IsZero() {
h, err := src.chainProvider.QueryIBCHeader(ctx, int64(dst.clientState.ConsensusHeight.RevisionHeight))
@@ -130,12 +164,19 @@ func (mp *messageProcessor) shouldUpdateClientNow(ctx context.Context, src, dst
shouldUpdateClientNow := enoughBlocksPassed && (pastTwoThirdsTrustingPeriod || pastConfiguredClientUpdateThreshold)
+ if mp.metrics != nil {
+ timeToExpiration := dst.clientState.TrustingPeriod - time.Since(consensusHeightTime)
+ mp.metrics.SetClientExpiration(src.info.PathName, dst.info.ChainID, dst.clientState.ClientID, fmt.Sprint(dst.clientState.TrustingPeriod.String()), timeToExpiration)
+ mp.metrics.SetClientTrustingPeriod(src.info.PathName, dst.info.ChainID, dst.info.ClientID, time.Duration(dst.clientState.TrustingPeriod))
+ }
+
if shouldUpdateClientNow {
mp.log.Info("Client update threshold condition met",
+ zap.String("path_name", src.info.PathName),
zap.String("chain_id", dst.info.ChainID),
zap.String("client_id", dst.info.ClientID),
zap.Int64("trusting_period", dst.clientState.TrustingPeriod.Milliseconds()),
- zap.Int64("time_since_client_update", time.Since(consensusHeightTime).Milliseconds()),
+ // zap.Int64("time_since_client_update", time.Since(consensusHeightTime).Milliseconds()),
zap.Int64("client_threshold_time", mp.clientUpdateThresholdTime.Milliseconds()),
)
}
@@ -147,10 +188,12 @@ func (mp *messageProcessor) shouldUpdateClientNow(ctx context.Context, src, dst
func (mp *messageProcessor) assembleMessages(ctx context.Context, messages pathEndMessages, src, dst *pathEndRuntime) {
var wg sync.WaitGroup
- mp.connMsgs = make([]connectionMessageToTrack, len(messages.connectionMessages))
- for i, msg := range messages.connectionMessages {
- wg.Add(1)
- go mp.assembleMessage(ctx, msg, src, dst, i, &wg)
+ if !mp.isLocalhost {
+ mp.connMsgs = make([]connectionMessageToTrack, len(messages.connectionMessages))
+ for i, msg := range messages.connectionMessages {
+ wg.Add(1)
+ go mp.assembleMessage(ctx, msg, src, dst, i, &wg)
+ }
}
mp.chanMsgs = make([]channelMessageToTrack, len(messages.channelMessages))
@@ -159,10 +202,12 @@ func (mp *messageProcessor) assembleMessages(ctx context.Context, messages pathE
go mp.assembleMessage(ctx, msg, src, dst, i, &wg)
}
- mp.clientICQMsgs = make([]clientICQMessageToTrack, len(messages.clientICQMessages))
- for i, msg := range messages.clientICQMessages {
- wg.Add(1)
- go mp.assembleMessage(ctx, msg, src, dst, i, &wg)
+ if !mp.isLocalhost {
+ mp.clientICQMsgs = make([]clientICQMessageToTrack, len(messages.clientICQMessages))
+ for i, msg := range messages.clientICQMessages {
+ wg.Add(1)
+ go mp.assembleMessage(ctx, msg, src, dst, i, &wg)
+ }
}
mp.pktMsgs = make([]packetMessageToTrack, len(messages.packetMessages))
@@ -199,7 +244,10 @@ func (mp *messageProcessor) assembleMessage(
mp.trackMessage(msg.tracker(assembled), i)
wg.Done()
if err != nil {
- dst.log.Error(fmt.Sprintf("Error assembling %s message", msg.msgType()), zap.Object("msg", msg))
+ dst.log.Error(fmt.Sprintf("Error assembling %s message", msg.msgType()),
+ zap.Object("msg", msg),
+ zap.Error(err),
+ )
return
}
dst.log.Debug(fmt.Sprintf("Assembled %s message", msg.msgType()), zap.Object("msg", msg))
@@ -207,10 +255,18 @@ func (mp *messageProcessor) assembleMessage(
// assembleMsgUpdateClient uses the ChainProvider from both pathEnds to assemble the client update header
// from the source and then assemble the update client message in the correct format for the destination.
-func (mp *messageProcessor) assembleMsgUpdateClient(ctx context.Context, src, dst *pathEndRuntime) error {
+func (mp *messageProcessor) assembleMsgUpdateClient(ctx context.Context, src, dst *pathEndRuntime, shouldUpdate bool) error {
+
+ if IsBTPLightClient(dst.clientState) {
+ err := mp.handleMsgUpdateClientForBTPClient(ctx, src, dst, shouldUpdate)
+ return err
+ }
+
+ // this needs to be edited
clientID := dst.info.ClientID
clientConsensusHeight := dst.clientState.ConsensusHeight
trustedConsensusHeight := dst.clientTrustedState.ClientState.ConsensusHeight
+
var trustedNextValidatorsHash []byte
if dst.clientTrustedState.IBCHeader != nil {
trustedNextValidatorsHash = dst.clientTrustedState.IBCHeader.NextValidatorsHash()
@@ -221,16 +277,21 @@ func (mp *messageProcessor) assembleMsgUpdateClient(ctx context.Context, src, ds
// If the client state height is in the past, beyond ibcHeadersToCache, then we need to query for it.
if !trustedConsensusHeight.EQ(clientConsensusHeight) {
deltaConsensusHeight := int64(clientConsensusHeight.RevisionHeight) - int64(trustedConsensusHeight.RevisionHeight)
+
if trustedConsensusHeight.RevisionHeight != 0 && deltaConsensusHeight <= clientConsensusHeightUpdateThresholdBlocks {
+
return fmt.Errorf("observed client trusted height: %d does not equal latest client state height: %d",
trustedConsensusHeight.RevisionHeight, clientConsensusHeight.RevisionHeight)
}
+
header, err := src.chainProvider.QueryIBCHeader(ctx, int64(clientConsensusHeight.RevisionHeight+1))
if err != nil {
- return fmt.Errorf("error getting IBC header at height: %d for chain_id: %s, %w",
- clientConsensusHeight.RevisionHeight+1, src.info.ChainID, err)
+ return fmt.Errorf("error getting Next IBC header after height: %d for chain_id: %s, %w",
+ clientConsensusHeight.RevisionHeight, src.info.ChainID, err)
}
+
mp.log.Debug("Had to query for client trusted IBC header",
+ zap.String("path_name", src.info.PathName),
zap.String("chain_id", src.info.ChainID),
zap.String("counterparty_chain_id", dst.info.ChainID),
zap.String("counterparty_client_id", clientID),
@@ -271,6 +332,67 @@ func (mp *messageProcessor) assembleMsgUpdateClient(ctx context.Context, src, ds
return nil
}
+func (mp *messageProcessor) handleMsgUpdateClientForBTPClient(ctx context.Context, src, dst *pathEndRuntime, shouldUpdate bool) error {
+
+ clientID := dst.info.ClientID
+ latestConsensusHeight := dst.clientState.ConsensusHeight
+
+ if src.BTPHeightQueue.Size() == 0 {
+ return nil
+ }
+ btpHeightInfo, err := src.BTPHeightQueue.GetQueue()
+ if err != nil {
+ return nil
+ }
+
+ if !shouldUpdate {
+ return nil
+ }
+
+ header, err := src.chainProvider.QueryIBCHeader(ctx, btpHeightInfo.Height)
+ if err != nil {
+ return fmt.Errorf("Failed to query header for height %d", btpHeightInfo.Height)
+ }
+
+ if !header.IsCompleteBlock() {
+ return fmt.Errorf("Should Update is true but the Header is incomplete")
+ }
+
+ if header.Height() <= latestConsensusHeight.RevisionHeight {
+ mp.log.Debug("Src latest header is less then latest client State",
+ zap.String("chain-id", src.info.ChainID),
+ zap.Int64("latest-header-height", int64(src.latestHeader.Height())),
+ zap.Int64("message processing btp-height", int64(src.latestHeader.Height())),
+ zap.Int64("client-state-height", int64(latestConsensusHeight.RevisionHeight)))
+
+ height, err := dst.chainProvider.QueryClientPrevConsensusStateHeight(ctx, int64(dst.latestBlock.Height), dst.clientState.ClientID, int64(header.Height()))
+ if err != nil {
+ return fmt.Errorf("Failed to query prevClientConsensusState")
+ }
+ latestConsensusHeight = types.Height{
+ RevisionNumber: height.GetRevisionNumber(),
+ RevisionHeight: height.GetRevisionHeight(),
+ }
+ }
+
+ msgUpdateClientHeader, err := src.chainProvider.MsgUpdateClientHeader(
+ header,
+ latestConsensusHeight,
+ nil,
+ )
+ if err != nil {
+ return fmt.Errorf("error assembling new client header: %w", err)
+ }
+
+ msgUpdateClient, err := dst.chainProvider.MsgUpdateClient(clientID, msgUpdateClientHeader)
+ if err != nil {
+ return fmt.Errorf("error assembling MsgUpdateClient: %w", err)
+ }
+
+ mp.msgUpdateClient = msgUpdateClient
+ return nil
+}
+
// trackAndSendMessages will increment attempt counters for each message and send each message.
// Messages will be batched if the broadcast mode is configured to 'batch' and there was not an error
// in a previous batch.
@@ -283,14 +405,22 @@ func (mp *messageProcessor) trackAndSendMessages(
var batch []messageToTrack
for _, t := range mp.trackers() {
+
retries := dst.trackProcessingMessage(t)
if t.assembledMsg() == nil {
continue
}
- if broadcastBatch && retries == 0 {
+
+ ordered := false
+ if m, ok := t.(packetMessageToTrack); ok && m.msg.info.ChannelOrder == chantypes.ORDERED.String() {
+ ordered = true
+ }
+
+ if broadcastBatch && (retries == 0 || ordered) {
batch = append(batch, t)
continue
}
+
go mp.sendSingleMessage(ctx, src, dst, t)
}
@@ -321,25 +451,101 @@ func (mp *messageProcessor) sendClientUpdate(
dst.log.Debug("Will relay client update")
- dst.lastClientUpdateHeightMu.Lock()
- dst.lastClientUpdateHeight = dst.latestBlock.Height
- dst.lastClientUpdateHeightMu.Unlock()
+ if IsBTPLightClient(dst.clientState) {
+ blockInfoHeight, err := src.BTPHeightQueue.GetQueue()
+ if err != nil {
+ mp.log.Debug("No message in the queue", zap.Error(err))
+ return
+ }
+ dst.lastClientUpdateHeightMu.Lock()
+ dst.lastClientUpdateHeight = uint64(blockInfoHeight.Height)
+ dst.lastClientUpdateHeightMu.Unlock()
+ src.BTPHeightQueue.ReplaceQueue(zeroIndex, BlockInfoHeight{
+ Height: int64(blockInfoHeight.Height),
+ IsProcessing: true,
+ RetryCount: blockInfoHeight.RetryCount + 1,
+ })
+
+ } else {
+ dst.lastClientUpdateHeightMu.Lock()
+ dst.lastClientUpdateHeight = dst.latestBlock.Height
+ dst.lastClientUpdateHeightMu.Unlock()
+ }
msgs := []provider.RelayerMessage{mp.msgUpdateClient}
- if err := dst.chainProvider.SendMessagesToMempool(broadcastCtx, msgs, mp.memo, ctx, nil); err != nil {
+ callback := func(rtr *provider.RelayerTxResponse, err error) {
+
+ mp.log.Debug("Executing callback of sendClientUpdate ",
+ zap.Any("Transaction Status", rtr.Code),
+ zap.Any("Response", rtr),
+ zap.Any("LastClientUpdateHeight", dst.lastClientUpdateHeight))
+
+ if IsBTPLightClient(dst.clientState) {
+ if src.BTPHeightQueue.Size() == 0 {
+ return
+ }
+ blockHeightInfo, err := src.BTPHeightQueue.GetQueue()
+ if err != nil {
+ return
+ }
+ if rtr.Code == 0 {
+ if blockHeightInfo.Height == int64(dst.lastClientUpdateHeight) {
+ src.BTPHeightQueue.Dequeue()
+ }
+ return
+ }
+ // this would represent a failure case in that case isProcessing should be false
+ if blockHeightInfo.Height == int64(dst.lastClientUpdateHeight) {
+ if blockHeightInfo.RetryCount >= 5 {
+ // removing btpBLock update
+ src.BTPHeightQueue.Dequeue()
+ return
+ }
+
+ src.BTPHeightQueue.ReplaceQueue(zeroIndex, BlockInfoHeight{
+ Height: int64(dst.lastClientUpdateHeight),
+ IsProcessing: false,
+ RetryCount: blockHeightInfo.RetryCount + 1,
+ })
+
+ }
+ }
+ }
+
+ if err := dst.chainProvider.SendMessagesToMempool(broadcastCtx, msgs, mp.memo, ctx, []func(*provider.RelayerTxResponse, error){callback}); err != nil {
mp.log.Error("Error sending client update message",
+ zap.String("path_name", src.info.PathName),
zap.String("src_chain_id", src.info.ChainID),
zap.String("dst_chain_id", dst.info.ChainID),
zap.String("src_client_id", src.info.ClientID),
zap.String("dst_client_id", dst.info.ClientID),
zap.Error(err),
)
+
+ for _, promError := range promErrorCatagories {
+ if mp.metrics != nil {
+ if errors.Is(err, promError) {
+ mp.metrics.IncTxFailure(src.info.PathName, src.info.ChainID, promError.Error())
+ } else {
+ mp.metrics.IncTxFailure(src.info.PathName, src.info.ChainID, "Tx Failure")
+ }
+ }
+ }
return
}
dst.log.Debug("Client update broadcast completed")
}
+type PathProcessorMessageResp struct {
+ Response *provider.RelayerTxResponse
+ DestinationChain provider.ChainProvider
+ SuccessfulTx bool
+ Error error
+}
+
+var PathProcMessageCollector chan *PathProcessorMessageResp
+
// sendBatchMessages will send a batch of messages,
// then increment metrics counters for successful packet messages.
func (mp *messageProcessor) sendBatchMessages(
@@ -350,18 +556,35 @@ func (mp *messageProcessor) sendBatchMessages(
broadcastCtx, cancel := context.WithTimeout(ctx, messageSendTimeout)
defer cancel()
- // messages are batch with appended MsgUpdateClient
- msgs := make([]provider.RelayerMessage, 1+len(batch))
- msgs[0] = mp.msgUpdateClient
- fields := []zapcore.Field{}
- for i, t := range batch {
- msgs[i+1] = t.assembledMsg()
- fields = append(fields, zap.Object(fmt.Sprintf("msg_%d", i), t))
+ var (
+ msgs []provider.RelayerMessage
+ fields []zapcore.Field
+ )
+
+ if mp.isLocalhost {
+ msgs = make([]provider.RelayerMessage, len(batch))
+ for i, t := range batch {
+ msgs[i] = t.assembledMsg()
+ fields = append(fields, zap.Object(fmt.Sprintf("msg_%d", i), t))
+ }
+ } else {
+ // messages are batch with appended MsgUpdateClient
+ msgs = make([]provider.RelayerMessage, 2+len(batch))
+ msgs[0] = mp.msgUpdateClient
+
+ // shouldn't send update incase of icon
+ if !IsBTPLightClient(dst.clientState) {
+ msgs = append(msgs, mp.msgUpdateClient)
+ }
+ for i, t := range batch {
+ msgs[i+1] = t.assembledMsg()
+ fields = append(fields, zap.Object(fmt.Sprintf("msg_%d", i), t))
+ }
}
dst.log.Debug("Will relay messages", fields...)
- callback := func(rtr *provider.RelayerTxResponse, err error) {
+ callback := func(_ *provider.RelayerTxResponse, err error) {
// only increment metrics counts for successful packets
if err != nil || mp.metrics == nil {
return
@@ -382,15 +605,42 @@ func (mp *messageProcessor) sendBatchMessages(
mp.metrics.IncPacketsRelayed(dst.info.PathName, dst.info.ChainID, channel, port, t.msg.eventType)
}
}
+ callbacks := []func(rtr *provider.RelayerTxResponse, err error){callback}
+
+ //During testing, this adds a callback so our test case can inspect the TX results
+ if PathProcMessageCollector != nil {
+ testCallback := func(rtr *provider.RelayerTxResponse, err error) {
+ msgResult := &PathProcessorMessageResp{
+ DestinationChain: dst.chainProvider,
+ Response: rtr,
+ SuccessfulTx: err == nil,
+ Error: err,
+ }
+ PathProcMessageCollector <- msgResult
+ }
+ callbacks = append(callbacks, testCallback)
+ }
- if err := dst.chainProvider.SendMessagesToMempool(broadcastCtx, msgs, mp.memo, ctx, callback); err != nil {
+ if err := dst.chainProvider.SendMessagesToMempool(broadcastCtx, msgs, mp.memo, ctx, callbacks); err != nil {
errFields := []zapcore.Field{
+ zap.String("path_name", src.info.PathName),
zap.String("src_chain_id", src.info.ChainID),
zap.String("dst_chain_id", dst.info.ChainID),
zap.String("src_client_id", src.info.ClientID),
zap.String("dst_client_id", dst.info.ClientID),
zap.Error(err),
}
+
+ for _, promError := range promErrorCatagories {
+ if mp.metrics != nil {
+ if errors.Is(err, promError) {
+ mp.metrics.IncTxFailure(src.info.PathName, src.info.ChainID, promError.Error())
+ } else {
+ mp.metrics.IncTxFailure(src.info.PathName, src.info.ChainID, "Tx Failure")
+ }
+ }
+ }
+
if errors.Is(err, chantypes.ErrRedundantTx) {
mp.log.Debug("Redundant message(s)", errFields...)
return
@@ -407,19 +657,29 @@ func (mp *messageProcessor) sendSingleMessage(
src, dst *pathEndRuntime,
tracker messageToTrack,
) {
- msgs := []provider.RelayerMessage{mp.msgUpdateClient, tracker.assembledMsg()}
+ var msgs []provider.RelayerMessage
+
+ if mp.isLocalhost {
+ msgs = []provider.RelayerMessage{tracker.assembledMsg()}
+ } else {
+ if !IsBTPLightClient(dst.clientState) {
+ msgs = append(msgs, mp.msgUpdateClient)
+ }
+ // {mp.msgUpdateClient}??
+ msgs = append(msgs, tracker.assembledMsg())
+ }
broadcastCtx, cancel := context.WithTimeout(ctx, messageSendTimeout)
defer cancel()
msgType := tracker.msgType()
- dst.log.Debug(fmt.Sprintf("Will broadcast %s message", msgType), zap.Object("msg", tracker))
+ // dst.log.Debug(fmt.Sprintf("Will broadcast %s message", msgType), zap.Object("msg", tracker))
// Set callback for packet messages so that we increment prometheus metrics on successful relays.
- var callback func(rtr *provider.RelayerTxResponse, err error)
+ callbacks := []func(rtr *provider.RelayerTxResponse, err error){}
if t, ok := tracker.(packetMessageToTrack); ok {
- callback = func(rtr *provider.RelayerTxResponse, err error) {
+ callback := func(_ *provider.RelayerTxResponse, err error) {
// only increment metrics counts for successful packets
if err != nil || mp.metrics == nil {
return
@@ -434,16 +694,44 @@ func (mp *messageProcessor) sendSingleMessage(
}
mp.metrics.IncPacketsRelayed(dst.info.PathName, dst.info.ChainID, channel, port, t.msg.eventType)
}
+
+ callbacks = append(callbacks, callback)
+ }
+
+ //During testing, this adds a callback so our test case can inspect the TX results
+ if PathProcMessageCollector != nil {
+ testCallback := func(rtr *provider.RelayerTxResponse, err error) {
+ msgResult := &PathProcessorMessageResp{
+ DestinationChain: dst.chainProvider,
+ Response: rtr,
+ SuccessfulTx: err == nil,
+ Error: err,
+ }
+ PathProcMessageCollector <- msgResult
+ }
+ callbacks = append(callbacks, testCallback)
}
- err := dst.chainProvider.SendMessagesToMempool(broadcastCtx, msgs, mp.memo, ctx, callback)
+ err := dst.chainProvider.SendMessagesToMempool(broadcastCtx, msgs, mp.memo, ctx, callbacks)
if err != nil {
errFields := []zapcore.Field{
+ zap.String("path_name", src.info.PathName),
zap.String("src_chain_id", src.info.ChainID),
zap.String("dst_chain_id", dst.info.ChainID),
zap.String("src_client_id", src.info.ClientID),
zap.String("dst_client_id", dst.info.ClientID),
}
+
+ for _, promError := range promErrorCatagories {
+ if mp.metrics != nil {
+ if errors.Is(err, promError) {
+ mp.metrics.IncTxFailure(src.info.PathName, src.info.ChainID, promError.Error())
+ } else {
+ mp.metrics.IncTxFailure(src.info.PathName, src.info.ChainID, "Tx Failure")
+ }
+ }
+ }
+
errFields = append(errFields, zap.Object("msg", tracker))
errFields = append(errFields, zap.Error(err))
if errors.Is(err, chantypes.ErrRedundantTx) {
diff --git a/relayer/processor/metrics.go b/relayer/processor/metrics.go
index f5f4245e7..1048eed1e 100644
--- a/relayer/processor/metrics.go
+++ b/relayer/processor/metrics.go
@@ -1,6 +1,8 @@
package processor
import (
+ "time"
+
"github.com/prometheus/client_golang/prometheus"
"github.com/prometheus/client_golang/prometheus/promauto"
)
@@ -12,32 +14,56 @@ type PrometheusMetrics struct {
LatestHeightGauge *prometheus.GaugeVec
WalletBalance *prometheus.GaugeVec
FeesSpent *prometheus.GaugeVec
+ TxFailureError *prometheus.CounterVec
+ BlockQueryFailure *prometheus.CounterVec
+ ClientExpiration *prometheus.GaugeVec
+ ClientTrustingPeriod *prometheus.GaugeVec
}
-func (m *PrometheusMetrics) AddPacketsObserved(path, chain, channel, port, eventType string, count int) {
- m.PacketObservedCounter.WithLabelValues(path, chain, channel, port, eventType).Add(float64(count))
+func (m *PrometheusMetrics) AddPacketsObserved(pathName, chain, channel, port, eventType string, count int) {
+ m.PacketObservedCounter.WithLabelValues(pathName, chain, channel, port, eventType).Add(float64(count))
}
-func (m *PrometheusMetrics) IncPacketsRelayed(path, chain, channel, port, eventType string) {
- m.PacketRelayedCounter.WithLabelValues(path, chain, channel, port, eventType).Inc()
+func (m *PrometheusMetrics) IncPacketsRelayed(pathName, chain, channel, port, eventType string) {
+ m.PacketRelayedCounter.WithLabelValues(pathName, chain, channel, port, eventType).Inc()
}
func (m *PrometheusMetrics) SetLatestHeight(chain string, height int64) {
m.LatestHeightGauge.WithLabelValues(chain).Set(float64(height))
}
-func (m *PrometheusMetrics) SetWalletBalance(chain, key, denom string, balance float64) {
- m.WalletBalance.WithLabelValues(chain, key, denom).Set(balance)
+func (m *PrometheusMetrics) SetWalletBalance(chain, gasPrice, key, address, denom string, balance float64) {
+ m.WalletBalance.WithLabelValues(chain, gasPrice, key, address, denom).Set(balance)
+}
+
+func (m *PrometheusMetrics) SetFeesSpent(chain, gasPrice, key, address, denom string, amount float64) {
+ m.FeesSpent.WithLabelValues(chain, gasPrice, key, address, denom).Set(amount)
+}
+
+func (m *PrometheusMetrics) SetClientExpiration(pathName, chain, clientID, trustingPeriod string, timeToExpiration time.Duration) {
+ m.ClientExpiration.WithLabelValues(pathName, chain, clientID, trustingPeriod).Set(timeToExpiration.Seconds())
+}
+
+func (m *PrometheusMetrics) SetClientTrustingPeriod(pathName, chain, clientID string, trustingPeriod time.Duration) {
+ m.ClientTrustingPeriod.WithLabelValues(pathName, chain, clientID).Set(trustingPeriod.Abs().Seconds())
+}
+
+func (m *PrometheusMetrics) IncBlockQueryFailure(chain, err string) {
+ m.BlockQueryFailure.WithLabelValues(chain, err).Inc()
}
-func (m *PrometheusMetrics) SetFeesSpent(chain, key, denom string, amount float64) {
- m.FeesSpent.WithLabelValues(chain, key, denom).Set(amount)
+func (m *PrometheusMetrics) IncTxFailure(pathName, chain, errDesc string) {
+ m.TxFailureError.WithLabelValues(pathName, chain, errDesc).Inc()
}
func NewPrometheusMetrics() *PrometheusMetrics {
- packetLabels := []string{"path", "chain", "channel", "port", "type"}
+ packetLabels := []string{"path_name", "chain", "channel", "port", "type"}
heightLabels := []string{"chain"}
- walletLabels := []string{"chain", "key", "denom"}
+ txFailureLabels := []string{"path_name", "chain", "cause"}
+ blockQueryFailureLabels := []string{"chain", "type"}
+ walletLabels := []string{"chain", "gas_price", "key", "address", "denom"}
+ clientExpirationLables := []string{"path_name", "chain", "client_id", "trusting_period"}
+ clientTrustingPeriodLables := []string{"path_name", "chain", "client_id"}
registry := prometheus.NewRegistry()
registerer := promauto.With(registry)
return &PrometheusMetrics{
@@ -62,5 +88,21 @@ func NewPrometheusMetrics() *PrometheusMetrics {
Name: "cosmos_relayer_fees_spent",
Help: "The amount of fees spent from the relayer's wallet",
}, walletLabels),
+ TxFailureError: registerer.NewCounterVec(prometheus.CounterOpts{
+ Name: "cosmos_relayer_tx_errors_total",
+ Help: "The total number of tx failures broken up into categories. See https://github.com/cosmos/relayer/blob/main/docs/advanced_usage.md#monitoring for list of catagories. 'Tx Failure' is the catch-all category",
+ }, txFailureLabels),
+ BlockQueryFailure: registerer.NewCounterVec(prometheus.CounterOpts{
+ Name: "cosmos_relayer_block_query_errors_total",
+ Help: "The total number of block query failures. The failures are separated into two categories: 'RPC Client' and 'IBC Header'",
+ }, blockQueryFailureLabels),
+ ClientExpiration: registerer.NewGaugeVec(prometheus.GaugeOpts{
+ Name: "cosmos_relayer_client_expiration_seconds",
+ Help: "Seconds until the client expires",
+ }, clientExpirationLables),
+ ClientTrustingPeriod: registerer.NewGaugeVec(prometheus.GaugeOpts{
+ Name: "cosmos_relayer_client_trusting_period_seconds",
+ Help: "The trusting period (in seconds) of the client",
+ }, clientTrustingPeriodLables),
}
}
diff --git a/relayer/processor/path_end_runtime.go b/relayer/processor/path_end_runtime.go
index 05c0f07b5..f42cf6df4 100644
--- a/relayer/processor/path_end_runtime.go
+++ b/relayer/processor/path_end_runtime.go
@@ -2,12 +2,17 @@ package processor
import (
"context"
+ "strings"
"sync"
"time"
+ clienttypes "github.com/cosmos/ibc-go/v7/modules/core/02-client/types"
conntypes "github.com/cosmos/ibc-go/v7/modules/core/03-connection/types"
chantypes "github.com/cosmos/ibc-go/v7/modules/core/04-channel/types"
+ ibcexported "github.com/cosmos/ibc-go/v7/modules/core/exported"
+ "github.com/cosmos/relayer/v2/relayer/common"
"github.com/cosmos/relayer/v2/relayer/provider"
+
"go.uber.org/zap"
)
@@ -22,12 +27,15 @@ type pathEndRuntime struct {
chainProvider provider.ChainProvider
// cached data
- latestBlock provider.LatestBlock
+ latestBlock provider.LatestBlock
+ latestBlockMu sync.Mutex
+
messageCache IBCMessagesCache
clientState provider.ClientState
clientTrustedState provider.ClientTrustedState
connectionStateCache ConnectionStateCache
channelStateCache ChannelStateCache
+ channelOrderCache map[string]chantypes.Order
latestHeader provider.IBCHeader
ibcHeaderCache IBCHeaderCache
@@ -50,7 +58,8 @@ type pathEndRuntime struct {
lastClientUpdateHeight uint64
lastClientUpdateHeightMu sync.Mutex
- metrics *PrometheusMetrics
+ metrics *PrometheusMetrics
+ BTPHeightQueue Queue[BlockInfoHeight]
}
func newPathEndRuntime(log *zap.Logger, pathEnd PathEnd, metrics *PrometheusMetrics) *pathEndRuntime {
@@ -69,9 +78,11 @@ func newPathEndRuntime(log *zap.Logger, pathEnd PathEnd, metrics *PrometheusMetr
packetProcessing: make(packetProcessingCache),
connProcessing: make(connectionProcessingCache),
channelProcessing: make(channelProcessingCache),
+ channelOrderCache: make(map[string]chantypes.Order),
clientICQProcessing: make(clientICQProcessingCache),
connSubscribers: make(map[string][]func(provider.ConnectionInfo)),
metrics: metrics,
+ BTPHeightQueue: NewBlockInfoHeightQueue[BlockInfoHeight](),
}
}
@@ -81,6 +92,7 @@ func (pathEnd *pathEndRuntime) isRelevantConnection(connectionID string) bool {
return true
}
}
+
return false
}
@@ -112,6 +124,7 @@ func (pathEnd *pathEndRuntime) mergeMessageCache(messageCache IBCMessagesCache,
packetMessages[ch] = pmc
}
}
+
pathEnd.messageCache.PacketFlow.Merge(packetMessages)
for eventType, cmc := range messageCache.ConnectionHandshake {
@@ -126,7 +139,9 @@ func (pathEnd *pathEndRuntime) mergeMessageCache(messageCache IBCMessagesCache,
if len(newCmc) == 0 {
continue
}
+
connectionHandshakeMessages[eventType] = newCmc
+
}
pathEnd.messageCache.ConnectionHandshake.Merge(connectionHandshakeMessages)
@@ -136,6 +151,7 @@ func (pathEnd *pathEndRuntime) mergeMessageCache(messageCache IBCMessagesCache,
if !pathEnd.isRelevantChannel(k.ChannelID) {
continue
}
+
// can complete channel handshakes on this client
// since PathProcessor holds reference to the counterparty chain pathEndRuntime.
if eventType == chantypes.EventTypeChannelOpenInit {
@@ -155,6 +171,7 @@ func (pathEnd *pathEndRuntime) mergeMessageCache(messageCache IBCMessagesCache,
channelHandshakeMessages[eventType] = newCmc
}
+
pathEnd.messageCache.ChannelHandshake.Merge(channelHandshakeMessages)
for icqType, cm := range messageCache.ClientICQ {
@@ -232,6 +249,12 @@ func (pathEnd *pathEndRuntime) shouldTerminate(ibcMessagesCache IBCMessagesCache
foundCounterpartyChannelID := m.Termination.Info.CounterpartyChannelID == ""
foundCounterpartyPortID := m.Termination.Info.CounterpartyPortID == ""
for _, ci := range cache {
+ pathEnd.log.Info("Channel handshake termination candidate",
+ zap.String("termination_port_id", m.Termination.Info.PortID),
+ zap.String("observed_port_id", ci.PortID),
+ zap.String("termination_counterparty_port_id", m.Termination.Info.CounterpartyPortID),
+ zap.String("observed_counterparty_port_id", ci.CounterpartyPortID),
+ )
if ci.ChannelID == m.Termination.Info.ChannelID {
foundChannelID = true
}
@@ -249,14 +272,52 @@ func (pathEnd *pathEndRuntime) shouldTerminate(ibcMessagesCache IBCMessagesCache
pathEnd.log.Info("Found termination condition for channel handshake")
return true
}
+ case *ChannelCloseLifecycle:
+ cache, ok := ibcMessagesCache.ChannelHandshake[chantypes.EventTypeChannelCloseConfirm]
+ if !ok {
+ return false
+ }
+ // check against m.Termination.Info
+ foundChannelID := m.SrcChannelID == ""
+ foundPortID := m.SrcPortID == ""
+ for _, ci := range cache {
+ pathEnd.log.Info("Channel close termination candidate",
+ zap.String("termination_port_id", m.SrcPortID),
+ zap.String("observed_port_id", ci.PortID),
+ zap.String("termination_channel_id", m.SrcChannelID),
+ zap.String("observed_channel_id", ci.ChannelID),
+ )
+ if pathEnd.info.ChainID == m.SrcChainID {
+ if ci.ChannelID == m.SrcChannelID {
+ foundChannelID = true
+ }
+ if ci.PortID == m.SrcPortID {
+ foundPortID = true
+ }
+ } else {
+ if ci.CounterpartyChannelID == m.SrcChannelID {
+ foundChannelID = true
+ }
+ if ci.CounterpartyPortID == m.SrcPortID {
+ foundPortID = true
+ }
+ }
+ }
+ if foundChannelID && foundPortID {
+ pathEnd.log.Info("Found termination condition for channel close")
+ return true
+ }
case *ConnectionMessageLifecycle:
+
if m.Termination == nil || m.Termination.ChainID != pathEnd.info.ChainID {
return false
}
cache, ok := ibcMessagesCache.ConnectionHandshake[m.Termination.EventType]
+
if !ok {
return false
}
+
// check against m.Termination.Info
foundClientID := m.Termination.Info.ClientID == ""
foundConnectionID := m.Termination.Info.ConnID == ""
@@ -270,12 +331,15 @@ func (pathEnd *pathEndRuntime) shouldTerminate(ibcMessagesCache IBCMessagesCache
zap.String("observed_counterparty_client_id", ci.CounterpartyClientID),
)
if ci.ClientID == m.Termination.Info.ClientID {
+
foundClientID = true
}
if ci.ConnID == m.Termination.Info.ConnID {
+
foundConnectionID = true
}
if ci.CounterpartyClientID == m.Termination.Info.CounterpartyClientID {
+
foundCounterpartyClientID = true
}
if ci.CounterpartyConnID == m.Termination.Info.CounterpartyConnID {
@@ -283,7 +347,6 @@ func (pathEnd *pathEndRuntime) shouldTerminate(ibcMessagesCache IBCMessagesCache
}
}
if foundClientID && foundConnectionID && foundCounterpartyClientID && foundCounterpartyConnectionID {
- pathEnd.log.Info("Found termination condition for connection handshake")
return true
}
}
@@ -325,14 +388,18 @@ func (pathEnd *pathEndRuntime) checkForMisbehaviour(
}
func (pathEnd *pathEndRuntime) mergeCacheData(ctx context.Context, cancel func(), d ChainProcessorCacheData, counterpartyChainID string, counterpartyInSync bool, messageLifecycle MessageLifecycle, counterParty *pathEndRuntime) {
- pathEnd.lastClientUpdateHeightMu.Lock()
+ pathEnd.latestBlockMu.Lock()
pathEnd.latestBlock = d.LatestBlock
- pathEnd.lastClientUpdateHeightMu.Unlock()
+ pathEnd.latestBlockMu.Unlock()
pathEnd.inSync = d.InSync
pathEnd.latestHeader = d.LatestHeader
pathEnd.clientState = d.ClientState
+ if pathEnd.chainProvider.Type() == common.IconModule && d.LatestHeader.IsCompleteBlock() {
+ pathEnd.BTPHeightQueue.Enqueue(BlockInfoHeight{Height: int64(d.LatestHeader.Height()), IsProcessing: false})
+ }
+
terminate, err := pathEnd.checkForMisbehaviour(ctx, pathEnd.clientState, counterParty)
if err != nil {
pathEnd.log.Error(
@@ -372,6 +439,7 @@ func (pathEnd *pathEndRuntime) shouldSendPacketMessage(message packetIBCMessage,
eventType := message.eventType
sequence := message.info.Sequence
k, err := message.channelKey()
+
if err != nil {
pathEnd.log.Error("Unexpected error checking if should send packet message",
zap.String("event_type", eventType),
@@ -383,10 +451,16 @@ func (pathEnd *pathEndRuntime) shouldSendPacketMessage(message packetIBCMessage,
}
pathEndForHeight := counterparty
- if eventType == chantypes.EventTypeTimeoutPacket || eventType == chantypes.EventTypeTimeoutPacketOnClose {
+ if eventType == chantypes.EventTypeTimeoutPacket ||
+ eventType == chantypes.EventTypeTimeoutPacketOnClose {
pathEndForHeight = pathEnd
}
+ // should be setCounterparty because of this message is generated in response to TimeoutRequest packet
+ if eventType == chantypes.EventTypeTimeoutPacket && IsBTPLightClient(pathEnd.clientState) {
+ pathEndForHeight = counterparty
+ }
+
if message.info.Height >= pathEndForHeight.latestBlock.Height {
pathEnd.log.Debug("Waiting to relay packet message until counterparty height has incremented",
zap.String("event_type", eventType),
@@ -397,7 +471,27 @@ func (pathEnd *pathEndRuntime) shouldSendPacketMessage(message packetIBCMessage,
)
return false
}
- if !pathEnd.channelStateCache[k] {
+
+ // allow to send only counterparty chain has consensusState
+ if IsBTPLightClient(pathEnd.clientState) && common.EventRequiresClientUpdate[eventType] {
+ if pathEnd.clientState.ConsensusHeight.RevisionHeight < message.info.Height {
+ pathEnd.log.Debug("Waiting to relay packet message until clientState is updated",
+ zap.Inline(message),
+ zap.String("event_type", eventType),
+ )
+ return false
+ }
+ if counterparty.BTPHeightQueue.ItemExist(int64(message.info.Height)) {
+
+ pathEnd.log.Debug("Waiting to relay packet message until clientState is in queue",
+ zap.Inline(message),
+ zap.String("event_type", eventType),
+ )
+ return false
+ }
+ }
+
+ if !pathEnd.channelStateCache[k].Open {
// channel is not open, do not send
pathEnd.log.Warn("Refusing to relay packet message because channel is not open",
zap.String("event_type", eventType),
@@ -428,6 +522,9 @@ func (pathEnd *pathEndRuntime) shouldSendPacketMessage(message packetIBCMessage,
// this message was sent less than blocksToRetrySendAfter ago, do not attempt to send again yet.
return false
}
+ if inProgress.retryCount <= 1 && blocksSinceLastProcessed < pathEnd.chainProvider.ProviderConfig().GetFirstRetryBlockAfter() {
+ return false
+ }
} else {
if blocksSinceLastProcessed < blocksToRetryAssemblyAfter {
// this message was sent less than blocksToRetryAssemblyAfter ago, do not attempt assembly again yet.
@@ -459,13 +556,24 @@ func (pathEnd *pathEndRuntime) removePacketRetention(
toDelete := make(map[string][]uint64)
toDeleteCounterparty := make(map[string][]uint64)
switch eventType {
+ case chantypes.EventTypeSendPacket:
+ toDelete[eventType] = []uint64{sequence}
+ toDelete[preInitKey] = []uint64{sequence}
case chantypes.EventTypeRecvPacket:
toDelete[eventType] = []uint64{sequence}
toDeleteCounterparty[chantypes.EventTypeSendPacket] = []uint64{sequence}
+ case chantypes.EventTypeWriteAck:
+ toDelete[eventType] = []uint64{sequence}
+ case common.EventTimeoutRequest:
+ toDelete[eventType] = []uint64{sequence}
+ toDeleteCounterparty[chantypes.EventTypeSendPacket] = []uint64{sequence}
case chantypes.EventTypeAcknowledgePacket, chantypes.EventTypeTimeoutPacket, chantypes.EventTypeTimeoutPacketOnClose:
toDelete[eventType] = []uint64{sequence}
toDeleteCounterparty[chantypes.EventTypeRecvPacket] = []uint64{sequence}
+ toDeleteCounterparty[chantypes.EventTypeWriteAck] = []uint64{sequence}
+ toDelete[chantypes.EventTypeAcknowledgePacket] = []uint64{sequence}
toDelete[chantypes.EventTypeSendPacket] = []uint64{sequence}
+ toDeleteCounterparty[common.EventTimeoutRequest] = []uint64{sequence}
}
// delete in progress send for this specific message
pathEnd.packetProcessing[k].deleteMessages(map[string][]uint64{
@@ -473,14 +581,19 @@ func (pathEnd *pathEndRuntime) removePacketRetention(
})
// delete all packet flow retention history for this sequence
pathEnd.messageCache.PacketFlow[k].DeleteMessages(toDelete)
- counterparty.messageCache.PacketFlow[k].DeleteMessages(toDeleteCounterparty)
+ counterparty.messageCache.PacketFlow[k.Counterparty()].DeleteMessages(toDeleteCounterparty)
}
// shouldSendConnectionMessage determines if the connection handshake message should be sent now.
// It will also determine if the message needs to be given up on entirely and remove retention if so.
func (pathEnd *pathEndRuntime) shouldSendConnectionMessage(message connectionIBCMessage, counterparty *pathEndRuntime) bool {
eventType := message.eventType
- k := connectionInfoConnectionKey(message.info).Counterparty()
+
+ k := ConnectionInfoConnectionKey(message.info)
+ if eventType != conntypes.EventTypeConnectionOpenInit {
+ k = k.Counterparty()
+ }
+
if message.info.Height >= counterparty.latestBlock.Height {
pathEnd.log.Debug("Waiting to relay connection message until counterparty height has incremented",
zap.Inline(k),
@@ -488,6 +601,18 @@ func (pathEnd *pathEndRuntime) shouldSendConnectionMessage(message connectionIBC
)
return false
}
+
+ // allow to send only counterparty chain has consensusState
+ if IsBTPLightClient(pathEnd.clientState) && common.EventRequiresClientUpdate[message.eventType] == true {
+ if pathEnd.clientState.ConsensusHeight.RevisionHeight < message.info.Height {
+ pathEnd.log.Debug("Waiting to relay connection message until clientState is updated",
+ zap.Inline(message),
+ zap.String("event_type", eventType),
+ )
+ return false
+ }
+ }
+
msgProcessCache, ok := pathEnd.connProcessing[eventType]
if !ok {
// in progress cache does not exist for this eventType, so can send.
@@ -504,6 +629,9 @@ func (pathEnd *pathEndRuntime) shouldSendConnectionMessage(message connectionIBC
// this message was sent less than blocksToRetrySendAfter ago, do not attempt to send again yet.
return false
}
+ if inProgress.retryCount <= 1 && blocksSinceLastProcessed < pathEnd.chainProvider.ProviderConfig().GetFirstRetryBlockAfter() {
+ return false
+ }
} else {
if blocksSinceLastProcessed < blocksToRetryAssemblyAfter {
// this message was sent less than blocksToRetryAssemblyAfter ago, do not attempt assembly again yet.
@@ -520,15 +648,20 @@ func (pathEnd *pathEndRuntime) shouldSendConnectionMessage(message connectionIBC
toDeleteCounterparty := make(map[string][]ConnectionKey)
counterpartyKey := k.Counterparty()
switch eventType {
+ case conntypes.EventTypeConnectionOpenInit:
+ toDelete[preInitKey] = []ConnectionKey{k.PreInitKey()}
case conntypes.EventTypeConnectionOpenTry:
toDeleteCounterparty[conntypes.EventTypeConnectionOpenInit] = []ConnectionKey{counterpartyKey.MsgInitKey()}
+ toDeleteCounterparty[preInitKey] = []ConnectionKey{counterpartyKey.PreInitKey()}
case conntypes.EventTypeConnectionOpenAck:
toDeleteCounterparty[conntypes.EventTypeConnectionOpenTry] = []ConnectionKey{counterpartyKey}
toDelete[conntypes.EventTypeConnectionOpenInit] = []ConnectionKey{k.MsgInitKey()}
+ toDelete[preInitKey] = []ConnectionKey{k.PreInitKey()}
case conntypes.EventTypeConnectionOpenConfirm:
toDeleteCounterparty[conntypes.EventTypeConnectionOpenAck] = []ConnectionKey{counterpartyKey}
toDelete[conntypes.EventTypeConnectionOpenTry] = []ConnectionKey{k}
toDeleteCounterparty[conntypes.EventTypeConnectionOpenInit] = []ConnectionKey{counterpartyKey.MsgInitKey()}
+ toDeleteCounterparty[preInitKey] = []ConnectionKey{counterpartyKey.PreInitKey()}
}
// delete in progress send for this specific message
pathEnd.connProcessing.deleteMessages(map[string][]ConnectionKey{eventType: {k}})
@@ -543,18 +676,43 @@ func (pathEnd *pathEndRuntime) shouldSendConnectionMessage(message connectionIBC
return true
}
-// shouldSendConnectionMessage determines if the channel handshake message should be sent now.
+// shouldSendChannelMessage determines if the channel handshake message should be sent now.
// It will also determine if the message needs to be given up on entirely and remove retention if so.
func (pathEnd *pathEndRuntime) shouldSendChannelMessage(message channelIBCMessage, counterparty *pathEndRuntime) bool {
+
eventType := message.eventType
- channelKey := channelInfoChannelKey(message.info).Counterparty()
- if message.info.Height >= counterparty.latestBlock.Height {
+ channelKey := ChannelInfoChannelKey(message.info)
+ if eventType != chantypes.EventTypeChannelOpenInit {
+ channelKey = channelKey.Counterparty()
+ }
+
+ // For localhost cache the channel order on OpenInit so that we can access it during the other channel handshake steps
+ if pathEnd.info.ClientID == ibcexported.LocalhostClientID && eventType == chantypes.EventTypeChannelOpenInit {
+ pathEnd.channelOrderCache[channelKey.ChannelID] = message.info.Order
+ counterparty.channelOrderCache[channelKey.CounterpartyChannelID] = message.info.Order
+ }
+
+ pathEndForHeight := counterparty
+
+ if strings.Contains(pathEnd.clientState.ClientID, "tendermint") && message.info.Height >= pathEndForHeight.latestBlock.Height {
pathEnd.log.Debug("Waiting to relay channel message until counterparty height has incremented",
zap.Inline(channelKey),
zap.String("event_type", eventType),
)
return false
}
+
+ // allow to send only counterparty chain has consensusState
+ if IsBTPLightClient(pathEnd.clientState) && common.EventRequiresClientUpdate[message.eventType] == true {
+ if pathEnd.clientState.ConsensusHeight.RevisionHeight < message.info.Height {
+ pathEnd.log.Debug("Waiting to relay channel message until clientState is updated",
+ zap.Inline(message),
+ zap.String("event_type", eventType),
+ )
+ return false
+ }
+ }
+
msgProcessCache, ok := pathEnd.channelProcessing[eventType]
if !ok {
// in progress cache does not exist for this eventType, so can send.
@@ -571,6 +729,9 @@ func (pathEnd *pathEndRuntime) shouldSendChannelMessage(message channelIBCMessag
// this message was sent less than blocksToRetrySendAfter ago, do not attempt to send again yet.
return false
}
+ if inProgress.retryCount <= 1 && blocksSinceLastProcessed < pathEnd.chainProvider.ProviderConfig().GetFirstRetryBlockAfter() {
+ return false
+ }
} else {
if blocksSinceLastProcessed < blocksToRetryAssemblyAfter {
// this message was sent less than blocksToRetryAssemblyAfter ago, do not attempt assembly again yet.
@@ -591,18 +752,24 @@ func (pathEnd *pathEndRuntime) shouldSendChannelMessage(message channelIBCMessag
counterpartyKey := channelKey.Counterparty()
switch eventType {
+ case chantypes.EventTypeChannelOpenInit:
+ toDelete[preInitKey] = []ChannelKey{channelKey.MsgInitKey()}
case chantypes.EventTypeChannelOpenTry:
toDeleteCounterparty[chantypes.EventTypeChannelOpenInit] = []ChannelKey{counterpartyKey.MsgInitKey()}
+ toDeleteCounterparty[preInitKey] = []ChannelKey{counterpartyKey.MsgInitKey()}
case chantypes.EventTypeChannelOpenAck:
toDeleteCounterparty[chantypes.EventTypeChannelOpenTry] = []ChannelKey{counterpartyKey}
toDelete[chantypes.EventTypeChannelOpenInit] = []ChannelKey{channelKey.MsgInitKey()}
+ toDelete[preInitKey] = []ChannelKey{channelKey.MsgInitKey()}
case chantypes.EventTypeChannelOpenConfirm:
toDeleteCounterparty[chantypes.EventTypeChannelOpenAck] = []ChannelKey{counterpartyKey}
toDelete[chantypes.EventTypeChannelOpenTry] = []ChannelKey{channelKey}
toDeleteCounterparty[chantypes.EventTypeChannelOpenInit] = []ChannelKey{counterpartyKey.MsgInitKey()}
+ toDeleteCounterparty[preInitKey] = []ChannelKey{counterpartyKey.MsgInitKey()}
case chantypes.EventTypeChannelCloseConfirm:
- toDeleteCounterparty[chantypes.EventTypeChannelCloseInit] = []ChannelKey{counterpartyKey}
toDelete[chantypes.EventTypeChannelCloseConfirm] = []ChannelKey{channelKey}
+ toDeleteCounterparty[chantypes.EventTypeChannelCloseInit] = []ChannelKey{counterpartyKey}
+ toDeleteCounterparty[preCloseKey] = []ChannelKey{counterpartyKey}
// Gather relevant send packet messages, for this channel key, that should be deleted if we
// are operating on an ordered channel.
@@ -722,7 +889,10 @@ func (pathEnd *pathEndRuntime) trackProcessingMessage(tracker messageToTrack) ui
}
case channelMessageToTrack:
eventType := t.msg.eventType
- channelKey := channelInfoChannelKey(t.msg.info).Counterparty()
+ channelKey := ChannelInfoChannelKey(t.msg.info)
+ if eventType != chantypes.EventTypeChannelOpenInit {
+ channelKey = channelKey.Counterparty()
+ }
msgProcessCache, ok := pathEnd.channelProcessing[eventType]
if !ok {
msgProcessCache = make(channelKeySendCache)
@@ -740,7 +910,10 @@ func (pathEnd *pathEndRuntime) trackProcessingMessage(tracker messageToTrack) ui
}
case connectionMessageToTrack:
eventType := t.msg.eventType
- connectionKey := connectionInfoConnectionKey(t.msg.info).Counterparty()
+ connectionKey := ConnectionInfoConnectionKey(t.msg.info)
+ if eventType != conntypes.EventTypeConnectionOpenInit {
+ connectionKey = connectionKey.Counterparty()
+ }
msgProcessCache, ok := pathEnd.connProcessing[eventType]
if !ok {
msgProcessCache = make(connectionKeySendCache)
@@ -772,3 +945,27 @@ func (pathEnd *pathEndRuntime) trackProcessingMessage(tracker messageToTrack) ui
return retryCount
}
+
+func (pathEnd *pathEndRuntime) localhostSentinelProofPacket(
+ _ context.Context,
+ _ provider.PacketInfo,
+ height uint64,
+) (provider.PacketProof, error) {
+ return provider.PacketProof{
+ Proof: []byte{0x01},
+ ProofHeight: clienttypes.NewHeight(clienttypes.ParseChainID(pathEnd.info.ChainID), height),
+ }, nil
+}
+
+func (pathEnd *pathEndRuntime) localhostSentinelProofChannel(
+ _ context.Context,
+ info provider.ChannelInfo,
+ height uint64,
+) (provider.ChannelProof, error) {
+ return provider.ChannelProof{
+ Proof: []byte{0x01},
+ ProofHeight: clienttypes.NewHeight(clienttypes.ParseChainID(pathEnd.info.ChainID), height),
+ Ordering: info.Order,
+ Version: info.Version,
+ }, nil
+}
diff --git a/relayer/processor/path_processor.go b/relayer/processor/path_processor.go
index 317764d0a..088597a79 100644
--- a/relayer/processor/path_processor.go
+++ b/relayer/processor/path_processor.go
@@ -5,6 +5,8 @@ import (
"fmt"
"time"
+ chantypes "github.com/cosmos/ibc-go/v7/modules/core/04-channel/types"
+ ibcexported "github.com/cosmos/ibc-go/v7/modules/core/exported"
"github.com/cosmos/relayer/v2/relayer/provider"
"go.uber.org/zap"
)
@@ -27,6 +29,9 @@ const (
// Amount of time to wait for interchain queries.
interchainQueryTimeout = 60 * time.Second
+ // Amount of time between flushes if the previous flush failed.
+ flushFailureRetry = 5 * time.Second
+
// If message assembly fails from either proof query failure on the source
// or assembling the message for the destination, how many blocks should pass
// before retrying.
@@ -34,7 +39,7 @@ const (
// If the message was assembled successfully, but sending the message failed,
// how many blocks should pass before retrying.
- blocksToRetrySendAfter = 5
+ blocksToRetrySendAfter = 1
// How many times to retry sending a message before giving up on it.
maxMessageSendRetries = 5
@@ -63,7 +68,7 @@ type PathProcessor struct {
messageLifecycle MessageLifecycle
initialFlushComplete bool
- flushTicker *time.Ticker
+ flushTimer *time.Timer
flushInterval time.Duration
// Signals to retry.
@@ -71,6 +76,11 @@ type PathProcessor struct {
sentInitialMsg bool
+ // true if this is a localhost IBC connection
+ isLocalhost bool
+
+ maxMsgs uint64
+
metrics *PrometheusMetrics
}
@@ -94,12 +104,11 @@ func NewPathProcessor(
memo string,
clientUpdateThresholdTime time.Duration,
flushInterval time.Duration,
+ maxMsgs uint64,
) *PathProcessor {
- if flushInterval == 0 {
- // "disable" periodic flushing by using a large value.
- flushInterval = 200 * 24 * 365 * time.Hour
- }
- return &PathProcessor{
+ isLocalhost := pathEnd1.ClientID == ibcexported.LocalhostClientID
+
+ pp := &PathProcessor{
log: log,
pathEnd1: newPathEndRuntime(log, pathEnd1, metrics),
pathEnd2: newPathEndRuntime(log, pathEnd2, metrics),
@@ -108,11 +117,36 @@ func NewPathProcessor(
clientUpdateThresholdTime: clientUpdateThresholdTime,
flushInterval: flushInterval,
metrics: metrics,
+ isLocalhost: isLocalhost,
+ maxMsgs: maxMsgs,
+ }
+ if flushInterval == 0 {
+ pp.disablePeriodicFlush()
}
+ return pp
+}
+
+// disablePeriodicFlush will "disable" periodic flushing by using a large value.
+func (pp *PathProcessor) disablePeriodicFlush() {
+ pp.flushInterval = 200 * 24 * 365 * time.Hour
}
func (pp *PathProcessor) SetMessageLifecycle(messageLifecycle MessageLifecycle) {
pp.messageLifecycle = messageLifecycle
+ if !pp.shouldFlush() {
+ // disable flushing when termination conditions are set, e.g. connection/channel handshakes
+ pp.disablePeriodicFlush()
+ }
+}
+
+func (pp *PathProcessor) shouldFlush() bool {
+ if pp.messageLifecycle == nil {
+ return true
+ }
+ if _, ok := pp.messageLifecycle.(*FlushLifecycle); ok {
+ return true
+ }
+ return false
}
// TEST USE ONLY
@@ -152,16 +186,16 @@ func (pp *PathProcessor) OnConnectionMessage(chainID string, eventType string, o
func (pp *PathProcessor) channelPairs() []channelPair {
// Channel keys are from pathEnd1's perspective
- channels := make(map[ChannelKey]bool)
- for k, open := range pp.pathEnd1.channelStateCache {
- channels[k] = open
+ channels := make(map[ChannelKey]ChannelState)
+ for k, cs := range pp.pathEnd1.channelStateCache {
+ channels[k] = cs
}
- for k, open := range pp.pathEnd2.channelStateCache {
- channels[k.Counterparty()] = open
+ for k, cs := range pp.pathEnd2.channelStateCache {
+ channels[k.Counterparty()] = cs
}
pairs := make([]channelPair, len(channels))
i := 0
- for k, _ := range channels {
+ for k := range channels {
pairs[i] = channelPair{
pathEnd1ChannelKey: k,
pathEnd2ChannelKey: k.Counterparty(),
@@ -179,9 +213,19 @@ func (pp *PathProcessor) SetChainProviderIfApplicable(chainProvider provider.Cha
}
if pp.pathEnd1.info.ChainID == chainProvider.ChainId() {
pp.pathEnd1.chainProvider = chainProvider
+
+ if pp.isLocalhost {
+ pp.pathEnd2.chainProvider = chainProvider
+ }
+
return true
} else if pp.pathEnd2.info.ChainID == chainProvider.ChainId() {
pp.pathEnd2.chainProvider = chainProvider
+
+ if pp.isLocalhost {
+ pp.pathEnd1.chainProvider = chainProvider
+ }
+
return true
}
return false
@@ -200,12 +244,15 @@ func (pp *PathProcessor) IsRelevantClient(chainID string, clientID string) bool
if pp.pathEnd1.info.ChainID == chainID {
return pp.pathEnd1.info.ClientID == clientID
} else if pp.pathEnd2.info.ChainID == chainID {
+
return pp.pathEnd2.info.ClientID == clientID
}
+
return false
}
func (pp *PathProcessor) IsRelevantConnection(chainID string, connectionID string) bool {
+
if pp.pathEnd1.info.ChainID == chainID {
return pp.pathEnd1.isRelevantConnection(connectionID)
} else if pp.pathEnd2.info.ChainID == chainID {
@@ -238,6 +285,11 @@ func (pp *PathProcessor) ProcessBacklogIfReady() {
// ChainProcessors call this method when they have new IBC messages
func (pp *PathProcessor) HandleNewData(chainID string, cacheData ChainProcessorCacheData) {
+ if pp.isLocalhost {
+ pp.handleLocalhostData(cacheData)
+ return
+ }
+
if pp.pathEnd1.info.ChainID == chainID {
pp.pathEnd1.incomingCacheData <- cacheData
} else if pp.pathEnd2.info.ChainID == chainID {
@@ -245,6 +297,16 @@ func (pp *PathProcessor) HandleNewData(chainID string, cacheData ChainProcessorC
}
}
+func (pp *PathProcessor) handleFlush(ctx context.Context) {
+ flushTimer := pp.flushInterval
+ if err := pp.flush(ctx); err != nil {
+ pp.log.Warn("Flush not complete", zap.Error(err))
+ flushTimer = flushFailureRetry
+ }
+ pp.flushTimer.Stop()
+ pp.flushTimer = time.NewTimer(flushTimer)
+}
+
// processAvailableSignals will block if signals are not yet available, otherwise it will process one of the available signals.
// It returns whether or not the pathProcessor should quit.
func (pp *PathProcessor) processAvailableSignals(ctx context.Context, cancel func()) bool {
@@ -260,6 +322,7 @@ func (pp *PathProcessor) processAvailableSignals(ctx context.Context, cancel fun
return true
case d := <-pp.pathEnd1.incomingCacheData:
// we have new data from ChainProcessor for pathEnd1
+
pp.pathEnd1.mergeCacheData(ctx, cancel, d, pp.pathEnd2.info.ChainID, pp.pathEnd2.inSync, pp.messageLifecycle, pp.pathEnd2)
case d := <-pp.pathEnd2.incomingCacheData:
@@ -268,9 +331,9 @@ func (pp *PathProcessor) processAvailableSignals(ctx context.Context, cancel fun
case <-pp.retryProcess:
// No new data to merge in, just retry handling.
- case <-pp.flushTicker.C:
+ case <-pp.flushTimer.C:
// Periodic flush to clear out any old packets
- pp.flush(ctx)
+ pp.handleFlush(ctx)
}
return false
}
@@ -279,8 +342,7 @@ func (pp *PathProcessor) processAvailableSignals(ctx context.Context, cancel fun
func (pp *PathProcessor) Run(ctx context.Context, cancel func()) {
var retryTimer *time.Timer
- pp.flushTicker = time.NewTicker(pp.flushInterval)
- defer pp.flushTicker.Stop()
+ pp.flushTimer = time.NewTimer(time.Hour)
for {
// block until we have any signals to process
@@ -299,16 +361,16 @@ func (pp *PathProcessor) Run(ctx context.Context, cancel func()) {
continue
}
- if !pp.initialFlushComplete {
- pp.flush(ctx)
+ if pp.shouldFlush() && !pp.initialFlushComplete {
+ // pp.handleFlush(ctx)
pp.initialFlushComplete = true
- } else if pp.shouldTerminateForFlushComplete(ctx, cancel) {
+ } else if pp.shouldTerminateForFlushComplete() {
cancel()
return
}
// process latest message cache state from both pathEnds
- if err := pp.processLatestMessages(ctx); err != nil {
+ if err := pp.processLatestMessages(ctx, cancel); err != nil {
// in case of IBC message send errors, schedule retry after durationErrorRetry
if retryTimer != nil {
retryTimer.Stop()
@@ -319,3 +381,116 @@ func (pp *PathProcessor) Run(ctx context.Context, cancel func()) {
}
}
}
+
+func (pp *PathProcessor) handleLocalhostData(cacheData ChainProcessorCacheData) {
+ pathEnd1Cache := ChainProcessorCacheData{
+ IBCMessagesCache: NewIBCMessagesCache(),
+ InSync: cacheData.InSync,
+ ClientState: cacheData.ClientState,
+ ConnectionStateCache: cacheData.ConnectionStateCache,
+ ChannelStateCache: cacheData.ChannelStateCache,
+ LatestBlock: cacheData.LatestBlock,
+ LatestHeader: cacheData.LatestHeader,
+ IBCHeaderCache: cacheData.IBCHeaderCache,
+ }
+ pathEnd2Cache := ChainProcessorCacheData{
+ IBCMessagesCache: NewIBCMessagesCache(),
+ InSync: cacheData.InSync,
+ ClientState: cacheData.ClientState,
+ ConnectionStateCache: cacheData.ConnectionStateCache,
+ ChannelStateCache: cacheData.ChannelStateCache,
+ LatestBlock: cacheData.LatestBlock,
+ LatestHeader: cacheData.LatestHeader,
+ IBCHeaderCache: cacheData.IBCHeaderCache,
+ }
+
+ // split up data and send lower channel-id data to pathEnd1 and higher channel-id data to pathEnd2.
+ for k, v := range cacheData.IBCMessagesCache.PacketFlow {
+ chan1, err := chantypes.ParseChannelSequence(k.ChannelID)
+ if err != nil {
+ pp.log.Error("Failed to parse channel ID int from string", zap.Error(err))
+ continue
+ }
+
+ chan2, err := chantypes.ParseChannelSequence(k.CounterpartyChannelID)
+ if err != nil {
+ pp.log.Error("Failed to parse channel ID int from string", zap.Error(err))
+ continue
+ }
+
+ if chan1 < chan2 {
+ pathEnd1Cache.IBCMessagesCache.PacketFlow[k] = v
+ } else {
+ pathEnd2Cache.IBCMessagesCache.PacketFlow[k] = v
+ }
+ }
+
+ for eventType, c := range cacheData.IBCMessagesCache.ChannelHandshake {
+ for k, v := range c {
+ switch eventType {
+ case chantypes.EventTypeChannelOpenInit, chantypes.EventTypeChannelOpenAck, chantypes.EventTypeChannelCloseInit:
+ if _, ok := pathEnd1Cache.IBCMessagesCache.ChannelHandshake[eventType]; !ok {
+ pathEnd1Cache.IBCMessagesCache.ChannelHandshake[eventType] = make(ChannelMessageCache)
+ }
+ if order, ok := pp.pathEnd1.channelOrderCache[k.ChannelID]; ok {
+ v.Order = order
+ }
+ if order, ok := pp.pathEnd2.channelOrderCache[k.CounterpartyChannelID]; ok {
+ v.Order = order
+ }
+ // TODO this is insanely hacky, need to figure out how to handle the ordering dilemma on ordered chans
+ if v.Order == chantypes.NONE {
+ v.Order = chantypes.ORDERED
+ }
+ pathEnd1Cache.IBCMessagesCache.ChannelHandshake[eventType][k] = v
+ case chantypes.EventTypeChannelOpenTry, chantypes.EventTypeChannelOpenConfirm, chantypes.EventTypeChannelCloseConfirm:
+ if _, ok := pathEnd2Cache.IBCMessagesCache.ChannelHandshake[eventType]; !ok {
+ pathEnd2Cache.IBCMessagesCache.ChannelHandshake[eventType] = make(ChannelMessageCache)
+ }
+ if order, ok := pp.pathEnd2.channelOrderCache[k.ChannelID]; ok {
+ v.Order = order
+ }
+ if order, ok := pp.pathEnd1.channelOrderCache[k.CounterpartyChannelID]; ok {
+ v.Order = order
+ }
+
+ pathEnd2Cache.IBCMessagesCache.ChannelHandshake[eventType][k] = v
+ default:
+ pp.log.Error("Invalid IBC channel event type", zap.String("event_type", eventType))
+ }
+ }
+ }
+
+ channelStateCache1 := make(map[ChannelKey]ChannelState)
+ channelStateCache2 := make(map[ChannelKey]ChannelState)
+
+ // split up data and send lower channel-id data to pathEnd2 and higher channel-id data to pathEnd1.
+ for k, v := range cacheData.ChannelStateCache {
+ chan1, err := chantypes.ParseChannelSequence(k.ChannelID)
+ chan2, secErr := chantypes.ParseChannelSequence(k.CounterpartyChannelID)
+
+ if err != nil && secErr != nil {
+ continue
+ }
+
+ // error parsing counterparty chan ID so write chan state to src cache.
+ // this should indicate that the chan handshake has not progressed past the TRY so,
+ // counterparty chan id has not been initialized yet.
+ if secErr != nil && err == nil {
+ channelStateCache1[k] = v
+ continue
+ }
+
+ if chan1 > chan2 {
+ channelStateCache2[k] = v
+ } else {
+ channelStateCache1[k] = v
+ }
+ }
+
+ pathEnd1Cache.ChannelStateCache = channelStateCache1
+ pathEnd2Cache.ChannelStateCache = channelStateCache2
+
+ pp.pathEnd1.incomingCacheData <- pathEnd1Cache
+ pp.pathEnd2.incomingCacheData <- pathEnd2Cache
+}
diff --git a/relayer/processor/path_processor_internal.go b/relayer/processor/path_processor_internal.go
index f588a44dc..405ff16c7 100644
--- a/relayer/processor/path_processor_internal.go
+++ b/relayer/processor/path_processor_internal.go
@@ -4,53 +4,193 @@ import (
"bytes"
"context"
"errors"
+ "fmt"
"sort"
"sync"
+ clienttypes "github.com/cosmos/ibc-go/v7/modules/core/02-client/types"
conntypes "github.com/cosmos/ibc-go/v7/modules/core/03-connection/types"
chantypes "github.com/cosmos/ibc-go/v7/modules/core/04-channel/types"
+
+ "github.com/cosmos/relayer/v2/relayer/common"
"github.com/cosmos/relayer/v2/relayer/provider"
"go.uber.org/zap"
"golang.org/x/sync/errgroup"
)
+// preInitKey is used to declare intent to initialize a connection or channel handshake
+// i.e. a MsgConnectionOpenInit or a MsgChannelOpenInit should be broadcasted to start
+// the handshake if this key exists in the relevant cache.
+const (
+ preInitKey = "pre_init"
+ preCloseKey = "pre_close"
+ maxPacketsPerFlush = 10
+)
+
// getMessagesToSend returns only the lowest sequence message (if it should be sent) for ordered channels,
// otherwise returns all which should be sent.
func (pp *PathProcessor) getMessagesToSend(
+ ctx context.Context,
msgs []packetIBCMessage,
src, dst *pathEndRuntime,
) (srcMsgs []packetIBCMessage, dstMsgs []packetIBCMessage) {
if len(msgs) == 0 {
return
}
- if msgs[0].info.ChannelOrder == chantypes.ORDERED.String() {
- // for packet messages on ordered channels, only handle the lowest sequence number now.
- sort.SliceStable(msgs, func(i, j int) bool {
- return msgs[i].info.Sequence < msgs[j].info.Sequence
- })
- firstMsg := msgs[0]
- switch firstMsg.eventType {
- case chantypes.EventTypeRecvPacket:
- if dst.shouldSendPacketMessage(firstMsg, src) {
- dstMsgs = append(dstMsgs, firstMsg)
+
+ ordered := false
+
+ // channelStateCache most likely has the ordering information.
+ if cs, ok := src.channelStateCache[packetInfoChannelKey(msgs[0].info)]; ok && cs.Order == chantypes.ORDERED {
+ ordered = true
+ }
+
+ // if packet info has the order defined, use that.
+ if msgs[0].info.ChannelOrder != "" && msgs[0].info.ChannelOrder != chantypes.NONE.String() {
+ ordered = msgs[0].info.ChannelOrder == chantypes.ORDERED.String()
+ }
+
+ if ordered {
+ eventMessages := make(map[string][]packetIBCMessage)
+ lowestSeq := make(map[string]uint64)
+
+ for _, m := range msgs {
+ eventMessages[m.eventType] = append(eventMessages[m.eventType], m)
+ switch m.eventType {
+ case chantypes.EventTypeRecvPacket:
+ dstChan, dstPort := m.info.DestChannel, m.info.DestPort
+ res, err := dst.chainProvider.QueryNextSeqRecv(ctx, 0, dstChan, dstPort)
+ if err != nil {
+ dst.log.Error("Failed to query next sequence recv",
+ zap.String("channel_id", dstChan),
+ zap.String("port_id", dstPort),
+ zap.Error(err),
+ )
+ return
+ }
+ lowestSeq[chantypes.EventTypeRecvPacket] = res.NextSequenceReceive
+ case chantypes.EventTypeAcknowledgePacket:
+ srcChan, srcPort := m.info.SourceChannel, m.info.SourcePort
+ res, err := src.chainProvider.QueryNextSeqAck(ctx, 0, srcChan, srcPort)
+ if err != nil {
+ src.log.Error("Failed to query next sequence ack",
+ zap.String("channel_id", srcChan),
+ zap.String("port_id", srcPort),
+ zap.Error(err),
+ )
+ return
+ }
+ lowestSeq[chantypes.EventTypeAcknowledgePacket] = res.NextSequenceReceive
}
- default:
- if src.shouldSendPacketMessage(firstMsg, dst) {
- srcMsgs = append(srcMsgs, firstMsg)
+ }
+
+ for e, m := range eventMessages {
+ m := m
+ sort.SliceStable(m, func(i, j int) bool {
+ return m[i].info.Sequence < m[j].info.Sequence
+ })
+
+ foundFirst := false
+ MsgLoop:
+ for _, msg := range m {
+ if e == chantypes.EventTypeRecvPacket || e == chantypes.EventTypeAcknowledgePacket {
+ if msg.info.Sequence < lowestSeq[e] {
+ // TODO prune these from caches
+ continue MsgLoop
+ } else if msg.info.Sequence > lowestSeq[e] && !foundFirst {
+ switch e {
+ case chantypes.EventTypeRecvPacket:
+ dst.log.Debug("Not yet ready to relay this recv sequence",
+ zap.String("channel_id", msg.info.DestChannel),
+ zap.String("port_id", msg.info.DestPort),
+ zap.Uint64("expected", lowestSeq[e]),
+ zap.Uint64("actual", msg.info.Sequence),
+ )
+ case chantypes.EventTypeAcknowledgePacket:
+ src.log.Debug("Not yet ready to relay this ack sequence",
+ zap.String("channel_id", msg.info.SourceChannel),
+ zap.String("port_id", msg.info.SourcePort),
+ zap.Uint64("expected", lowestSeq[e]),
+ zap.Uint64("actual", msg.info.Sequence),
+ )
+ }
+
+ break MsgLoop
+ }
+ }
+
+ switch e {
+ case chantypes.EventTypeRecvPacket:
+ if len(dstMsgs) > 0 && dstMsgs[len(dstMsgs)-1].eventType == e && dstMsgs[len(dstMsgs)-1].info.Sequence != msg.info.Sequence-1 {
+ dst.log.Debug("Skipping non-consecutive packet(s)",
+ zap.String("event_type", e),
+ zap.String("channel_id", msg.info.DestChannel),
+ zap.String("port_id", msg.info.DestChannel),
+ zap.Uint64("seq", msg.info.Sequence),
+ zap.Uint64("prior_seq", dstMsgs[len(dstMsgs)-1].info.Sequence),
+ )
+ break MsgLoop
+ }
+ if uint64(len(dstMsgs)) <= pp.maxMsgs && dst.shouldSendPacketMessage(msg, src) {
+ dst.log.Debug("Appending packet",
+ zap.String("event_type", e),
+ zap.String("channel_id", msg.info.DestChannel),
+ zap.String("port_id", msg.info.DestChannel),
+ zap.Uint64("seq", msg.info.Sequence),
+ )
+ dstMsgs = append(dstMsgs, msg)
+ if e == chantypes.EventTypeRecvPacket && msg.info.Sequence == lowestSeq[e] {
+ foundFirst = true
+ }
+ }
+ case common.EventTimeoutRequest:
+ if dst.shouldSendPacketMessage(msg, src) {
+ dstMsgs = append(dstMsgs, msg)
+ }
+ default:
+ if len(srcMsgs) > 0 && srcMsgs[len(srcMsgs)-1].eventType == e && srcMsgs[len(srcMsgs)-1].info.Sequence != msg.info.Sequence-1 {
+ src.log.Debug("Skipping non-consecutive packet(s)",
+ zap.String("event_type", e),
+ zap.String("channel_id", msg.info.SourceChannel),
+ zap.String("port_id", msg.info.SourcePort),
+ zap.Uint64("seq", msg.info.Sequence),
+ zap.Uint64("prior_seq", srcMsgs[len(srcMsgs)-1].info.Sequence),
+ )
+ break MsgLoop
+ }
+
+ if uint64(len(srcMsgs)) <= pp.maxMsgs && src.shouldSendPacketMessage(msg, dst) {
+ src.log.Debug("Appending packet",
+ zap.String("event_type", e),
+ zap.String("channel_id", msg.info.SourceChannel),
+ zap.String("port_id", msg.info.SourcePort),
+ zap.Uint64("seq", msg.info.Sequence),
+ )
+ srcMsgs = append(srcMsgs, msg)
+ if e == chantypes.EventTypeAcknowledgePacket && msg.info.Sequence == lowestSeq[e] {
+ foundFirst = true
+ }
+ }
+ }
}
}
+
return srcMsgs, dstMsgs
}
- // for unordered channels, can handle multiple simultaneous packets.
+ // for unordered channels, don't need to worry about sequence ordering.
for _, msg := range msgs {
switch msg.eventType {
case chantypes.EventTypeRecvPacket:
+ if uint64(len(dstMsgs)) <= pp.maxMsgs && dst.shouldSendPacketMessage(msg, src) {
+ dstMsgs = append(dstMsgs, msg)
+ }
+ case common.EventTimeoutRequest:
if dst.shouldSendPacketMessage(msg, src) {
dstMsgs = append(dstMsgs, msg)
}
default:
- if src.shouldSendPacketMessage(msg, dst) {
+ if uint64(len(srcMsgs)) <= pp.maxMsgs && src.shouldSendPacketMessage(msg, dst) {
srcMsgs = append(srcMsgs, msg)
}
}
@@ -58,108 +198,152 @@ func (pp *PathProcessor) getMessagesToSend(
return srcMsgs, dstMsgs
}
-func (pp *PathProcessor) getUnrelayedPacketsAndAcksAndToDelete(ctx context.Context, pathEndPacketFlowMessages pathEndPacketFlowMessages) pathEndPacketFlowResponse {
- res := pathEndPacketFlowResponse{
- ToDeleteSrc: make(map[string][]uint64),
- ToDeleteDst: make(map[string][]uint64),
- ToDeleteDstChannel: make(map[string][]ChannelKey),
- }
-
- var msgs []packetIBCMessage
-
-MsgTransferLoop:
- for transferSeq, msgTransfer := range pathEndPacketFlowMessages.SrcMsgTransfer {
- for ackSeq := range pathEndPacketFlowMessages.SrcMsgAcknowledgement {
- if transferSeq == ackSeq {
- // we have an ack for this packet, so packet flow is complete
- // remove all retention of this sequence number
- res.ToDeleteSrc[chantypes.EventTypeSendPacket] = append(res.ToDeleteSrc[chantypes.EventTypeSendPacket], transferSeq)
- res.ToDeleteDst[chantypes.EventTypeRecvPacket] = append(res.ToDeleteDst[chantypes.EventTypeRecvPacket], transferSeq)
- res.ToDeleteDst[chantypes.EventTypeWriteAck] = append(res.ToDeleteDst[chantypes.EventTypeWriteAck], transferSeq)
- res.ToDeleteSrc[chantypes.EventTypeAcknowledgePacket] = append(res.ToDeleteSrc[chantypes.EventTypeAcknowledgePacket], transferSeq)
- continue MsgTransferLoop
- }
- }
-
- for timeoutSeq, msgTimeout := range pathEndPacketFlowMessages.SrcMsgTimeout {
- if transferSeq == timeoutSeq {
- if msgTimeout.ChannelOrder == chantypes.ORDERED.String() {
- // For ordered channel packets, flow is not done until channel-close-confirm is observed.
- if pathEndPacketFlowMessages.DstMsgChannelCloseConfirm == nil {
- // have not observed a channel-close-confirm yet for this channel, send it if ready.
- // will come back through here next block if not yet ready.
- closeChan := channelIBCMessage{
- eventType: chantypes.EventTypeChannelCloseConfirm,
- info: provider.ChannelInfo{
- Height: msgTimeout.Height,
- PortID: msgTimeout.SourcePort,
- ChannelID: msgTimeout.SourceChannel,
- CounterpartyPortID: msgTimeout.DestPort,
- CounterpartyChannelID: msgTimeout.DestChannel,
- Order: orderFromString(msgTimeout.ChannelOrder),
- },
- }
+func (pp *PathProcessor) unrelayedPacketFlowMessages(
+ ctx context.Context,
+ pathEndPacketFlowMessages pathEndPacketFlowMessages,
+) pathEndPacketFlowResponse {
+ var (
+ res pathEndPacketFlowResponse
+ msgs []packetIBCMessage
+ toDeleteSrc = make(map[string][]uint64)
+ toDeleteDst = make(map[string][]uint64)
+ toDeleteDstChannel = make(map[string][]ChannelKey)
+ )
- if pathEndPacketFlowMessages.Dst.shouldSendChannelMessage(closeChan, pathEndPacketFlowMessages.Src) {
- res.DstChannelMessage = append(res.DstChannelMessage, closeChan)
- }
- } else {
- // ordered channel, and we have a channel close confirm, so packet-flow and channel-close-flow is complete.
- // remove all retention of this sequence number and this channel-close-confirm.
- res.ToDeleteDstChannel[chantypes.EventTypeChannelCloseConfirm] = append(res.ToDeleteDstChannel[chantypes.EventTypeChannelCloseConfirm], pathEndPacketFlowMessages.ChannelKey.Counterparty())
- res.ToDeleteSrc[chantypes.EventTypeSendPacket] = append(res.ToDeleteSrc[chantypes.EventTypeSendPacket], transferSeq)
- res.ToDeleteSrc[chantypes.EventTypeTimeoutPacket] = append(res.ToDeleteSrc[chantypes.EventTypeTimeoutPacket], transferSeq)
- }
- } else {
- // unordered channel, and we have a timeout for this packet, so packet flow is complete
- // remove all retention of this sequence number
- res.ToDeleteSrc[chantypes.EventTypeSendPacket] = append(res.ToDeleteSrc[chantypes.EventTypeSendPacket], transferSeq)
- res.ToDeleteSrc[chantypes.EventTypeTimeoutPacket] = append(res.ToDeleteSrc[chantypes.EventTypeTimeoutPacket], transferSeq)
- }
- continue MsgTransferLoop
- }
+ k := pathEndPacketFlowMessages.ChannelKey
+
+ deletePreInitIfMatches := func(info provider.PacketInfo) {
+ cachedInfo, ok := pathEndPacketFlowMessages.SrcPreTransfer[0]
+ if !ok {
+ return
}
- for timeoutOnCloseSeq := range pathEndPacketFlowMessages.SrcMsgTimeoutOnClose {
- if transferSeq == timeoutOnCloseSeq {
- // we have a timeout for this packet, so packet flow is complete
- // remove all retention of this sequence number
- res.ToDeleteSrc[chantypes.EventTypeSendPacket] = append(res.ToDeleteSrc[chantypes.EventTypeSendPacket], transferSeq)
- res.ToDeleteSrc[chantypes.EventTypeTimeoutPacketOnClose] = append(res.ToDeleteSrc[chantypes.EventTypeTimeoutPacketOnClose], transferSeq)
- continue MsgTransferLoop
- }
+ if !bytes.Equal(cachedInfo.Data, info.Data) {
+ return
}
- for msgRecvSeq, msgAcknowledgement := range pathEndPacketFlowMessages.DstMsgRecvPacket {
- if transferSeq == msgRecvSeq {
- if len(msgAcknowledgement.Ack) == 0 {
- // have recv_packet but not write_acknowledgement yet. skip for now.
- continue MsgTransferLoop
- }
- // msg is received by dst chain, but no ack yet. Need to relay ack from dst to src!
- ackMsg := packetIBCMessage{
- eventType: chantypes.EventTypeAcknowledgePacket,
- info: msgAcknowledgement,
- }
- msgs = append(msgs, ackMsg)
- continue MsgTransferLoop
+ toDeleteSrc[preInitKey] = []uint64{0}
+ }
+
+ processRemovals := func() {
+ pathEndPacketFlowMessages.Src.messageCache.PacketFlow[k].DeleteMessages(toDeleteSrc)
+ pathEndPacketFlowMessages.Dst.messageCache.PacketFlow[k.Counterparty()].DeleteMessages(toDeleteDst)
+ pathEndPacketFlowMessages.Dst.messageCache.ChannelHandshake.DeleteMessages(toDeleteDstChannel)
+ pathEndPacketFlowMessages.Src.packetProcessing[k].deleteMessages(toDeleteSrc)
+ pathEndPacketFlowMessages.Dst.packetProcessing[k.Counterparty()].deleteMessages(toDeleteDst)
+ pathEndPacketFlowMessages.Dst.channelProcessing.deleteMessages(toDeleteDstChannel)
+ toDeleteSrc = make(map[string][]uint64)
+ toDeleteDst = make(map[string][]uint64)
+ toDeleteDstChannel = make(map[string][]ChannelKey)
+ }
+
+ for seq, info := range pathEndPacketFlowMessages.SrcMsgAcknowledgement {
+ // we have observed an ack on chain for this packet, so packet flow is complete
+ // remove all retention of this sequence number
+ deletePreInitIfMatches(info)
+ toDeleteSrc[chantypes.EventTypeSendPacket] = append(toDeleteSrc[chantypes.EventTypeSendPacket], seq)
+ toDeleteDst[chantypes.EventTypeRecvPacket] = append(toDeleteDst[chantypes.EventTypeRecvPacket], seq)
+ toDeleteDst[chantypes.EventTypeWriteAck] = append(toDeleteDst[chantypes.EventTypeWriteAck], seq)
+ toDeleteSrc[chantypes.EventTypeAcknowledgePacket] = append(toDeleteSrc[chantypes.EventTypeAcknowledgePacket], seq)
+ }
+
+ for seq, info := range pathEndPacketFlowMessages.SrcMsgTimeoutOnClose {
+ // we have observed a timeout-on-close on chain for this packet, so packet flow is complete
+ // remove all retention of this sequence number
+ deletePreInitIfMatches(info)
+ toDeleteSrc[chantypes.EventTypeSendPacket] = append(toDeleteSrc[chantypes.EventTypeSendPacket], seq)
+ toDeleteDst[chantypes.EventTypeRecvPacket] = append(toDeleteDst[chantypes.EventTypeRecvPacket], seq)
+ toDeleteDst[chantypes.EventTypeWriteAck] = append(toDeleteDst[chantypes.EventTypeWriteAck], seq)
+ toDeleteSrc[chantypes.EventTypeAcknowledgePacket] = append(toDeleteSrc[chantypes.EventTypeAcknowledgePacket], seq)
+ }
+
+ for seq, info := range pathEndPacketFlowMessages.SrcMsgTimeout {
+ deletePreInitIfMatches(info)
+ toDeleteSrc[chantypes.EventTypeSendPacket] = append(toDeleteSrc[chantypes.EventTypeSendPacket], seq)
+ toDeleteSrc[chantypes.EventTypeTimeoutPacket] = append(toDeleteSrc[chantypes.EventTypeTimeoutPacket], seq)
+ if info.ChannelOrder == chantypes.ORDERED.String() {
+ // Channel is now closed on src.
+ // enqueue channel close init observation to be handled by channel close correlation
+ if _, ok := pathEndPacketFlowMessages.Src.messageCache.ChannelHandshake[chantypes.EventTypeChannelCloseInit]; !ok {
+ pathEndPacketFlowMessages.Src.messageCache.ChannelHandshake[chantypes.EventTypeChannelCloseInit] = make(ChannelMessageCache)
+ }
+ pathEndPacketFlowMessages.Src.messageCache.ChannelHandshake[chantypes.EventTypeChannelCloseInit][k] = provider.ChannelInfo{
+ Height: info.Height,
+ PortID: info.SourcePort,
+ ChannelID: info.SourceChannel,
+ CounterpartyPortID: info.DestPort,
+ CounterpartyChannelID: info.DestChannel,
+ Order: orderFromString(info.ChannelOrder),
}
}
+ }
+
+ processRemovals()
+
+ for seq, info := range pathEndPacketFlowMessages.DstMsgRecvPacket {
+ deletePreInitIfMatches(info)
+ toDeleteSrc[chantypes.EventTypeSendPacket] = append(toDeleteSrc[chantypes.EventTypeSendPacket], seq)
+ toDeleteDst[chantypes.EventTypeRecvPacket] = append(toDeleteDst[chantypes.EventTypeRecvPacket], seq)
+
+ }
+
+ processRemovals()
+
+ for _, info := range pathEndPacketFlowMessages.DstMsgWriteAcknowledgementPacket {
+ ackMsg := packetIBCMessage{
+ eventType: chantypes.EventTypeAcknowledgePacket,
+ info: info,
+ }
+ msgs = append(msgs, ackMsg)
+ }
+
+ for seq, msgTimeoutRequest := range pathEndPacketFlowMessages.DstMsgRequestTimeout {
+ toDeleteSrc[chantypes.EventTypeSendPacket] = append(toDeleteSrc[chantypes.EventTypeSendPacket], seq)
+ timeoutMsg := packetIBCMessage{
+ eventType: chantypes.EventTypeTimeoutPacket,
+ info: msgTimeoutRequest,
+ }
+ msgs = append(msgs, timeoutMsg)
+ }
+ processRemovals()
+
+ for _, info := range pathEndPacketFlowMessages.SrcMsgTransfer {
+ deletePreInitIfMatches(info)
+
// Packet is not yet relayed! need to relay either MsgRecvPacket from src to dst, or MsgTimeout/MsgTimeoutOnClose from dst to src
- if err := pathEndPacketFlowMessages.Dst.chainProvider.ValidatePacket(msgTransfer, pathEndPacketFlowMessages.Dst.latestBlock); err != nil {
+ if err := pathEndPacketFlowMessages.Dst.chainProvider.ValidatePacket(info, pathEndPacketFlowMessages.Dst.latestBlock); err != nil {
var timeoutHeightErr *provider.TimeoutHeightError
var timeoutTimestampErr *provider.TimeoutTimestampError
var timeoutOnCloseErr *provider.TimeoutOnCloseError
+ if pathEndPacketFlowMessages.Dst.chainProvider.Type() == common.IconModule {
+
+ switch {
+ case errors.As(err, &timeoutHeightErr) || errors.As(err, &timeoutTimestampErr):
+ timeoutRequestMsg := packetIBCMessage{
+ eventType: common.EventTimeoutRequest,
+ info: info,
+ }
+ msgs = append(msgs, timeoutRequestMsg)
+
+ default:
+ pp.log.Error("Packet is invalid",
+ zap.String("chain_id", pathEndPacketFlowMessages.Src.info.ChainID),
+ zap.Error(err),
+ )
+ }
+ continue
+ }
+
switch {
case errors.As(err, &timeoutHeightErr) || errors.As(err, &timeoutTimestampErr):
timeoutMsg := packetIBCMessage{
eventType: chantypes.EventTypeTimeoutPacket,
- info: msgTransfer,
+ info: info,
}
msgs = append(msgs, timeoutMsg)
case errors.As(err, &timeoutOnCloseErr):
timeoutOnCloseMsg := packetIBCMessage{
eventType: chantypes.EventTypeTimeoutPacketOnClose,
- info: msgTransfer,
+ info: info,
}
msgs = append(msgs, timeoutOnCloseMsg)
default:
@@ -168,209 +352,366 @@ MsgTransferLoop:
zap.Error(err),
)
}
- continue MsgTransferLoop
+ continue
}
recvPacketMsg := packetIBCMessage{
eventType: chantypes.EventTypeRecvPacket,
- info: msgTransfer,
+ info: info,
}
msgs = append(msgs, recvPacketMsg)
}
- res.SrcMessages, res.DstMessages = pp.getMessagesToSend(msgs, pathEndPacketFlowMessages.Src, pathEndPacketFlowMessages.Dst)
+ processRemovals()
- // now iterate through packet-flow-complete messages and remove any leftover messages if the MsgTransfer or MsgRecvPacket was in a previous block that we did not query
- for ackSeq := range pathEndPacketFlowMessages.SrcMsgAcknowledgement {
- res.ToDeleteSrc[chantypes.EventTypeSendPacket] = append(res.ToDeleteSrc[chantypes.EventTypeSendPacket], ackSeq)
- res.ToDeleteDst[chantypes.EventTypeRecvPacket] = append(res.ToDeleteDst[chantypes.EventTypeRecvPacket], ackSeq)
- res.ToDeleteDst[chantypes.EventTypeWriteAck] = append(res.ToDeleteDst[chantypes.EventTypeWriteAck], ackSeq)
- res.ToDeleteSrc[chantypes.EventTypeAcknowledgePacket] = append(res.ToDeleteSrc[chantypes.EventTypeAcknowledgePacket], ackSeq)
- }
- for timeoutSeq, msgTimeout := range pathEndPacketFlowMessages.SrcMsgTimeout {
- if msgTimeout.ChannelOrder != chantypes.ORDERED.String() {
- res.ToDeleteSrc[chantypes.EventTypeSendPacket] = append(res.ToDeleteSrc[chantypes.EventTypeSendPacket], timeoutSeq)
- res.ToDeleteSrc[chantypes.EventTypeTimeoutPacket] = append(res.ToDeleteSrc[chantypes.EventTypeTimeoutPacket], timeoutSeq)
+ for _, info := range pathEndPacketFlowMessages.SrcPreTransfer {
+ msgTransfer := packetIBCMessage{
+ eventType: chantypes.EventTypeSendPacket,
+ info: info,
}
+ msgs = append(msgs, msgTransfer)
}
- for timeoutOnCloseSeq := range pathEndPacketFlowMessages.SrcMsgTimeoutOnClose {
- res.ToDeleteSrc[chantypes.EventTypeSendPacket] = append(res.ToDeleteSrc[chantypes.EventTypeSendPacket], timeoutOnCloseSeq)
- res.ToDeleteSrc[chantypes.EventTypeTimeoutPacketOnClose] = append(res.ToDeleteSrc[chantypes.EventTypeTimeoutPacketOnClose], timeoutOnCloseSeq)
- }
+
+ res.SrcMessages, res.DstMessages = pp.getMessagesToSend(
+ ctx,
+ msgs,
+ pathEndPacketFlowMessages.Src,
+ pathEndPacketFlowMessages.Dst,
+ )
+
+ res.SrcMessages, res.DstMessages = pp.getMessagesToSend(
+ ctx,
+ msgs,
+ pathEndPacketFlowMessages.Src,
+ pathEndPacketFlowMessages.Dst,
+ )
return res
}
-func (pp *PathProcessor) getUnrelayedConnectionHandshakeMessagesAndToDelete(pathEndConnectionHandshakeMessages pathEndConnectionHandshakeMessages) pathEndConnectionHandshakeResponse {
- res := pathEndConnectionHandshakeResponse{
- ToDeleteSrc: make(map[string][]ConnectionKey),
- ToDeleteDst: make(map[string][]ConnectionKey),
+func (pp *PathProcessor) unrelayedConnectionHandshakeMessages(
+ pathEndConnectionHandshakeMessages pathEndConnectionHandshakeMessages,
+) pathEndConnectionHandshakeResponse {
+ var (
+ res pathEndConnectionHandshakeResponse
+ toDeleteSrc = make(map[string][]ConnectionKey)
+ toDeleteDst = make(map[string][]ConnectionKey)
+ )
+
+ processRemovals := func() {
+ pathEndConnectionHandshakeMessages.Src.messageCache.ConnectionHandshake.DeleteMessages(toDeleteSrc)
+ pathEndConnectionHandshakeMessages.Dst.messageCache.ConnectionHandshake.DeleteMessages(toDeleteDst)
+ pathEndConnectionHandshakeMessages.Src.connProcessing.deleteMessages(toDeleteSrc)
+ pathEndConnectionHandshakeMessages.Dst.connProcessing.deleteMessages(toDeleteDst)
+ toDeleteSrc = make(map[string][]ConnectionKey)
+ toDeleteDst = make(map[string][]ConnectionKey)
}
-ConnectionHandshakeLoop:
- for openInitKey, openInitMsg := range pathEndConnectionHandshakeMessages.SrcMsgConnectionOpenInit {
- var foundOpenTry *provider.ConnectionInfo
- for openTryKey, openTryMsg := range pathEndConnectionHandshakeMessages.DstMsgConnectionOpenTry {
- // MsgConnectionOpenInit does not have counterparty connection ID, so check if everything
- // else matches for counterparty. If so, add counterparty connection ID for
- // the checks later on in this function.
- if openInitKey == openTryKey.Counterparty().MsgInitKey() {
- openInitKey.CounterpartyConnID = openTryKey.ConnectionID
- foundOpenTry = &openTryMsg
- break
- }
+ for connKey := range pathEndConnectionHandshakeMessages.DstMsgConnectionOpenConfirm {
+ // found open confirm, channel handshake complete. remove all retention
+
+ counterpartyKey := connKey.Counterparty()
+ toDeleteDst[conntypes.EventTypeConnectionOpenConfirm] = append(
+ toDeleteDst[conntypes.EventTypeConnectionOpenConfirm],
+ connKey,
+ )
+ toDeleteSrc[conntypes.EventTypeConnectionOpenAck] = append(
+ toDeleteSrc[conntypes.EventTypeConnectionOpenAck],
+ counterpartyKey,
+ )
+ toDeleteDst[conntypes.EventTypeConnectionOpenTry] = append(
+ toDeleteDst[conntypes.EventTypeConnectionOpenTry],
+ connKey,
+ )
+
+ // MsgConnectionOpenInit does not have CounterpartyConnectionID
+ toDeleteSrc[conntypes.EventTypeConnectionOpenInit] = append(
+ toDeleteSrc[conntypes.EventTypeConnectionOpenInit],
+ counterpartyKey.MsgInitKey(),
+ )
+ toDeleteSrc[preInitKey] = append(toDeleteSrc[preInitKey], counterpartyKey.PreInitKey())
+ }
+
+ processRemovals()
+
+ for connKey, info := range pathEndConnectionHandshakeMessages.SrcMsgConnectionOpenAck {
+ // need to send an open confirm to dst
+ msgOpenConfirm := connectionIBCMessage{
+ eventType: conntypes.EventTypeConnectionOpenConfirm,
+ info: info,
}
- if foundOpenTry == nil {
- // need to send an open try to dst
- msgOpenTry := connectionIBCMessage{
- eventType: conntypes.EventTypeConnectionOpenTry,
- info: openInitMsg,
- }
- if pathEndConnectionHandshakeMessages.Dst.shouldSendConnectionMessage(msgOpenTry, pathEndConnectionHandshakeMessages.Src) {
- res.DstMessages = append(res.DstMessages, msgOpenTry)
- }
- continue ConnectionHandshakeLoop
+
+ if pathEndConnectionHandshakeMessages.Dst.shouldSendConnectionMessage(
+ msgOpenConfirm,
+ pathEndConnectionHandshakeMessages.Src,
+ ) {
+ res.DstMessages = append(res.DstMessages, msgOpenConfirm)
}
- var foundOpenAck *provider.ConnectionInfo
- for openAckKey, openAckMsg := range pathEndConnectionHandshakeMessages.SrcMsgConnectionOpenAck {
- if openInitKey == openAckKey {
- foundOpenAck = &openAckMsg
- break
- }
+
+ toDeleteDst[conntypes.EventTypeConnectionOpenTry] = append(
+ toDeleteDst[conntypes.EventTypeConnectionOpenTry], connKey.Counterparty(),
+ )
+
+ // MsgConnectionOpenInit does not have CounterpartyConnectionID
+ toDeleteSrc[conntypes.EventTypeConnectionOpenInit] = append(
+ toDeleteSrc[conntypes.EventTypeConnectionOpenInit], connKey.MsgInitKey(),
+ )
+ toDeleteSrc[preInitKey] = append(toDeleteSrc[preInitKey], connKey.PreInitKey())
+ }
+
+ processRemovals()
+
+ for connKey, info := range pathEndConnectionHandshakeMessages.DstMsgConnectionOpenTry {
+ // need to send an open ack to src
+ msgOpenAck := connectionIBCMessage{
+ eventType: conntypes.EventTypeConnectionOpenAck,
+ info: info,
}
- if foundOpenAck == nil {
- // need to send an open ack to src
- msgOpenAck := connectionIBCMessage{
- eventType: conntypes.EventTypeConnectionOpenAck,
- info: *foundOpenTry,
- }
- if pathEndConnectionHandshakeMessages.Src.shouldSendConnectionMessage(msgOpenAck, pathEndConnectionHandshakeMessages.Dst) {
- res.SrcMessages = append(res.SrcMessages, msgOpenAck)
- }
- continue ConnectionHandshakeLoop
+ if pathEndConnectionHandshakeMessages.Src.shouldSendConnectionMessage(
+ msgOpenAck, pathEndConnectionHandshakeMessages.Dst,
+ ) {
+ res.SrcMessages = append(res.SrcMessages, msgOpenAck)
}
- var foundOpenConfirm *provider.ConnectionInfo
- for openConfirmKey, openConfirmMsg := range pathEndConnectionHandshakeMessages.DstMsgConnectionOpenConfirm {
- if openInitKey == openConfirmKey.Counterparty() {
- foundOpenConfirm = &openConfirmMsg
- break
- }
+
+ counterpartyKey := connKey.Counterparty()
+
+ // MsgConnectionOpenInit does not have CounterpartyConnectionID
+ toDeleteSrc[conntypes.EventTypeConnectionOpenInit] = append(
+ toDeleteSrc[conntypes.EventTypeConnectionOpenInit], counterpartyKey.MsgInitKey(),
+ )
+ toDeleteSrc[preInitKey] = append(toDeleteSrc[preInitKey], counterpartyKey.PreInitKey())
+ }
+
+ processRemovals()
+
+ for connKey, info := range pathEndConnectionHandshakeMessages.SrcMsgConnectionOpenInit {
+ // need to send an open try to dst
+ msgOpenTry := connectionIBCMessage{
+ eventType: conntypes.EventTypeConnectionOpenTry,
+ info: info,
}
- if foundOpenConfirm == nil {
- // need to send an open confirm to dst
- msgOpenConfirm := connectionIBCMessage{
- eventType: conntypes.EventTypeConnectionOpenConfirm,
- info: *foundOpenAck,
- }
- if pathEndConnectionHandshakeMessages.Dst.shouldSendConnectionMessage(msgOpenConfirm, pathEndConnectionHandshakeMessages.Src) {
- res.DstMessages = append(res.DstMessages, msgOpenConfirm)
- }
- continue ConnectionHandshakeLoop
+ if pathEndConnectionHandshakeMessages.Dst.shouldSendConnectionMessage(
+ msgOpenTry, pathEndConnectionHandshakeMessages.Src,
+ ) {
+ res.DstMessages = append(res.DstMessages, msgOpenTry)
}
- // handshake is complete for this connection, remove all retention.
- res.ToDeleteDst[conntypes.EventTypeConnectionOpenTry] = append(res.ToDeleteDst[conntypes.EventTypeConnectionOpenTry], openInitKey)
- res.ToDeleteSrc[conntypes.EventTypeConnectionOpenAck] = append(res.ToDeleteSrc[conntypes.EventTypeConnectionOpenAck], openInitKey)
- res.ToDeleteDst[conntypes.EventTypeConnectionOpenConfirm] = append(res.ToDeleteDst[conntypes.EventTypeConnectionOpenConfirm], openInitKey)
// MsgConnectionOpenInit does not have CounterpartyConnectionID
- openInitKey.CounterpartyConnID = ""
- res.ToDeleteSrc[conntypes.EventTypeConnectionOpenInit] = append(res.ToDeleteSrc[conntypes.EventTypeConnectionOpenInit], openInitKey)
+ toDeleteSrc[preInitKey] = append(toDeleteSrc[preInitKey], connKey.PreInitKey())
}
- // now iterate through connection-handshake-complete messages and remove any leftover messages
- for openConfirmKey := range pathEndConnectionHandshakeMessages.DstMsgConnectionOpenConfirm {
- res.ToDeleteDst[conntypes.EventTypeConnectionOpenTry] = append(res.ToDeleteDst[conntypes.EventTypeConnectionOpenTry], openConfirmKey)
- res.ToDeleteSrc[conntypes.EventTypeConnectionOpenAck] = append(res.ToDeleteSrc[conntypes.EventTypeConnectionOpenAck], openConfirmKey)
- res.ToDeleteDst[conntypes.EventTypeConnectionOpenConfirm] = append(res.ToDeleteDst[conntypes.EventTypeConnectionOpenConfirm], openConfirmKey)
+ processRemovals()
- // MsgConnectionOpenInit does not have CounterpartyConnectionID
- openConfirmKey.CounterpartyConnID = ""
- res.ToDeleteSrc[conntypes.EventTypeConnectionOpenInit] = append(res.ToDeleteSrc[conntypes.EventTypeConnectionOpenInit], openConfirmKey)
+ for _, info := range pathEndConnectionHandshakeMessages.SrcMsgConnectionPreInit {
+ // need to send an open init to src
+ msgOpenInit := connectionIBCMessage{
+ eventType: conntypes.EventTypeConnectionOpenInit,
+ info: info,
+ }
+ if pathEndConnectionHandshakeMessages.Src.shouldSendConnectionMessage(
+ msgOpenInit, pathEndConnectionHandshakeMessages.Dst,
+ ) {
+ res.SrcMessages = append(res.SrcMessages, msgOpenInit)
+ }
}
+
return res
}
-func (pp *PathProcessor) getUnrelayedChannelHandshakeMessagesAndToDelete(pathEndChannelHandshakeMessages pathEndChannelHandshakeMessages) pathEndChannelHandshakeResponse {
- res := pathEndChannelHandshakeResponse{
- ToDeleteSrc: make(map[string][]ChannelKey),
- ToDeleteDst: make(map[string][]ChannelKey),
+func (pp *PathProcessor) unrelayedChannelHandshakeMessages(
+ pathEndChannelHandshakeMessages pathEndChannelHandshakeMessages,
+) pathEndChannelHandshakeResponse {
+ var (
+ res pathEndChannelHandshakeResponse
+ toDeleteSrc = make(map[string][]ChannelKey)
+ toDeleteDst = make(map[string][]ChannelKey)
+ )
+ processRemovals := func() {
+ pathEndChannelHandshakeMessages.Src.messageCache.ChannelHandshake.DeleteMessages(toDeleteSrc)
+ pathEndChannelHandshakeMessages.Dst.messageCache.ChannelHandshake.DeleteMessages(toDeleteDst)
+ pathEndChannelHandshakeMessages.Src.channelProcessing.deleteMessages(toDeleteSrc)
+ pathEndChannelHandshakeMessages.Dst.channelProcessing.deleteMessages(toDeleteDst)
+ toDeleteSrc = make(map[string][]ChannelKey)
+ toDeleteDst = make(map[string][]ChannelKey)
}
-ChannelHandshakeLoop:
- for openInitKey, openInitMsg := range pathEndChannelHandshakeMessages.SrcMsgChannelOpenInit {
- var foundOpenTry *provider.ChannelInfo
- for openTryKey, openTryMsg := range pathEndChannelHandshakeMessages.DstMsgChannelOpenTry {
- // MsgChannelOpenInit does not have counterparty channel ID, so check if everything
- // else matches for counterparty. If so, add counterparty channel ID for
- // the checks later on in this function.
- if openInitKey == openTryKey.Counterparty().MsgInitKey() {
- openInitKey.CounterpartyChannelID = openTryMsg.ChannelID
- foundOpenTry = &openTryMsg
- break
- }
+ for chanKey := range pathEndChannelHandshakeMessages.DstMsgChannelOpenConfirm {
+ // found open confirm, channel handshake complete. remove all retention
+
+ counterpartyKey := chanKey.Counterparty()
+ toDeleteDst[chantypes.EventTypeChannelOpenConfirm] = append(
+ toDeleteDst[chantypes.EventTypeChannelOpenConfirm],
+ chanKey,
+ )
+ toDeleteSrc[chantypes.EventTypeChannelOpenAck] = append(
+ toDeleteSrc[chantypes.EventTypeChannelOpenAck],
+ counterpartyKey,
+ )
+ toDeleteDst[chantypes.EventTypeChannelOpenTry] = append(
+ toDeleteDst[chantypes.EventTypeChannelOpenTry],
+ chanKey,
+ )
+
+ // MsgChannelOpenInit does not have CounterpartyChannelID
+ toDeleteSrc[chantypes.EventTypeChannelOpenInit] = append(
+ toDeleteSrc[chantypes.EventTypeChannelOpenInit],
+ counterpartyKey.MsgInitKey(),
+ )
+ toDeleteSrc[preInitKey] = append(toDeleteSrc[preInitKey], counterpartyKey.PreInitKey())
+ }
+
+ processRemovals()
+
+ for chanKey, info := range pathEndChannelHandshakeMessages.SrcMsgChannelOpenAck {
+ // need to send an open confirm to dst
+ msgOpenConfirm := channelIBCMessage{
+ eventType: chantypes.EventTypeChannelOpenConfirm,
+ info: info,
}
- if foundOpenTry == nil {
- // need to send an open try to dst
- msgOpenTry := channelIBCMessage{
- eventType: chantypes.EventTypeChannelOpenTry,
- info: openInitMsg,
- }
- if pathEndChannelHandshakeMessages.Dst.shouldSendChannelMessage(msgOpenTry, pathEndChannelHandshakeMessages.Src) {
- res.DstMessages = append(res.DstMessages, msgOpenTry)
- }
- continue ChannelHandshakeLoop
+
+ if pathEndChannelHandshakeMessages.Dst.shouldSendChannelMessage(
+ msgOpenConfirm,
+ pathEndChannelHandshakeMessages.Src,
+ ) {
+ res.DstMessages = append(res.DstMessages, msgOpenConfirm)
}
- var foundOpenAck *provider.ChannelInfo
- for openAckKey, openAckMsg := range pathEndChannelHandshakeMessages.SrcMsgChannelOpenAck {
- if openInitKey == openAckKey {
- foundOpenAck = &openAckMsg
- break
- }
+
+ toDeleteDst[chantypes.EventTypeChannelOpenTry] = append(
+ toDeleteDst[chantypes.EventTypeChannelOpenTry], chanKey.Counterparty(),
+ )
+
+ // MsgChannelOpenInit does not have CounterpartyChannelID
+ toDeleteSrc[chantypes.EventTypeChannelOpenInit] = append(
+ toDeleteSrc[chantypes.EventTypeChannelOpenInit], chanKey.MsgInitKey(),
+ )
+ toDeleteSrc[preInitKey] = append(toDeleteSrc[preInitKey], chanKey.PreInitKey())
+ }
+
+ processRemovals()
+
+ for chanKey, info := range pathEndChannelHandshakeMessages.DstMsgChannelOpenTry {
+ // need to send an open ack to src
+ msgOpenAck := channelIBCMessage{
+ eventType: chantypes.EventTypeChannelOpenAck,
+ info: info,
}
- if foundOpenAck == nil {
- // need to send an open ack to src
- msgOpenAck := channelIBCMessage{
- eventType: chantypes.EventTypeChannelOpenAck,
- info: *foundOpenTry,
- }
- if pathEndChannelHandshakeMessages.Src.shouldSendChannelMessage(msgOpenAck, pathEndChannelHandshakeMessages.Dst) {
- res.SrcMessages = append(res.SrcMessages, msgOpenAck)
- }
- continue ChannelHandshakeLoop
+ if pathEndChannelHandshakeMessages.Src.shouldSendChannelMessage(
+ msgOpenAck, pathEndChannelHandshakeMessages.Dst,
+ ) {
+ res.SrcMessages = append(res.SrcMessages, msgOpenAck)
}
- var foundOpenConfirm *provider.ChannelInfo
- for openConfirmKey, openConfirmMsg := range pathEndChannelHandshakeMessages.DstMsgChannelOpenConfirm {
- if openInitKey == openConfirmKey.Counterparty() {
- foundOpenConfirm = &openConfirmMsg
- break
- }
+
+ counterpartyKey := chanKey.Counterparty()
+
+ // MsgChannelOpenInit does not have CounterpartyChannelID
+ toDeleteSrc[chantypes.EventTypeChannelOpenInit] = append(
+ toDeleteSrc[chantypes.EventTypeChannelOpenInit], counterpartyKey.MsgInitKey(),
+ )
+ toDeleteSrc[preInitKey] = append(toDeleteSrc[preInitKey], counterpartyKey.PreInitKey())
+ }
+
+ processRemovals()
+
+ for chanKey, info := range pathEndChannelHandshakeMessages.SrcMsgChannelOpenInit {
+ // need to send an open try to dst
+ msgOpenTry := channelIBCMessage{
+ eventType: chantypes.EventTypeChannelOpenTry,
+ info: info,
}
- if foundOpenConfirm == nil {
- // need to send an open confirm to dst
- msgOpenConfirm := channelIBCMessage{
- eventType: chantypes.EventTypeChannelOpenConfirm,
- info: *foundOpenAck,
- }
- if pathEndChannelHandshakeMessages.Dst.shouldSendChannelMessage(msgOpenConfirm, pathEndChannelHandshakeMessages.Src) {
- res.DstMessages = append(res.DstMessages, msgOpenConfirm)
- }
- continue ChannelHandshakeLoop
+ if pathEndChannelHandshakeMessages.Dst.shouldSendChannelMessage(
+ msgOpenTry, pathEndChannelHandshakeMessages.Src,
+ ) {
+ res.DstMessages = append(res.DstMessages, msgOpenTry)
}
- // handshake is complete for this channel, remove all retention.
- res.ToDeleteDst[chantypes.EventTypeChannelOpenTry] = append(res.ToDeleteDst[chantypes.EventTypeChannelOpenTry], openInitKey)
- res.ToDeleteSrc[chantypes.EventTypeChannelOpenAck] = append(res.ToDeleteSrc[chantypes.EventTypeChannelOpenAck], openInitKey)
- res.ToDeleteDst[chantypes.EventTypeChannelOpenConfirm] = append(res.ToDeleteDst[chantypes.EventTypeChannelOpenConfirm], openInitKey)
+
// MsgChannelOpenInit does not have CounterpartyChannelID
- res.ToDeleteSrc[chantypes.EventTypeChannelOpenInit] = append(res.ToDeleteSrc[chantypes.EventTypeChannelOpenInit], openInitKey.MsgInitKey())
+ toDeleteSrc[preInitKey] = append(toDeleteSrc[preInitKey], chanKey.PreInitKey())
}
- // now iterate through channel-handshake-complete messages and remove any leftover messages
- for openConfirmKey := range pathEndChannelHandshakeMessages.DstMsgChannelOpenConfirm {
- res.ToDeleteDst[chantypes.EventTypeChannelOpenTry] = append(res.ToDeleteDst[chantypes.EventTypeChannelOpenTry], openConfirmKey)
- res.ToDeleteSrc[chantypes.EventTypeChannelOpenAck] = append(res.ToDeleteSrc[chantypes.EventTypeChannelOpenAck], openConfirmKey)
- res.ToDeleteDst[chantypes.EventTypeChannelOpenConfirm] = append(res.ToDeleteDst[chantypes.EventTypeChannelOpenConfirm], openConfirmKey)
- // MsgChannelOpenInit does not have CounterpartyChannelID
- res.ToDeleteSrc[chantypes.EventTypeChannelOpenInit] = append(res.ToDeleteSrc[chantypes.EventTypeChannelOpenInit], openConfirmKey.MsgInitKey())
+ processRemovals()
+
+ for _, info := range pathEndChannelHandshakeMessages.SrcMsgChannelPreInit {
+ // need to send an open init to src
+ msgOpenInit := channelIBCMessage{
+ eventType: chantypes.EventTypeChannelOpenInit,
+ info: info,
+ }
+ if pathEndChannelHandshakeMessages.Src.shouldSendChannelMessage(
+ msgOpenInit, pathEndChannelHandshakeMessages.Dst,
+ ) {
+ res.SrcMessages = append(res.SrcMessages, msgOpenInit)
+ }
+ }
+
+ return res
+}
+
+func (pp *PathProcessor) unrelayedChannelCloseMessages(
+ pathEndChannelCloseMessages pathEndChannelCloseMessages,
+) pathEndChannelHandshakeResponse {
+ var (
+ res pathEndChannelHandshakeResponse
+ toDeleteSrc = make(map[string][]ChannelKey)
+ toDeleteDst = make(map[string][]ChannelKey)
+ )
+ processRemovals := func() {
+ pathEndChannelCloseMessages.Src.messageCache.ChannelHandshake.DeleteMessages(toDeleteSrc)
+ pathEndChannelCloseMessages.Dst.messageCache.ChannelHandshake.DeleteMessages(toDeleteDst)
+ pathEndChannelCloseMessages.Src.channelProcessing.deleteMessages(toDeleteSrc)
+ pathEndChannelCloseMessages.Dst.channelProcessing.deleteMessages(toDeleteDst)
+ toDeleteSrc = make(map[string][]ChannelKey)
+ toDeleteDst = make(map[string][]ChannelKey)
+ }
+
+ for chanKey := range pathEndChannelCloseMessages.DstMsgChannelCloseConfirm {
+ // found close confirm, channel handshake complete. remove all retention
+
+ counterpartyKey := chanKey.Counterparty()
+ toDeleteDst[chantypes.EventTypeChannelCloseConfirm] = append(
+ toDeleteDst[chantypes.EventTypeChannelCloseConfirm],
+ chanKey,
+ )
+ // MsgChannelCloseInit does not have CounterpartyChannelID // TODO: confirm this
+ toDeleteSrc[chantypes.EventTypeChannelCloseInit] = append(
+ toDeleteSrc[chantypes.EventTypeChannelCloseInit],
+ counterpartyKey.MsgInitKey(),
+ )
+ // TODO: confirm chankey does not need modification
+ toDeleteSrc[preCloseKey] = append(toDeleteSrc[preCloseKey], counterpartyKey)
+ }
+
+ processRemovals()
+
+ for chanKey, info := range pathEndChannelCloseMessages.SrcMsgChannelCloseInit {
+ // need to send a close confirm to dst
+ msgCloseConfirm := channelIBCMessage{
+ eventType: chantypes.EventTypeChannelCloseConfirm,
+ info: info,
+ }
+ if pathEndChannelCloseMessages.Dst.shouldSendChannelMessage(
+ msgCloseConfirm, pathEndChannelCloseMessages.Src,
+ ) {
+ res.DstMessages = append(res.DstMessages, msgCloseConfirm)
+ }
+
+ // TODO: confirm chankey does not need modification
+ toDeleteSrc[preCloseKey] = append(toDeleteSrc[preCloseKey], chanKey)
+ }
+
+ processRemovals()
+
+ for _, info := range pathEndChannelCloseMessages.SrcMsgChannelPreInit {
+ // need to send a close init to src
+ msgCloseInit := channelIBCMessage{
+ eventType: chantypes.EventTypeChannelCloseInit,
+ info: info,
+ }
+ if pathEndChannelCloseMessages.Src.shouldSendChannelMessage(
+ msgCloseInit, pathEndChannelCloseMessages.Dst,
+ ) {
+ res.SrcMessages = append(res.SrcMessages, msgCloseInit)
+ }
}
+
return res
}
@@ -401,6 +742,8 @@ ClientICQLoop:
return res
}
+//
+
// updateClientTrustedState combines the counterparty chains trusted IBC header
// with the latest client state, which will be used for constructing MsgUpdateClient messages.
func (pp *PathProcessor) updateClientTrustedState(src *pathEndRuntime, dst *pathEndRuntime) {
@@ -408,39 +751,77 @@ func (pp *PathProcessor) updateClientTrustedState(src *pathEndRuntime, dst *path
// current height already trusted
return
}
- // need to assemble new trusted state
+
+ if IsBTPLightClient(src.clientState) {
+ ibcheader, ok := nextIconIBCHeader(dst.ibcHeaderCache.Clone(), src.clientState.ConsensusHeight.RevisionHeight)
+ if !ok {
+ pp.log.Debug("No cached IBC header found for client next trusted height",
+ zap.String("chain_id", src.info.ChainID),
+ zap.String("client_id", src.info.ClientID),
+ zap.Uint64("height", src.clientState.ConsensusHeight.RevisionHeight),
+ )
+ return
+
+ }
+
+ src.clientTrustedState = provider.ClientTrustedState{
+ ClientState: src.clientState,
+ IBCHeader: ibcheader,
+ }
+ return
+ }
+
ibcHeader, ok := dst.ibcHeaderCache[src.clientState.ConsensusHeight.RevisionHeight+1]
if !ok {
- if ibcHeaderCurrent, ok := dst.ibcHeaderCache[src.clientState.ConsensusHeight.RevisionHeight]; ok &&
- dst.clientTrustedState.IBCHeader != nil &&
- bytes.Equal(dst.clientTrustedState.IBCHeader.NextValidatorsHash(), ibcHeaderCurrent.NextValidatorsHash()) {
- src.clientTrustedState = provider.ClientTrustedState{
- ClientState: src.clientState,
- IBCHeader: ibcHeaderCurrent,
+ if ibcHeaderCurrent, ok := dst.ibcHeaderCache[src.clientState.ConsensusHeight.RevisionHeight]; ok {
+ if dst.clientTrustedState.IBCHeader != nil &&
+ bytes.Equal(src.clientTrustedState.IBCHeader.NextValidatorsHash(), ibcHeaderCurrent.NextValidatorsHash()) {
+ src.clientTrustedState = provider.ClientTrustedState{
+ ClientState: src.clientState,
+ IBCHeader: ibcHeaderCurrent,
+ }
+
+ return
}
- return
}
pp.log.Debug("No cached IBC header for client trusted height",
zap.String("chain_id", src.info.ChainID),
zap.String("client_id", src.info.ClientID),
- zap.Uint64("height", src.clientState.ConsensusHeight.RevisionHeight+1),
+ zap.Uint64("height", src.clientState.ConsensusHeight.RevisionHeight),
)
return
-
}
+
src.clientTrustedState = provider.ClientTrustedState{
ClientState: src.clientState,
IBCHeader: ibcHeader,
}
}
-func (pp *PathProcessor) appendInitialMessageIfNecessary(pathEnd1Messages, pathEnd2Messages *pathEndMessages) {
+var observedEventTypeForDesiredMessage = map[string]string{
+ conntypes.EventTypeConnectionOpenConfirm: conntypes.EventTypeConnectionOpenAck,
+ conntypes.EventTypeConnectionOpenAck: conntypes.EventTypeConnectionOpenTry,
+ conntypes.EventTypeConnectionOpenTry: conntypes.EventTypeConnectionOpenInit,
+ conntypes.EventTypeConnectionOpenInit: preInitKey,
+
+ chantypes.EventTypeChannelOpenConfirm: chantypes.EventTypeChannelOpenAck,
+ chantypes.EventTypeChannelOpenAck: chantypes.EventTypeChannelOpenTry,
+ chantypes.EventTypeChannelOpenTry: chantypes.EventTypeChannelOpenInit,
+ chantypes.EventTypeChannelOpenInit: preInitKey,
+
+ chantypes.EventTypeAcknowledgePacket: chantypes.EventTypeRecvPacket,
+ chantypes.EventTypeRecvPacket: chantypes.EventTypeSendPacket,
+ chantypes.EventTypeSendPacket: preInitKey,
+}
+
+func (pp *PathProcessor) queuePreInitMessages(cancel func()) {
if pp.messageLifecycle == nil || pp.sentInitialMsg {
return
}
- pp.sentInitialMsg = true
+
switch m := pp.messageLifecycle.(type) {
case *PacketMessageLifecycle:
+ pp.sentInitialMsg = true
if m.Initial == nil {
return
}
@@ -451,72 +832,204 @@ func (pp *PathProcessor) appendInitialMessageIfNecessary(pathEnd1Messages, pathE
zap.Inline(channelKey),
zap.Error(err),
)
+ cancel()
return
}
if !pp.IsRelayedChannel(m.Initial.ChainID, channelKey) {
return
}
+ eventType, ok := observedEventTypeForDesiredMessage[m.Initial.EventType]
+ if !ok {
+ pp.log.Error(
+ "Failed to queue initial connection message, event type not handled",
+ zap.String("event_type", m.Initial.EventType),
+ )
+ cancel()
+ return
+ }
if m.Initial.ChainID == pp.pathEnd1.info.ChainID {
- pathEnd1Messages.packetMessages = append(pathEnd1Messages.packetMessages, packetIBCMessage{
- eventType: m.Initial.EventType,
- info: m.Initial.Info,
- })
+ _, ok = pp.pathEnd1.messageCache.PacketFlow[channelKey][eventType]
+ if !ok {
+ pp.pathEnd1.messageCache.PacketFlow[channelKey][eventType] = make(PacketSequenceCache)
+ }
+ pp.pathEnd1.messageCache.PacketFlow[channelKey][eventType][0] = m.Initial.Info
} else if m.Initial.ChainID == pp.pathEnd2.info.ChainID {
- pathEnd2Messages.packetMessages = append(pathEnd2Messages.packetMessages, packetIBCMessage{
- eventType: m.Initial.EventType,
- info: m.Initial.Info,
- })
+ _, ok = pp.pathEnd2.messageCache.PacketFlow[channelKey][eventType]
+ if !ok {
+ pp.pathEnd2.messageCache.PacketFlow[channelKey][eventType] = make(PacketSequenceCache)
+ }
+ pp.pathEnd2.messageCache.PacketFlow[channelKey][eventType][0] = m.Initial.Info
}
case *ConnectionMessageLifecycle:
+ pp.sentInitialMsg = true
if m.Initial == nil {
return
}
+
if !pp.IsRelevantClient(m.Initial.ChainID, m.Initial.Info.ClientID) {
return
}
+
+ eventType, ok := observedEventTypeForDesiredMessage[m.Initial.EventType]
+ if !ok {
+ pp.log.Error(
+ "Failed to queue initial connection message, event type not handled",
+ zap.String("event_type", m.Initial.EventType),
+ )
+ cancel()
+ return
+ }
+ connKey := ConnectionInfoConnectionKey(m.Initial.Info)
if m.Initial.ChainID == pp.pathEnd1.info.ChainID {
- pathEnd1Messages.connectionMessages = append(pathEnd1Messages.connectionMessages, connectionIBCMessage{
- eventType: m.Initial.EventType,
- info: m.Initial.Info,
- })
+ _, ok = pp.pathEnd1.messageCache.ConnectionHandshake[eventType]
+ if !ok {
+ pp.pathEnd1.messageCache.ConnectionHandshake[eventType] = make(ConnectionMessageCache)
+ }
+ pp.pathEnd1.messageCache.ConnectionHandshake[eventType][connKey] = m.Initial.Info
} else if m.Initial.ChainID == pp.pathEnd2.info.ChainID {
- pathEnd2Messages.connectionMessages = append(pathEnd2Messages.connectionMessages, connectionIBCMessage{
- eventType: m.Initial.EventType,
- info: m.Initial.Info,
- })
+ _, ok = pp.pathEnd2.messageCache.ConnectionHandshake[eventType]
+ if !ok {
+ pp.pathEnd2.messageCache.ConnectionHandshake[eventType] = make(ConnectionMessageCache)
+ }
+ pp.pathEnd2.messageCache.ConnectionHandshake[eventType][connKey] = m.Initial.Info
}
case *ChannelMessageLifecycle:
+ pp.sentInitialMsg = true
if m.Initial == nil {
return
}
+
if !pp.IsRelevantConnection(m.Initial.ChainID, m.Initial.Info.ConnID) {
return
}
+
+ eventType, ok := observedEventTypeForDesiredMessage[m.Initial.EventType]
+ if !ok {
+ pp.log.Error(
+ "Failed to queue initial channel message, event type not handled",
+ zap.String("event_type", m.Initial.EventType),
+ )
+ cancel()
+ return
+ }
+ chanKey := ChannelInfoChannelKey(m.Initial.Info)
if m.Initial.ChainID == pp.pathEnd1.info.ChainID {
- pathEnd1Messages.channelMessages = append(pathEnd1Messages.channelMessages, channelIBCMessage{
- eventType: m.Initial.EventType,
- info: m.Initial.Info,
- })
+ _, ok = pp.pathEnd1.messageCache.ChannelHandshake[eventType]
+ if !ok {
+ pp.pathEnd1.messageCache.ChannelHandshake[eventType] = make(ChannelMessageCache)
+ }
+ pp.pathEnd1.messageCache.ChannelHandshake[eventType][chanKey] = m.Initial.Info
} else if m.Initial.ChainID == pp.pathEnd2.info.ChainID {
- pathEnd2Messages.channelMessages = append(pathEnd2Messages.channelMessages, channelIBCMessage{
- eventType: m.Initial.EventType,
- info: m.Initial.Info,
- })
+ _, ok = pp.pathEnd2.messageCache.ChannelHandshake[eventType]
+ if !ok {
+ pp.pathEnd2.messageCache.ChannelHandshake[eventType] = make(ChannelMessageCache)
+ }
+ pp.pathEnd2.messageCache.ChannelHandshake[eventType][chanKey] = m.Initial.Info
+ }
+ case *ChannelCloseLifecycle:
+ pp.sentInitialMsg = true
+
+ if !pp.IsRelevantConnection(pp.pathEnd1.info.ChainID, m.SrcConnID) {
+ return
+ }
+
+ for k, cs := range pp.pathEnd1.channelStateCache {
+ if k.ChannelID == m.SrcChannelID && k.PortID == m.SrcPortID && k.CounterpartyChannelID != "" && k.CounterpartyPortID != "" {
+ if cs.Open {
+ // channel is still open on pathEnd1
+ if _, ok := pp.pathEnd1.messageCache.ChannelHandshake[preCloseKey]; !ok {
+ pp.pathEnd1.messageCache.ChannelHandshake[preCloseKey] = make(ChannelMessageCache)
+ pp.pathEnd1.messageCache.ChannelHandshake[preCloseKey][k] = provider.ChannelInfo{
+ PortID: k.PortID,
+ ChannelID: k.ChannelID,
+ CounterpartyPortID: k.CounterpartyPortID,
+ CounterpartyChannelID: k.CounterpartyChannelID,
+ ConnID: m.SrcConnID,
+ }
+ }
+ return
+ }
+ if counterpartyState, ok := pp.pathEnd2.channelStateCache[k.Counterparty()]; ok && !counterpartyState.Open {
+ pp.log.Info("Channel already closed on both sides")
+ cancel()
+ return
+ }
+ // queue channel close init on pathEnd1
+ if _, ok := pp.pathEnd1.messageCache.ChannelHandshake[chantypes.EventTypeChannelCloseInit]; !ok {
+ pp.pathEnd1.messageCache.ChannelHandshake[chantypes.EventTypeChannelCloseInit] = make(ChannelMessageCache)
+ }
+ pp.pathEnd1.messageCache.ChannelHandshake[chantypes.EventTypeChannelCloseInit][k] = provider.ChannelInfo{
+ PortID: k.PortID,
+ ChannelID: k.ChannelID,
+ CounterpartyPortID: k.CounterpartyPortID,
+ CounterpartyChannelID: k.CounterpartyChannelID,
+ ConnID: m.SrcConnID,
+ }
+ return
+ }
}
+
+ for k, cs := range pp.pathEnd2.channelStateCache {
+ if k.CounterpartyChannelID == m.SrcChannelID && k.CounterpartyPortID == m.SrcPortID && k.ChannelID != "" && k.PortID != "" {
+ if cs.Open {
+ // channel is still open on pathEnd2
+ if _, ok := pp.pathEnd2.messageCache.ChannelHandshake[preCloseKey]; !ok {
+ pp.pathEnd2.messageCache.ChannelHandshake[preCloseKey] = make(ChannelMessageCache)
+ pp.pathEnd2.messageCache.ChannelHandshake[preCloseKey][k] = provider.ChannelInfo{
+ PortID: k.PortID,
+ ChannelID: k.ChannelID,
+ CounterpartyPortID: k.CounterpartyPortID,
+ CounterpartyChannelID: k.CounterpartyChannelID,
+ ConnID: m.SrcConnID,
+ }
+ }
+ return
+ }
+ if counterpartyChanState, ok := pp.pathEnd1.channelStateCache[k.Counterparty()]; ok && !counterpartyChanState.Open {
+ pp.log.Info("Channel already closed on both sides")
+ cancel()
+ return
+ }
+ // queue channel close init on pathEnd2
+ if _, ok := pp.pathEnd2.messageCache.ChannelHandshake[chantypes.EventTypeChannelCloseInit]; !ok {
+ pp.pathEnd2.messageCache.ChannelHandshake[chantypes.EventTypeChannelCloseInit] = make(ChannelMessageCache)
+ }
+ pp.pathEnd2.messageCache.ChannelHandshake[chantypes.EventTypeChannelCloseInit][k] = provider.ChannelInfo{
+ PortID: k.PortID,
+ ChannelID: k.ChannelID,
+ CounterpartyPortID: k.CounterpartyPortID,
+ CounterpartyChannelID: k.CounterpartyChannelID,
+ ConnID: m.DstConnID,
+ }
+ }
+ }
+
+ pp.log.Error("This channel is unable to be closed. Channel must already be closed on one chain.",
+ zap.String("src_channel_id", m.SrcChannelID),
+ zap.String("src_port_id", m.SrcPortID),
+ )
+ cancel()
}
}
// messages from both pathEnds are needed in order to determine what needs to be relayed for a single pathEnd
-func (pp *PathProcessor) processLatestMessages(ctx context.Context) error {
+func (pp *PathProcessor) processLatestMessages(ctx context.Context, cancel func()) error {
// Update trusted client state for both pathends
pp.updateClientTrustedState(pp.pathEnd1, pp.pathEnd2)
pp.updateClientTrustedState(pp.pathEnd2, pp.pathEnd1)
+ //for btp updateClient steps
+ pp.UpdateBTPHeight(ctx, pp.pathEnd1, pp.pathEnd2)
+ pp.UpdateBTPHeight(ctx, pp.pathEnd2, pp.pathEnd1)
+
channelPairs := pp.channelPairs()
+ pp.queuePreInitMessages(cancel)
+
pathEnd1ConnectionHandshakeMessages := pathEndConnectionHandshakeMessages{
Src: pp.pathEnd1,
Dst: pp.pathEnd2,
+ SrcMsgConnectionPreInit: pp.pathEnd1.messageCache.ConnectionHandshake[preInitKey],
SrcMsgConnectionOpenInit: pp.pathEnd1.messageCache.ConnectionHandshake[conntypes.EventTypeConnectionOpenInit],
DstMsgConnectionOpenTry: pp.pathEnd2.messageCache.ConnectionHandshake[conntypes.EventTypeConnectionOpenTry],
SrcMsgConnectionOpenAck: pp.pathEnd1.messageCache.ConnectionHandshake[conntypes.EventTypeConnectionOpenAck],
@@ -525,53 +1038,64 @@ func (pp *PathProcessor) processLatestMessages(ctx context.Context) error {
pathEnd2ConnectionHandshakeMessages := pathEndConnectionHandshakeMessages{
Src: pp.pathEnd2,
Dst: pp.pathEnd1,
+ SrcMsgConnectionPreInit: pp.pathEnd2.messageCache.ConnectionHandshake[preInitKey],
SrcMsgConnectionOpenInit: pp.pathEnd2.messageCache.ConnectionHandshake[conntypes.EventTypeConnectionOpenInit],
DstMsgConnectionOpenTry: pp.pathEnd1.messageCache.ConnectionHandshake[conntypes.EventTypeConnectionOpenTry],
SrcMsgConnectionOpenAck: pp.pathEnd2.messageCache.ConnectionHandshake[conntypes.EventTypeConnectionOpenAck],
DstMsgConnectionOpenConfirm: pp.pathEnd1.messageCache.ConnectionHandshake[conntypes.EventTypeConnectionOpenConfirm],
}
- pathEnd1ConnectionHandshakeRes := pp.getUnrelayedConnectionHandshakeMessagesAndToDelete(pathEnd1ConnectionHandshakeMessages)
- pathEnd2ConnectionHandshakeRes := pp.getUnrelayedConnectionHandshakeMessagesAndToDelete(pathEnd2ConnectionHandshakeMessages)
+ pathEnd1ConnectionHandshakeRes := pp.unrelayedConnectionHandshakeMessages(pathEnd1ConnectionHandshakeMessages)
+ pathEnd2ConnectionHandshakeRes := pp.unrelayedConnectionHandshakeMessages(pathEnd2ConnectionHandshakeMessages)
pathEnd1ChannelHandshakeMessages := pathEndChannelHandshakeMessages{
Src: pp.pathEnd1,
Dst: pp.pathEnd2,
+ SrcMsgChannelPreInit: pp.pathEnd1.messageCache.ChannelHandshake[preInitKey],
SrcMsgChannelOpenInit: pp.pathEnd1.messageCache.ChannelHandshake[chantypes.EventTypeChannelOpenInit],
DstMsgChannelOpenTry: pp.pathEnd2.messageCache.ChannelHandshake[chantypes.EventTypeChannelOpenTry],
SrcMsgChannelOpenAck: pp.pathEnd1.messageCache.ChannelHandshake[chantypes.EventTypeChannelOpenAck],
DstMsgChannelOpenConfirm: pp.pathEnd2.messageCache.ChannelHandshake[chantypes.EventTypeChannelOpenConfirm],
}
+
pathEnd2ChannelHandshakeMessages := pathEndChannelHandshakeMessages{
Src: pp.pathEnd2,
Dst: pp.pathEnd1,
+ SrcMsgChannelPreInit: pp.pathEnd2.messageCache.ChannelHandshake[preInitKey],
SrcMsgChannelOpenInit: pp.pathEnd2.messageCache.ChannelHandshake[chantypes.EventTypeChannelOpenInit],
DstMsgChannelOpenTry: pp.pathEnd1.messageCache.ChannelHandshake[chantypes.EventTypeChannelOpenTry],
SrcMsgChannelOpenAck: pp.pathEnd2.messageCache.ChannelHandshake[chantypes.EventTypeChannelOpenAck],
DstMsgChannelOpenConfirm: pp.pathEnd1.messageCache.ChannelHandshake[chantypes.EventTypeChannelOpenConfirm],
}
- pathEnd1ChannelHandshakeRes := pp.getUnrelayedChannelHandshakeMessagesAndToDelete(pathEnd1ChannelHandshakeMessages)
- pathEnd2ChannelHandshakeRes := pp.getUnrelayedChannelHandshakeMessagesAndToDelete(pathEnd2ChannelHandshakeMessages)
+ pathEnd1ChannelHandshakeRes := pp.unrelayedChannelHandshakeMessages(pathEnd1ChannelHandshakeMessages)
+ pathEnd2ChannelHandshakeRes := pp.unrelayedChannelHandshakeMessages(pathEnd2ChannelHandshakeMessages)
// process the packet flows for both path ends to determine what needs to be relayed
pathEnd1ProcessRes := make([]pathEndPacketFlowResponse, len(channelPairs))
pathEnd2ProcessRes := make([]pathEndPacketFlowResponse, len(channelPairs))
for i, pair := range channelPairs {
- var pathEnd1ChannelCloseConfirm, pathEnd2ChannelCloseConfirm *provider.ChannelInfo
-
- if pathEnd1ChanCloseConfirmMsgs, ok := pp.pathEnd1.messageCache.ChannelHandshake[chantypes.EventTypeChannelCloseConfirm]; ok {
- if pathEnd1ChannelCloseConfirmMsg, ok := pathEnd1ChanCloseConfirmMsgs[pair.pathEnd1ChannelKey]; ok {
- pathEnd1ChannelCloseConfirm = &pathEnd1ChannelCloseConfirmMsg
- }
- }
-
- if pathEnd2ChanCloseConfirmMsgs, ok := pp.pathEnd2.messageCache.ChannelHandshake[chantypes.EventTypeChannelCloseConfirm]; ok {
- if pathEnd2ChannelCloseConfirmMsg, ok := pathEnd2ChanCloseConfirmMsgs[pair.pathEnd2ChannelKey]; ok {
- pathEnd2ChannelCloseConfirm = &pathEnd2ChannelCloseConfirmMsg
- }
- }
-
// Append acks into recv packet info if present
+ // pathEnd1DstMsgRecvPacket :=
+ // for seq, ackInfo := range pp.pathEnd2.messageCache.PacketFlow[pair.pathEnd2ChannelKey][chantypes.EventTypeWriteAck] {
+ // if recvPacketInfo, ok := pathEnd1DstMsgRecvPacket[seq]; ok {
+ // recvPacketInfo.Ack = ackInfo.Ack
+ // pathEnd1DstMsgRecvPacket[seq] = recvPacketInfo
+ // continue
+ // }
+ // pathEnd1DstMsgRecvPacket[seq] = ackInfo
+
+ // }
+
+ // pathEnd2DstMsgRecvPacket := pp.pathEnd1.messageCache.PacketFlow[pair.pathEnd1ChannelKey][chantypes.EventTypeRecvPacket]
+ // for seq, ackInfo := range pp.pathEnd1.messageCache.PacketFlow[pair.pathEnd1ChannelKey][chantypes.EventTypeWriteAck] {
+ // if recvPacketInfo, ok := pathEnd2DstMsgRecvPacket[seq]; ok {
+ // recvPacketInfo.Ack = ackInfo.Ack
+ // pathEnd2DstMsgRecvPacket[seq] = recvPacketInfo
+ // continue
+ // }
+
+ // pathEnd2DstMsgRecvPacket[seq] = ackInfo
+ // }
pathEnd1DstMsgRecvPacket := pp.pathEnd2.messageCache.PacketFlow[pair.pathEnd2ChannelKey][chantypes.EventTypeRecvPacket]
for seq, ackInfo := range pp.pathEnd2.messageCache.PacketFlow[pair.pathEnd2ChannelKey][chantypes.EventTypeWriteAck] {
if recvPacketInfo, ok := pathEnd1DstMsgRecvPacket[seq]; ok {
@@ -589,35 +1113,60 @@ func (pp *PathProcessor) processLatestMessages(ctx context.Context) error {
}
pathEnd1PacketFlowMessages := pathEndPacketFlowMessages{
- Src: pp.pathEnd1,
- Dst: pp.pathEnd2,
- ChannelKey: pair.pathEnd1ChannelKey,
- SrcMsgTransfer: pp.pathEnd1.messageCache.PacketFlow[pair.pathEnd1ChannelKey][chantypes.EventTypeSendPacket],
- DstMsgRecvPacket: pathEnd1DstMsgRecvPacket,
- SrcMsgAcknowledgement: pp.pathEnd1.messageCache.PacketFlow[pair.pathEnd1ChannelKey][chantypes.EventTypeAcknowledgePacket],
- SrcMsgTimeout: pp.pathEnd1.messageCache.PacketFlow[pair.pathEnd1ChannelKey][chantypes.EventTypeTimeoutPacket],
- SrcMsgTimeoutOnClose: pp.pathEnd1.messageCache.PacketFlow[pair.pathEnd1ChannelKey][chantypes.EventTypeTimeoutPacketOnClose],
- DstMsgChannelCloseConfirm: pathEnd2ChannelCloseConfirm,
+ Src: pp.pathEnd1,
+ Dst: pp.pathEnd2,
+ ChannelKey: pair.pathEnd1ChannelKey,
+ SrcPreTransfer: pp.pathEnd1.messageCache.PacketFlow[pair.pathEnd1ChannelKey][preInitKey],
+ SrcMsgTransfer: pp.pathEnd1.messageCache.PacketFlow[pair.pathEnd1ChannelKey][chantypes.EventTypeSendPacket],
+ DstMsgRecvPacket: pathEnd1DstMsgRecvPacket,
+ DstMsgWriteAcknowledgementPacket: pp.pathEnd2.messageCache.PacketFlow[pair.pathEnd2ChannelKey][chantypes.EventTypeWriteAck],
+ SrcMsgAcknowledgement: pp.pathEnd1.messageCache.PacketFlow[pair.pathEnd1ChannelKey][chantypes.EventTypeAcknowledgePacket],
+ SrcMsgTimeout: pp.pathEnd1.messageCache.PacketFlow[pair.pathEnd1ChannelKey][chantypes.EventTypeTimeoutPacket],
+ SrcMsgTimeoutOnClose: pp.pathEnd1.messageCache.PacketFlow[pair.pathEnd1ChannelKey][chantypes.EventTypeTimeoutPacketOnClose],
+ DstMsgRequestTimeout: pp.pathEnd2.messageCache.PacketFlow[pair.pathEnd2ChannelKey][common.EventTimeoutRequest],
}
+
pathEnd2PacketFlowMessages := pathEndPacketFlowMessages{
- Src: pp.pathEnd2,
- Dst: pp.pathEnd1,
- ChannelKey: pair.pathEnd2ChannelKey,
- SrcMsgTransfer: pp.pathEnd2.messageCache.PacketFlow[pair.pathEnd2ChannelKey][chantypes.EventTypeSendPacket],
- DstMsgRecvPacket: pathEnd2DstMsgRecvPacket,
- SrcMsgAcknowledgement: pp.pathEnd2.messageCache.PacketFlow[pair.pathEnd2ChannelKey][chantypes.EventTypeAcknowledgePacket],
- SrcMsgTimeout: pp.pathEnd2.messageCache.PacketFlow[pair.pathEnd2ChannelKey][chantypes.EventTypeTimeoutPacket],
- SrcMsgTimeoutOnClose: pp.pathEnd2.messageCache.PacketFlow[pair.pathEnd2ChannelKey][chantypes.EventTypeTimeoutPacketOnClose],
- DstMsgChannelCloseConfirm: pathEnd1ChannelCloseConfirm,
+ Src: pp.pathEnd2,
+ Dst: pp.pathEnd1,
+ ChannelKey: pair.pathEnd2ChannelKey,
+ SrcPreTransfer: pp.pathEnd2.messageCache.PacketFlow[pair.pathEnd1ChannelKey][preInitKey],
+ SrcMsgTransfer: pp.pathEnd2.messageCache.PacketFlow[pair.pathEnd2ChannelKey][chantypes.EventTypeSendPacket],
+ DstMsgRecvPacket: pathEnd2DstMsgRecvPacket,
+ DstMsgWriteAcknowledgementPacket: pp.pathEnd1.messageCache.PacketFlow[pair.pathEnd1ChannelKey][chantypes.EventTypeWriteAck],
+ SrcMsgAcknowledgement: pp.pathEnd2.messageCache.PacketFlow[pair.pathEnd2ChannelKey][chantypes.EventTypeAcknowledgePacket],
+ SrcMsgTimeout: pp.pathEnd2.messageCache.PacketFlow[pair.pathEnd2ChannelKey][chantypes.EventTypeTimeoutPacket],
+ SrcMsgTimeoutOnClose: pp.pathEnd2.messageCache.PacketFlow[pair.pathEnd2ChannelKey][chantypes.EventTypeTimeoutPacketOnClose],
+ DstMsgRequestTimeout: pp.pathEnd1.messageCache.PacketFlow[pair.pathEnd1ChannelKey][common.EventTimeoutRequest],
}
- pathEnd1ProcessRes[i] = pp.getUnrelayedPacketsAndAcksAndToDelete(ctx, pathEnd1PacketFlowMessages)
- pathEnd2ProcessRes[i] = pp.getUnrelayedPacketsAndAcksAndToDelete(ctx, pathEnd2PacketFlowMessages)
+ pathEnd1ProcessRes[i] = pp.unrelayedPacketFlowMessages(ctx, pathEnd1PacketFlowMessages)
+ pathEnd2ProcessRes[i] = pp.unrelayedPacketFlowMessages(ctx, pathEnd2PacketFlowMessages)
+ }
+
+ pathEnd1ChannelCloseMessages := pathEndChannelCloseMessages{
+ Src: pp.pathEnd1,
+ Dst: pp.pathEnd2,
+ SrcMsgChannelPreInit: pp.pathEnd1.messageCache.ChannelHandshake[preCloseKey],
+ SrcMsgChannelCloseInit: pp.pathEnd1.messageCache.ChannelHandshake[chantypes.EventTypeChannelCloseInit],
+ DstMsgChannelCloseConfirm: pp.pathEnd2.messageCache.ChannelHandshake[chantypes.EventTypeChannelCloseConfirm],
+ }
+ pathEnd2ChannelCloseMessages := pathEndChannelCloseMessages{
+ Src: pp.pathEnd2,
+ Dst: pp.pathEnd1,
+ SrcMsgChannelPreInit: pp.pathEnd2.messageCache.ChannelHandshake[preCloseKey],
+ SrcMsgChannelCloseInit: pp.pathEnd2.messageCache.ChannelHandshake[chantypes.EventTypeChannelCloseInit],
+ DstMsgChannelCloseConfirm: pp.pathEnd1.messageCache.ChannelHandshake[chantypes.EventTypeChannelCloseConfirm],
}
+ pathEnd1ChannelCloseRes := pp.unrelayedChannelCloseMessages(pathEnd1ChannelCloseMessages)
+ pathEnd2ChannelCloseRes := pp.unrelayedChannelCloseMessages(pathEnd2ChannelCloseMessages)
// concatenate applicable messages for pathend
pathEnd1ConnectionMessages, pathEnd2ConnectionMessages := pp.connectionMessagesToSend(pathEnd1ConnectionHandshakeRes, pathEnd2ConnectionHandshakeRes)
- pathEnd1ChannelMessages, pathEnd2ChannelMessages := pp.channelMessagesToSend(pathEnd1ChannelHandshakeRes, pathEnd2ChannelHandshakeRes)
+ pathEnd1ChannelMessages, pathEnd2ChannelMessages := pp.channelMessagesToSend(
+ pathEnd1ChannelHandshakeRes, pathEnd2ChannelHandshakeRes,
+ pathEnd1ChannelCloseRes, pathEnd2ChannelCloseRes,
+ )
pathEnd1PacketMessages, pathEnd2PacketMessages, pathEnd1ChanCloseMessages, pathEnd2ChanCloseMessages := pp.packetMessagesToSend(channelPairs, pathEnd1ProcessRes, pathEnd2ProcessRes)
pathEnd1ChannelMessages = append(pathEnd1ChannelMessages, pathEnd1ChanCloseMessages...)
@@ -648,42 +1197,45 @@ func (pp *PathProcessor) processLatestMessages(ctx context.Context) error {
clientICQMessages: pathEnd2ClientICQMessages,
}
- pp.appendInitialMessageIfNecessary(&pathEnd1Messages, &pathEnd2Messages)
-
// now assemble and send messages in parallel
// if sending messages fails to one pathEnd, we don't need to halt sending to the other pathEnd.
var eg errgroup.Group
eg.Go(func() error {
- mp := newMessageProcessor(pp.log, pp.metrics, pp.memo, pp.clientUpdateThresholdTime)
+ mp := newMessageProcessor(pp.log, pp.metrics, pp.memo, pp.clientUpdateThresholdTime, pp.isLocalhost)
return mp.processMessages(ctx, pathEnd1Messages, pp.pathEnd2, pp.pathEnd1)
})
eg.Go(func() error {
- mp := newMessageProcessor(pp.log, pp.metrics, pp.memo, pp.clientUpdateThresholdTime)
+ mp := newMessageProcessor(pp.log, pp.metrics, pp.memo, pp.clientUpdateThresholdTime, pp.isLocalhost)
return mp.processMessages(ctx, pathEnd2Messages, pp.pathEnd1, pp.pathEnd2)
})
return eg.Wait()
}
-func (pp *PathProcessor) channelMessagesToSend(pathEnd1ChannelHandshakeRes, pathEnd2ChannelHandshakeRes pathEndChannelHandshakeResponse) ([]channelIBCMessage, []channelIBCMessage) {
- pathEnd1ChannelSrcLen := len(pathEnd1ChannelHandshakeRes.SrcMessages)
- pathEnd1ChannelDstLen := len(pathEnd1ChannelHandshakeRes.DstMessages)
- pathEnd2ChannelDstLen := len(pathEnd2ChannelHandshakeRes.DstMessages)
- pathEnd2ChannelSrcLen := len(pathEnd2ChannelHandshakeRes.SrcMessages)
- pathEnd1ChannelMessages := make([]channelIBCMessage, 0, pathEnd1ChannelSrcLen+pathEnd2ChannelDstLen)
- pathEnd2ChannelMessages := make([]channelIBCMessage, 0, pathEnd2ChannelSrcLen+pathEnd1ChannelDstLen)
+func (pp *PathProcessor) channelMessagesToSend(pathEnd1ChannelHandshakeRes, pathEnd2ChannelHandshakeRes, pathEnd1ChannelCloseRes, pathEnd2ChannelCloseRes pathEndChannelHandshakeResponse) ([]channelIBCMessage, []channelIBCMessage) {
+ pathEnd1ChannelOpenSrcLen := len(pathEnd1ChannelHandshakeRes.SrcMessages)
+ pathEnd1ChannelOpenDstLen := len(pathEnd1ChannelHandshakeRes.DstMessages)
+ pathEnd2ChannelOpenDstLen := len(pathEnd2ChannelHandshakeRes.DstMessages)
+ pathEnd2ChannelOpenSrcLen := len(pathEnd2ChannelHandshakeRes.SrcMessages)
+
+ pathEnd1ChannelCloseSrcLen := len(pathEnd1ChannelHandshakeRes.SrcMessages)
+ pathEnd1ChannelCloseDstLen := len(pathEnd1ChannelHandshakeRes.DstMessages)
+ pathEnd2ChannelCloseDstLen := len(pathEnd2ChannelHandshakeRes.DstMessages)
+ pathEnd2ChannelCloseSrcLen := len(pathEnd2ChannelHandshakeRes.SrcMessages)
+
+ pathEnd1ChannelMessages := make([]channelIBCMessage, 0, pathEnd1ChannelOpenSrcLen+pathEnd2ChannelOpenDstLen+pathEnd1ChannelCloseSrcLen+pathEnd2ChannelCloseDstLen)
+ pathEnd2ChannelMessages := make([]channelIBCMessage, 0, pathEnd2ChannelOpenSrcLen+pathEnd1ChannelOpenDstLen+pathEnd2ChannelCloseSrcLen+pathEnd1ChannelCloseDstLen)
// pathEnd1 channel messages come from pathEnd1 src and pathEnd2 dst
pathEnd1ChannelMessages = append(pathEnd1ChannelMessages, pathEnd2ChannelHandshakeRes.DstMessages...)
+ pathEnd1ChannelMessages = append(pathEnd1ChannelMessages, pathEnd2ChannelCloseRes.DstMessages...)
pathEnd1ChannelMessages = append(pathEnd1ChannelMessages, pathEnd1ChannelHandshakeRes.SrcMessages...)
+ pathEnd1ChannelMessages = append(pathEnd1ChannelMessages, pathEnd1ChannelCloseRes.SrcMessages...)
// pathEnd2 channel messages come from pathEnd2 src and pathEnd1 dst
pathEnd2ChannelMessages = append(pathEnd2ChannelMessages, pathEnd1ChannelHandshakeRes.DstMessages...)
+ pathEnd2ChannelMessages = append(pathEnd2ChannelMessages, pathEnd1ChannelCloseRes.DstMessages...)
pathEnd2ChannelMessages = append(pathEnd2ChannelMessages, pathEnd2ChannelHandshakeRes.SrcMessages...)
-
- pp.pathEnd1.messageCache.ChannelHandshake.DeleteMessages(pathEnd1ChannelHandshakeRes.ToDeleteSrc, pathEnd2ChannelHandshakeRes.ToDeleteDst)
- pp.pathEnd2.messageCache.ChannelHandshake.DeleteMessages(pathEnd2ChannelHandshakeRes.ToDeleteSrc, pathEnd1ChannelHandshakeRes.ToDeleteDst)
- pp.pathEnd1.channelProcessing.deleteMessages(pathEnd1ChannelHandshakeRes.ToDeleteSrc, pathEnd2ChannelHandshakeRes.ToDeleteDst)
- pp.pathEnd2.channelProcessing.deleteMessages(pathEnd2ChannelHandshakeRes.ToDeleteSrc, pathEnd1ChannelHandshakeRes.ToDeleteDst)
+ pathEnd2ChannelMessages = append(pathEnd2ChannelMessages, pathEnd2ChannelCloseRes.SrcMessages...)
return pathEnd1ChannelMessages, pathEnd2ChannelMessages
}
@@ -704,11 +1256,6 @@ func (pp *PathProcessor) connectionMessagesToSend(pathEnd1ConnectionHandshakeRes
pathEnd2ConnectionMessages = append(pathEnd2ConnectionMessages, pathEnd1ConnectionHandshakeRes.DstMessages...)
pathEnd2ConnectionMessages = append(pathEnd2ConnectionMessages, pathEnd2ConnectionHandshakeRes.SrcMessages...)
- pp.pathEnd1.messageCache.ConnectionHandshake.DeleteMessages(pathEnd1ConnectionHandshakeRes.ToDeleteSrc, pathEnd2ConnectionHandshakeRes.ToDeleteDst)
- pp.pathEnd2.messageCache.ConnectionHandshake.DeleteMessages(pathEnd2ConnectionHandshakeRes.ToDeleteSrc, pathEnd1ConnectionHandshakeRes.ToDeleteDst)
- pp.pathEnd1.connProcessing.deleteMessages(pathEnd1ConnectionHandshakeRes.ToDeleteSrc, pathEnd2ConnectionHandshakeRes.ToDeleteDst)
- pp.pathEnd2.connProcessing.deleteMessages(pathEnd2ConnectionHandshakeRes.ToDeleteSrc, pathEnd1ConnectionHandshakeRes.ToDeleteDst)
-
return pathEnd1ConnectionMessages, pathEnd2ConnectionMessages
}
@@ -735,7 +1282,7 @@ func (pp *PathProcessor) packetMessagesToSend(
pathEnd1ChannelMessage := make([]channelIBCMessage, 0, pathEnd1ChannelLen)
pathEnd2ChannelMessage := make([]channelIBCMessage, 0, pathEnd2ChannelLen)
- for i, channelPair := range channelPairs {
+ for i := range channelPairs {
pathEnd1PacketMessages = append(pathEnd1PacketMessages, pathEnd2ProcessRes[i].DstMessages...)
pathEnd1PacketMessages = append(pathEnd1PacketMessages, pathEnd1ProcessRes[i].SrcMessages...)
@@ -744,18 +1291,6 @@ func (pp *PathProcessor) packetMessagesToSend(
pathEnd1ChannelMessage = append(pathEnd1ChannelMessage, pathEnd2ProcessRes[i].DstChannelMessage...)
pathEnd2ChannelMessage = append(pathEnd2ChannelMessage, pathEnd1ProcessRes[i].DstChannelMessage...)
-
- pp.pathEnd1.messageCache.ChannelHandshake.DeleteMessages(pathEnd2ProcessRes[i].ToDeleteDstChannel)
- pp.pathEnd1.channelProcessing.deleteMessages(pathEnd2ProcessRes[i].ToDeleteDstChannel)
-
- pp.pathEnd2.messageCache.ChannelHandshake.DeleteMessages(pathEnd1ProcessRes[i].ToDeleteDstChannel)
- pp.pathEnd2.channelProcessing.deleteMessages(pathEnd1ProcessRes[i].ToDeleteDstChannel)
-
- pp.pathEnd1.messageCache.PacketFlow[channelPair.pathEnd1ChannelKey].DeleteMessages(pathEnd1ProcessRes[i].ToDeleteSrc, pathEnd2ProcessRes[i].ToDeleteDst)
- pp.pathEnd2.messageCache.PacketFlow[channelPair.pathEnd2ChannelKey].DeleteMessages(pathEnd2ProcessRes[i].ToDeleteSrc, pathEnd1ProcessRes[i].ToDeleteDst)
-
- pp.pathEnd1.packetProcessing[channelPair.pathEnd1ChannelKey].deleteMessages(pathEnd1ProcessRes[i].ToDeleteSrc, pathEnd2ProcessRes[i].ToDeleteDst)
- pp.pathEnd2.packetProcessing[channelPair.pathEnd2ChannelKey].deleteMessages(pathEnd2ProcessRes[i].ToDeleteSrc, pathEnd1ProcessRes[i].ToDeleteDst)
}
return pathEnd1PacketMessages, pathEnd2PacketMessages, pathEnd1ChannelMessage, pathEnd2ChannelMessage
@@ -766,7 +1301,7 @@ func queryPacketCommitments(
pathEnd *pathEndRuntime,
k ChannelKey,
commitments map[ChannelKey][]uint64,
- mu *sync.Mutex,
+ mu sync.Locker,
) func() error {
return func() error {
pathEnd.log.Debug("Flushing", zap.String("channel", k.ChannelID), zap.String("port", k.PortID))
@@ -781,108 +1316,222 @@ func queryPacketCommitments(
for i, p := range c.Commitments {
commitments[k][i] = p.Sequence
}
+ sort.SliceStable(commitments[k], func(i, j int) bool {
+ return commitments[k][i] < commitments[k][j]
+ })
return nil
}
}
-func queuePendingRecvAndAcks(
+// skippedPackets is used to track the number of packets skipped during a flush.
+type skippedPackets struct {
+ Recv uint64
+ Ack uint64
+}
+
+// queuePendingRecvAndAcks returns the number of packets skipped during a flush (nil if none).
+func (pp *PathProcessor) queuePendingRecvAndAcks(
ctx context.Context,
src, dst *pathEndRuntime,
k ChannelKey,
seqs []uint64,
srcCache ChannelPacketMessagesCache,
dstCache ChannelPacketMessagesCache,
- srcMu *sync.Mutex,
- dstMu *sync.Mutex,
-) func() error {
- return func() error {
- if len(seqs) == 0 {
- src.log.Debug("Nothing to flush", zap.String("channel", k.ChannelID), zap.String("port", k.PortID))
- return nil
- }
+ srcMu sync.Locker,
+ dstMu sync.Locker,
+) (*skippedPackets, error) {
- unrecv, err := dst.chainProvider.QueryUnreceivedPackets(ctx, dst.latestBlock.Height, k.CounterpartyChannelID, k.CounterpartyPortID, seqs)
+ if len(seqs) == 0 {
+ src.log.Debug("Nothing to flush", zap.String("channel", k.ChannelID), zap.String("port", k.PortID))
+ return nil, nil
+ }
+
+ dstChan, dstPort := k.CounterpartyChannelID, k.CounterpartyPortID
+
+ unrecv, err := dst.chainProvider.QueryUnreceivedPackets(ctx, dst.latestBlock.Height, dstChan, dstPort, seqs)
+ if err != nil {
+ return nil, err
+ }
+
+ dstHeight := int64(dst.latestBlock.Height)
+
+ var order chantypes.Order
+
+ if len(unrecv) > 0 {
+ channel, err := dst.chainProvider.QueryChannel(ctx, dstHeight, dstChan, dstPort)
if err != nil {
- return err
+ return nil, err
+ }
+
+ order = channel.Channel.Ordering
+
+ if channel.Channel.Ordering == chantypes.ORDERED {
+ nextSeqRecv, err := dst.chainProvider.QueryNextSeqRecv(ctx, dstHeight, dstChan, dstPort)
+ if err != nil {
+ return nil, err
+ }
+
+ var newUnrecv []uint64
+
+ for _, seq := range unrecv {
+ if seq >= nextSeqRecv.NextSequenceReceive {
+ newUnrecv = append(newUnrecv, seq)
+ }
+ }
+
+ unrecv = newUnrecv
+
+ sort.SliceStable(unrecv, func(i, j int) bool {
+ return unrecv[i] < unrecv[j]
+ })
+ }
+ }
+
+ var eg errgroup.Group
+
+ var skipped *skippedPackets
+
+ for i, seq := range unrecv {
+ srcMu.Lock()
+ if srcCache.IsCached(chantypes.EventTypeSendPacket, k, seq) {
+ continue // already cached
}
+ srcMu.Unlock()
- if len(unrecv) > 0 {
- src.log.Debug("Will flush MsgRecvPacket", zap.String("channel", k.ChannelID), zap.String("port", k.PortID), zap.Uint64s("sequences", unrecv))
- } else {
- src.log.Debug("No MsgRecvPacket to flush", zap.String("channel", k.ChannelID), zap.String("port", k.PortID))
+ if i >= int(pp.maxMsgs) {
+ if skipped == nil {
+ skipped = new(skippedPackets)
+ }
+ skipped.Recv = uint64(len(unrecv) - i)
+ break
}
- for _, seq := range unrecv {
+ src.log.Debug("Querying send packet",
+ zap.String("channel", k.ChannelID),
+ zap.String("port", k.PortID),
+ zap.Uint64("sequence", seq),
+ )
+
+ seq := seq
+
+ eg.Go(func() error {
sendPacket, err := src.chainProvider.QuerySendPacket(ctx, k.ChannelID, k.PortID, seq)
if err != nil {
return err
}
+ sendPacket.ChannelOrder = order.String()
srcMu.Lock()
- if _, ok := srcCache[k]; !ok {
- srcCache[k] = make(PacketMessagesCache)
- }
- if _, ok := srcCache[k][chantypes.EventTypeSendPacket]; !ok {
- srcCache[k][chantypes.EventTypeSendPacket] = make(PacketSequenceCache)
- }
- srcCache[k][chantypes.EventTypeSendPacket][seq] = sendPacket
+ srcCache.Cache(chantypes.EventTypeSendPacket, k, seq, sendPacket)
srcMu.Unlock()
- }
- var unacked []uint64
+ src.log.Debug("Cached send packet",
+ zap.String("channel", k.ChannelID),
+ zap.String("port", k.PortID),
+ zap.String("ctrpty_channel", k.CounterpartyChannelID),
+ zap.String("ctrpty_port", k.CounterpartyPortID),
+ zap.Uint64("sequence", seq),
+ )
- SeqLoop:
- for _, seq := range seqs {
- for _, unrecvSeq := range unrecv {
- if seq == unrecvSeq {
- continue SeqLoop
- }
+ return nil
+ })
+ }
+
+ if err := eg.Wait(); err != nil {
+ return skipped, err
+ }
+
+ if len(unrecv) > 0 {
+ src.log.Debug("Will flush MsgRecvPacket",
+ zap.String("channel", k.ChannelID),
+ zap.String("port", k.PortID),
+ zap.Uint64s("sequences", unrecv),
+ )
+ } else {
+ src.log.Debug("No MsgRecvPacket to flush",
+ zap.String("channel", k.ChannelID),
+ zap.String("port", k.PortID),
+ )
+ }
+
+ var unacked []uint64
+
+SeqLoop:
+ for _, seq := range seqs {
+ for _, unrecvSeq := range unrecv {
+ if seq == unrecvSeq {
+ continue SeqLoop
}
- // does not exist in unrecv, so this is an ack that must be written
- unacked = append(unacked, seq)
}
+ // does not exist in unrecv, so this is an ack that must be written
+ unacked = append(unacked, seq)
+ }
- if len(unacked) > 0 {
- src.log.Debug("Will flush MsgAcknowledgement", zap.String("channel", k.ChannelID), zap.String("port", k.PortID), zap.Uint64s("sequences", unrecv))
- } else {
- src.log.Debug("No MsgAcknowledgement to flush", zap.String("channel", k.ChannelID), zap.String("port", k.PortID))
+ for i, seq := range unacked {
+ dstMu.Lock()
+ ck := k.Counterparty()
+ if dstCache.IsCached(chantypes.EventTypeRecvPacket, ck, seq) &&
+ dstCache.IsCached(chantypes.EventTypeWriteAck, ck, seq) {
+ continue // already cached
}
+ dstMu.Unlock()
- for _, seq := range unacked {
+ if i >= int(pp.maxMsgs) {
+ if skipped == nil {
+ skipped = new(skippedPackets)
+ }
+ skipped.Ack = uint64(len(unacked) - i)
+ break
+ }
+
+ seq := seq
+
+ dst.log.Debug("Querying recv packet",
+ zap.String("channel", k.CounterpartyChannelID),
+ zap.String("port", k.CounterpartyPortID),
+ zap.Uint64("sequence", seq),
+ )
+
+ eg.Go(func() error {
recvPacket, err := dst.chainProvider.QueryRecvPacket(ctx, k.CounterpartyChannelID, k.CounterpartyPortID, seq)
if err != nil {
return err
}
- srcMu.Lock()
- if _, ok := srcCache[k]; !ok {
- srcCache[k] = make(PacketMessagesCache)
- }
- if _, ok := srcCache[k][chantypes.EventTypeSendPacket]; !ok {
- srcCache[k][chantypes.EventTypeSendPacket] = make(PacketSequenceCache)
- }
- srcCache[k][chantypes.EventTypeSendPacket][seq] = recvPacket
- srcMu.Unlock()
+ ck := k.Counterparty()
+ recvPacket.ChannelOrder = order.String()
dstMu.Lock()
- if _, ok := dstCache[k]; !ok {
- dstCache[k] = make(PacketMessagesCache)
- }
- if _, ok := dstCache[k][chantypes.EventTypeRecvPacket]; !ok {
- dstCache[k][chantypes.EventTypeRecvPacket] = make(PacketSequenceCache)
- }
- if _, ok := dstCache[k][chantypes.EventTypeWriteAck]; !ok {
- dstCache[k][chantypes.EventTypeWriteAck] = make(PacketSequenceCache)
- }
- dstCache[k][chantypes.EventTypeRecvPacket][seq] = recvPacket
- dstCache[k][chantypes.EventTypeWriteAck][seq] = recvPacket
+ dstCache.Cache(chantypes.EventTypeRecvPacket, ck, seq, recvPacket)
+ dstCache.Cache(chantypes.EventTypeWriteAck, ck, seq, recvPacket)
dstMu.Unlock()
- }
- return nil
+
+ return nil
+ })
}
+
+ if err := eg.Wait(); err != nil {
+ return skipped, err
+ }
+
+ if len(unacked) > 0 {
+ dst.log.Debug(
+ "Will flush MsgAcknowledgement",
+ zap.Object("channel", k),
+ zap.Uint64s("sequences", unacked),
+ )
+ } else {
+ dst.log.Debug(
+ "No MsgAcknowledgement to flush",
+ zap.String("channel", k.CounterpartyChannelID),
+ zap.String("port", k.CounterpartyPortID),
+ )
+ }
+
+ return skipped, nil
}
// flush runs queries to relay any pending messages which may have been
// in blocks before the height that the chain processors started querying.
-func (pp *PathProcessor) flush(ctx context.Context) {
+func (pp *PathProcessor) flush(ctx context.Context) error {
var (
commitments1 = make(map[ChannelKey][]uint64)
commitments2 = make(map[ChannelKey][]uint64)
@@ -895,46 +1544,114 @@ func (pp *PathProcessor) flush(ctx context.Context) {
// Query remaining packet commitments on both chains
var eg errgroup.Group
- for k := range pp.pathEnd1.channelStateCache {
+ for k, cs := range pp.pathEnd1.channelStateCache {
+ if !cs.Open {
+ continue
+ }
+ if !pp.pathEnd1.info.ShouldRelayChannel(ChainChannelKey{
+ ChainID: pp.pathEnd1.info.ChainID,
+ CounterpartyChainID: pp.pathEnd2.info.ChainID,
+ ChannelKey: k,
+ }) {
+ continue
+ }
eg.Go(queryPacketCommitments(ctx, pp.pathEnd1, k, commitments1, &commitments1Mu))
}
- for k := range pp.pathEnd2.channelStateCache {
+ for k, cs := range pp.pathEnd2.channelStateCache {
+ if !cs.Open {
+ continue
+ }
+ if !pp.pathEnd2.info.ShouldRelayChannel(ChainChannelKey{
+ ChainID: pp.pathEnd2.info.ChainID,
+ CounterpartyChainID: pp.pathEnd1.info.ChainID,
+ ChannelKey: k,
+ }) {
+ continue
+ }
eg.Go(queryPacketCommitments(ctx, pp.pathEnd2, k, commitments2, &commitments2Mu))
}
if err := eg.Wait(); err != nil {
- pp.log.Error("Failed to query packet commitments", zap.Error(err))
+ return fmt.Errorf("failed to query packet commitments: %w", err)
}
// From remaining packet commitments, determine if:
// 1. Packet commitment is on source, but MsgRecvPacket has not yet been relayed to destination
// 2. Packet commitment is on source, and MsgRecvPacket has been relayed to destination, but MsgAcknowledgement has not been written to source to clear the packet commitment.
// Based on above conditions, enqueue MsgRecvPacket and MsgAcknowledgement messages
+ skipped := make(map[string]map[ChannelKey]skippedPackets)
for k, seqs := range commitments1 {
- eg.Go(queuePendingRecvAndAcks(ctx, pp.pathEnd1, pp.pathEnd2, k, seqs, pathEnd1Cache.PacketFlow, pathEnd2Cache.PacketFlow, &pathEnd1CacheMu, &pathEnd2CacheMu))
+ k := k
+ seqs := seqs
+ eg.Go(func() error {
+ s, err := pp.queuePendingRecvAndAcks(ctx, pp.pathEnd1, pp.pathEnd2, k, seqs, pathEnd1Cache.PacketFlow, pathEnd2Cache.PacketFlow, &pathEnd1CacheMu, &pathEnd2CacheMu)
+ if err != nil {
+ return err
+ }
+ if s != nil {
+ if _, ok := skipped[pp.pathEnd1.info.ChainID]; !ok {
+ skipped[pp.pathEnd1.info.ChainID] = make(map[ChannelKey]skippedPackets)
+ }
+ skipped[pp.pathEnd1.info.ChainID][k] = *s
+ }
+ return nil
+ })
}
for k, seqs := range commitments2 {
- eg.Go(queuePendingRecvAndAcks(ctx, pp.pathEnd2, pp.pathEnd1, k, seqs, pathEnd2Cache.PacketFlow, pathEnd1Cache.PacketFlow, &pathEnd2CacheMu, &pathEnd1CacheMu))
+ k := k
+ seqs := seqs
+ eg.Go(func() error {
+ s, err := pp.queuePendingRecvAndAcks(ctx, pp.pathEnd2, pp.pathEnd1, k, seqs, pathEnd2Cache.PacketFlow, pathEnd1Cache.PacketFlow, &pathEnd2CacheMu, &pathEnd1CacheMu)
+ if err != nil {
+ return err
+ }
+ if s != nil {
+ if _, ok := skipped[pp.pathEnd2.info.ChainID]; !ok {
+ skipped[pp.pathEnd2.info.ChainID] = make(map[ChannelKey]skippedPackets)
+ }
+ skipped[pp.pathEnd2.info.ChainID][k] = *s
+ }
+ return nil
+ })
}
if err := eg.Wait(); err != nil {
- pp.log.Error("Failed to enqueue pending messages for flush", zap.Error(err))
+ return fmt.Errorf("failed to enqueue pending messages for flush: %w", err)
}
pp.pathEnd1.mergeMessageCache(pathEnd1Cache, pp.pathEnd2.info.ChainID, pp.pathEnd2.inSync)
pp.pathEnd2.mergeMessageCache(pathEnd2Cache, pp.pathEnd1.info.ChainID, pp.pathEnd1.inSync)
+
+ if len(skipped) > 0 {
+ skippedPacketsString := ""
+ for chainID, chainSkipped := range skipped {
+ for channelKey, skipped := range chainSkipped {
+ skippedPacketsString += fmt.Sprintf(
+ "{ %s %s %s recv: %d, ack: %d } ",
+ chainID, channelKey.ChannelID, channelKey.PortID, skipped.Recv, skipped.Ack,
+ )
+ }
+ }
+ return fmt.Errorf(
+ "flush was successful, but packets are still pending. %s",
+ skippedPacketsString,
+ )
+ }
+
+ return nil
}
// shouldTerminateForFlushComplete will determine if the relayer should exit
// when FlushLifecycle is used. It will exit when all of the message caches are cleared.
-func (pp *PathProcessor) shouldTerminateForFlushComplete(
- ctx context.Context, cancel func(),
-) bool {
+func (pp *PathProcessor) shouldTerminateForFlushComplete() bool {
if _, ok := pp.messageLifecycle.(*FlushLifecycle); !ok {
return false
}
- for _, packetMessagesCache := range pp.pathEnd1.messageCache.PacketFlow {
+ for k, packetMessagesCache := range pp.pathEnd1.messageCache.PacketFlow {
+ if cs, ok := pp.pathEnd1.channelStateCache[k]; !ok || !cs.Open {
+ continue
+ }
for _, c := range packetMessagesCache {
if len(c) > 0 {
return false
@@ -942,16 +1659,23 @@ func (pp *PathProcessor) shouldTerminateForFlushComplete(
}
}
for _, c := range pp.pathEnd1.messageCache.ChannelHandshake {
- if len(c) > 0 {
- return false
+ for k := range pp.pathEnd1.channelStateCache {
+ if _, ok := c[k]; ok {
+ return false
+ }
}
}
for _, c := range pp.pathEnd1.messageCache.ConnectionHandshake {
- if len(c) > 0 {
- return false
+ for k := range pp.pathEnd1.connectionStateCache {
+ if _, ok := c[k]; ok {
+ return false
+ }
}
}
- for _, packetMessagesCache := range pp.pathEnd2.messageCache.PacketFlow {
+ for k, packetMessagesCache := range pp.pathEnd2.messageCache.PacketFlow {
+ if cs, ok := pp.pathEnd1.channelStateCache[k]; !ok || !cs.Open {
+ continue
+ }
for _, c := range packetMessagesCache {
if len(c) > 0 {
return false
@@ -959,15 +1683,61 @@ func (pp *PathProcessor) shouldTerminateForFlushComplete(
}
}
for _, c := range pp.pathEnd2.messageCache.ChannelHandshake {
- if len(c) > 0 {
- return false
+ for k := range pp.pathEnd1.channelStateCache {
+ if _, ok := c[k]; ok {
+ return false
+ }
}
}
for _, c := range pp.pathEnd2.messageCache.ConnectionHandshake {
- if len(c) > 0 {
- return false
+ for k := range pp.pathEnd1.connectionStateCache {
+ if _, ok := c[k]; ok {
+ return false
+ }
}
}
pp.log.Info("Found termination condition for flush, all caches cleared")
return true
}
+
+func (pp *PathProcessor) UpdateBTPHeight(ctx context.Context, src *pathEndRuntime, dst *pathEndRuntime) {
+ srcIsIcon := src.chainProvider.Type() == common.IconModule
+ dstIsBtpClient := IsBTPLightClient(dst.clientState)
+
+ if !srcIsIcon && !dstIsBtpClient {
+ return
+ }
+
+ if srcIsIcon && !dstIsBtpClient || !srcIsIcon && dstIsBtpClient {
+ pp.log.Error("Src Icon module mismatch with dst btp client",
+ zap.String("Src Chain Type ", src.chainProvider.Type()),
+ zap.String("Dst client Id", dst.clientState.ClientID),
+ )
+ return
+ }
+
+ if src.BTPHeightQueue.Size() == 0 {
+ return
+ }
+ size := src.BTPHeightQueue.Size()
+ for i := 0; i < size; i++ {
+ btpHeightInfo, err := src.BTPHeightQueue.GetQueue()
+ if err != nil {
+ continue
+ }
+ if dst.clientState.ConsensusHeight.RevisionHeight < uint64(btpHeightInfo.Height) {
+ break
+ }
+ if dst.clientState.ConsensusHeight.RevisionHeight == uint64(btpHeightInfo.Height) {
+ src.BTPHeightQueue.Dequeue()
+ continue
+ }
+ if dst.clientState.ConsensusHeight.RevisionHeight > uint64(btpHeightInfo.Height) {
+ cs, err := dst.chainProvider.QueryClientConsensusState(ctx, int64(dst.latestBlock.Height), dst.clientState.ClientID, clienttypes.NewHeight(0, uint64(btpHeightInfo.Height)))
+ if err == nil && cs != nil {
+ // removing latest height element
+ src.BTPHeightQueue.Dequeue()
+ }
+ }
+ }
+}
diff --git a/relayer/processor/types.go b/relayer/processor/types.go
index ac2dced07..72c37c455 100644
--- a/relayer/processor/types.go
+++ b/relayer/processor/types.go
@@ -3,12 +3,18 @@ package processor
import (
"fmt"
"sort"
+ "sync"
chantypes "github.com/cosmos/ibc-go/v7/modules/core/04-channel/types"
+ "github.com/cosmos/relayer/v2/relayer/common"
"github.com/cosmos/relayer/v2/relayer/provider"
"go.uber.org/zap/zapcore"
)
+var (
+ zeroIndex = 0
+)
+
// MessageLifecycle is used to send an initial IBC message to a chain
// once the chains are in sync for the PathProcessor.
// It also allows setting a stop condition for the PathProcessor.
@@ -72,6 +78,18 @@ type ChannelMessageLifecycle struct {
func (t *ChannelMessageLifecycle) messageLifecycler() {}
+// ChannelCloseLifecycle is used as a stop condition for the PathProcessor.
+// It will attempt to finish closing the channel and terminate once the channel is closed.
+type ChannelCloseLifecycle struct {
+ SrcChainID string
+ SrcChannelID string
+ SrcPortID string
+ SrcConnID string
+ DstConnID string
+}
+
+func (t *ChannelCloseLifecycle) messageLifecycler() {}
+
// IBCMessagesCache holds cached messages for packet flows, connection handshakes,
// and channel handshakes. The PathProcessors use this for message correlation to determine
// when messages should be sent and are pruned when flows/handshakes are complete.
@@ -109,6 +127,13 @@ func NewIBCMessagesCache() IBCMessagesCache {
}
}
+func (m *IBCMessagesCache) IsEmpty() bool {
+ if len(m.PacketFlow) > 0 || len(m.ConnectionHandshake) > 0 || len(m.ChannelHandshake) > 0 || len(m.ClientICQ) > 0 {
+ return false
+ }
+ return true
+}
+
// ChannelPacketMessagesCache is used for caching a PacketMessagesCache for a given IBC channel.
type ChannelPacketMessagesCache map[ChannelKey]PacketMessagesCache
@@ -147,6 +172,12 @@ type ChannelKey struct {
CounterpartyPortID string
}
+// ChannelState is used for caching channel open state and a lookup for the channel order.
+type ChannelState struct {
+ Order chantypes.Order
+ Open bool
+}
+
// Counterparty flips a ChannelKey for the perspective of the counterparty chain
func (k ChannelKey) Counterparty() ChannelKey {
return ChannelKey{
@@ -168,6 +199,18 @@ func (k ChannelKey) MsgInitKey() ChannelKey {
}
}
+// PreInitKey is used for comparing pre-init keys with other connection
+// handshake messages. Before the channel handshake,
+// do not have ChannelID or CounterpartyChannelID.
+func (k ChannelKey) PreInitKey() ChannelKey {
+ return ChannelKey{
+ ChannelID: "",
+ PortID: k.PortID,
+ CounterpartyChannelID: "",
+ CounterpartyPortID: k.CounterpartyPortID,
+ }
+}
+
func (k ChannelKey) MarshalLogObject(enc zapcore.ObjectEncoder) error {
enc.AddString("channel_id", k.ChannelID)
enc.AddString("port_id", k.PortID)
@@ -205,6 +248,18 @@ func (connectionKey ConnectionKey) MsgInitKey() ConnectionKey {
}
}
+// PreInitKey is used for comparing pre-init keys with other connection
+// handshake messages. Before starting a connection handshake,
+// do not have ConnectionID or CounterpartyConnectionID.
+func (connectionKey ConnectionKey) PreInitKey() ConnectionKey {
+ return ConnectionKey{
+ ClientID: connectionKey.ClientID,
+ ConnectionID: "",
+ CounterpartyClientID: connectionKey.CounterpartyClientID,
+ CounterpartyConnID: "",
+ }
+}
+
func (k ConnectionKey) MarshalLogObject(enc zapcore.ObjectEncoder) error {
enc.AddString("connection_id", k.ConnectionID)
enc.AddString("client_id", k.ClientID)
@@ -214,7 +269,23 @@ func (k ConnectionKey) MarshalLogObject(enc zapcore.ObjectEncoder) error {
}
// ChannelStateCache maintains channel open state for multiple channels.
-type ChannelStateCache map[ChannelKey]bool
+type ChannelStateCache map[ChannelKey]ChannelState
+
+// SetOpen sets the open state for a channel, and also the order if it is not NONE.
+func (c ChannelStateCache) SetOpen(k ChannelKey, open bool, order chantypes.Order) {
+ if s, ok := c[k]; ok {
+ s.Open = open
+ if order != chantypes.NONE {
+ s.Order = order
+ }
+ c[k] = s
+ return
+ }
+ c[k] = ChannelState{
+ Open: open,
+ Order: order,
+ }
+}
// FilterForClient returns a filtered copy of channels on top of an underlying clientID so it can be used by other goroutines.
func (c ChannelStateCache) FilterForClient(clientID string, channelConnections map[string]string, connectionClients map[string]string) ChannelStateCache {
@@ -261,6 +332,7 @@ type ChainProcessorCacheData struct {
LatestBlock provider.LatestBlock
LatestHeader provider.IBCHeader
IBCHeaderCache IBCHeaderCache
+ IsGenesis bool
}
// Clone creates a deep copy of a PacketMessagesCache.
@@ -286,6 +358,36 @@ func (c PacketMessagesCache) DeleteMessages(toDelete ...map[string][]uint64) {
}
}
+// IsCached returns true if a sequence for a channel key and event type is already cached.
+func (c ChannelPacketMessagesCache) IsCached(eventType string, k ChannelKey, sequence uint64) bool {
+ if _, ok := c[k]; !ok {
+ return false
+ }
+ if _, ok := c[k][eventType]; !ok {
+ return false
+ }
+ if _, ok := c[k][eventType][sequence]; !ok {
+ return false
+ }
+ return true
+}
+
+// Cache stores packet info safely, generating intermediate maps along the way if necessary.
+func (c ChannelPacketMessagesCache) Cache(
+ eventType string,
+ k ChannelKey,
+ sequence uint64,
+ packetInfo provider.PacketInfo,
+) {
+ if _, ok := c[k]; !ok {
+ c[k] = make(PacketMessagesCache)
+ }
+ if _, ok := c[k][eventType]; !ok {
+ c[k][eventType] = make(PacketSequenceCache)
+ }
+ c[k][eventType][sequence] = packetInfo
+}
+
// Merge merges another ChannelPacketMessagesCache into this one.
func (c ChannelPacketMessagesCache) Merge(other ChannelPacketMessagesCache) {
for channelKey, messageCache := range other {
@@ -490,7 +592,7 @@ func (c IBCHeaderCache) Prune(keep int) {
// PacketInfoChannelKey returns the applicable ChannelKey for the chain based on the eventType.
func PacketInfoChannelKey(eventType string, info provider.PacketInfo) (ChannelKey, error) {
switch eventType {
- case chantypes.EventTypeRecvPacket, chantypes.EventTypeWriteAck:
+ case chantypes.EventTypeRecvPacket, chantypes.EventTypeWriteAck, common.EventTimeoutRequest:
return packetInfoChannelKey(info).Counterparty(), nil
case chantypes.EventTypeSendPacket, chantypes.EventTypeAcknowledgePacket, chantypes.EventTypeTimeoutPacket, chantypes.EventTypeTimeoutPacketOnClose:
return packetInfoChannelKey(info), nil
@@ -517,3 +619,106 @@ func ConnectionInfoConnectionKey(info provider.ConnectionInfo) ConnectionKey {
CounterpartyConnID: info.CounterpartyConnID,
}
}
+
+type Queue[T any] interface {
+ Enqueue(item T)
+ Dequeue() (T, error)
+ MustGetQueue() T
+ GetQueue() (T, error)
+ ItemExist(interface{}) bool
+ ReplaceQueue(index int, item T)
+ Size() int
+}
+
+type ExistenceChecker interface {
+ Exists(target interface{}) bool
+}
+
+type BlockInfoHeight struct {
+ Height int64
+ IsProcessing bool
+ RetryCount int64
+}
+
+func (bi BlockInfoHeight) Exists(target interface{}) bool {
+ if height, ok := target.(int64); ok {
+ return bi.Height == height
+ }
+ return false
+}
+
+type ArrayQueue[T ExistenceChecker] struct {
+ items []T
+ mu *sync.Mutex
+}
+
+func (q *ArrayQueue[T]) Enqueue(item T) {
+ q.mu.Lock()
+ defer q.mu.Unlock()
+ q.items = append(q.items, item)
+}
+
+func (q *ArrayQueue[T]) MustGetQueue() T {
+ q.mu.Lock()
+ defer q.mu.Unlock()
+ if q.Size() == 0 {
+ panic("the size of queue is zero")
+ }
+
+ item := q.items[0]
+ return item
+}
+
+func (q *ArrayQueue[T]) ItemExist(target interface{}) bool {
+ q.mu.Lock()
+ defer q.mu.Unlock()
+ for _, item := range q.items {
+ if item.Exists(target) {
+ return true
+ }
+ }
+ return false
+}
+
+func (q *ArrayQueue[T]) GetQueue() (T, error) {
+ q.mu.Lock()
+ defer q.mu.Unlock()
+ if q.Size() == 0 {
+ var element T
+ return element, fmt.Errorf("The queue is of empty length")
+ }
+ item := q.items[0]
+ return item, nil
+
+}
+
+func (q *ArrayQueue[T]) ReplaceQueue(index int, element T) {
+ q.mu.Lock()
+ defer q.mu.Unlock()
+ if index >= 0 && index < len(q.items) {
+ q.items[index] = element
+ }
+}
+
+func (q *ArrayQueue[T]) Dequeue() (T, error) {
+ q.mu.Lock()
+ defer q.mu.Unlock()
+ if q.Size() == 0 {
+ var element T
+ return element, fmt.Errorf("all element dequed")
+ }
+ item := q.items[0]
+ q.items = q.items[1:]
+ return item, nil
+}
+
+func (q *ArrayQueue[T]) Size() int {
+ return len(q.items)
+}
+
+func NewBlockInfoHeightQueue[T ExistenceChecker]() *ArrayQueue[T] {
+ return &ArrayQueue[T]{
+ items: make([]T, 0),
+ mu: &sync.Mutex{},
+ }
+}
diff --git a/relayer/processor/types_internal.go b/relayer/processor/types_internal.go
index 188e3d670..5a63b868b 100644
--- a/relayer/processor/types_internal.go
+++ b/relayer/processor/types_internal.go
@@ -8,10 +8,17 @@ import (
conntypes "github.com/cosmos/ibc-go/v7/modules/core/03-connection/types"
chantypes "github.com/cosmos/ibc-go/v7/modules/core/04-channel/types"
+ ibcexported "github.com/cosmos/ibc-go/v7/modules/core/exported"
+ "github.com/cosmos/relayer/v2/relayer/common"
"github.com/cosmos/relayer/v2/relayer/provider"
"go.uber.org/zap/zapcore"
)
+var _ zapcore.ObjectMarshaler = packetIBCMessage{}
+var _ zapcore.ObjectMarshaler = channelIBCMessage{}
+var _ zapcore.ObjectMarshaler = connectionIBCMessage{}
+var _ zapcore.ObjectMarshaler = clientICQMessage{}
+
// pathEndMessages holds the different IBC messages that
// will attempt to be sent to the pathEnd.
type pathEndMessages struct {
@@ -51,6 +58,7 @@ func (msg packetIBCMessage) assemble(
) (provider.RelayerMessage, error) {
var packetProof func(context.Context, provider.PacketInfo, uint64) (provider.PacketProof, error)
var assembleMessage func(provider.PacketInfo, provider.PacketProof) (provider.RelayerMessage, error)
+
switch msg.eventType {
case chantypes.EventTypeRecvPacket:
packetProof = src.chainProvider.PacketCommitment
@@ -59,6 +67,7 @@ func (msg packetIBCMessage) assemble(
packetProof = src.chainProvider.PacketAcknowledgement
assembleMessage = dst.chainProvider.MsgAcknowledgement
case chantypes.EventTypeTimeoutPacket:
+
if msg.info.ChannelOrder == chantypes.ORDERED.String() {
packetProof = src.chainProvider.NextSeqRecv
} else {
@@ -66,6 +75,10 @@ func (msg packetIBCMessage) assemble(
}
assembleMessage = dst.chainProvider.MsgTimeout
+ case common.EventTimeoutRequest:
+ assembleMessage = dst.chainProvider.MsgTimeoutRequest
+ packetProof = src.chainProvider.PacketCommitment
+
case chantypes.EventTypeTimeoutPacketOnClose:
if msg.info.ChannelOrder == chantypes.ORDERED.String() {
packetProof = src.chainProvider.NextSeqRecv
@@ -77,15 +90,20 @@ func (msg packetIBCMessage) assemble(
default:
return nil, fmt.Errorf("unexepected packet message eventType for message assembly: %s", msg.eventType)
}
+ if src.clientState.ClientID == ibcexported.LocalhostClientID {
+ packetProof = src.localhostSentinelProofPacket
+ }
ctx, cancel := context.WithTimeout(ctx, packetProofQueryTimeout)
defer cancel()
var proof provider.PacketProof
var err error
- proof, err = packetProof(ctx, msg.info, src.latestBlock.Height)
- if err != nil {
- return nil, fmt.Errorf("error querying packet proof: %w", err)
+ if packetProof != nil {
+ proof, err = packetProof(ctx, msg.info, src.latestBlock.Height)
+ if err != nil {
+ return nil, fmt.Errorf("error querying packet proof: %w", err)
+ }
}
return assembleMessage(msg.info, proof)
}
@@ -112,6 +130,7 @@ func (msg packetIBCMessage) MarshalLogObject(enc zapcore.ObjectEncoder) error {
enc.AddString("dst_port", msg.info.DestPort)
enc.AddString("dst_channel", msg.info.DestChannel)
enc.AddUint64("sequence", msg.info.Sequence)
+ enc.AddUint64("packet height", msg.info.Height)
enc.AddString("timeout_height", fmt.Sprintf(
"%d-%d",
msg.info.TimeoutHeight.RevisionNumber,
@@ -144,6 +163,7 @@ func (msg channelIBCMessage) assemble(
) (provider.RelayerMessage, error) {
var chanProof func(context.Context, provider.ChannelInfo, uint64) (provider.ChannelProof, error)
var assembleMessage func(provider.ChannelInfo, provider.ChannelProof) (provider.RelayerMessage, error)
+
switch msg.eventType {
case chantypes.EventTypeChannelOpenInit:
// don't need proof for this message
@@ -157,6 +177,7 @@ func (msg channelIBCMessage) assemble(
case chantypes.EventTypeChannelOpenConfirm:
chanProof = src.chainProvider.ChannelProof
assembleMessage = dst.chainProvider.MsgChannelOpenConfirm
+
case chantypes.EventTypeChannelCloseInit:
// don't need proof for this message
assembleMessage = dst.chainProvider.MsgChannelCloseInit
@@ -166,6 +187,10 @@ func (msg channelIBCMessage) assemble(
default:
return nil, fmt.Errorf("unexepected channel message eventType for message assembly: %s", msg.eventType)
}
+ if src.clientState.ClientID == ibcexported.LocalhostClientID {
+ chanProof = src.localhostSentinelProofChannel
+ }
+
var proof provider.ChannelProof
var err error
if chanProof != nil {
@@ -220,13 +245,14 @@ func (msg connectionIBCMessage) assemble(
) (provider.RelayerMessage, error) {
var connProof func(context.Context, provider.ConnectionInfo, uint64) (provider.ConnectionProof, error)
var assembleMessage func(provider.ConnectionInfo, provider.ConnectionProof) (provider.RelayerMessage, error)
+
switch msg.eventType {
case conntypes.EventTypeConnectionOpenInit:
// don't need proof for this message
msg.info.CounterpartyCommitmentPrefix = src.chainProvider.CommitmentPrefix()
assembleMessage = dst.chainProvider.MsgConnectionOpenInit
case conntypes.EventTypeConnectionOpenTry:
- msg.info.CounterpartyCommitmentPrefix = src.chainProvider.CommitmentPrefix()
+ msg.info.CommitmentPrefix = src.chainProvider.CommitmentPrefix()
connProof = src.chainProvider.ConnectionHandshakeProof
assembleMessage = dst.chainProvider.MsgConnectionOpenTry
case conntypes.EventTypeConnectionOpenAck:
@@ -238,6 +264,7 @@ func (msg connectionIBCMessage) assemble(
default:
return nil, fmt.Errorf("unexepected connection message eventType for message assembly: %s", msg.eventType)
}
+
var proof provider.ConnectionProof
var err error
if connProof != nil {
@@ -246,6 +273,7 @@ func (msg connectionIBCMessage) assemble(
return nil, fmt.Errorf("error querying connection proof: %w", err)
}
}
+
return assembleMessage(msg.info, proof)
}
@@ -376,20 +404,25 @@ type clientICQProcessingCache map[provider.ClientICQQueryID]processingMessage
// contains MsgRecvPacket from counterparty
// entire packet flow
type pathEndPacketFlowMessages struct {
- Src *pathEndRuntime
- Dst *pathEndRuntime
- ChannelKey ChannelKey
- SrcMsgTransfer PacketSequenceCache
- DstMsgRecvPacket PacketSequenceCache
- SrcMsgAcknowledgement PacketSequenceCache
- SrcMsgTimeout PacketSequenceCache
- SrcMsgTimeoutOnClose PacketSequenceCache
- DstMsgChannelCloseConfirm *provider.ChannelInfo
+ Src *pathEndRuntime
+ Dst *pathEndRuntime
+ ChannelKey ChannelKey
+ SrcPreTransfer PacketSequenceCache
+ SrcMsgTransfer PacketSequenceCache
+ DstMsgRecvPacket PacketSequenceCache
+ DstMsgWriteAcknowledgementPacket PacketSequenceCache
+ SrcMsgAcknowledgement PacketSequenceCache
+ SrcMsgTimeout PacketSequenceCache
+ SrcMsgTimeoutOnClose PacketSequenceCache
+
+ // Adding for Icon chain
+ DstMsgRequestTimeout PacketSequenceCache
}
type pathEndConnectionHandshakeMessages struct {
Src *pathEndRuntime
Dst *pathEndRuntime
+ SrcMsgConnectionPreInit ConnectionMessageCache
SrcMsgConnectionOpenInit ConnectionMessageCache
DstMsgConnectionOpenTry ConnectionMessageCache
SrcMsgConnectionOpenAck ConnectionMessageCache
@@ -399,37 +432,36 @@ type pathEndConnectionHandshakeMessages struct {
type pathEndChannelHandshakeMessages struct {
Src *pathEndRuntime
Dst *pathEndRuntime
+ SrcMsgChannelPreInit ChannelMessageCache
SrcMsgChannelOpenInit ChannelMessageCache
DstMsgChannelOpenTry ChannelMessageCache
SrcMsgChannelOpenAck ChannelMessageCache
DstMsgChannelOpenConfirm ChannelMessageCache
}
+type pathEndChannelCloseMessages struct {
+ Src *pathEndRuntime
+ Dst *pathEndRuntime
+ SrcMsgChannelPreInit ChannelMessageCache
+ SrcMsgChannelCloseInit ChannelMessageCache
+ DstMsgChannelCloseConfirm ChannelMessageCache
+}
+
type pathEndPacketFlowResponse struct {
SrcMessages []packetIBCMessage
DstMessages []packetIBCMessage
DstChannelMessage []channelIBCMessage
-
- ToDeleteSrc map[string][]uint64
- ToDeleteDst map[string][]uint64
- ToDeleteDstChannel map[string][]ChannelKey
}
type pathEndChannelHandshakeResponse struct {
SrcMessages []channelIBCMessage
DstMessages []channelIBCMessage
-
- ToDeleteSrc map[string][]ChannelKey
- ToDeleteDst map[string][]ChannelKey
}
type pathEndConnectionHandshakeResponse struct {
SrcMessages []connectionIBCMessage
DstMessages []connectionIBCMessage
-
- ToDeleteSrc map[string][]ConnectionKey
- ToDeleteDst map[string][]ConnectionKey
}
func packetInfoChannelKey(p provider.PacketInfo) ChannelKey {
@@ -441,24 +473,6 @@ func packetInfoChannelKey(p provider.PacketInfo) ChannelKey {
}
}
-func connectionInfoConnectionKey(c provider.ConnectionInfo) ConnectionKey {
- return ConnectionKey{
- ClientID: c.ClientID,
- ConnectionID: c.ConnID,
- CounterpartyClientID: c.CounterpartyClientID,
- CounterpartyConnID: c.CounterpartyConnID,
- }
-}
-
-func channelInfoChannelKey(c provider.ChannelInfo) ChannelKey {
- return ChannelKey{
- ChannelID: c.ChannelID,
- PortID: c.PortID,
- CounterpartyChannelID: c.CounterpartyChannelID,
- CounterpartyPortID: c.CounterpartyPortID,
- }
-}
-
type messageToTrack interface {
// assembledMsg returns the assembled message ready to send.
assembledMsg() provider.RelayerMessage
diff --git a/relayer/processor/types_test.go b/relayer/processor/types_test.go
index 39224dc74..5edb510fb 100644
--- a/relayer/processor/types_test.go
+++ b/relayer/processor/types_test.go
@@ -13,6 +13,8 @@ type mockIBCHeader struct{}
func (h mockIBCHeader) Height() uint64 { return 0 }
func (h mockIBCHeader) ConsensusState() ibcexported.ConsensusState { return nil }
func (h mockIBCHeader) NextValidatorsHash() []byte { return nil }
+func (h mockIBCHeader) IsCompleteBlock() bool { return true }
+func (h mockIBCHeader) ShouldUpdateWithZeroMessage() bool { return false }
func TestIBCHeaderCachePrune(t *testing.T) {
cache := make(processor.IBCHeaderCache)
diff --git a/relayer/processor/utils.go b/relayer/processor/utils.go
new file mode 100644
index 000000000..1837546f9
--- /dev/null
+++ b/relayer/processor/utils.go
@@ -0,0 +1,59 @@
+package processor
+
+import (
+ "math"
+ "strings"
+
+ "github.com/cosmos/relayer/v2/relayer/common"
+ "github.com/cosmos/relayer/v2/relayer/provider"
+)
+
+func IsBTPLightClient(cs provider.ClientState) bool {
+ if strings.Contains(cs.ClientID, common.IconLightClient) {
+ return true
+ }
+ return false
+}
+
+func findNextGreaterHeight(headercache IBCHeaderCache, prevHeight uint64) (uint64, bool) {
+ minDiff := uint64(math.MaxUint64)
+ var nextGreaterHeight uint64
+ found := false
+
+ for key := range headercache {
+ if key > prevHeight && key-prevHeight < minDiff {
+ minDiff = key - prevHeight
+ nextGreaterHeight = key
+ found = true
+ }
+ }
+
+ if found {
+ return nextGreaterHeight, true
+ }
+ return 0, false
+}
+
+func nextIconIBCHeader(heightMap IBCHeaderCache, height uint64) (provider.IBCHeader, bool) {
+ var nextHeight uint64
+ nextHeight = math.MaxUint64
+
+ if height == 0 {
+ return nil, false
+ }
+ for h := range heightMap {
+ if h > height && h < nextHeight {
+ nextHeight = h
+ }
+ }
+ if nextHeight == math.MaxUint64 {
+ return nil, false
+ }
+
+ header, ok := heightMap[nextHeight]
+ return header, ok
+}
+
+func FindConsensusHeightFromEventLog([]provider.RelayerEvent) int64 {
+ return 0
+}
diff --git a/relayer/provider/provider.go b/relayer/provider/provider.go
index 2431604af..803cc082d 100644
--- a/relayer/provider/provider.go
+++ b/relayer/provider/provider.go
@@ -15,7 +15,7 @@ import (
chantypes "github.com/cosmos/ibc-go/v7/modules/core/04-channel/types"
commitmenttypes "github.com/cosmos/ibc-go/v7/modules/core/23-commitment/types"
ibcexported "github.com/cosmos/ibc-go/v7/modules/core/exported"
- "github.com/cosmos/ibc-go/v7/modules/light-clients/07-tendermint"
+ tendermint "github.com/cosmos/ibc-go/v7/modules/light-clients/07-tendermint"
"go.uber.org/zap"
"go.uber.org/zap/zapcore"
)
@@ -31,6 +31,8 @@ type ProviderConfig interface {
NewProvider(log *zap.Logger, homepath string, debug bool, chainName string) (ChainProvider, error)
Validate() error
BroadcastMode() BroadcastMode
+ GetBlockInterval() uint64
+ GetFirstRetryBlockAfter() uint64
}
type RelayerMessage interface {
@@ -61,15 +63,17 @@ type IBCHeader interface {
Height() uint64
ConsensusState() ibcexported.ConsensusState
NextValidatorsHash() []byte
+ IsCompleteBlock() bool //defined for IconIBCHeader
+ ShouldUpdateWithZeroMessage() bool //defined for IconIBCHeader
}
// ClientState holds the current state of a client from a single chain's perspective
type ClientState struct {
ClientID string
ConsensusHeight clienttypes.Height
- TrustingPeriod time.Duration
- ConsensusTime time.Time
- Header []byte
+ TrustingPeriod time.Duration // trustring period wont be there in ICON client state
+ ConsensusTime time.Time // consensus time wont be there in ICON light client State
+ Header []byte //
}
// ClientTrustedState holds the current state of a client from the perspective of both involved chains,
@@ -114,6 +118,7 @@ type ConnectionInfo struct {
Height uint64
ConnID string
ClientID string
+ CommitmentPrefix commitmenttypes.MerklePrefix
CounterpartyClientID string
CounterpartyConnID string
CounterpartyCommitmentPrefix commitmenttypes.MerklePrefix
@@ -215,8 +220,8 @@ func (r RelayerTxResponse) MarshalLogObject(enc zapcore.ObjectEncoder) error {
type KeyProvider interface {
CreateKeystore(path string) error
KeystoreCreated(path string) bool
- AddKey(name string, coinType uint32) (output *KeyOutput, err error)
- RestoreKey(name, mnemonic string, coinType uint32) (address string, err error)
+ AddKey(name string, coinType uint32, signingAlgorithm string, password string) (output *KeyOutput, err error)
+ RestoreKey(name, mnemonic string, coinType uint32, signingAlgorithm string) (address string, err error)
ShowAddress(name string) (address string, err error)
ListAddresses() (map[string]string, error)
DeleteKey(name string) error
@@ -282,6 +287,8 @@ type ChainProvider interface {
// i.e. the chain where the MsgTransfer was committed.
MsgTimeout(msgTransfer PacketInfo, proofUnreceived PacketProof) (RelayerMessage, error)
+ MsgTimeoutRequest(msgTransfer PacketInfo, proofUnreceived PacketProof) (RelayerMessage, error)
+
// MsgTimeoutOnClose takes the packet information from a MsgTransfer along
// with the packet receipt to prove that the packet was never relayed,
// i.e. that the MsgRecvPacket was never written to the counterparty chain,
@@ -289,6 +296,9 @@ type ChainProvider interface {
// i.e. the chain where the MsgTransfer was committed.
MsgTimeoutOnClose(msgTransfer PacketInfo, proofUnreceived PacketProof) (RelayerMessage, error)
+ // Get the commitment prefix of the chain.
+ CommitmentPrefix() commitmenttypes.MerklePrefix
+
// [End] Packet flow IBC message assembly
// [Begin] Connection handshake IBC message assembly
@@ -388,14 +398,15 @@ type ChainProvider interface {
memo string,
asyncCtx context.Context,
- asyncCallback func(*RelayerTxResponse, error),
+ asyncCallbacks []func(*RelayerTxResponse, error),
) error
+ MsgRegisterCounterpartyPayee(portID, channelID, relayerAddr, counterpartyPayeeAddr string) (RelayerMessage, error)
+
ChainName() string
ChainId() string
Type() string
ProviderConfig() ProviderConfig
- CommitmentPrefix() commitmenttypes.MerklePrefix
Key() string
Address() (string, error)
Timeout() string
@@ -434,7 +445,7 @@ type QueryProvider interface {
QueryUpgradedConsState(ctx context.Context, height int64) (*clienttypes.QueryConsensusStateResponse, error)
QueryConsensusState(ctx context.Context, height int64) (ibcexported.ConsensusState, int64, error)
QueryClients(ctx context.Context) (clienttypes.IdentifiedClientStates, error)
-
+ QueryClientPrevConsensusStateHeight(ctx context.Context, chainHeight int64, clinetId string, clientHeight int64) (ibcexported.Height, error)
// ics 03 - connection
QueryConnection(ctx context.Context, height int64, connectionid string) (*conntypes.QueryConnectionResponse, error)
QueryConnections(ctx context.Context) (conns []*conntypes.IdentifiedConnection, err error)
@@ -453,6 +464,7 @@ type QueryProvider interface {
QueryUnreceivedPackets(ctx context.Context, height uint64, channelid, portid string, seqs []uint64) ([]uint64, error)
QueryUnreceivedAcknowledgements(ctx context.Context, height uint64, channelid, portid string, seqs []uint64) ([]uint64, error)
QueryNextSeqRecv(ctx context.Context, height int64, channelid, portid string) (recvRes *chantypes.QueryNextSequenceReceiveResponse, err error)
+ QueryNextSeqAck(ctx context.Context, height int64, channelid, portid string) (recvRes *chantypes.QueryNextSequenceReceiveResponse, err error)
QueryPacketCommitment(ctx context.Context, height int64, channelid, portid string, seq uint64) (comRes *chantypes.QueryPacketCommitmentResponse, err error)
QueryPacketAcknowledgement(ctx context.Context, height int64, channelid, portid string, seq uint64) (ackRes *chantypes.QueryPacketAcknowledgementResponse, err error)
QueryPacketReceipt(ctx context.Context, height int64, channelid, portid string, seq uint64) (recRes *chantypes.QueryPacketReceiptResponse, err error)
@@ -539,6 +551,13 @@ func (h TendermintIBCHeader) ConsensusState() ibcexported.ConsensusState {
}
}
+func (h TendermintIBCHeader) IsCompleteBlock() bool {
+ return true
+}
+func (h TendermintIBCHeader) ShouldUpdateWithZeroMessage() bool {
+ return false
+}
+
func (h TendermintIBCHeader) NextValidatorsHash() []byte {
return h.SignedHeader.NextValidatorsHash
}
@@ -561,3 +580,8 @@ func (h TendermintIBCHeader) TMHeader() (*tendermint.Header, error) {
TrustedValidators: trustedVals,
}, nil
}
+
+type ExtensionOption struct {
+ Type string `json:"type"`
+ Value string `json:"value"`
+}
diff --git a/relayer/query.go b/relayer/query.go
index 24c40672a..53d97f7fe 100644
--- a/relayer/query.go
+++ b/relayer/query.go
@@ -10,6 +10,7 @@ import (
sdk "github.com/cosmos/cosmos-sdk/types"
chantypes "github.com/cosmos/ibc-go/v7/modules/core/04-channel/types"
ibcexported "github.com/cosmos/ibc-go/v7/modules/core/exported"
+ "github.com/cosmos/relayer/v2/relayer/common"
"github.com/cosmos/relayer/v2/relayer/provider"
"go.uber.org/zap"
"golang.org/x/sync/errgroup"
@@ -234,7 +235,7 @@ func QueryBalance(ctx context.Context, chain *Chain, address string, showDenoms
return nil, err
}
- if showDenoms {
+ if showDenoms || chain.ChainProvider.Type() == common.IconModule {
return coins, nil
}
@@ -272,39 +273,48 @@ func QueryBalance(ctx context.Context, chain *Chain, address string, showDenoms
return out, nil
}
-func QueryClientExpiration(ctx context.Context, src, dst *Chain) (time.Time, error) {
+func QueryClientExpiration(ctx context.Context, src, dst *Chain) (time.Time, ClientStateInfo, error) {
latestHeight, err := src.ChainProvider.QueryLatestHeight(ctx)
if err != nil {
- return time.Time{}, err
+ return time.Time{}, ClientStateInfo{}, err
}
clientStateRes, err := src.ChainProvider.QueryClientStateResponse(ctx, latestHeight, src.ClientID())
if err != nil {
- return time.Time{}, err
+ return time.Time{}, ClientStateInfo{}, err
}
clientInfo, err := ClientInfoFromClientState(clientStateRes.ClientState)
if err != nil {
- return time.Time{}, err
+ return time.Time{}, ClientStateInfo{}, err
}
clientTime, err := dst.ChainProvider.BlockTime(ctx, int64(clientInfo.LatestHeight.GetRevisionHeight()))
if err != nil {
- return time.Time{}, err
+ return time.Time{}, ClientStateInfo{}, err
}
- return clientTime.Add(clientInfo.TrustingPeriod), nil
+ return clientTime.Add(clientInfo.TrustingPeriod), clientInfo, nil
}
-func SPrintClientExpiration(chain *Chain, expiration time.Time) string {
+func SPrintClientExpiration(chain *Chain, expiration time.Time, clientInfo ClientStateInfo) string {
now := time.Now()
remainingTime := expiration.Sub(now)
expirationFormatted := expiration.Format(time.RFC822)
- if remainingTime < 0 {
- return fmt.Sprintf("client %s (%s) is already expired (%s)\n",
- chain.ClientID(), chain.ChainID(), expirationFormatted)
+ var status string
+ if remainingTime <= 0 {
+ status = "EXPIRED"
+ } else {
+ status = "GOOD"
}
- return fmt.Sprintf("client %s (%s) expires in %s (%s)\n",
- chain.ClientID(), chain.ChainID(), remainingTime.Round(time.Second), expirationFormatted)
+
+ return fmt.Sprintf(`
+ client: %s (%s)
+ HEALTH: %s
+ TIME: %s (%s)
+ LAST UPDATE HEIGHT: %d
+ TRUSTING PERIOD: %s
+ `,
+ chain.ClientID(), chain.ChainID(), status, expirationFormatted, remainingTime.Round(time.Second), clientInfo.LatestHeight.GetRevisionHeight(), clientInfo.TrustingPeriod.String())
}
diff --git a/relayer/query_test.go b/relayer/query_test.go
index fb67c60d1..39dc837b7 100644
--- a/relayer/query_test.go
+++ b/relayer/query_test.go
@@ -1,76 +1,124 @@
package relayer
import (
- "github.com/cosmos/relayer/v2/relayer/chains/cosmos"
"testing"
"time"
+ "github.com/cosmos/relayer/v2/relayer/chains/cosmos"
+
+ clienttypes "github.com/cosmos/ibc-go/v7/modules/core/02-client/types"
+ ibcexported "github.com/cosmos/ibc-go/v7/modules/core/exported"
"github.com/stretchr/testify/require"
)
func TestSPrintClientExpiration_PrintChainId(t *testing.T) {
previousTime := time.Now().Add(10 * time.Hour)
+ mockHeight := clienttypes.NewHeight(1, 100)
+ trustingPeriod := time.Duration(1 * time.Hour)
chain := mockChain("expected-chain-id", "test-client-id")
- expiration := SPrintClientExpiration(chain, previousTime)
+ clientStateInfo := mockClientStateInfo("test-chain-id", trustingPeriod, mockHeight)
+ expiration := SPrintClientExpiration(chain, previousTime, *clientStateInfo)
require.Contains(t, expiration, "expected-chain-id")
}
func TestSPrintClientExpiration_PrintClientId(t *testing.T) {
previousTime := time.Now().Add(10 * time.Hour)
+ mockHeight := clienttypes.NewHeight(1, 100)
+ trustingPeriod := time.Duration(1 * time.Hour)
chain := mockChain("test-chain-id", "expected-client-id")
- expiration := SPrintClientExpiration(chain, previousTime)
+ clientStateInfo := mockClientStateInfo("test-chain-id", trustingPeriod, mockHeight)
+ expiration := SPrintClientExpiration(chain, previousTime, *clientStateInfo)
require.Contains(t, expiration, "expected-client-id")
}
-func TestSPrintClientExpiration_PrintIsAlreadyExpired_WhenTimeIsInPast(t *testing.T) {
+func TestSPrintClientExpiration_PrintExpired_WhenTimeIsInPast(t *testing.T) {
previousTime := time.Now().Add(-10 * time.Hour)
+ mockHeight := clienttypes.NewHeight(1, 100)
+ trustingPeriod := time.Duration(1 * time.Hour)
chain := mockChain("test-chain-id", "test-client-id")
- expiration := SPrintClientExpiration(chain, previousTime)
+ clientStateInfo := mockClientStateInfo("test-chain-id", trustingPeriod, mockHeight)
+ expiration := SPrintClientExpiration(chain, previousTime, *clientStateInfo)
- require.Contains(t, expiration, "is already expired")
+ require.Contains(t, expiration, "EXPIRED")
}
func TestSPrintClientExpiration_PrintRFC822FormattedTime_WhenTimeIsInPast(t *testing.T) {
pastTime := time.Now().Add(-10 * time.Hour)
+ mockHeight := clienttypes.NewHeight(1, 100)
+ trustingPeriod := time.Duration(1 * time.Hour)
- chain := mockChain("test-chain-id", "test-client-id")
- expiration := SPrintClientExpiration(chain, pastTime)
+ chain := mockChain("expected-chain-id", "test-client-id")
+ clientStateInfo := mockClientStateInfo("test-chain-id", trustingPeriod, mockHeight)
+ expiration := SPrintClientExpiration(chain, pastTime, *clientStateInfo)
require.Contains(t, expiration, pastTime.Format(time.RFC822))
}
-func TestSPrintClientExpiration_PrintExpiresIn_WhenTimeIsInFuture(t *testing.T) {
+func TestSPrintClientExpiration_PrintGood_WhenTimeIsInFuture(t *testing.T) {
previousTime := time.Now().Add(10 * time.Hour)
+ mockHeight := clienttypes.NewHeight(1, 100)
+ trustingPeriod := time.Duration(1 * time.Hour)
chain := mockChain("test-chain-id", "test-client-id")
- expiration := SPrintClientExpiration(chain, previousTime)
+ clientStateInfo := mockClientStateInfo("test-chain-id", trustingPeriod, mockHeight)
+ expiration := SPrintClientExpiration(chain, previousTime, *clientStateInfo)
- require.Contains(t, expiration, "expires in")
+ require.Contains(t, expiration, "GOOD")
}
func TestSPrintClientExpiration_PrintRFC822FormattedTime_WhenTimeIsInFuture(t *testing.T) {
futureTime := time.Now().Add(10 * time.Hour)
+ mockHeight := clienttypes.NewHeight(1, 100)
+ trustingPeriod := time.Duration(1 * time.Hour)
chain := mockChain("test-chain-id", "test-client-id")
- expiration := SPrintClientExpiration(chain, futureTime)
+ clientStateInfo := mockClientStateInfo("test-chain-id", trustingPeriod, mockHeight)
+ expiration := SPrintClientExpiration(chain, futureTime, *clientStateInfo)
require.Contains(t, expiration, futureTime.Format(time.RFC822))
}
func TestSPrintClientExpiration_PrintRemainingTime_WhenTimeIsInFuture(t *testing.T) {
futureTime := time.Now().Add(10 * time.Hour)
+ mockHeight := clienttypes.NewHeight(1, 100)
+ trustingPeriod := time.Duration(1 * time.Hour)
chain := mockChain("test-chain-id", "test-client-id")
- expiration := SPrintClientExpiration(chain, futureTime)
+ clientStateInfo := mockClientStateInfo("test-chain-id", trustingPeriod, mockHeight)
+ expiration := SPrintClientExpiration(chain, futureTime, *clientStateInfo)
require.Contains(t, expiration, "10h0m0s")
}
+func TestSPrintClientExpiration_TrustingPeriod(t *testing.T) {
+ previousTime := time.Now().Add(10 * time.Hour)
+ mockHeight := clienttypes.NewHeight(1, 100)
+ trustingPeriod := time.Duration(1 * time.Hour)
+
+ chain := mockChain("expected-chain-id", "test-client-id")
+ clientStateInfo := mockClientStateInfo("test-chain-id", trustingPeriod, mockHeight)
+ expiration := SPrintClientExpiration(chain, previousTime, *clientStateInfo)
+
+ require.Contains(t, expiration, "1h0m0s")
+}
+
+func TestSPrintClientExpiration_LastUpdateHeight(t *testing.T) {
+ previousTime := time.Now().Add(10 * time.Hour)
+ mockHeight := clienttypes.NewHeight(1, 100)
+ trustingPeriod := time.Duration(1 * time.Hour)
+
+ chain := mockChain("expected-chain-id", "test-client-id")
+ clientStateInfo := mockClientStateInfo("test-chain-id", trustingPeriod, mockHeight)
+ expiration := SPrintClientExpiration(chain, previousTime, *clientStateInfo)
+
+ require.Contains(t, expiration, "100")
+}
+
func mockChain(chainId string, clientId string) *Chain {
return &Chain{
Chainid: chainId,
@@ -85,3 +133,12 @@ func mockChain(chainId string, clientId string) *Chain {
},
}
}
+
+func mockClientStateInfo(chainID string, trustingPeriod time.Duration, latestHeight ibcexported.Height) *ClientStateInfo {
+ mockHeight := clienttypes.NewHeight(1, 100)
+ return &ClientStateInfo{
+ ChainID: chainID,
+ TrustingPeriod: time.Duration(1 * time.Hour),
+ LatestHeight: mockHeight,
+ }
+}
diff --git a/relayer/relayMsgs.go b/relayer/relayMsgs.go
index 52d95f160..698e8b28a 100644
--- a/relayer/relayMsgs.go
+++ b/relayer/relayMsgs.go
@@ -108,6 +108,11 @@ type SendMsgsResult struct {
SrcSendError, DstSendError error
}
+// SuccessfullySent reports the presence successfully sent batches
+func (r SendMsgsResult) SuccessfullySent() bool {
+ return (r.SuccessfulSrcBatches > 0 || r.SuccessfulDstBatches > 0)
+}
+
// PartiallySent reports the presence of both some successfully sent batches
// and some errors.
func (r SendMsgsResult) PartiallySent() bool {
diff --git a/relayer/relaymsgs_test.go b/relayer/relaymsgs_test.go
index dab099072..0a3f1c972 100644
--- a/relayer/relaymsgs_test.go
+++ b/relayer/relaymsgs_test.go
@@ -5,7 +5,7 @@ import (
"fmt"
"testing"
- "github.com/cosmos/relayer/v2/relayer"
+ relayer "github.com/cosmos/relayer/v2/relayer"
"github.com/cosmos/relayer/v2/relayer/provider"
"github.com/stretchr/testify/require"
"go.uber.org/zap/zaptest"
diff --git a/relayer/strategies.go b/relayer/strategies.go
index dd82beb94..dbfc9e9ed 100644
--- a/relayer/strategies.go
+++ b/relayer/strategies.go
@@ -8,9 +8,14 @@ import (
"sync"
"time"
+ sdk "github.com/cosmos/cosmos-sdk/types"
+
"github.com/avast/retry-go/v4"
"github.com/cosmos/ibc-go/v7/modules/core/04-channel/types"
"github.com/cosmos/relayer/v2/relayer/chains/cosmos"
+ "github.com/cosmos/relayer/v2/relayer/chains/icon"
+ penumbraprocessor "github.com/cosmos/relayer/v2/relayer/chains/penumbra"
+ "github.com/cosmos/relayer/v2/relayer/chains/wasm"
"github.com/cosmos/relayer/v2/relayer/processor"
"go.uber.org/zap"
)
@@ -26,15 +31,38 @@ const (
ProcessorLegacy = "legacy"
DefaultClientUpdateThreshold = 0 * time.Millisecond
DefaultFlushInterval = 5 * time.Minute
+ DefaultMaxMsgLength = 5
+ TwoMB = 2 * 1024 * 1024
)
+func timerChannel(ctx context.Context, log *zap.Logger, timerChan map[string]chan struct{}, chains map[string]*Chain) {
+ ticker := time.NewTicker(time.Hour)
+ defer ticker.Stop()
+ for {
+ NamedLoop:
+ select {
+ case <-ticker.C:
+ for _, c := range chains {
+ _, err := c.ChainProvider.QueryLatestHeight(ctx)
+ if err != nil {
+ log.Warn("Failed getting status of chain", zap.String("chain_id", c.ChainID()), zap.Error(err))
+ break NamedLoop
+ }
+ }
+ for _, c := range timerChan {
+ c <- struct{}{}
+ }
+ }
+ }
+}
+
// StartRelayer starts the main relaying loop and returns a channel that will contain any control-flow related errors.
func StartRelayer(
ctx context.Context,
log *zap.Logger,
chains map[string]*Chain,
paths []NamedPath,
- maxTxSize, maxMsgLength uint64,
+ maxMsgLength uint64,
memo string,
clientUpdateThresholdTime time.Duration,
flushInterval time.Duration,
@@ -43,14 +71,23 @@ func StartRelayer(
initialBlockHistory uint64,
metrics *processor.PrometheusMetrics,
) chan error {
+ //prevent incorrect bech32 address prefixed addresses when calling AccAddress.String()
+ sdk.SetAddrCacheEnabled(false)
errorChan := make(chan error, 1)
+ chans := make(map[string]chan struct{})
+
+ for k := range chains {
+ chans[k] = make(chan struct{})
+ }
+
+ go timerChannel(ctx, log, chans, chains)
switch processorType {
case ProcessorEvents:
chainProcessors := make([]processor.ChainProcessor, 0, len(chains))
- for _, chain := range chains {
- chainProcessors = append(chainProcessors, chain.chainProcessor(log, metrics))
+ for name, chain := range chains {
+ chainProcessors = append(chainProcessors, chain.chainProcessor(log, metrics, chans[name]))
}
ePaths := make([]path, len(paths))
@@ -79,7 +116,6 @@ func StartRelayer(
chainProcessors,
ePaths,
initialBlockHistory,
- maxTxSize,
maxMsgLength,
memo,
messageLifecycle,
@@ -97,7 +133,7 @@ func StartRelayer(
src, dst := chains[p.Src.ChainID], chains[p.Dst.ChainID]
src.PathEnd = p.Src
dst.PathEnd = p.Dst
- go relayerStartLegacy(ctx, log, src, dst, p.Filter, maxTxSize, maxMsgLength, memo, errorChan)
+ go relayerStartLegacy(ctx, log, src, dst, p.Filter, TwoMB, maxMsgLength, memo, errorChan)
return errorChan
default:
panic(fmt.Errorf("unexpected processor type: %s, supports one of: [%s, %s]", processorType, ProcessorEvents, ProcessorLegacy))
@@ -112,11 +148,17 @@ type path struct {
}
// chainProcessor returns the corresponding ChainProcessor implementation instance for a pathChain.
-func (chain *Chain) chainProcessor(log *zap.Logger, metrics *processor.PrometheusMetrics) processor.ChainProcessor {
+func (chain *Chain) chainProcessor(log *zap.Logger, metrics *processor.PrometheusMetrics, timerChan chan struct{}) processor.ChainProcessor {
// Handle new ChainProcessor implementations as cases here
switch p := chain.ChainProvider.(type) {
+ case *penumbraprocessor.PenumbraProvider:
+ return penumbraprocessor.NewPenumbraChainProcessor(log, p)
case *cosmos.CosmosProvider:
return cosmos.NewCosmosChainProcessor(log, p, metrics)
+ case *icon.IconProvider:
+ return icon.NewIconChainProcessor(log, p, metrics, timerChan)
+ case *wasm.WasmProvider:
+ return wasm.NewWasmChainProcessor(log, p, metrics, timerChan)
default:
panic(fmt.Errorf("unsupported chain provider type: %T", chain.ChainProvider))
}
@@ -129,7 +171,6 @@ func relayerStartEventProcessor(
chainProcessors []processor.ChainProcessor,
paths []path,
initialBlockHistory uint64,
- maxTxSize,
maxMsgLength uint64,
memo string,
messageLifecycle processor.MessageLifecycle,
@@ -152,6 +193,7 @@ func relayerStartEventProcessor(
memo,
clientUpdateThresholdTime,
flushInterval,
+ maxMsgLength,
))
}
diff --git a/scripts/protocgen.sh b/scripts/protocgen.sh
index 856fb275f..ae4f20240 100755
--- a/scripts/protocgen.sh
+++ b/scripts/protocgen.sh
@@ -15,8 +15,14 @@ for dir in $proto_dirs; do
done
done
+buf generate --template proto/buf.gen.penumbra.yaml buf.build/penumbra-zone/penumbra
+
# move proto files to the right places
+
#
# Note: Proto files are suffixed with the current binary version.
+rm -r github.com/cosmos/relayer/v2/relayer/chains/penumbra/client
+rm -r github.com/cosmos/relayer/v2/relayer/chains/penumbra/narsil
cp -r github.com/cosmos/relayer/v2/* ./
-rm -rf github.com
\ No newline at end of file
+cp -r github.com/cosmos/relayer/relayer/* relayer/
+rm -rf github.com
diff --git a/third_party/proto/amino/amino.proto b/third_party/proto/amino/amino.proto
deleted file mode 100644
index 05f965830..000000000
--- a/third_party/proto/amino/amino.proto
+++ /dev/null
@@ -1,80 +0,0 @@
-syntax = "proto3";
-
-package amino;
-
-import "google/protobuf/descriptor.proto";
-
-// TODO(fdymylja): once we fully migrate to protov2 the go_package needs to be
-// updated. We need this right now because gogoproto codegen needs to import the
-// extension.
-option go_package = "github.com/cosmos/cosmos-sdk/types/tx/amino";
-
-extend google.protobuf.MessageOptions {
- // name is the string used when registering a concrete
- // type into the Amino type registry, via the Amino codec's
- // `RegisterConcrete()` method. This string MUST be at most 39
- // characters long, or else the message will be rejected by the
- // Ledger hardware device.
- string name = 11110001;
-
- // encoding describes the encoding format used by Amino for the given
- // message. The field type is chosen to be a string for
- // flexibility, but it should ideally be short and expected to be
- // machine-readable, for example "base64" or "utf8_json". We
- // highly recommend to use underscores for word separation instead of spaces.
- //
- // If left empty, then the Amino encoding is expected to be the same as the
- // Protobuf one.
- //
- // This annotation should not be confused with the `encoding`
- // one which operates on the field level.
- string message_encoding = 11110002;
-}
-
-extend google.protobuf.FieldOptions {
- // encoding describes the encoding format used by Amino for
- // the given field. The field type is chosen to be a string for
- // flexibility, but it should ideally be short and expected to be
- // machine-readable, for example "base64" or "utf8_json". We
- // highly recommend to use underscores for word separation instead of spaces.
- //
- // If left empty, then the Amino encoding is expected to be the same as the
- // Protobuf one.
- //
- // This annotation should not be confused with the
- // `message_encoding` one which operates on the message level.
- string encoding = 11110003;
-
- // field_name sets a different field name (i.e. key name) in
- // the amino JSON object for the given field.
- //
- // Example:
- //
- // message Foo {
- // string bar = 1 [(amino.field_name) = "baz"];
- // }
- //
- // Then the Amino encoding of Foo will be:
- // `{"baz":"some value"}`
- string field_name = 11110004;
-
- // dont_omitempty sets the field in the JSON object even if
- // its value is empty, i.e. equal to the Golang zero value. To learn what
- // the zero values are, see https://go.dev/ref/spec#The_zero_value.
- //
- // Fields default to `omitempty`, which is the default behavior when this
- // annotation is unset. When set to true, then the field value in the
- // JSON object will be set, i.e. not `undefined`.
- //
- // Example:
- //
- // message Foo {
- // string bar = 1;
- // string baz = 2 [(amino.dont_omitempty) = true];
- // }
- //
- // f := Foo{};
- // out := AminoJSONEncoder(&f);
- // out == {"baz":""}
- bool dont_omitempty = 11110005;
-}
\ No newline at end of file
diff --git a/third_party/proto/buf.yaml b/third_party/proto/buf.yaml
deleted file mode 100644
index e1693df81..000000000
--- a/third_party/proto/buf.yaml
+++ /dev/null
@@ -1,6 +0,0 @@
-version: v1
-lint:
- ignore:
- - cometbft
- - gogoproto
- - cosmos_proto
\ No newline at end of file
diff --git a/third_party/proto/cosmos/auth/v1beta1/auth.proto b/third_party/proto/cosmos/auth/v1beta1/auth.proto
deleted file mode 100644
index 2b9ead613..000000000
--- a/third_party/proto/cosmos/auth/v1beta1/auth.proto
+++ /dev/null
@@ -1,23 +0,0 @@
-syntax = "proto3";
-package cosmos.auth.v1beta1;
-
-import "cosmos_proto/cosmos.proto";
-import "gogoproto/gogo.proto";
-import "google/protobuf/any.proto";
-
-option go_package = "github.com/cosmos/cosmos-sdk/x/auth/types";
-
-// BaseAccount defines a base account type. It contains all the necessary fields
-// for basic account functionality. Any custom account type should extend this
-// type for additional functionality (e.g. vesting).
-message BaseAccount {
- option (gogoproto.goproto_getters) = false;
- option (gogoproto.goproto_stringer) = false;
- option (gogoproto.equal) = false;
-
- string address = 1 [ (cosmos_proto.scalar) = "cosmos.AddressString" ];
- google.protobuf.Any pub_key = 2
- [ (gogoproto.jsontag) = "public_key,omitempty" ];
- uint64 account_number = 3;
- uint64 sequence = 4;
-}
diff --git a/third_party/proto/cosmos_proto/cosmos.proto b/third_party/proto/cosmos_proto/cosmos.proto
deleted file mode 100644
index 1524a4257..000000000
--- a/third_party/proto/cosmos_proto/cosmos.proto
+++ /dev/null
@@ -1,97 +0,0 @@
-syntax = "proto3";
-package cosmos_proto;
-
-import "google/protobuf/descriptor.proto";
-
-option go_package = "github.com/cosmos/cosmos-proto;cosmos_proto";
-
-extend google.protobuf.MessageOptions {
-
- // implements_interface is used to indicate the type name of the interface
- // that a message implements so that it can be used in google.protobuf.Any
- // fields that accept that interface. A message can implement multiple
- // interfaces. Interfaces should be declared using a declare_interface
- // file option.
- repeated string implements_interface = 93001;
-}
-
-extend google.protobuf.FieldOptions {
-
- // accepts_interface is used to annotate that a google.protobuf.Any
- // field accepts messages that implement the specified interface.
- // Interfaces should be declared using a declare_interface file option.
- string accepts_interface = 93001;
-
- // scalar is used to indicate that this field follows the formatting defined
- // by the named scalar which should be declared with declare_scalar. Code
- // generators may choose to use this information to map this field to a
- // language-specific type representing the scalar.
- string scalar = 93002;
-}
-
-extend google.protobuf.FileOptions {
-
- // declare_interface declares an interface type to be used with
- // accepts_interface and implements_interface. Interface names are
- // expected to follow the following convention such that their declaration
- // can be discovered by tools: for a given interface type a.b.C, it is
- // expected that the declaration will be found in a protobuf file named
- // a/b/interfaces.proto in the file descriptor set.
- repeated InterfaceDescriptor declare_interface = 793021;
-
- // declare_scalar declares a scalar type to be used with
- // the scalar field option. Scalar names are
- // expected to follow the following convention such that their declaration
- // can be discovered by tools: for a given scalar type a.b.C, it is
- // expected that the declaration will be found in a protobuf file named
- // a/b/scalars.proto in the file descriptor set.
- repeated ScalarDescriptor declare_scalar = 793022;
-}
-
-// InterfaceDescriptor describes an interface type to be used with
-// accepts_interface and implements_interface and declared by declare_interface.
-message InterfaceDescriptor {
-
- // name is the name of the interface. It should be a short-name (without
- // a period) such that the fully qualified name of the interface will be
- // package.name, ex. for the package a.b and interface named C, the
- // fully-qualified name will be a.b.C.
- string name = 1;
-
- // description is a human-readable description of the interface and its
- // purpose.
- string description = 2;
-}
-
-// ScalarDescriptor describes an scalar type to be used with
-// the scalar field option and declared by declare_scalar.
-// Scalars extend simple protobuf built-in types with additional
-// syntax and semantics, for instance to represent big integers.
-// Scalars should ideally define an encoding such that there is only one
-// valid syntactical representation for a given semantic meaning,
-// i.e. the encoding should be deterministic.
-message ScalarDescriptor {
-
- // name is the name of the scalar. It should be a short-name (without
- // a period) such that the fully qualified name of the scalar will be
- // package.name, ex. for the package a.b and scalar named C, the
- // fully-qualified name will be a.b.C.
- string name = 1;
-
- // description is a human-readable description of the scalar and its
- // encoding format. For instance a big integer or decimal scalar should
- // specify precisely the expected encoding format.
- string description = 2;
-
- // field_type is the type of field with which this scalar can be used.
- // Scalars can be used with one and only one type of field so that
- // encoding standards and simple and clear. Currently only string and
- // bytes fields are supported for scalars.
- repeated ScalarType field_type = 3;
-}
-
-enum ScalarType {
- SCALAR_TYPE_UNSPECIFIED = 0;
- SCALAR_TYPE_STRING = 1;
- SCALAR_TYPE_BYTES = 2;
-}
\ No newline at end of file
diff --git a/third_party/proto/gogoproto/gogo.proto b/third_party/proto/gogoproto/gogo.proto
deleted file mode 100644
index bf975466a..000000000
--- a/third_party/proto/gogoproto/gogo.proto
+++ /dev/null
@@ -1,145 +0,0 @@
-// Protocol Buffers for Go with Gadgets
-//
-// Copyright (c) 2013, The GoGo Authors. All rights reserved.
-// http://github.com/gogo/protobuf
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-
-syntax = "proto2";
-package gogoproto;
-
-import "google/protobuf/descriptor.proto";
-
-option java_package = "com.google.protobuf";
-option java_outer_classname = "GoGoProtos";
-option go_package = "github.com/gogo/protobuf/gogoproto";
-
-extend google.protobuf.EnumOptions {
- optional bool goproto_enum_prefix = 62001;
- optional bool goproto_enum_stringer = 62021;
- optional bool enum_stringer = 62022;
- optional string enum_customname = 62023;
- optional bool enumdecl = 62024;
-}
-
-extend google.protobuf.EnumValueOptions {
- optional string enumvalue_customname = 66001;
-}
-
-extend google.protobuf.FileOptions {
- optional bool goproto_getters_all = 63001;
- optional bool goproto_enum_prefix_all = 63002;
- optional bool goproto_stringer_all = 63003;
- optional bool verbose_equal_all = 63004;
- optional bool face_all = 63005;
- optional bool gostring_all = 63006;
- optional bool populate_all = 63007;
- optional bool stringer_all = 63008;
- optional bool onlyone_all = 63009;
-
- optional bool equal_all = 63013;
- optional bool description_all = 63014;
- optional bool testgen_all = 63015;
- optional bool benchgen_all = 63016;
- optional bool marshaler_all = 63017;
- optional bool unmarshaler_all = 63018;
- optional bool stable_marshaler_all = 63019;
-
- optional bool sizer_all = 63020;
-
- optional bool goproto_enum_stringer_all = 63021;
- optional bool enum_stringer_all = 63022;
-
- optional bool unsafe_marshaler_all = 63023;
- optional bool unsafe_unmarshaler_all = 63024;
-
- optional bool goproto_extensions_map_all = 63025;
- optional bool goproto_unrecognized_all = 63026;
- optional bool gogoproto_import = 63027;
- optional bool protosizer_all = 63028;
- optional bool compare_all = 63029;
- optional bool typedecl_all = 63030;
- optional bool enumdecl_all = 63031;
-
- optional bool goproto_registration = 63032;
- optional bool messagename_all = 63033;
-
- optional bool goproto_sizecache_all = 63034;
- optional bool goproto_unkeyed_all = 63035;
-}
-
-extend google.protobuf.MessageOptions {
- optional bool goproto_getters = 64001;
- optional bool goproto_stringer = 64003;
- optional bool verbose_equal = 64004;
- optional bool face = 64005;
- optional bool gostring = 64006;
- optional bool populate = 64007;
- optional bool stringer = 67008;
- optional bool onlyone = 64009;
-
- optional bool equal = 64013;
- optional bool description = 64014;
- optional bool testgen = 64015;
- optional bool benchgen = 64016;
- optional bool marshaler = 64017;
- optional bool unmarshaler = 64018;
- optional bool stable_marshaler = 64019;
-
- optional bool sizer = 64020;
-
- optional bool unsafe_marshaler = 64023;
- optional bool unsafe_unmarshaler = 64024;
-
- optional bool goproto_extensions_map = 64025;
- optional bool goproto_unrecognized = 64026;
-
- optional bool protosizer = 64028;
- optional bool compare = 64029;
-
- optional bool typedecl = 64030;
-
- optional bool messagename = 64033;
-
- optional bool goproto_sizecache = 64034;
- optional bool goproto_unkeyed = 64035;
-}
-
-extend google.protobuf.FieldOptions {
- optional bool nullable = 65001;
- optional bool embed = 65002;
- optional string customtype = 65003;
- optional string customname = 65004;
- optional string jsontag = 65005;
- optional string moretags = 65006;
- optional string casttype = 65007;
- optional string castkey = 65008;
- optional string castvalue = 65009;
-
- optional bool stdtime = 65010;
- optional bool stdduration = 65011;
- optional bool wktpointer = 65012;
-
- optional string castrepeated = 65013;
-}
\ No newline at end of file
diff --git a/third_party/proto/tendermint/crypto/proof.proto b/third_party/proto/tendermint/crypto/proof.proto
deleted file mode 100644
index ad4145f3d..000000000
--- a/third_party/proto/tendermint/crypto/proof.proto
+++ /dev/null
@@ -1,41 +0,0 @@
-syntax = "proto3";
-
-// buf:lint:ignore PACKAGE_VERSION_SUFFIX
-package tendermint.crypto;
-
-option go_package = "github.com/cometbft/cometbft/proto/tendermint/crypto";
-
-import "gogoproto/gogo.proto";
-
-message Proof {
- int64 total = 1;
- int64 index = 2;
- bytes leaf_hash = 3;
- repeated bytes aunts = 4;
-}
-
-message ValueOp {
- // Encoded in ProofOp.Key.
- bytes key = 1;
-
- // To encode in ProofOp.Data
- Proof proof = 2;
-}
-
-message DominoOp {
- string key = 1;
- string input = 2;
- string output = 3;
-}
-
-// ProofOp defines an operation used for calculating Merkle root
-// The data could be arbitrary format, providing nessecary data
-// for example neighbouring node hash
-message ProofOp {
- string type = 1;
- bytes key = 2;
- bytes data = 3;
-}
-
-// ProofOps is Merkle proof defined by the list of ProofOps
-message ProofOps { repeated ProofOp ops = 1 [ (gogoproto.nullable) = false ]; }
\ No newline at end of file