Skip to content

Commit

Permalink
(maint) Common CLI and config implementation for engine hosts
Browse files Browse the repository at this point in the history
  • Loading branch information
tphoney committed Oct 29, 2024
1 parent 44d13fa commit 6ae40c0
Show file tree
Hide file tree
Showing 2 changed files with 16 additions and 50 deletions.
52 changes: 14 additions & 38 deletions cmd/root.go
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,6 @@ import (
"time"

"github.com/getsentry/sentry-go"
"github.com/google/uuid"
"github.com/nats-io/jwt/v2"
"github.com/nats-io/nkeys"
"github.com/overmindtech/aws-source/proc"
Expand Down Expand Up @@ -48,20 +47,14 @@ var rootCmd = &cobra.Command{
panic(err)
}
}()

var err error

// Get srcman supplied config
natsServers := viper.GetStringSlice("nats-servers")
natsJWT := viper.GetString("nats-jwt")
natsNKeySeed := viper.GetString("nats-nkey-seed")
maxParallel := viper.GetInt("max-parallel")
apiKey := viper.GetString("api-key")
app := viper.GetString("app")
healthCheckPort := viper.GetInt("health-check-port")
natsConnectionName := viper.GetString("nats-connection-name")
sourceName := viper.GetString("source-name")
sourceUUIDString := viper.GetString("source-uuid")

