Skip to content
New issue

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

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

Already on GitHub? Sign in to your account

feat(submitter): stateful submitter #43

Merged
merged 10 commits into from
Sep 16, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
6 changes: 6 additions & 0 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -75,3 +75,9 @@ update-changelog:
./scripts/update_changelog.sh $(sinceTag) $(upcomingTag)

.PHONY: build test test-e2e build-docker rm-docker mocks update-changelog

proto-gen:
@$(call print, "Compiling protos.")
cd ./proto; ./gen_protos_docker.sh

.PHONY: proto-gen
4 changes: 4 additions & 0 deletions btcclient/client_wallet.go
Original file line number Diff line number Diff line change
Expand Up @@ -121,3 +121,7 @@ func (c *Client) FundRawTransaction(tx *wire.MsgTx, opts btcjson.FundRawTransact
func (c *Client) SignRawTransactionWithWallet(tx *wire.MsgTx) (*wire.MsgTx, bool, error) {
return c.Client.SignRawTransactionWithWallet(tx)
}

func (c *Client) GetRawTransaction(txHash *chainhash.Hash) (*btcutil.Tx, error) {
return c.Client.GetRawTransaction(txHash)
}
1 change: 1 addition & 0 deletions btcclient/interface.go
Original file line number Diff line number Diff line change
Expand Up @@ -38,4 +38,5 @@ type BTCWallet interface {
GetHighUTXOAndSum() (*btcjson.ListUnspentResult, float64, error)
FundRawTransaction(tx *wire.MsgTx, opts btcjson.FundRawTransactionOpts, isWitness *bool) (*btcjson.FundRawTransactionResult, error)
SignRawTransactionWithWallet(tx *wire.MsgTx) (*wire.MsgTx, bool, error)
GetRawTransaction(txHash *chainhash.Hash) (*btcutil.Tx, error)
}
6 changes: 6 additions & 0 deletions cmd/vigilante/cmd/submitter.go
Original file line number Diff line number Diff line change
Expand Up @@ -62,6 +62,11 @@ func GetSubmitterCmd() *cobra.Command {
// register submitter metrics
submitterMetrics := metrics.NewSubmitterMetrics()

dbBackend, err := cfg.Submitter.DatabaseConfig.GetDbBackend()
if err != nil {
panic(err)
}

// create submitter
vigilantSubmitter, err := submitter.New(
&cfg.Submitter,
Expand All @@ -73,6 +78,7 @@ func GetSubmitterCmd() *cobra.Command {
cfg.Common.MaxRetrySleepTime,
cfg.Common.MaxRetryTimes,
submitterMetrics,
dbBackend,
)
if err != nil {
panic(fmt.Errorf("failed to create vigilante submitter: %w", err))
Expand Down
3 changes: 2 additions & 1 deletion config/submitter.go
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,8 @@ type SubmitterConfig struct {
PollingIntervalSeconds uint `mapstructure:"polling-interval-seconds"`
// ResendIntervalSeconds defines the time (in seconds) which the submitter awaits
// before resubmitting checkpoints to BTC
ResendIntervalSeconds uint `mapstructure:"resend-interval-seconds"`
ResendIntervalSeconds uint `mapstructure:"resend-interval-seconds"`
DatabaseConfig *DBConfig `mapstructure:"database-config"`
}

func (cfg *SubmitterConfig) Validate() error {
Expand Down
1 change: 1 addition & 0 deletions e2etest/monitor_e2e_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -61,6 +61,7 @@ func TestMonitorBootstrap(t *testing.T) {
tm.Config.Common.MaxRetrySleepTime,
tm.Config.Common.MaxRetryTimes,
metrics.NewSubmitterMetrics(),
testutil.MakeTestBackend(t),
)

vigilantSubmitter.Start()
Expand Down
3 changes: 3 additions & 0 deletions e2etest/submitter_e2e_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@
package e2etest

import (
"github.com/babylonlabs-io/vigilante/testutil"
"math/rand"
"testing"
"time"
Expand Down Expand Up @@ -64,6 +65,7 @@ func TestSubmitterSubmission(t *testing.T) {
tm.Config.Common.MaxRetrySleepTime,
tm.Config.Common.MaxRetryTimes,
metrics.NewSubmitterMetrics(),
testutil.MakeTestBackend(t),
)

vigilantSubmitter.Start()
Expand Down Expand Up @@ -138,6 +140,7 @@ func TestSubmitterSubmissionReplace(t *testing.T) {
tm.Config.Common.MaxRetrySleepTime,
tm.Config.Common.MaxRetryTimes,
metrics.NewSubmitterMetrics(),
testutil.MakeTestBackend(t),
)

vigilantSubmitter.Start()
Expand Down
7 changes: 7 additions & 0 deletions proto/.clang-format
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
---
Language: Proto
BasedOnStyle: Google
IndentWidth: 4
AllowShortFunctionsOnASingleLine: None
SpaceBeforeParens: Always
CompactNamespaces: false
36 changes: 36 additions & 0 deletions proto/Dockerfile
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@
# If you change this value, please change it in the following files as well:
# /.github/workflows/main.yaml
# /Dockerfile
# /dev.Dockerfile
# /make/builder.Dockerfile
# /tools/Dockerfile
FROM golang:1.20.5-buster

RUN apt-get update && apt-get install -y \
git \
protobuf-compiler='3.6.1*' \
clang-format='1:7.0*'

# We don't want any default values for these variables to make sure they're
# explicitly provided by parsing the go.mod file. Otherwise we might forget to
# update them here if we bump the versions.
ARG PROTOBUF_VERSION
ARG GRPC_GATEWAY_VERSION

ENV PROTOC_GEN_GO_GRPC_VERSION="v1.1.0"
ENV GOCACHE=/tmp/build/.cache
ENV GOMODCACHE=/tmp/build/.modcache

RUN cd /tmp \
&& mkdir -p /tmp/build/.cache \
&& mkdir -p /tmp/build/.modcache \
&& go install google.golang.org/protobuf/cmd/protoc-gen-go@${PROTOBUF_VERSION} \
&& go install google.golang.org/grpc/cmd/protoc-gen-go-grpc@${PROTOC_GEN_GO_GRPC_VERSION} \
&& go install github.com/grpc-ecosystem/grpc-gateway/v2/protoc-gen-grpc-gateway@${GRPC_GATEWAY_VERSION} \
&& go install github.com/grpc-ecosystem/grpc-gateway/v2/protoc-gen-openapiv2@${GRPC_GATEWAY_VERSION} \
&& go install golang.org/x/tools/cmd/[email protected] \
&& chmod -R 777 /tmp/build/

WORKDIR /build

CMD ["/bin/bash", "/build/proto/protocgen.sh"]
163 changes: 163 additions & 0 deletions proto/checkpoint.pb.go

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

12 changes: 12 additions & 0 deletions proto/checkpoint.proto
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
syntax = "proto3";

package proto;

option go_package = "github.com/babylonlabs-io/vigilante/proto";

// StoredCheckpoint holds two transactions and an epoch number
message StoredCheckpoint {
bytes tx1 = 1; // wire.MsgTx serialized as bytes
bytes tx2 = 2;
uint64 epoch = 3;
}
24 changes: 24 additions & 0 deletions proto/gen_protos_docker.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
#!/bin/bash

set -e

# Directory of the script file, independent of where it's called from.
DIR="$(cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd)"

PROTOBUF_VERSION=$(go list -f '{{.Version}}' -m google.golang.org/protobuf)
GRPC_GATEWAY_VERSION=$(go list -f '{{.Version}}' -m github.com/grpc-ecosystem/grpc-gateway/v2)

echo "Building protobuf compiler docker image..."
docker build -t vigilante-protobuf-builder \
--build-arg PROTOBUF_VERSION="$PROTOBUF_VERSION" \
--build-arg GRPC_GATEWAY_VERSION="$GRPC_GATEWAY_VERSION" \
.

echo "Compiling and formatting *.proto files..."
docker run \
--rm \
--user "$UID:$(id -g)" \
-e UID=$UID \
-e SUBSERVER_PREFIX \
-v "$DIR/../:/build" \
vigilante-protobuf-builder
41 changes: 41 additions & 0 deletions proto/protocgen.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,41 @@
#!/bin/bash

set -e

# generate compiles the *.pb.go stubs from the *.proto files.
function generate() {
echo "Generating vigilatne protos"

PROTOS="checkpoint.proto"

# For each of the sub-servers, we then generate their protos, but a restricted
# set as they don't yet require REST proxies, or swagger docs.
for file in $PROTOS; do
DIRECTORY=$(dirname "${file}")
echo "Generating protos from ${file}, into ${DIRECTORY}"

# Generate the protos.
protoc --go_out . --go_opt paths=source_relative \
--go-grpc_out . --go-grpc_opt paths=source_relative \
"${file}" --proto_path=$GOPATH/src/ --proto_path=.
done
}

# format formats the *.proto files with the clang-format utility.
function format() {
echo "Formatting protos"
#| xargs -0 clang-format --style=file -i
find . -name "*.proto" -print0 | xargs -0
}

# Compile and format the proto package.
pushd proto
format
generate
popd

if [[ "$COMPILE_MOBILE" == "1" ]]; then
pushd mobile
./gen_bindings.sh $FALAFEL_VERSION
popd
fi
3 changes: 2 additions & 1 deletion submitter/relayer/change_address_test.go
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
package relayer_test

import (
"github.com/babylonlabs-io/vigilante/testutil"
"testing"

"github.com/btcsuite/btcd/btcjson"
Expand Down Expand Up @@ -48,7 +49,7 @@ func TestGetChangeAddress(t *testing.T) {
logger, err := config.NewRootLogger("auto", "debug")
require.NoError(t, err)
testRelayer := relayer.New(wallet, []byte("bbnt"), btctxformatter.CurrentVersion, submitterAddr,
submitterMetrics.RelayerMetrics, nil, &cfg, logger)
submitterMetrics.RelayerMetrics, nil, &cfg, logger, testutil.MakeTestBackend(t))

// 1. only SegWit Bech32 addresses
segWitBech32Addrs := append(SegWitBech32p2wshAddrsStr, SegWitBech32p2wpkhAddrsStr...)
Expand Down
Loading
Loading