2014-06-26 19:05:21 -05:00
|
|
|
package command
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
2014-06-27 00:01:05 -05:00
|
|
|
"sync"
|
2014-06-26 19:05:21 -05:00
|
|
|
|
|
|
|
"github.com/hashicorp/terraform/terraform"
|
|
|
|
"github.com/mitchellh/cli"
|
|
|
|
)
|
|
|
|
|
|
|
|
type UiHook struct {
|
|
|
|
terraform.NilHook
|
|
|
|
|
|
|
|
Ui cli.Ui
|
2014-06-27 00:01:05 -05:00
|
|
|
|
|
|
|
once sync.Once
|
|
|
|
ui cli.Ui
|
2014-06-26 19:05:21 -05:00
|
|
|
}
|
|
|
|
|
2014-06-27 00:11:04 -05:00
|
|
|
func (h *UiHook) PreApply(
|
|
|
|
id string,
|
|
|
|
s *terraform.ResourceState,
|
|
|
|
d *terraform.ResourceDiff) (terraform.HookAction, error) {
|
|
|
|
h.once.Do(h.init)
|
|
|
|
|
|
|
|
h.ui.Output(fmt.Sprintf("%s: Applying...", id))
|
|
|
|
return terraform.HookActionContinue, nil
|
|
|
|
}
|
|
|
|
|
2014-06-26 19:18:46 -05:00
|
|
|
func (h *UiHook) PreDiff(
|
|
|
|
id string, s *terraform.ResourceState) (terraform.HookAction, error) {
|
2014-06-27 00:01:05 -05:00
|
|
|
h.once.Do(h.init)
|
|
|
|
|
|
|
|
h.ui.Output(fmt.Sprintf("%s: Calculating diff", id))
|
2014-06-26 19:18:46 -05:00
|
|
|
return terraform.HookActionContinue, nil
|
|
|
|
}
|
|
|
|
|
2014-06-26 19:05:21 -05:00
|
|
|
func (h *UiHook) PreRefresh(
|
|
|
|
id string, s *terraform.ResourceState) (terraform.HookAction, error) {
|
2014-06-27 00:01:05 -05:00
|
|
|
h.once.Do(h.init)
|
|
|
|
|
|
|
|
h.ui.Output(fmt.Sprintf("%s: Refreshing state (ID: %s)", id, s.ID))
|
2014-06-26 19:05:21 -05:00
|
|
|
return terraform.HookActionContinue, nil
|
|
|
|
}
|
2014-06-27 00:01:05 -05:00
|
|
|
|
|
|
|
func (h *UiHook) init() {
|
|
|
|
// Wrap the ui so that it is safe for concurrency regardless of the
|
|
|
|
// underlying reader/writer that is in place.
|
|
|
|
h.ui = &cli.ConcurrentUi{Ui: h.Ui}
|
|
|
|
}
|