mirror of
https://github.com/letic/terraform-provider-google.git
synced 2024-07-01 07:42:40 +00:00
Use beta endpoint for shared vpc resources (#3458)
<!-- This change is generated by MagicModules. --> Original Author: @leg100
This commit is contained in:
parent
86caed3c70
commit
9485b763bd
|
@ -30,14 +30,14 @@ func resourceComputeSharedVpcHostProjectCreate(d *schema.ResourceData, meta inte
|
||||||
config := meta.(*Config)
|
config := meta.(*Config)
|
||||||
|
|
||||||
hostProject := d.Get("project").(string)
|
hostProject := d.Get("project").(string)
|
||||||
op, err := config.clientCompute.Projects.EnableXpnHost(hostProject).Do()
|
op, err := config.clientComputeBeta.Projects.EnableXpnHost(hostProject).Do()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return fmt.Errorf("Error enabling Shared VPC Host %q: %s", hostProject, err)
|
return fmt.Errorf("Error enabling Shared VPC Host %q: %s", hostProject, err)
|
||||||
}
|
}
|
||||||
|
|
||||||
d.SetId(hostProject)
|
d.SetId(hostProject)
|
||||||
|
|
||||||
err = computeOperationWait(config.clientCompute, op, hostProject, "Enabling Shared VPC Host")
|
err = computeBetaOperationWaitTime(config.clientCompute, op, hostProject, "Enabling Shared VPC Host", int(d.Timeout(schema.TimeoutCreate).Minutes()))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
d.SetId("")
|
d.SetId("")
|
||||||
return err
|
return err
|
||||||
|
@ -51,7 +51,7 @@ func resourceComputeSharedVpcHostProjectRead(d *schema.ResourceData, meta interf
|
||||||
|
|
||||||
hostProject := d.Id()
|
hostProject := d.Id()
|
||||||
|
|
||||||
project, err := config.clientCompute.Projects.Get(hostProject).Do()
|
project, err := config.clientComputeBeta.Projects.Get(hostProject).Do()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return handleNotFoundError(err, d, fmt.Sprintf("Project data for project %q", hostProject))
|
return handleNotFoundError(err, d, fmt.Sprintf("Project data for project %q", hostProject))
|
||||||
}
|
}
|
||||||
|
@ -70,12 +70,12 @@ func resourceComputeSharedVpcHostProjectDelete(d *schema.ResourceData, meta inte
|
||||||
config := meta.(*Config)
|
config := meta.(*Config)
|
||||||
hostProject := d.Get("project").(string)
|
hostProject := d.Get("project").(string)
|
||||||
|
|
||||||
op, err := config.clientCompute.Projects.DisableXpnHost(hostProject).Do()
|
op, err := config.clientComputeBeta.Projects.DisableXpnHost(hostProject).Do()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return fmt.Errorf("Error disabling Shared VPC Host %q: %s", hostProject, err)
|
return fmt.Errorf("Error disabling Shared VPC Host %q: %s", hostProject, err)
|
||||||
}
|
}
|
||||||
|
|
||||||
err = computeOperationWait(config.clientCompute, op, hostProject, "Disabling Shared VPC Host")
|
err = computeBetaOperationWaitTime(config.clientCompute, op, hostProject, "Disabling Shared VPC Host", int(d.Timeout(schema.TimeoutCreate).Minutes()))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,7 +4,7 @@ import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
"google.golang.org/api/compute/v1"
|
computeBeta "google.golang.org/api/compute/v0.beta"
|
||||||
|
|
||||||
"log"
|
"log"
|
||||||
|
|
||||||
|
@ -42,17 +42,18 @@ func resourceComputeSharedVpcServiceProjectCreate(d *schema.ResourceData, meta i
|
||||||
hostProject := d.Get("host_project").(string)
|
hostProject := d.Get("host_project").(string)
|
||||||
serviceProject := d.Get("service_project").(string)
|
serviceProject := d.Get("service_project").(string)
|
||||||
|
|
||||||
req := &compute.ProjectsEnableXpnResourceRequest{
|
req := &computeBeta.ProjectsEnableXpnResourceRequest{
|
||||||
XpnResource: &compute.XpnResourceId{
|
XpnResource: &computeBeta.XpnResourceId{
|
||||||
Id: serviceProject,
|
Id: serviceProject,
|
||||||
Type: "PROJECT",
|
Type: "PROJECT",
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
op, err := config.clientCompute.Projects.EnableXpnResource(hostProject, req).Do()
|
op, err := config.clientComputeBeta.Projects.EnableXpnResource(hostProject, req).Do()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
if err = computeOperationWait(config.clientCompute, op, hostProject, "Enabling Shared VPC Resource"); err != nil {
|
err = computeBetaOperationWaitTime(config.clientCompute, op, hostProject, "Enabling Shared VPC Resource", int(d.Timeout(schema.TimeoutCreate).Minutes()))
|
||||||
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -96,7 +97,7 @@ func resourceComputeSharedVpcServiceProjectDelete(d *schema.ResourceData, meta i
|
||||||
hostProject := d.Get("host_project").(string)
|
hostProject := d.Get("host_project").(string)
|
||||||
serviceProject := d.Get("service_project").(string)
|
serviceProject := d.Get("service_project").(string)
|
||||||
|
|
||||||
if err := disableXpnResource(config, hostProject, serviceProject); err != nil {
|
if err := disableXpnResource(d, config, hostProject, serviceProject); err != nil {
|
||||||
// Don't fail if the service project is already disabled.
|
// Don't fail if the service project is already disabled.
|
||||||
if !isDisabledXpnResourceError(err) {
|
if !isDisabledXpnResourceError(err) {
|
||||||
return fmt.Errorf("Error disabling Shared VPC Resource %q: %s", serviceProject, err)
|
return fmt.Errorf("Error disabling Shared VPC Resource %q: %s", serviceProject, err)
|
||||||
|
@ -106,18 +107,19 @@ func resourceComputeSharedVpcServiceProjectDelete(d *schema.ResourceData, meta i
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func disableXpnResource(config *Config, hostProject, project string) error {
|
func disableXpnResource(d *schema.ResourceData, config *Config, hostProject, project string) error {
|
||||||
req := &compute.ProjectsDisableXpnResourceRequest{
|
req := &computeBeta.ProjectsDisableXpnResourceRequest{
|
||||||
XpnResource: &compute.XpnResourceId{
|
XpnResource: &computeBeta.XpnResourceId{
|
||||||
Id: project,
|
Id: project,
|
||||||
Type: "PROJECT",
|
Type: "PROJECT",
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
op, err := config.clientCompute.Projects.DisableXpnResource(hostProject, req).Do()
|
op, err := config.clientComputeBeta.Projects.DisableXpnResource(hostProject, req).Do()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
if err = computeOperationWait(config.clientCompute, op, hostProject, "Disabling Shared VPC Resource"); err != nil {
|
err = computeBetaOperationWaitTime(config.clientCompute, op, hostProject, "Disabling Shared VPC Resource", int(d.Timeout(schema.TimeoutCreate).Minutes()))
|
||||||
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
|
|
Loading…
Reference in New Issue
Block a user