// Copyright © 2022 Weald Technology Trading. // 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 validatorcredentialsget import ( "context" "time" eth2client "github.com/attestantio/go-eth2-client" apiv1 "github.com/attestantio/go-eth2-client/api/v1" "github.com/pkg/errors" "github.com/spf13/viper" ) type command struct { quiet bool verbose bool debug bool // Input. validator string // Beacon node connection. timeout time.Duration connection string allowInsecureConnections bool // Data access. consensusClient eth2client.Service validatorsProvider eth2client.ValidatorsProvider // Output. validatorInfo *apiv1.Validator } func newCommand(_ context.Context) (*command, error) { c := &command{ quiet: viper.GetBool("quiet"), verbose: viper.GetBool("verbose"), debug: viper.GetBool("debug"), } // Timeout. if viper.GetDuration("timeout") == 0 { return nil, errors.New("timeout is required") } c.timeout = viper.GetDuration("timeout") c.connection = viper.GetString("connection") c.allowInsecureConnections = viper.GetBool("allow-insecure-connections") if viper.GetString("validator") == "" { return nil, errors.New("validator is required") } c.validator = viper.GetString("validator") return c, nil }