-
Notifications
You must be signed in to change notification settings - Fork 221
/
import.go
54 lines (44 loc) · 1.2 KB
/
import.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
package secrets
import (
"context"
"errors"
"fmt"
"os"
"github.com/spf13/cobra"
"github.com/superfly/flyctl/client"
"github.com/superfly/flyctl/internal/appconfig"
"github.com/superfly/flyctl/internal/command"
"github.com/superfly/flyctl/internal/flag"
)
func newImport() (cmd *cobra.Command) {
const (
long = `Set one or more encrypted secrets for an application. Values are read from stdin as NAME=VALUE pairs`
short = `Set secrets as NAME=VALUE pairs from stdin`
usage = "import [flags]"
)
cmd = command.New(usage, short, long, runImport, command.RequireSession, command.RequireAppName)
flag.Add(cmd,
sharedFlags,
)
return cmd
}
func runImport(ctx context.Context) (err error) {
client := client.FromContext(ctx).API()
appName := appconfig.NameFromContext(ctx)
app, err := client.GetAppCompact(ctx, appName)
if err != nil {
return
}
secrets, err := parseSecrets(os.Stdin)
if err != nil {
return fmt.Errorf("Failed to parse secrets from stdin: %w", err)
}
if len(secrets) < 1 {
return errors.New("requires at least one SECRET=VALUE pair")
}
release, err := client.SetSecrets(ctx, appName, secrets)
if err != nil {
return err
}
return deployForSecrets(ctx, app, release)
}