/
operation_waiter.go
53 lines (41 loc) · 1.18 KB
/
operation_waiter.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
package container
import (
"fmt"
"github.com/genevieve/leftovers/gcp/common"
gcpcontainer "google.golang.org/api/container/v1"
)
type operationWaiter struct {
op *gcpcontainer.Operation
service *gcpcontainer.ProjectsZonesService
project string
logger logger
}
func NewOperationWaiter(op *gcpcontainer.Operation, service *gcpcontainer.Service, project string, logger logger) operationWaiter {
return operationWaiter{
op: op,
service: service.Projects.Zones,
project: project,
logger: logger,
}
}
func (w *operationWaiter) Wait() error {
state := common.NewState(w.logger, w.refreshFunc())
raw, err := state.Wait()
if err != nil {
return fmt.Errorf("Waiting for operation to complete: %s", err)
}
result, ok := raw.(*gcpcontainer.Operation)
if ok && result.Status != "DONE" {
return fmt.Errorf("Operation error: %s", result.Status)
}
return nil
}
func (c *operationWaiter) refreshFunc() common.StateRefreshFunc {
return func() (interface{}, string, error) {
op, err := c.service.Operations.Get(c.project, c.op.Zone, c.op.Name).Do()
if err != nil {
return nil, "", fmt.Errorf("Refreshing operation request: %s", err)
}
return op, op.Status, nil
}
}