func addInterface(t *testing.T, routerID, subnetID string) { ir, err := routers.AddInterface(base.Client, routerID, routers.InterfaceOpts{SubnetID: subnetID}).Extract() th.AssertNoErr(t, err) t.Logf("Interface added to router %s: SubnetID [%s] PortID [%s]", routerID, ir.SubnetID, ir.PortID) }
func resourceNetworkingRouterInterfaceV2Create(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) } createOpts := routers.InterfaceOpts{ SubnetID: d.Get("subnet_id").(string), } log.Printf("[DEBUG] Create Options: %#v", createOpts) n, err := routers.AddInterface(networkingClient, d.Get("router_id").(string), createOpts).Extract() if err != nil { return fmt.Errorf("Error creating OpenStack Neutron router interface: %s", err) } log.Printf("[INFO] Router interface Port ID: %s", n.PortID) log.Printf("[DEBUG] Waiting for Router Interface (%s) to become available", n.PortID) stateConf := &resource.StateChangeConf{ Pending: []string{"BUILD", "PENDING_CREATE", "PENDING_UPDATE"}, Target: "ACTIVE", Refresh: waitForRouterInterfaceActive(networkingClient, n.PortID), Timeout: 2 * time.Minute, Delay: 5 * time.Second, MinTimeout: 3 * time.Second, } _, err = stateConf.WaitForState() d.SetId(n.PortID) return resourceNetworkingRouterInterfaceV2Read(d, meta) }
func resourceNetworkingRouterInterfaceV2Create(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) } createOpts := routers.InterfaceOpts{ SubnetID: d.Get("subnet_id").(string), } log.Printf("[DEBUG] Create Options: %#v", createOpts) n, err := routers.AddInterface(networkingClient, d.Get("router_id").(string), createOpts).Extract() if err != nil { return fmt.Errorf("Error creating OpenStack Neutron router interface: %s", err) } log.Printf("[INFO] Router interface Port ID: %s", n.PortID) d.SetId(n.PortID) return resourceNetworkingRouterInterfaceV2Read(d, meta) }