func resourceMemberV2Create(d *schema.ResourceData, meta interface{}) error { config := meta.(*Config) networkingClient, err := config.networkingV2Client(d.Get("region").(string)) if err != nil { return fmt.Errorf("Error creating OpenStack networking client: %s", err) } adminStateUp := d.Get("admin_state_up").(bool) createOpts := pools.CreateMemberOpts{ Name: d.Get("name").(string), TenantID: d.Get("tenant_id").(string), Address: d.Get("address").(string), ProtocolPort: d.Get("protocol_port").(int), Weight: d.Get("weight").(int), AdminStateUp: &adminStateUp, } // Must omit if not set if v, ok := d.GetOk("subnet_id"); ok { createOpts.SubnetID = v.(string) } poolID := d.Get("pool_id").(string) log.Printf("[DEBUG] Create Options: %#v", createOpts) member, err := pools.CreateMember(networkingClient, poolID, createOpts).Extract() if err != nil { return fmt.Errorf("Error creating OpenStack LBaaSV2 member: %s", err) } log.Printf("[INFO] member ID: %s", member.ID) log.Printf("[DEBUG] Waiting for Openstack LBaaSV2 member (%s) to become available.", member.ID) stateConf := &resource.StateChangeConf{ Pending: []string{"PENDING_CREATE"}, Target: []string{"ACTIVE"}, Refresh: waitForMemberActive(networkingClient, poolID, member.ID), Timeout: 2 * time.Minute, Delay: 5 * time.Second, MinTimeout: 3 * time.Second, } _, err = stateConf.WaitForState() if err != nil { return err } d.SetId(member.ID) return resourceMemberV2Read(d, meta) }
func resourceMemberV2Create(d *schema.ResourceData, meta interface{}) error { config := meta.(*Config) networkingClient, err := config.networkingV2Client(GetRegion(d)) if err != nil { return fmt.Errorf("Error creating OpenStack networking client: %s", err) } adminStateUp := d.Get("admin_state_up").(bool) createOpts := pools.CreateMemberOpts{ Name: d.Get("name").(string), TenantID: d.Get("tenant_id").(string), Address: d.Get("address").(string), ProtocolPort: d.Get("protocol_port").(int), Weight: d.Get("weight").(int), AdminStateUp: &adminStateUp, } // Must omit if not set if v, ok := d.GetOk("subnet_id"); ok { createOpts.SubnetID = v.(string) } poolID := d.Get("pool_id").(string) log.Printf("[DEBUG] Create Options: %#v", createOpts) var member *pools.Member err = resource.Retry(10*time.Minute, func() *resource.RetryError { var err error log.Printf("[DEBUG] Attempting to create LBaaSV2 member") member, err = pools.CreateMember(networkingClient, poolID, createOpts).Extract() if err != nil { if errCode, ok := err.(gophercloud.ErrUnexpectedResponseCode); ok { if errCode.Actual == 409 || errCode.Actual == 500 { log.Printf("[DEBUG] OpenStack LBaaSV2 member is still creating.") return resource.RetryableError(err) } } return resource.NonRetryableError(err) } return nil }) if err != nil { return fmt.Errorf("Error creating OpenStack LBaaSV2 member: %s", err) } log.Printf("[INFO] member ID: %s", member.ID) log.Printf("[DEBUG] Waiting for Openstack LBaaSV2 member (%s) to become available.", member.ID) stateConf := &resource.StateChangeConf{ Pending: []string{"PENDING_CREATE"}, Target: []string{"ACTIVE"}, Refresh: waitForMemberActive(networkingClient, poolID, member.ID), Timeout: 2 * time.Minute, Delay: 5 * time.Second, MinTimeout: 3 * time.Second, } _, err = stateConf.WaitForState() if err != nil { return err } d.SetId(member.ID) return resourceMemberV2Read(d, meta) }