Skip to content

Commit

Permalink
Add SageMaker studio resources (#612)
Browse files Browse the repository at this point in the history
* Add SageMaker studio resources

* Add properties function to SageMakerDomain

* Add filter to SageMakerApp

* Rename domainId -> domainID
  • Loading branch information
kurtmc committed Mar 29, 2021
1 parent 6aefe9b commit d9185e9
Show file tree
Hide file tree
Showing 3 changed files with 229 additions and 0 deletions.
90 changes: 90 additions & 0 deletions resources/sagemaker-apps.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,90 @@
package resources

import (
"fmt"

"github.com/aws/aws-sdk-go/aws"
"github.com/aws/aws-sdk-go/aws/session"
"github.com/aws/aws-sdk-go/service/sagemaker"
"github.com/rebuy-de/aws-nuke/pkg/types"
)

type SageMakerApp struct {
svc *sagemaker.SageMaker
domainID *string
appName *string
appType *string
userProfileName *string
status *string
}

func init() {
register("SageMakerApp", ListSageMakerApps)
}

func ListSageMakerApps(sess *session.Session) ([]Resource, error) {
svc := sagemaker.New(sess)
resources := []Resource{}

params := &sagemaker.ListAppsInput{
MaxResults: aws.Int64(30),
}

for {
resp, err := svc.ListApps(params)
if err != nil {
return nil, err
}

for _, app := range resp.Apps {
resources = append(resources, &SageMakerApp{
svc: svc,
domainID: app.DomainId,
appName: app.AppName,
appType: app.AppType,
userProfileName: app.UserProfileName,
status: app.Status,
})
}

if resp.NextToken == nil {
break
}

params.NextToken = resp.NextToken
}

return resources, nil
}

func (f *SageMakerApp) Remove() error {
_, err := f.svc.DeleteApp(&sagemaker.DeleteAppInput{
DomainId: f.domainID,
AppName: f.appName,
AppType: f.appType,
UserProfileName: f.userProfileName,
})

return err
}

func (f *SageMakerApp) String() string {
return *f.appName
}

func (i *SageMakerApp) Properties() types.Properties {
properties := types.NewProperties()
properties.
Set("DomainID", i.domainID).
Set("AppName", i.appName).
Set("AppType", i.appType).
Set("UserProfileName", i.userProfileName)
return properties
}

func (f *SageMakerApp) Filter() error {
if *f.status == sagemaker.AppStatusDeleted {
return fmt.Errorf("already deleted")
}
return nil
}
68 changes: 68 additions & 0 deletions resources/sagemaker-domain.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,68 @@
package resources

import (
"github.com/aws/aws-sdk-go/aws"
"github.com/aws/aws-sdk-go/aws/session"
"github.com/aws/aws-sdk-go/service/sagemaker"
"github.com/rebuy-de/aws-nuke/pkg/types"
)

type SageMakerDomain struct {
svc *sagemaker.SageMaker
domainID *string
}

func init() {
register("SageMakerDomain", ListSageMakerDomains)
}

func ListSageMakerDomains(sess *session.Session) ([]Resource, error) {
svc := sagemaker.New(sess)
resources := []Resource{}

params := &sagemaker.ListDomainsInput{
MaxResults: aws.Int64(30),
}

for {
resp, err := svc.ListDomains(params)
if err != nil {
return nil, err
}

for _, domain := range resp.Domains {
resources = append(resources, &SageMakerDomain{
svc: svc,
domainID: domain.DomainId,
})
}

if resp.NextToken == nil {
break
}

params.NextToken = resp.NextToken
}

return resources, nil
}

func (f *SageMakerDomain) Remove() error {
_, err := f.svc.DeleteDomain(&sagemaker.DeleteDomainInput{
DomainId: f.domainID,
RetentionPolicy: &sagemaker.RetentionPolicy{HomeEfsFileSystem: aws.String(sagemaker.RetentionTypeDelete)},
})

return err
}

func (f *SageMakerDomain) String() string {
return *f.domainID
}

func (i *SageMakerDomain) Properties() types.Properties {
properties := types.NewProperties()
properties.
Set("DomainID", i.domainID)
return properties
}
71 changes: 71 additions & 0 deletions resources/sagemaker-userprofiles.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,71 @@
package resources

import (
"github.com/aws/aws-sdk-go/aws"
"github.com/aws/aws-sdk-go/aws/session"
"github.com/aws/aws-sdk-go/service/sagemaker"
"github.com/rebuy-de/aws-nuke/pkg/types"
)

type SageMakerUserProfile struct {
svc *sagemaker.SageMaker
domainID *string
userProfileName *string
}

func init() {
register("SageMakerUserProfiles", ListSageMakerUserProfiles)
}

func ListSageMakerUserProfiles(sess *session.Session) ([]Resource, error) {
svc := sagemaker.New(sess)
resources := []Resource{}

params := &sagemaker.ListUserProfilesInput{
MaxResults: aws.Int64(30),
}

for {
resp, err := svc.ListUserProfiles(params)
if err != nil {
return nil, err
}

for _, userProfile := range resp.UserProfiles {
resources = append(resources, &SageMakerUserProfile{
svc: svc,
domainID: userProfile.DomainId,
userProfileName: userProfile.UserProfileName,
})
}

if resp.NextToken == nil {
break
}

params.NextToken = resp.NextToken
}

return resources, nil
}

func (f *SageMakerUserProfile) Remove() error {
_, err := f.svc.DeleteUserProfile(&sagemaker.DeleteUserProfileInput{
DomainId: f.domainID,
UserProfileName: f.userProfileName,
})

return err
}

func (f *SageMakerUserProfile) String() string {
return *f.userProfileName
}

func (i *SageMakerUserProfile) Properties() types.Properties {
properties := types.NewProperties()
properties.
Set("DomainID", i.domainID).
Set("UserProfileName", i.userProfileName)
return properties
}

0 comments on commit d9185e9

Please sign in to comment.