Skip to content

Commit

Permalink
Allow publishing of additional information to IPAM
Browse files Browse the repository at this point in the history
Adds an IPAM driver capability that allows libnetwork
to send additional information during subnet and address
allocation.

Signed-off-by: John Belamaric <[email protected]>
  • Loading branch information
johnbelamaric committed Mar 8, 2016
1 parent 9994ce1 commit da5610c
Show file tree
Hide file tree
Showing 4 changed files with 33 additions and 1 deletion.
2 changes: 2 additions & 0 deletions ipamapi/contract.go
Original file line number Diff line number Diff line change
Expand Up @@ -79,4 +79,6 @@ type Ipam interface {
// Capability represents the requirements and capabilities of the IPAM driver
type Capability struct {
RequiresMACAddress bool
RequiresEndpointID bool
RequiresNetworkID bool
}
7 changes: 6 additions & 1 deletion ipams/remote/api/api.go
Original file line number Diff line number Diff line change
Expand Up @@ -23,11 +23,16 @@ func (r *Response) GetError() string {
type GetCapabilityResponse struct {
Response
RequiresMACAddress bool
RequiresEndpointID bool
RequiresNetworkID bool
}

// ToCapability converts the capability response into the internal ipam driver capaility structure
func (capRes GetCapabilityResponse) ToCapability() *ipamapi.Capability {
return &ipamapi.Capability{RequiresMACAddress: capRes.RequiresMACAddress}
return &ipamapi.Capability{
RequiresMACAddress: capRes.RequiresMACAddress,
RequiresEndpointID: capRes.RequiresEndpointID,
RequiresNetworkID: capRes.RequiresNetworkID}
}

// GetAddressSpacesResponse is the response to the ``get default address spaces`` request message
Expand Down
6 changes: 6 additions & 0 deletions netlabel/labels.go
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,12 @@ const (
// MacAddress constant represents Mac Address config of a Container
MacAddress = Prefix + ".endpoint.macaddress"

// NetworkID constant represents the network ID
NetworkID = Prefix + ".id"

// EndpointID constant represents the endpoint ID
EndpointID = Prefix + ".endpoint.id"

// ExposedPorts constant represents the container's Exposed Ports
ExposedPorts = Prefix + ".endpoint.exposedports"

Expand Down
19 changes: 19 additions & 0 deletions network.go
Original file line number Diff line number Diff line change
Expand Up @@ -736,6 +736,13 @@ func (n *network) CreateEndpoint(name string, options ...EndpointOption) (Endpoi
ep.ipamOptions[netlabel.MacAddress] = ep.iface.mac.String()
}

if ipam.capability.RequiresEndpointID {
if ep.ipamOptions == nil {
ep.ipamOptions = make(map[string]string)
}
ep.ipamOptions[netlabel.EndpointID] = ep.id
}

if err = ep.assignAddress(ipam.driver, true, !n.postIPv6); err != nil {
return nil, err
}
Expand Down Expand Up @@ -1009,6 +1016,18 @@ func (n *network) ipamAllocateVersion(ipVer int, ipam ipamapi.Ipam) error {

*infoList = make([]*IpamInfo, len(*cfgList))

id, err := n.getController().getIPAM(n.ipamType)
if err != nil {
return err
}

if id.capability.RequiresNetworkID {
if n.ipamOptions == nil {
n.ipamOptions = make(map[string]string)
}
n.ipamOptions[netlabel.NetworkID] = n.ID()
}

log.Debugf("Allocating IPv%d pools for network %s (%s)", ipVer, n.Name(), n.ID())

for i, cfg := range *cfgList {
Expand Down

0 comments on commit da5610c

Please sign in to comment.