Skip to content

Commit

Permalink
feat(live): live domain resource support new field is_ipv6
Browse files Browse the repository at this point in the history
  • Loading branch information
deer-hang committed Dec 26, 2024
1 parent 713b8ea commit b4dc748
Show file tree
Hide file tree
Showing 3 changed files with 38 additions and 3 deletions.
3 changes: 3 additions & 0 deletions docs/resources/live_domain.md
Original file line number Diff line number Diff line change
Expand Up @@ -64,6 +64,9 @@ The following arguments are supported:
* `ingest_domain_name` - (Optional, String) Specifies the ingest domain name, which associates with the streaming
domain name to push streams to nearby CDN nodes.

* `is_ipv6` - (Optional, Bool) Specifies whether enable IPv6 switch. Defaults to **false**.
This field can only be edited when `status` is on.

* `status` - (Optional, String) Specifies status of the domain name. The options are as follows:
+ **on**: enable the domain name.
+ **off**: disable the domain name.
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -52,6 +52,7 @@ func TestAccDomain_basic(t *testing.T) {
resource.TestCheckResourceAttr(pushResourceName, "type", "push"),
resource.TestCheckResourceAttr(pushResourceName, "status", "on"),
resource.TestCheckResourceAttr(pushResourceName, "service_area", "mainland_china"),
resource.TestCheckResourceAttr(pushResourceName, "is_ipv6", "true"),
resource.TestCheckResourceAttr(pushResourceName, "enterprise_project_id", acceptance.HW_ENTERPRISE_PROJECT_ID_TEST),

resource.TestCheckResourceAttr(pullResourceName, "name", pullDomainName),
Expand All @@ -69,6 +70,7 @@ func TestAccDomain_basic(t *testing.T) {
resource.TestCheckResourceAttr(pushResourceName, "type", "push"),
resource.TestCheckResourceAttr(pushResourceName, "status", "on"),
resource.TestCheckResourceAttr(pushResourceName, "service_area", "mainland_china"),
resource.TestCheckResourceAttr(pushResourceName, "is_ipv6", "false"),
resource.TestCheckResourceAttr(pushResourceName, "enterprise_project_id", acceptance.HW_ENTERPRISE_PROJECT_ID_TEST),

resource.TestCheckResourceAttr(pullResourceName, "name", pullDomainName),
Expand All @@ -94,6 +96,7 @@ resource "huaweicloud_live_domain" "ingestDomain" {
name = "%[1]s"
type = "push"
service_area = "mainland_china"
is_ipv6 = true
enterprise_project_id = "%[3]s"
}
Expand All @@ -113,6 +116,7 @@ resource "huaweicloud_live_domain" "ingestDomain" {
name = "%[1]s"
type = "push"
service_area = "mainland_china"
is_ipv6 = false
enterprise_project_id = "%[3]s"
}
Expand Down
34 changes: 31 additions & 3 deletions huaweicloud/services/live/resource_huaweicloud_live_domain.go
Original file line number Diff line number Diff line change
Expand Up @@ -74,6 +74,11 @@ func ResourceDomain() *schema.Resource {
Type: schema.TypeString,
Optional: true,
},
"is_ipv6": {
Type: schema.TypeBool,
Optional: true,
Computed: true,
},
"status": {
Type: schema.TypeString,
Optional: true,
Expand Down Expand Up @@ -127,6 +132,12 @@ func resourceDomainCreate(ctx context.Context, d *schema.ResourceData, meta inte
}
}

if d.Get("is_ipv6").(bool) {
if err := updateIPv6Switch(client, d); err != nil {
return diag.Errorf("error updating Live domain IPv6 switch in creation operation: %s", err)
}
}

return resourceDomainRead(ctx, d, meta)
}

Expand Down Expand Up @@ -162,6 +173,7 @@ func resourceDomainRead(_ context.Context, d *schema.ResourceData, meta interfac
d.Set("cname", detail.DomainCname),
d.Set("service_area", flattenServiceAreaAttribute(detail.ServiceArea)),
d.Set("enterprise_project_id", detail.EnterpriseProjectId),
d.Set("is_ipv6", detail.IsIpv6),
)

return diag.FromErr(mErr.ErrorOrNil())
Expand All @@ -183,14 +195,12 @@ func resourceDomainUpdate(ctx context.Context, d *schema.ResourceData, meta inte
return diag.Errorf("error creating Live v1 client: %s", err)
}

domainName := d.Get("name").(string)

// associate the streaming domain name with an ingest domain Or delete association
if d.HasChange("ingest_domain_name") {
ingetstDomainNameOld, ingetstDomainName := d.GetChange("ingest_domain_name")

if ingetstDomainName == "" {
err = deleteAssociation(client, domainName, ingetstDomainNameOld.(string))
err = deleteAssociation(client, d.Get("name").(string), ingetstDomainNameOld.(string))
} else {
err = associatingDomain(d, client)
}
Expand All @@ -207,6 +217,12 @@ func resourceDomainUpdate(ctx context.Context, d *schema.ResourceData, meta inte
}
}

if d.HasChange("is_ipv6") {
if err := updateIPv6Switch(client, d); err != nil {
return diag.Errorf("error updating Live domain IPv6 switch in update operation: %s", err)
}
}

return resourceDomainRead(ctx, d, meta)
}

Expand Down Expand Up @@ -371,3 +387,15 @@ func updateStatus(ctx context.Context, d *schema.ResourceData, client *livev1.Li

return waitingForDomainStatus(ctx, client, d.Id(), respStatus, d.Timeout(schema.TimeoutUpdate))
}

func updateIPv6Switch(client *livev1.LiveClient, d *schema.ResourceData) error {
switchRequest := model.UpdateDomainIp6SwitchRequest{
Body: &model.DomainIpv6SwitchReq{
Domain: d.Get("name").(string),
IsIpv6: utils.Bool(d.Get("is_ipv6").(bool)),
},
}

_, err := client.UpdateDomainIp6Switch(&switchRequest)
return err
}

0 comments on commit b4dc748

Please sign in to comment.