-
Notifications
You must be signed in to change notification settings - Fork 221
/
deploy.go
97 lines (80 loc) · 2.81 KB
/
deploy.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
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
package launch
import (
"context"
"fmt"
"github.com/samber/lo"
"github.com/superfly/flyctl/internal/appconfig"
"github.com/superfly/flyctl/internal/command/deploy"
"github.com/superfly/flyctl/internal/flag"
"github.com/superfly/flyctl/iostreams"
)
// firstDeploy performs the first deploy of an app.
// Note that this function checks and respects the --no-deploy flag, so it may not actually deploy.
func (state *launchState) firstDeploy(ctx context.Context) error {
// This function is only called if state.sourceInfo is not nil, so we don't need to do any checking.
io := iostreams.FromContext(ctx)
ctx = appconfig.WithName(ctx, state.Plan.AppName)
ctx = appconfig.WithConfig(ctx, state.appConfig)
// Notices from a launcher about its behavior that should always be displayed
if state.sourceInfo.Notice != "" {
fmt.Fprintln(io.Out, state.sourceInfo.Notice)
}
// TODO(Allison): Do we want to make the executive decision to just *always* deploy?
deployNow := true
// deployNow := false
// promptForDeploy := true
if state.sourceInfo.SkipDeploy || flag.GetBool(ctx, "no-deploy") {
deployNow = false
// promptForDeploy = false
}
if flag.GetBool(ctx, "now") {
deployNow = true
// promptForDeploy = false
}
/*
if promptForDeploy {
confirm, err := prompt.Confirm(ctx, "Would you like to deploy now?")
if confirm && err == nil {
deployNow = true
}
// Reload and validate the app config in case the user edited it before confirming
if deployNow {
path := appConfig.ConfigFilePath()
newCfg, err := appconfig.LoadConfig(path)
if err != nil {
return fmt.Errorf("failed to reload configuration file %state: %w", path, err)
}
if appConfig.ForMachines() {
if err := newCfg.SetMachinesPlatform(); err != nil {
return fmt.Errorf("failed to parse fly.toml, check the configuration format: %w", err)
}
}
appConfig = newCfg
}
}
*/
err, extraInfo := state.appConfig.Validate(ctx)
if extraInfo != "" {
fmt.Fprintf(io.ErrOut, extraInfo)
}
if err != nil {
return fmt.Errorf("invalid configuration file: %w", err)
}
if deployNow {
// We want to allow overriding HA, but otherwise we want to inherit HA from the plan.
if !flag.IsSpecified(ctx, "ha") {
// TODO(Ali): This is a hack to get launch v2 shipping. We probably want to pipe the HA flag through deploy properly.
if err := flag.SetString(ctx, "ha", lo.Ternary(state.Plan.HighAvailability, "true", "false")); err != nil {
return err
}
}
return deploy.DeployWithConfig(ctx, state.appConfig, flag.GetBool(ctx, "now"))
}
// Alternative deploy documentation if our standard deploy method is not correct
if state.sourceInfo.DeployDocs != "" {
fmt.Fprintln(io.Out, state.sourceInfo.DeployDocs)
} else {
fmt.Fprintln(io.Out, "Your app is ready! Deploy with `flyctl deploy`")
}
return nil
}