awsAuthConfig := proc.AwsAuthConfig{
Strategy: viper.GetString("aws-access-strategy"),
Expand All @@ -73,7 +66,7 @@ var rootCmd = &cobra.Command{
AutoConfig: viper.GetBool("auto-config"),
}

err = viper.UnmarshalKey("aws-regions", &awsAuthConfig.Regions)
err := viper.UnmarshalKey("aws-regions", &awsAuthConfig.Regions)
if err != nil {
log.WithError(err).Fatal("Could not parse aws-regions")
}
Expand All @@ -83,12 +76,17 @@ var rootCmd = &cobra.Command{
natsNKeySeedLog = "[REDACTED]"
}

engineConfig, err := discovery.EngineConfigFromViper("aws", tracing.ServiceVersion)
if err != nil {
log.WithError(err).Fatal("Could not create engine config")
}

log.WithFields(log.Fields{
"nats-servers": natsServers,
"nats-jwt": natsJWT,
"nats-nkey-seed": natsNKeySeedLog,
"nats-connection-name": natsConnectionName,
"max-parallel": maxParallel,
"max-parallel": engineConfig.MaxParallelExecutions,
"aws-regions": awsAuthConfig.Regions,
"aws-access-strategy": awsAuthConfig.Strategy,
"aws-external-id": awsAuthConfig.ExternalID,
Expand All @@ -97,21 +95,10 @@ var rootCmd = &cobra.Command{
"auto-config": awsAuthConfig.AutoConfig,
"health-check-port": healthCheckPort,
"app": app,
"source-name": sourceName,
"source-uuid": sourceUUIDString,
"source-name": engineConfig.SourceName,
"source-uuid": engineConfig.SourceUUID,
}).Info("Got config")

var sourceUUID uuid.UUID
if sourceUUIDString == "" {
sourceUUID = uuid.New()
} else {
sourceUUID, err = uuid.Parse(sourceUUIDString)

if err != nil {
log.WithError(err).Fatal("Could not parse source UUID")
}
}

// Determine the required Overmind URLs
ctx, cancel := context.WithTimeout(context.Background(), 10*time.Second)
defer cancel()
Expand Down Expand Up @@ -179,14 +166,12 @@ var rootCmd = &cobra.Command{
log.WithError(err).Fatal("Could not create AWS configs")
}

// Initialize the engine
e, err := proc.InitializeAwsSourceEngine(
rateLimitContext,
sourceName,
tracing.ServiceVersion,
sourceUUID,
engineConfig,
natsOptions,
heartbeatOptions,
maxParallel,
999_999, // Very high max retries as it'll time out after 15min anyway
configs...,
)
Expand Down Expand Up @@ -284,6 +269,9 @@ func init() {
log.WithError(err).Fatal("Could not determine hostname for use in NATS connection name and source name")
}

// add engine flags
discovery.AddEngineFlags(rootCmd)

// General config options
rootCmd.PersistentFlags().StringVar(&cfgFile, "config", "/etc/srcman/config/source.yaml", "config file path")
rootCmd.PersistentFlags().StringVar(&logLevel, "log", "info", "Set the log level. Valid values: panic, fatal, error, warn, info, debug, trace")
Expand All @@ -295,16 +283,6 @@ func init() {
rootCmd.PersistentFlags().String("nats-nkey-seed", "", "The NKey seed which corresponds to the NATS JWT e.g. SUAFK6QUC...")
rootCmd.PersistentFlags().String("nats-connection-name", hostname, "The name that the source should use to connect to NATS")

rootCmd.PersistentFlags().String("api-key", "", "The API key to use to authenticate to the Overmind API")
// Support API Keys in the environment
err = viper.BindEnv("api-key", "OVM_API_KEY", "API_KEY")
if err != nil {
log.WithError(err).Fatal("could not bind api key to env")
}

rootCmd.PersistentFlags().String("app", "https://app.overmind.tech", "The URL of the Overmind app to use")
rootCmd.PersistentFlags().Int("max-parallel", 2_000, "Max number of requests to run in parallel")

// Custom flags for this source
rootCmd.PersistentFlags().String("aws-access-strategy", "defaults", "The strategy to use to access this customer's AWS account. Valid values: 'access-key', 'external-id', 'sso-profile', 'defaults'. Default: 'defaults'.")
rootCmd.PersistentFlags().String("aws-access-key-id", "", "The ID of the access key to use")
Expand All @@ -315,8 +293,6 @@ func init() {
rootCmd.PersistentFlags().String("aws-regions", "", "Comma-separated list of AWS regions that this source should operate in")
rootCmd.PersistentFlags().BoolP("auto-config", "a", false, "Use the local AWS config, the same as the AWS CLI could use. This can be set up with \"aws configure\"")
rootCmd.PersistentFlags().IntP("health-check-port", "", 8080, "The port that the health check should run on")
rootCmd.PersistentFlags().String("source-name", fmt.Sprintf("aws-source-%v", hostname), "The name of the source")
rootCmd.PersistentFlags().String("source-uuid", "", "The UUID of the source, is this is blank it will be auto-generated. This is used in heartbeats and shouldn't be supplied usually")

// tracing
rootCmd.PersistentFlags().String("honeycomb-api-key", "", "If specified, configures opentelemetry libraries to submit traces to honeycomb")
Expand Down
14 changes: 2 additions & 12 deletions proc/proc.go
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,6 @@ import (
awssns "github.com/aws/aws-sdk-go-v2/service/sns"
awssqs "github.com/aws/aws-sdk-go-v2/service/sqs"
"github.com/cenkalti/backoff/v4"
"github.com/google/uuid"
"github.com/sourcegraph/conc/pool"

"github.com/aws/aws-sdk-go-v2/aws"
Expand Down Expand Up @@ -198,8 +197,8 @@ func CreateAWSConfigs(awsAuthConfig AwsAuthConfig) ([]aws.Config, error) {
// engine, and an error if any. The context provided will be used for the rate
// limit buckets and should not be cancelled until the source is shut down. AWS
// configs should be provided for each region that is enabled
func InitializeAwsSourceEngine(ctx context.Context, name string, version string, engineUUID uuid.UUID, natsOptions auth.NATSOptions, heartbeatOptions *discovery.HeartbeatOptions, maxParallel int, maxRetries uint64, configs ...aws.Config) (*discovery.Engine, error) {
e, err := discovery.NewEngine()
func InitializeAwsSourceEngine(ctx context.Context, ec *discovery.EngineConfig, natsOptions auth.NATSOptions, heartbeatOptions *discovery.HeartbeatOptions, maxRetries uint64, configs ...aws.Config) (*discovery.Engine, error) {

Check failure on line 200 in proc/proc.go

View workflow job for this annotation

GitHub Actions / Test

undefined: discovery.EngineConfig
e, err := discovery.NewEngine(ec)

Check failure on line 201 in proc/proc.go

View workflow job for this annotation

GitHub Actions / Test

too many arguments in call to discovery.NewEngine
if err != nil {
return nil, fmt.Errorf("error initializing Engine: %w", err)
}
Expand All @@ -215,22 +214,13 @@ func InitializeAwsSourceEngine(ctx context.Context, name string, version string,
e.HeartbeatOptions = heartbeatOptions
}

e.Name = "aws-source"
e.NATSOptions = &natsOptions
e.MaxParallelExecutions = maxParallel
e.Version = version
e.Name = name
e.UUID = engineUUID
e.Type = "aws"

e.StartSendingHeartbeats(ctx)

if len(configs) == 0 {
return nil, errors.New("No configs specified")
}

var globalDone atomic.Bool

var b backoff.BackOff
b = backoff.NewExponentialBackOff(
backoff.WithMaxInterval(30*time.Second),
Expand Down

0 comments on commit 6ae40c0

Please sign in to comment.