/
data_source_instance_security_group.go
72 lines (60 loc) · 2.19 KB
/
data_source_instance_security_group.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
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
package scaleway
import (
"context"
"github.com/hashicorp/terraform-plugin-sdk/v2/diag"
"github.com/hashicorp/terraform-plugin-sdk/v2/helper/schema"
"github.com/scaleway/scaleway-sdk-go/api/instance/v1"
"github.com/scaleway/scaleway-sdk-go/scw"
"github.com/scaleway/terraform-provider-scaleway/v2/internal/datasource"
"github.com/scaleway/terraform-provider-scaleway/v2/internal/types"
"github.com/scaleway/terraform-provider-scaleway/v2/internal/verify"
)
func DataSourceScalewayInstanceSecurityGroup() *schema.Resource {
// Generate datasource schema from resource
dsSchema := datasource.SchemaFromResourceSchema(ResourceScalewayInstanceSecurityGroup().Schema)
// Set 'Optional' schema elements
datasource.AddOptionalFieldsToSchema(dsSchema, "name", "zone", "project_id")
dsSchema["name"].ConflictsWith = []string{"security_group_id"}
dsSchema["security_group_id"] = &schema.Schema{
Type: schema.TypeString,
Optional: true,
Description: "The ID of the security group",
ValidateFunc: verify.IsUUIDorUUIDWithLocality(),
ConflictsWith: []string{"name"},
}
return &schema.Resource{
ReadContext: dataSourceScalewayInstanceSecurityGroupRead,
Schema: dsSchema,
}
}
func dataSourceScalewayInstanceSecurityGroupRead(ctx context.Context, d *schema.ResourceData, m interface{}) diag.Diagnostics {
instanceAPI, zone, err := instanceAPIWithZone(d, m)
if err != nil {
return diag.FromErr(err)
}
securityGroupID, ok := d.GetOk("security_group_id")
if !ok {
sgName := d.Get("name").(string)
res, err := instanceAPI.ListSecurityGroups(&instance.ListSecurityGroupsRequest{
Zone: zone,
Name: types.ExpandStringPtr(sgName),
Project: types.ExpandStringPtr(d.Get("project_id")),
}, scw.WithAllPages(), scw.WithContext(ctx))
if err != nil {
return diag.FromErr(err)
}
foundSG, err := findExact(
res.SecurityGroups,
func(s *instance.SecurityGroup) bool { return s.Name == sgName },
sgName,
)
if err != nil {
return diag.FromErr(err)
}
securityGroupID = foundSG.ID
}
zonedID := datasource.NewZonedID(securityGroupID, zone)
d.SetId(zonedID)
_ = d.Set("security_group_id", zonedID)
return resourceScalewayInstanceSecurityGroupRead(ctx, d, m)
}