This repository has been archived by the owner on Mar 24, 2023. It is now read-only.
/
update.go
87 lines (68 loc) · 2.43 KB
/
update.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
package ship
import (
"context"
"github.com/go-kit/kit/log"
"github.com/go-kit/kit/log/level"
"github.com/pkg/errors"
"github.com/replicatedhq/ship/pkg/constants"
"github.com/replicatedhq/ship/pkg/lifecycle/daemon/daemontypes"
)
func (s *Ship) UpdateAndMaybeExit(ctx context.Context) error {
if err := s.Update(ctx); err != nil {
s.ExitWithError(err)
return err
}
return nil
}
func (s *Ship) Update(ctx context.Context) error {
debug := level.Debug(log.With(s.Logger, "method", "update"))
ctx, cancelFunc := context.WithCancel(ctx)
defer s.Shutdown(cancelFunc)
if err := s.maybeWriteStateFromFile(); err != nil {
return err
}
s.Viper.Set("rm-asset-dest", true)
s.Daemon.SetProgress(daemontypes.StringProgress("kustomize", `loading state`))
// does a state already exist
existingState, err := s.State.CachedState()
if err != nil {
return errors.Wrap(err, "load state")
}
uiPrintableStatePath := s.Viper.GetString("state-file")
if uiPrintableStatePath == "" {
uiPrintableStatePath = constants.StatePath
}
if existingState.IsEmpty() {
debug.Log("event", "state.missing")
return errors.Errorf(`No state file found at %s please run "ship init"`, uiPrintableStatePath)
}
s.State.UpdateVersion()
debug.Log("event", "read.upstream")
upstreamURL := existingState.Upstream()
if upstreamURL == "" {
return errors.Errorf(`No upstream URL found at %s, please run "ship init"`, uiPrintableStatePath)
}
p := s.Resolver.NewContentProcessor()
maybeVersionedUpstream, err := p.MaybeResolveVersionedUpstream(ctx, upstreamURL, existingState)
if err != nil {
return errors.New(`Unable to resolve versioned upstream ` + upstreamURL)
}
debug.Log("event", "fetch latest chart")
s.Daemon.SetProgress(daemontypes.StringProgress("kustomize", `Downloading latest from upstream `+maybeVersionedUpstream))
debug.Log("event", "reset steps completed")
if err := s.StateManager.ResetLifecycle(); err != nil {
return errors.Wrap(err, "reset state.json completed lifecycle")
}
release, err := s.Resolver.ResolveRelease(ctx, maybeVersionedUpstream)
if err != nil {
return errors.Wrapf(err, "resolve helm chart metadata for %s", maybeVersionedUpstream)
}
release.Spec.Lifecycle = s.IDPatcher.EnsureAllStepsHaveUniqueIDs(release.Spec.Lifecycle)
if err := s.execute(ctx, release, nil); err != nil {
return errors.Wrap(err, "execute")
}
if err := s.State.CommitState(); err != nil {
return errors.Wrap(err, "commit state")
}
return nil
}