diff --git a/pkg/providers/openstack/network.go b/pkg/providers/openstack/network.go index 48a416c..4ca6c2b 100644 --- a/pkg/providers/openstack/network.go +++ b/pkg/providers/openstack/network.go @@ -29,11 +29,13 @@ import ( "github.com/gophercloud/gophercloud/v2/openstack/networking/v2/extensions/external" "github.com/gophercloud/gophercloud/v2/openstack/networking/v2/extensions/layer3/routers" "github.com/gophercloud/gophercloud/v2/openstack/networking/v2/extensions/provider" + "github.com/gophercloud/gophercloud/v2/openstack/networking/v2/extensions/quotas" "github.com/gophercloud/gophercloud/v2/openstack/networking/v2/networks" "github.com/gophercloud/gophercloud/v2/openstack/networking/v2/subnets" "go.opentelemetry.io/otel" "go.opentelemetry.io/otel/trace" + "github.com/unikorn-cloud/core/pkg/util" "github.com/unikorn-cloud/core/pkg/util/cache" unikornv1 "github.com/unikorn-cloud/region/pkg/apis/unikorn/v1alpha1" "github.com/unikorn-cloud/region/pkg/constants" @@ -294,3 +296,20 @@ func (c *NetworkClient) RemoveRouterInterface(ctx context.Context, routerID, sub return routers.RemoveInterface(ctx, c.client, routerID, opts).Err } + +func (c *NetworkClient) UpdateQuotas(ctx context.Context, projectID string) error { + tracer := otel.GetTracerProvider().Tracer(constants.Application) + + _, span := tracer.Start(ctx, "PUT /network/v2.0/os-quota-sets") + defer span.End() + + opts := "as.UpdateOpts{ + // TODO: this is a relatively restrictive default, as floating IPs are + // in short supply. This allows 1 for a Kubernetes API load balancer, + // 1 for an ingress controller, and a spare for debugging or as a + // bastion. + FloatingIP: util.ToPointer(3), + } + + return quotas.Update(ctx, c.client, projectID, opts).Err +} diff --git a/pkg/providers/openstack/provider.go b/pkg/providers/openstack/provider.go index b86e35b..3b0adb5 100644 --- a/pkg/providers/openstack/provider.go +++ b/pkg/providers/openstack/provider.go @@ -553,6 +553,15 @@ func (p *Provider) provisionQuotas(ctx context.Context, identity *unikornv1.Open return err } + network, err := NewNetworkClient(ctx, providerClient, p.region.Spec.Openstack.Network) + if err != nil { + return err + } + + if err := network.UpdateQuotas(ctx, *identity.Spec.ProjectID); err != nil { + return err + } + return nil }