Skip to content

Commit fad4e83

Browse files
authored
Create network-endpoint-group-zonal.go
1 parent 99cde2c commit fad4e83

File tree

1 file changed

+147
-0
lines changed

1 file changed

+147
-0
lines changed
Lines changed: 147 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,147 @@
1+
package resources
2+
3+
import (
4+
"context"
5+
"errors"
6+
"fmt"
7+
"path"
8+
9+
"github.com/ekristen/gcp-nuke/pkg/nuke"
10+
liberror "github.com/ekristen/libnuke/pkg/errors"
11+
"github.com/ekristen/libnuke/pkg/registry"
12+
"github.com/ekristen/libnuke/pkg/resource"
13+
"github.com/ekristen/libnuke/pkg/types"
14+
"github.com/sirupsen/logrus"
15+
"google.golang.org/api/iterator"
16+
17+
compute "cloud.google.com/go/compute/apiv1"
18+
"cloud.google.com/go/compute/apiv1/computepb"
19+
)
20+
21+
const ZonalNetworkEndpointGroupResource = "ZonalNetworkEndpointGroup"
22+
23+
func init() {
24+
registry.Register(&registry.Registration{
25+
Name: ZonalNetworkEndpointGroupResource,
26+
Scope: nuke.Project,
27+
Lister: &ZonalNetworkEndpointGroupLister{},
28+
})
29+
}
30+
31+
type ZonalNetworkEndpointGroupLister struct {
32+
svc *compute.NetworkEndpointGroupsClient
33+
}
34+
35+
func (l *ZonalNetworkEndpointGroupLister) Close() {
36+
if l.svc != nil {
37+
l.svc.Close()
38+
}
39+
}
40+
41+
func (l *ZonalNetworkEndpointGroupLister) List(ctx context.Context, o interface{}) ([]resource.Resource, error) {
42+
var resources []resource.Resource
43+
44+
opts := o.(*nuke.ListerOpts)
45+
if err := opts.BeforeList(nuke.Global, "compute.googleapis.com"); err != nil {
46+
return resources, err
47+
}
48+
49+
if l.svc == nil {
50+
var err error
51+
l.svc, err = compute.NewNetworkEndpointGroupsRESTClient(ctx, opts.ClientOptions...)
52+
if err != nil {
53+
return nil, err
54+
}
55+
}
56+
57+
req := &computepb.AggregatedListNetworkEndpointGroupsRequest{
58+
Project: *opts.Project,
59+
}
60+
61+
it := l.svc.AggregatedList(ctx, req)
62+
for {
63+
resp, err := it.Next()
64+
if errors.Is(err, iterator.Done) {
65+
break
66+
}
67+
if err != nil {
68+
logrus.WithError(err).Error("unable to iterate network endpoint groups")
69+
break
70+
}
71+
72+
// resp is a NetworkEndpointGroupsScopedListPair which has Key (string) and Value (*computepb.NetworkEndpointGroupsScopedList)
73+
if resp.Value.NetworkEndpointGroups == nil {
74+
continue
75+
}
76+
77+
for _, neg := range resp.Value.NetworkEndpointGroups {
78+
zoneName := path.Base(resp.Key) // Extract zone name from the Key
79+
resources = append(resources, &ZonalNetworkEndpointGroup{
80+
svc: l.svc,
81+
project: opts.Project,
82+
zone: &zoneName,
83+
Name: neg.Name, // Assign directly since neg.Name is already *string
84+
negType: neg.NetworkEndpointType, // neg.NetworkEndpointType is already *string
85+
creationDate: neg.CreationTimestamp, // neg.CreationTimestamp is already *string
86+
})
87+
}
88+
}
89+
90+
return resources, nil
91+
}
92+
93+
type ZonalNetworkEndpointGroup struct {
94+
svc *compute.NetworkEndpointGroupsClient
95+
removeOp *compute.Operation
96+
project *string
97+
zone *string
98+
Name *string
99+
negType *string
100+
creationDate *string
101+
}
102+
103+
func (r *ZonalNetworkEndpointGroup) Remove(ctx context.Context) error {
104+
var err error
105+
r.removeOp, err = r.svc.Delete(ctx, &computepb.DeleteNetworkEndpointGroupRequest{
106+
Project: *r.project,
107+
Zone: *r.zone,
108+
NetworkEndpointGroup: *r.Name,
109+
})
110+
if err != nil {
111+
return err
112+
}
113+
114+
return r.HandleWait(ctx)
115+
}
116+
117+
func (r *ZonalNetworkEndpointGroup) Properties() types.Properties {
118+
return types.NewPropertiesFromStruct(r)
119+
}
120+
121+
func (r *ZonalNetworkEndpointGroup) String() string {
122+
return *r.Name
123+
}
124+
125+
// HandleWait is a hook into the libnuke resource lifecycle to allow for waiting on a resource to be removed.
126+
func (r *ZonalNetworkEndpointGroup) HandleWait(ctx context.Context) error {
127+
if r.removeOp == nil {
128+
return nil
129+
}
130+
131+
if err := r.removeOp.Poll(ctx); err != nil {
132+
logrus.WithError(err).Trace("network endpoint group remove op polling encountered error")
133+
return err
134+
}
135+
136+
if !r.removeOp.Done() {
137+
return liberror.ErrWaitResource("waiting for operation to complete")
138+
}
139+
140+
if r.removeOp.Done() && r.removeOp.Proto().GetError() != nil {
141+
removeErr := fmt.Errorf("delete error on '%s': %s", r.removeOp.Proto().GetTargetLink(), r.removeOp.Proto().GetHttpErrorMessage())
142+
logrus.WithError(removeErr).WithField("status_code", r.removeOp.Proto().GetError()).Error("unable to delete zonal network endpoint group")
143+
return removeErr
144+
}
145+
146+
return nil
147+
}

0 commit comments

Comments
 (0)