84 lines
2.5 KiB
Go
84 lines
2.5 KiB
Go
package cmd
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
|
|
"git.faercol.me/faercol/polyculeconnect/polyculeconnect/cmd/utils"
|
|
"git.faercol.me/faercol/polyculeconnect/polyculeconnect/internal/db"
|
|
"git.faercol.me/faercol/polyculeconnect/polyculeconnect/internal/model"
|
|
"git.faercol.me/faercol/polyculeconnect/polyculeconnect/logger"
|
|
"github.com/google/uuid"
|
|
"github.com/spf13/cobra"
|
|
)
|
|
|
|
var (
|
|
backendID string
|
|
backendName string
|
|
backendIssuer string
|
|
backendClientID string
|
|
backendClientSecret string
|
|
)
|
|
|
|
var backendAddCmd = &cobra.Command{
|
|
Use: "add",
|
|
Short: "Add a new backend to the storage",
|
|
Long: `Add a new backend to the storage.
|
|
|
|
Parameters to provide:
|
|
- id: Unique ID to represent the backend in the storage
|
|
- name: Human readable name to represent the backend. It will be used by
|
|
the user in the authentication page to select a backend during
|
|
authentication
|
|
- issuer: Full hostname of the OIDC provider, e.g. 'https://github.com'
|
|
- client-id: OIDC Client ID for the backend
|
|
- client-secret OIDC Client secret for the backend`,
|
|
Run: func(cmd *cobra.Command, args []string) {
|
|
addNewBackend()
|
|
},
|
|
}
|
|
|
|
func addNewBackend() {
|
|
c := utils.InitConfig("")
|
|
logger.Init(c.LogLevel)
|
|
|
|
s, err := db.New(*c)
|
|
if err != nil {
|
|
utils.Failf("failed to init storage: %s", err.Error())
|
|
}
|
|
|
|
if backendClientID == "" {
|
|
utils.Fail("Empty client ID")
|
|
}
|
|
if backendClientSecret == "" {
|
|
utils.Fail("Empty client secret")
|
|
}
|
|
|
|
backendIDUUID := uuid.New()
|
|
|
|
backendConf := model.Backend{
|
|
ID: backendIDUUID,
|
|
Name: backendName,
|
|
Config: model.BackendOIDCConfig{
|
|
ClientID: backendClientID,
|
|
ClientSecret: backendClientSecret,
|
|
Issuer: backendIssuer,
|
|
RedirectURI: c.RedirectURI(),
|
|
},
|
|
}
|
|
if err := s.BackendStorage().AddBackend(context.Background(), &backendConf); err != nil {
|
|
utils.Failf("Failed to add new backend to storage: %s", err.Error())
|
|
}
|
|
|
|
fmt.Printf("New backend %s added.\n", backendName)
|
|
}
|
|
|
|
func init() {
|
|
backendCmd.AddCommand(backendAddCmd)
|
|
|
|
backendAddCmd.Flags().StringVarP(&backendID, "id", "i", "", "ID to identify the backend in the storage")
|
|
backendAddCmd.Flags().StringVarP(&backendName, "name", "n", "", "Name to represent the backend")
|
|
backendAddCmd.Flags().StringVarP(&backendIssuer, "issuer", "d", "", "Full hostname of the backend")
|
|
backendAddCmd.Flags().StringVarP(&backendClientID, "client-id", "", "", "OIDC Client ID for the backend")
|
|
backendAddCmd.Flags().StringVarP(&backendClientSecret, "client-secret", "", "", "OIDC Client secret for the backend")
|
|
}
|