]> git.immae.eu Git - github/fretlink/terraform-provider-statuscake.git/blame - vendor/github.com/hashicorp/terraform/terraform/hook_stop.go
Upgrade to 0.12
[github/fretlink/terraform-provider-statuscake.git] / vendor / github.com / hashicorp / terraform / terraform / hook_stop.go
CommitLineData
bae9f6d2
JC
1package terraform
2
3import (
4 "sync/atomic"
107c1cdb
ND
5
6 "github.com/zclconf/go-cty/cty"
7
8 "github.com/hashicorp/terraform/addrs"
9 "github.com/hashicorp/terraform/plans"
10 "github.com/hashicorp/terraform/providers"
11 "github.com/hashicorp/terraform/states"
bae9f6d2
JC
12)
13
14// stopHook is a private Hook implementation that Terraform uses to
15// signal when to stop or cancel actions.
16type stopHook struct {
17 stop uint32
18}
19
107c1cdb
ND
20var _ Hook = (*stopHook)(nil)
21
22func (h *stopHook) PreApply(addr addrs.AbsResourceInstance, gen states.Generation, action plans.Action, priorState, plannedNewState cty.Value) (HookAction, error) {
bae9f6d2
JC
23 return h.hook()
24}
25
107c1cdb 26func (h *stopHook) PostApply(addr addrs.AbsResourceInstance, gen states.Generation, newState cty.Value, err error) (HookAction, error) {
bae9f6d2
JC
27 return h.hook()
28}
29
107c1cdb 30func (h *stopHook) PreDiff(addr addrs.AbsResourceInstance, gen states.Generation, priorState, proposedNewState cty.Value) (HookAction, error) {
bae9f6d2
JC
31 return h.hook()
32}
33
107c1cdb 34func (h *stopHook) PostDiff(addr addrs.AbsResourceInstance, gen states.Generation, action plans.Action, priorState, plannedNewState cty.Value) (HookAction, error) {
bae9f6d2
JC
35 return h.hook()
36}
37
107c1cdb 38func (h *stopHook) PreProvisionInstance(addr addrs.AbsResourceInstance, state cty.Value) (HookAction, error) {
bae9f6d2
JC
39 return h.hook()
40}
41
107c1cdb 42func (h *stopHook) PostProvisionInstance(addr addrs.AbsResourceInstance, state cty.Value) (HookAction, error) {
bae9f6d2
JC
43 return h.hook()
44}
45
107c1cdb 46func (h *stopHook) PreProvisionInstanceStep(addr addrs.AbsResourceInstance, typeName string) (HookAction, error) {
bae9f6d2
JC
47 return h.hook()
48}
49
107c1cdb 50func (h *stopHook) PostProvisionInstanceStep(addr addrs.AbsResourceInstance, typeName string, err error) (HookAction, error) {
bae9f6d2
JC
51 return h.hook()
52}
53
107c1cdb 54func (h *stopHook) ProvisionOutput(addr addrs.AbsResourceInstance, typeName string, line string) {
bae9f6d2
JC
55}
56
107c1cdb 57func (h *stopHook) PreRefresh(addr addrs.AbsResourceInstance, gen states.Generation, priorState cty.Value) (HookAction, error) {
bae9f6d2
JC
58 return h.hook()
59}
60
107c1cdb 61func (h *stopHook) PostRefresh(addr addrs.AbsResourceInstance, gen states.Generation, priorState cty.Value, newState cty.Value) (HookAction, error) {
bae9f6d2
JC
62 return h.hook()
63}
64
107c1cdb 65func (h *stopHook) PreImportState(addr addrs.AbsResourceInstance, importID string) (HookAction, error) {
bae9f6d2
JC
66 return h.hook()
67}
68
107c1cdb 69func (h *stopHook) PostImportState(addr addrs.AbsResourceInstance, imported []providers.ImportedResource) (HookAction, error) {
bae9f6d2
JC
70 return h.hook()
71}
72
107c1cdb 73func (h *stopHook) PostStateUpdate(new *states.State) (HookAction, error) {
bae9f6d2
JC
74 return h.hook()
75}
76
77func (h *stopHook) hook() (HookAction, error) {
78 if h.Stopped() {
107c1cdb
ND
79 // FIXME: This should really return an error since stopping partway
80 // through is not a successful run-to-completion, but we'll need to
81 // introduce that cautiously since existing automation solutions may
82 // be depending on this behavior.
bae9f6d2
JC
83 return HookActionHalt, nil
84 }
85
86 return HookActionContinue, nil
87}
88
89// reset should be called within the lock context
90func (h *stopHook) Reset() {
91 atomic.StoreUint32(&h.stop, 0)
92}
93
94func (h *stopHook) Stop() {
95 atomic.StoreUint32(&h.stop, 1)
96}
97
98func (h *stopHook) Stopped() bool {
99 return atomic.LoadUint32(&h.stop) == 1
100}