Skip to content

Commit

Permalink
Adding VPC config (#2)
Browse files Browse the repository at this point in the history
  • Loading branch information
KensoDev authored and jckuester committed Feb 6, 2019
1 parent b6a8e78 commit beda4ab
Showing 1 changed file with 55 additions and 0 deletions.
55 changes: 55 additions & 0 deletions aws/resource_aws_sagemaker_model.go
Original file line number Diff line number Diff line change
Expand Up @@ -73,6 +73,27 @@ func resourceAwsSagemakerModel() *schema.Resource {
},
},

"vpc_config": {
Type: schema.TypeList,
Optional: true,
MaxItems: 1,
ForceNew: true,
Elem: &schema.Resource{
Schema: map[string]*schema.Schema{
"subnets": {
Type: schema.TypeSet,
Required: true,
Elem: &schema.Schema{Type: schema.TypeString},
},
"security_group_ids": {
Type: schema.TypeSet,
Required: true,
Elem: &schema.Schema{Type: schema.TypeString},
},
},
},
},

"execution_role_arn": {
Type: schema.TypeString,
Required: true,
Expand Down Expand Up @@ -110,6 +131,11 @@ func resourceAwsSagemakerModelCreate(d *schema.ResourceData, meta interface{}) e
createOpts.Tags = tagsFromMapSagemaker(v.(map[string]interface{}))
}

if v, ok := d.GetOk("vpc_config"); ok {
vpcConfig := expandSageMakerVpcConfigRequest(v.([]interface{}))
createOpts.SetVpcConfig(vpcConfig)
}

log.Printf("[DEBUG] Sagemaker model create config: %#v", *createOpts)
_, err := retryOnAwsCode("ValidationException", func() (interface{}, error) {
return conn.CreateModel(createOpts)
Expand All @@ -122,6 +148,19 @@ func resourceAwsSagemakerModelCreate(d *schema.ResourceData, meta interface{}) e
return resourceAwsSagemakerModelRead(d, meta)
}

func expandSageMakerVpcConfigRequest(l []interface{}) *sagemaker.VpcConfig {
if len(l) == 0 {
return nil
}

m := l[0].(map[string]interface{})

return &sagemaker.VpcConfig{
SecurityGroupIds: expandStringSet(m["security_group_ids"].(*schema.Set)),
Subnets: expandStringSet(m["subnets"].(*schema.Set)),
}
}

func resourceAwsSagemakerModelRead(d *schema.ResourceData, meta interface{}) error {
conn := meta.(*AWSClient).sagemakerconn

Expand Down Expand Up @@ -151,6 +190,9 @@ func resourceAwsSagemakerModelRead(d *schema.ResourceData, meta interface{}) err
if err := d.Set("primary_container", flattenPrimaryContainer(model.PrimaryContainer)); err != nil {
return err
}
if err := d.Set("vpc_config", flattenSageMakerVpcConfigResponse(model.VpcConfig)); err != nil {
return fmt.Errorf("error setting vpc_config: %s", err)
}

tagsOutput, err := conn.ListTags(&sagemaker.ListTagsInput{
ResourceArn: model.ModelArn,
Expand All @@ -161,6 +203,19 @@ func resourceAwsSagemakerModelRead(d *schema.ResourceData, meta interface{}) err
return nil
}

func flattenSageMakerVpcConfigResponse(vpcConfig *sagemaker.VpcConfig) []map[string]interface{} {
if vpcConfig == nil {
return []map[string]interface{}{}
}

m := map[string]interface{}{
"security_group_ids": schema.NewSet(schema.HashString, flattenStringList(vpcConfig.SecurityGroupIds)),
"subnets": schema.NewSet(schema.HashString, flattenStringList(vpcConfig.Subnets)),
}

return []map[string]interface{}{m}
}

func resourceAwsSagemakerModelUpdate(d *schema.ResourceData, meta interface{}) error {
conn := meta.(*AWSClient).sagemakerconn

Expand Down

0 comments on commit beda4ab

Please sign in to comment.