Skip to content
This repository has been archived by the owner on Apr 15, 2024. It is now read-only.

feat: support using config files for orchestrator and relayer #583

Merged
merged 8 commits into from
Nov 10, 2023
Merged
Show file tree
Hide file tree
Changes from 7 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
214 changes: 214 additions & 0 deletions cmd/blobstream/base/config.go
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,10 @@ import (
"os"
"strings"

ethcmn "github.com/ethereum/go-ethereum/common"

"github.com/celestiaorg/orchestrator-relayer/evm"

"github.com/spf13/cobra"

"github.com/pkg/errors"
rach-id marked this conversation as resolved.
Show resolved Hide resolved
Expand All @@ -24,6 +28,19 @@ type Config struct {
EVMPassphrase string
}

func AddEVMPassphraseFlag(cmd *cobra.Command) {
cmd.Flags().String(FlagEVMPassphrase, "", "the evm account passphrase (if not specified as a flag, it will be asked interactively)")
}

func GetEVMPassphraseFlag(cmd *cobra.Command) (string, bool, error) {
changed := cmd.Flags().Changed(FlagEVMPassphrase)
val, err := cmd.Flags().GetString(FlagEVMPassphrase)
if err != nil {
return "", changed, err
}
return val, changed, nil
}

// DefaultServicePath constructs the default Blobstream store path for
// the provided service.
// It tries to get the home directory from an environment variable
Expand All @@ -47,20 +64,217 @@ const (
FlagP2PListenAddress = "p2p.listen-addr"
FlagP2PNickname = "p2p.nickname"
FlagGRPCInsecure = "grpc.insecure"

FlagEVMAccAddress = "evm.account"
FlagEVMChainID = "evm.chain-id"
FlagEVMRPC = "evm.rpc"
FlagEVMGasLimit = "evm.gas-limit"
FlagEVMContractAddress = "evm.contract-address"

FlagCoreGRPC = "core.grpc"
FlagCoreRPC = "core.rpc"

FlagStartingNonce = "starting-nonce"
)
rach-id marked this conversation as resolved.
Show resolved Hide resolved

func AddStartingNonceFlag(cmd *cobra.Command) {
cmd.Flags().String(
FlagStartingNonce,
"latest",
"Specify the nonce to start the Blobstream contract from. "+
"\"earliest\": for genesis, "+
"\"latest\": for latest nonce, "+
"\"nonce\": for a specific nonce.",
)
}

func GetStartingNonceFlag(cmd *cobra.Command) (string, bool, error) {
changed := cmd.Flags().Changed(FlagStartingNonce)
val, err := cmd.Flags().GetString(FlagStartingNonce)
if err != nil {
return "", changed, err
}
return val, changed, nil
}

func AddP2PNicknameFlag(cmd *cobra.Command) {
cmd.Flags().String(FlagP2PNickname, "", "Nickname of the p2p private key to use (if not provided, an existing one from the p2p store or a newly generated one will be used)")
}

func GetP2PNicknameFlag(cmd *cobra.Command) (string, bool, error) {
changed := cmd.Flags().Changed(FlagP2PNickname)
val, err := cmd.Flags().GetString(FlagP2PNickname)
if err != nil {
return "", changed, err
}
return val, changed, nil
}

func AddP2PListenAddressFlag(cmd *cobra.Command) {
cmd.Flags().String(FlagP2PListenAddress, "/ip4/0.0.0.0/tcp/30000", "MultiAddr for the p2p peer to listen on")
}

func GetP2PListenAddressFlag(cmd *cobra.Command) (string, bool, error) {
changed := cmd.Flags().Changed(FlagP2PListenAddress)
val, err := cmd.Flags().GetString(FlagP2PListenAddress)
if err != nil {
return "", changed, err
}
return val, changed, nil
}

func AddBootstrappersFlag(cmd *cobra.Command) {
cmd.Flags().String(FlagBootstrappers, "", "Comma-separated multiaddresses of p2p peers to connect to")
}

func GetBootstrappersFlag(cmd *cobra.Command) (string, bool, error) {
changed := cmd.Flags().Changed(FlagBootstrappers)
val, err := cmd.Flags().GetString(FlagBootstrappers)
if err != nil {
return "", changed, err
}
return val, changed, nil
}

func AddGRPCInsecureFlag(cmd *cobra.Command) {
cmd.Flags().Bool(FlagGRPCInsecure, false, "allow gRPC over insecure channels, if not TLS the server must use TLS")
}

func GetGRPCInsecureFlag(cmd *cobra.Command) (bool, bool, error) {
changed := cmd.Flags().Changed(FlagGRPCInsecure)
val, err := cmd.Flags().GetBool(FlagGRPCInsecure)
if err != nil {
return false, changed, err
}
return val, changed, nil
}

func AddCoreGRPCFlag(cmd *cobra.Command) {
cmd.Flags().String(FlagCoreGRPC, "localhost:9090", "Specify the celestia app grpc address")
}

func GetCoreGRPCFlag(cmd *cobra.Command) (string, bool, error) {
changed := cmd.Flags().Changed(FlagCoreGRPC)
val, err := cmd.Flags().GetString(FlagCoreGRPC)
if err != nil {
return "", changed, err
}
return val, changed, nil
}

func AddEVMChainIDFlag(cmd *cobra.Command) {
cmd.Flags().Uint64(FlagEVMChainID, 5, "Specify the evm chain id")
}

func GetEVMChainIDFlag(cmd *cobra.Command) (uint64, bool, error) {
changed := cmd.Flags().Changed(FlagEVMChainID)
val, err := cmd.Flags().GetUint64(FlagEVMChainID)
if err != nil {
return 0, changed, err
}
return val, changed, nil
}

func AddCoreRPCFlag(cmd *cobra.Command) {
cmd.Flags().String(FlagCoreRPC, "tcp://localhost:26657", "Specify the celestia app rest rpc address")
}

func GetCoreRPCFlag(cmd *cobra.Command) (string, bool, error) {
changed := cmd.Flags().Changed(FlagCoreRPC)
val, err := cmd.Flags().GetString(FlagCoreRPC)
if err != nil {
return "", changed, err
}
return val, changed, nil
}

func AddEVMRPCFlag(cmd *cobra.Command) {
cmd.Flags().String(FlagEVMRPC, "http://localhost:8545", "Specify the ethereum rpc address")
}

func GetEVMRPCFlag(cmd *cobra.Command) (string, bool, error) {
changed := cmd.Flags().Changed(FlagEVMRPC)
val, err := cmd.Flags().GetString(FlagEVMRPC)
if err != nil {
return "", changed, err
}
return val, changed, nil
}

func AddEVMContractAddressFlag(cmd *cobra.Command) {
cmd.Flags().String(FlagEVMContractAddress, "", "Specify the contract at which the Blobstream is deployed")
}

func GetEVMContractAddressFlag(cmd *cobra.Command) (string, bool, error) {
changed := cmd.Flags().Changed(FlagEVMContractAddress)
val, err := cmd.Flags().GetString(FlagEVMContractAddress)
if err != nil {
return "", changed, err
}
return val, changed, nil
}

func AddEVMGasLimitFlag(cmd *cobra.Command) {
cmd.Flags().Uint64(FlagEVMGasLimit, evm.DefaultEVMGasLimit, "Specify the evm gas limit")
}

func GetEVMGasLimitFlag(cmd *cobra.Command) (uint64, bool, error) {
changed := cmd.Flags().Changed(FlagEVMGasLimit)
val, err := cmd.Flags().GetUint64(FlagEVMGasLimit)
if err != nil {
return 0, changed, err
}
return val, changed, nil
}

func AddHomeFlag(cmd *cobra.Command, serviceName string, defaultHomeDir string) {
cmd.Flags().String(FlagHome, defaultHomeDir, fmt.Sprintf("The Blobstream %s home directory", serviceName))
}

func GetHomeFlag(cmd *cobra.Command) (string, bool, error) {
changed := cmd.Flags().Changed(FlagHome)
val, err := cmd.Flags().GetString(FlagHome)
if err != nil {
return "", changed, err
}
return val, changed, nil
}

func GetHomeDirectory(cmd *cobra.Command, service string) (string, error) {
homeDir, changed, err := GetHomeFlag(cmd)
if err != nil {
return "", err
}
if changed && homeDir != "" {
return homeDir, nil
}
return DefaultServicePath(service)
}

func AddEVMAccAddressFlag(cmd *cobra.Command) {
cmd.Flags().String(FlagEVMAccAddress, "", "Specify the EVM account address to use for signing (Note: the private key should be in the keystore)")
}

func GetEVMAccAddressFlag(cmd *cobra.Command) (string, bool, error) {
changed := cmd.Flags().Changed(FlagEVMAccAddress)
val, err := cmd.Flags().GetString(FlagEVMAccAddress)
if err != nil {
return "", changed, err
}
return val, changed, nil
}

func ValidateEVMAddress(addr string) error {
if addr == "" {
return fmt.Errorf("the EVM address cannot be empty")
}
if !ethcmn.IsHexAddress(addr) {
return errors.New("valid EVM address is required")
}
return nil
}
rach-id marked this conversation as resolved.
Show resolved Hide resolved

// EnsureConfigPath creates a directory configPath if it does not exist
func EnsureConfigPath(configPath string) error {
return os.MkdirAll(configPath, os.ModePerm)
}
2 changes: 1 addition & 1 deletion cmd/blobstream/deploy/cmd.go
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
package deploy

Check failure on line 1 in cmd/blobstream/deploy/cmd.go

View workflow job for this annotation

GitHub Actions / lint / golangci-lint

: # github.com/celestiaorg/orchestrator-relayer/cmd/blobstream/deploy

import (
"context"
Expand Down Expand Up @@ -27,7 +27,7 @@
Use: "deploy <flags>",
Short: "Deploys the Blobstream contract and initializes it using the provided Celestia chain",
RunE: func(cmd *cobra.Command, args []string) error {
config, err := parseDeployFlags(cmd)
config, err := parseDeployFlags(cmd, &deployConfig{})

Check failure on line 30 in cmd/blobstream/deploy/cmd.go

View workflow job for this annotation

GitHub Actions / Analyze (go)

too many arguments in call to parseDeployFlags

Check failure on line 30 in cmd/blobstream/deploy/cmd.go

View workflow job for this annotation

GitHub Actions / lint / golangci-lint

too many arguments in call to parseDeployFlags

Check failure on line 30 in cmd/blobstream/deploy/cmd.go

View workflow job for this annotation

GitHub Actions / lint / golangci-lint

too many arguments in call to parseDeployFlags

Check failure on line 30 in cmd/blobstream/deploy/cmd.go

View workflow job for this annotation

GitHub Actions / test / test

too many arguments in call to parseDeployFlags

Check failure on line 30 in cmd/blobstream/deploy/cmd.go

View workflow job for this annotation

GitHub Actions / test / test-coverage

too many arguments in call to parseDeployFlags

Check failure on line 30 in cmd/blobstream/deploy/cmd.go

View workflow job for this annotation

GitHub Actions / test / test-race

too many arguments in call to parseDeployFlags
if err != nil {
return err
}
Expand Down
Loading
Loading