diff --git a/pkg/apis/openstackproviderconfig/v1alpha1/types.go b/pkg/apis/openstackproviderconfig/v1alpha1/types.go index 42eec77cdd..92c3deeea2 100644 --- a/pkg/apis/openstackproviderconfig/v1alpha1/types.go +++ b/pkg/apis/openstackproviderconfig/v1alpha1/types.go @@ -135,8 +135,9 @@ type NetworkParam struct { // NoAllowedAddressPairs disables creation of allowed address pairs for the network ports NoAllowedAddressPairs bool `json:"noAllowedAddressPairs,omitempty"` // PortTags allows users to specify a list of tags to add to ports created in a given network - PortTags []string `json:"portTags,omitempty"` - VNICType string `json:"vnicType,omitempty"` + PortTags []string `json:"portTags,omitempty"` + VNICType string `json:"vnicType,omitempty"` + Profile map[string]interface{} `json:"profile,omitempty"` // PortSecurity optionally enables or disables security on ports managed by OpenStack PortSecurity *bool `json:"portSecurity,omitempty"` } @@ -218,6 +219,11 @@ type PortOpts struct { // neutron port. VNICType string `json:"vnicType,omitempty"` + // A dictionary that enables the application running on the specified + // host to pass and receive virtual network interface (VIF) port-specific + // information to the plug-in. + Profile map[string]interface{} `json:"profile,omitempty"` + // enable or disable security on a given port // incompatible with securityGroups and allowedAddressPairs PortSecurity *bool `json:"portSecurity,omitempty"` diff --git a/pkg/cloud/openstack/clients/machineservice.go b/pkg/cloud/openstack/clients/machineservice.go index dfd80cbffc..29c0be0188 100644 --- a/pkg/cloud/openstack/clients/machineservice.go +++ b/pkg/cloud/openstack/clients/machineservice.go @@ -375,7 +375,7 @@ func getOrCreatePort(is *InstanceService, name string, portOpts openstackconfigv CreateOptsBuilder: createOpts, HostID: portOpts.HostID, VNICType: portOpts.VNICType, - Profile: nil, + Profile: portOpts.Profile, }).Extract() if err != nil { return nil, err @@ -572,6 +572,7 @@ func (is *InstanceService) InstanceCreate(clusterName string, name string, clust NameSuffix: net.UUID, Tags: net.PortTags, VNICType: net.VNICType, + Profile: net.Profile, PortSecurity: net.PortSecurity, }) } @@ -598,6 +599,7 @@ func (is *InstanceService) InstanceCreate(clusterName string, name string, clust FixedIPs: []openstackconfigv1.FixedIPs{{SubnetID: snet.ID}}, Tags: append(net.PortTags, snetParam.PortTags...), VNICType: net.VNICType, + Profile: net.Profile, PortSecurity: portSecurity, }) }