cmd

package
v0.0.0-...-ec1afac Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Jun 28, 2024 License: AGPL-3.0 Imports: 17 Imported by: 0

Documentation

Overview

Copyright © 2023 NAME HERE <EMAIL ADDRESS>

Index

Constants

This section is empty.

Variables

View Source
var AgentCmd = &cobra.Command{
	Use:   "agent",
	Short: "A brief description of your command",

	Run: func(cmd *cobra.Command, args []string) {
		if envFile != "" {

			err := godotenv.Load(envFile)
			if err != nil {
				log.Fatal("Error loading .env file")
			}
		}

		e := env.Env{
			ErrorHandler: func(err error) {
				log.Fatalf("unable to load environment variable: %s", err.Error())
			},
		}

		logConfig := &logging.Config{
			Debug:  e.Bool("DEBUG", false),
			Writer: []io.Writer{},
		}
		axiomToken := e.String("AXIOM_TOKEN", "")
		axiomOrgId := e.String("AXIOM_ORG_ID", "")
		if axiomToken != "" && axiomOrgId != "" {
			axiomWriter, err := logging.NewAxiomWriter(logging.AxiomWriterConfig{
				AxiomToken: axiomToken,
				AxiomOrgId: axiomOrgId,
			})
			if err != nil {
				log.Fatalf("unable to create axiom writer: %s", err)
			}
			logConfig.Writer = append(logConfig.Writer, axiomWriter)
		}

		logger := logging.New(logConfig)

		storage, err := storage.NewS3(storage.S3Config{
			S3URL:             e.String("S3_URL"),
			S3Bucket:          e.String("S3_BUCKET"),
			S3AccessKeyId:     e.String("S3_ACCESS_KEY_ID"),
			S3AccessKeySecret: e.String("S3_ACCESS_KEY_SECRET"),
			Logger:            logger,
		})
		if err != nil {
			logger.Fatal().Err(err).Msg("failed to create storage")
		}

		masterKeys := e.Strings("VAULT_MASTER_KEYS")

		vault, err := service.New(service.Config{
			Logger:     logger,
			Storage:    storage,
			MasterKeys: masterKeys,
		})
		if err != nil {
			logger.Fatal().Err(err).Msg("failed to create service")
		}

		if len(masterKeys) > 1 {
			go func() {

				time.Sleep(5 * time.Minute)
				logger.Info().Msg("multiple master keys detected, rolling DEKs")
				err := vault.RollDeks(context.Background())
				if err != nil {
					logger.Err(err).Msg("failed to roll deks")
				}
				logger.Info().Msg("DEKs rolled")
			}()
		}

		srv, err := connect.New(connect.Config{Logger: logger, Service: vault})
		if err != nil {
			logger.Fatal().Err(err).Msg("failed to create service")
		}

		heartbeatUrl := e.String("HEARTBEAT_URL", "")
		if heartbeatUrl != "" {
			h := heartbeat.New(heartbeat.Config{
				Url:    heartbeatUrl,
				Logger: logger,
			})
			go h.Run()
		}

		err = srv.Listen(fmt.Sprintf(":%s", e.String("PORT", "8080")))
		if err != nil {
			logger.Fatal().Err(err).Msg("failed to listen")
		}

		cShutdown := make(chan os.Signal, 1)
		signal.Notify(cShutdown, os.Interrupt, syscall.SIGTERM)

		<-cShutdown

	},
}

AgentCmd represents the agent command

View Source
var GenerateKEK = &cobra.Command{
	Use:   "generate-kek",
	Short: "Generate and print a new master key",

	RunE: func(cmd *cobra.Command, args []string) error {
		kek, key, err := keys.GenerateMasterKey()
		if err != nil {
			return fmt.Errorf("failed to generate master key: %w", err)
		}

		fmt.Printf("Key ID  : %s\n", kek.Id)
		fmt.Printf("Created : %v\n", time.UnixMilli(kek.CreatedAt))
		fmt.Printf("Secret  : %s\n", key)
		return nil
	},
}

AgentCmd represents the agent command

Functions

func Execute

func Execute()

Execute adds all child commands to the root command and sets flags appropriately. This is called by main.main(). It only needs to happen once to the rootCmd.

Types

This section is empty.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL