Skip to content

Commit

Permalink
fix(iot-twin-maker): limit to the supported regions
Browse files Browse the repository at this point in the history
  • Loading branch information
ekristen committed Dec 8, 2024
1 parent e3ce7cd commit 564c66a
Show file tree
Hide file tree
Showing 6 changed files with 67 additions and 10 deletions.
10 changes: 8 additions & 2 deletions resources/iottwinmaker-component-type.go
Original file line number Diff line number Diff line change
Expand Up @@ -26,13 +26,19 @@ func init() {
})
}

type IoTTwinMakerComponentTypeLister struct{}
type IoTTwinMakerComponentTypeLister struct {
IoTTwinMaker
}

func (l *IoTTwinMakerComponentTypeLister) List(_ context.Context, o interface{}) ([]resource.Resource, error) {
opts := o.(*nuke.ListerOpts)
resources := make([]resource.Resource, 0)

if !l.IsSupportedRegion(opts.Region.Name) {
return resources, nil
}

svc := iottwinmaker.New(opts.Session)
resources := make([]resource.Resource, 0)

// Require to have workspaces identifiers to query components
workspaceListResponse, err := ListWorkspacesComponentType(svc)
Expand Down
10 changes: 8 additions & 2 deletions resources/iottwinmaker-entity.go
Original file line number Diff line number Diff line change
Expand Up @@ -24,13 +24,19 @@ func init() {
})
}

type IoTTwinMakerEntityLister struct{}
type IoTTwinMakerEntityLister struct {
IoTTwinMaker
}

func (l *IoTTwinMakerEntityLister) List(_ context.Context, o interface{}) ([]resource.Resource, error) {
opts := o.(*nuke.ListerOpts)
resources := make([]resource.Resource, 0)

if !l.IsSupportedRegion(opts.Region.Name) {
return resources, nil
}

svc := iottwinmaker.New(opts.Session)
resources := make([]resource.Resource, 0)

// Require to have workspaces identifiers to query entities
workspaceListResponse, err := ListWorkspacesEntities(svc)
Expand Down
10 changes: 8 additions & 2 deletions resources/iottwinmaker-scene.go
Original file line number Diff line number Diff line change
Expand Up @@ -24,13 +24,19 @@ func init() {
})
}

type IoTTwinMakerSceneLister struct{}
type IoTTwinMakerSceneLister struct {
IoTTwinMaker
}

func (l *IoTTwinMakerSceneLister) List(_ context.Context, o interface{}) ([]resource.Resource, error) {
opts := o.(*nuke.ListerOpts)
resources := make([]resource.Resource, 0)

if !l.IsSupportedRegion(opts.Region.Name) {
return resources, nil
}

svc := iottwinmaker.New(opts.Session)
resources := make([]resource.Resource, 0)

// Require to have workspaces identifiers to query scenes
workspaceListResponse, err := ListWorkspacesScene(svc)
Expand Down
10 changes: 8 additions & 2 deletions resources/iottwinmaker-sync-job.go
Original file line number Diff line number Diff line change
Expand Up @@ -24,13 +24,19 @@ func init() {
})
}

type IoTTwinMakerSyncJobLister struct{}
type IoTTwinMakerSyncJobLister struct {
IoTTwinMaker
}

func (l *IoTTwinMakerSyncJobLister) List(_ context.Context, o interface{}) ([]resource.Resource, error) {
opts := o.(*nuke.ListerOpts)
resources := make([]resource.Resource, 0)

if !l.IsSupportedRegion(opts.Region.Name) {
return resources, nil
}

svc := iottwinmaker.New(opts.Session)
resources := make([]resource.Resource, 0)

// Require to have workspaces identifiers to query sync jobs
workspaceListResponse, err := ListWorkspacesSyncJob(svc)
Expand Down
10 changes: 8 additions & 2 deletions resources/iottwinmaker-workspace.go
Original file line number Diff line number Diff line change
Expand Up @@ -30,13 +30,19 @@ func init() {
})
}

type IoTTwinMakerWorkspaceLister struct{}
type IoTTwinMakerWorkspaceLister struct {
IoTTwinMaker
}

func (l *IoTTwinMakerWorkspaceLister) List(_ context.Context, o interface{}) ([]resource.Resource, error) {
opts := o.(*nuke.ListerOpts)
resources := make([]resource.Resource, 0)

if !l.IsSupportedRegion(opts.Region.Name) {
return resources, nil
}

svc := iottwinmaker.New(opts.Session)
resources := make([]resource.Resource, 0)

params := &iottwinmaker.ListWorkspacesInput{
MaxResults: aws.Int64(25),
Expand Down
27 changes: 27 additions & 0 deletions resources/iottwinmaker.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
package resources

import "slices"

type IoTTwinMaker struct{}

func (i *IoTTwinMaker) IsSupportedRegion(region string) bool {
// ref: https://docs.aws.amazon.com/general/latest/gr/iot-twinmaker.html
supportedRegions := []string{
"us-east-1",
"us-west-2",
"ap-south-1",
"ap-northeast-2",
"ap-southeast-1",
"ap-southeast-2",
"ap-northeast-1",
"eu-central-1",
"eu-west-1",
"us-gov-west-1",
}

if slices.Contains(supportedRegions, region) {

Check failure on line 22 in resources/iottwinmaker.go

View workflow job for this annotation

GitHub Actions / golangci-lint

S1008: should use 'return slices.Contains(supportedRegions, region)' instead of 'if slices.Contains(supportedRegions, region) { return true }; return false' (gosimple)
return true
}

return false
}

0 comments on commit 564c66a

Please sign in to comment.