2022-02-09 15:01:19 +01:00
|
|
|
package setup
|
|
|
|
|
|
|
|
import (
|
2022-03-23 09:02:39 +01:00
|
|
|
"context"
|
2022-02-09 15:01:19 +01:00
|
|
|
_ "embed"
|
|
|
|
|
|
|
|
"github.com/spf13/cobra"
|
2022-03-23 09:02:39 +01:00
|
|
|
"github.com/spf13/viper"
|
2022-04-27 01:01:45 +02:00
|
|
|
"github.com/zitadel/logging"
|
2022-03-23 09:02:39 +01:00
|
|
|
|
2022-06-27 12:32:34 +02:00
|
|
|
"github.com/zitadel/zitadel/cmd/key"
|
|
|
|
"github.com/zitadel/zitadel/cmd/tls"
|
2022-04-27 01:01:45 +02:00
|
|
|
"github.com/zitadel/zitadel/internal/database"
|
|
|
|
"github.com/zitadel/zitadel/internal/eventstore"
|
|
|
|
"github.com/zitadel/zitadel/internal/migration"
|
2022-03-23 09:02:39 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
|
|
|
//go:embed steps.yaml
|
|
|
|
defaultSteps []byte
|
2022-04-25 17:05:20 +02:00
|
|
|
stepFiles []string
|
2022-02-09 15:01:19 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
func New() *cobra.Command {
|
2022-04-25 17:05:20 +02:00
|
|
|
cmd := &cobra.Command{
|
2022-02-09 15:01:19 +01:00
|
|
|
Use: "setup",
|
|
|
|
Short: "setup ZITADEL instance",
|
|
|
|
Long: `sets up data to start ZITADEL.
|
|
|
|
Requirements:
|
|
|
|
- cockroachdb`,
|
2022-03-23 09:02:39 +01:00
|
|
|
Run: func(cmd *cobra.Command, args []string) {
|
2022-06-24 14:38:22 +02:00
|
|
|
err := tls.ModeFromFlag(cmd)
|
|
|
|
logging.OnError(err).Fatal("invalid tlsMode")
|
|
|
|
|
2022-03-28 10:05:09 +02:00
|
|
|
config := MustNewConfig(viper.GetViper())
|
|
|
|
steps := MustNewSteps(viper.New())
|
2022-03-23 09:02:39 +01:00
|
|
|
|
2022-04-12 16:20:17 +02:00
|
|
|
masterKey, err := key.MasterKey(cmd)
|
|
|
|
logging.OnError(err).Panic("No master key provided")
|
|
|
|
|
|
|
|
Setup(config, steps, masterKey)
|
2022-02-09 15:01:19 +01:00
|
|
|
},
|
|
|
|
}
|
2022-04-25 17:05:20 +02:00
|
|
|
|
|
|
|
Flags(cmd)
|
|
|
|
|
|
|
|
return cmd
|
|
|
|
}
|
|
|
|
|
|
|
|
func Flags(cmd *cobra.Command) {
|
|
|
|
cmd.PersistentFlags().StringArrayVar(&stepFiles, "steps", nil, "paths to step files to overwrite default steps")
|
|
|
|
key.AddMasterKeyFlag(cmd)
|
2022-06-24 14:38:22 +02:00
|
|
|
tls.AddTLSModeFlag(cmd)
|
2022-02-09 15:01:19 +01:00
|
|
|
}
|
2022-03-23 09:02:39 +01:00
|
|
|
|
2022-04-12 16:20:17 +02:00
|
|
|
func Setup(config *Config, steps *Steps, masterKey string) {
|
2022-03-23 09:02:39 +01:00
|
|
|
dbClient, err := database.Connect(config.Database)
|
|
|
|
logging.OnError(err).Fatal("unable to connect to database")
|
|
|
|
|
|
|
|
eventstoreClient, err := eventstore.Start(dbClient)
|
|
|
|
logging.OnError(err).Fatal("unable to start eventstore")
|
2022-03-28 10:05:09 +02:00
|
|
|
migration.RegisterMappers(eventstoreClient)
|
|
|
|
|
2022-04-06 08:13:40 +02:00
|
|
|
steps.s1ProjectionTable = &ProjectionTable{dbClient: dbClient}
|
|
|
|
steps.s2AssetsTable = &AssetTable{dbClient: dbClient}
|
2022-04-13 07:42:48 +02:00
|
|
|
|
2022-04-28 10:30:41 +02:00
|
|
|
steps.S3DefaultInstance.instanceSetup = config.DefaultInstance
|
|
|
|
steps.S3DefaultInstance.userEncryptionKey = config.EncryptionKeys.User
|
2022-05-13 14:13:07 +02:00
|
|
|
steps.S3DefaultInstance.smtpEncryptionKey = config.EncryptionKeys.SMTP
|
2022-04-28 10:30:41 +02:00
|
|
|
steps.S3DefaultInstance.masterKey = masterKey
|
2022-04-12 16:20:17 +02:00
|
|
|
steps.S3DefaultInstance.db = dbClient
|
2022-04-28 10:30:41 +02:00
|
|
|
steps.S3DefaultInstance.es = eventstoreClient
|
2022-04-12 16:20:17 +02:00
|
|
|
steps.S3DefaultInstance.defaults = config.SystemDefaults
|
|
|
|
steps.S3DefaultInstance.zitadelRoles = config.InternalAuthZ.RolePermissionMappings
|
2022-04-28 10:30:41 +02:00
|
|
|
steps.S3DefaultInstance.externalDomain = config.ExternalDomain
|
2022-04-21 12:37:39 +02:00
|
|
|
steps.S3DefaultInstance.externalSecure = config.ExternalSecure
|
2022-04-25 11:16:36 +02:00
|
|
|
steps.S3DefaultInstance.externalPort = config.ExternalPort
|
2022-03-23 09:02:39 +01:00
|
|
|
|
2022-03-28 10:05:09 +02:00
|
|
|
ctx := context.Background()
|
2022-04-21 12:37:39 +02:00
|
|
|
err = migration.Migrate(ctx, eventstoreClient, steps.s1ProjectionTable)
|
|
|
|
logging.OnError(err).Fatal("unable to migrate step 1")
|
|
|
|
err = migration.Migrate(ctx, eventstoreClient, steps.s2AssetsTable)
|
2022-04-28 10:30:41 +02:00
|
|
|
logging.OnError(err).Fatal("unable to migrate step 2")
|
2022-04-21 12:37:39 +02:00
|
|
|
err = migration.Migrate(ctx, eventstoreClient, steps.S3DefaultInstance)
|
2022-04-28 10:30:41 +02:00
|
|
|
logging.OnError(err).Fatal("unable to migrate step 3")
|
2022-03-23 09:02:39 +01:00
|
|
|
}
|
2022-04-25 17:05:20 +02:00
|
|
|
|
|
|
|
func initSteps(v *viper.Viper, files ...string) func() {
|
|
|
|
return func() {
|
|
|
|
for _, file := range files {
|
|
|
|
v.SetConfigFile(file)
|
|
|
|
err := v.MergeInConfig()
|
|
|
|
logging.WithFields("file", file).OnError(err).Warn("unable to read setup file")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|