/
noop.go
51 lines (40 loc) · 1.61 KB
/
noop.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
// SPDX-License-Identifier: Apache-2.0
// Copyright Authors of Cilium
package allocator
import (
"errors"
"net"
"github.com/cilium/cilium/pkg/ipam/types"
)
var errNotSupported = errors.New("Operation not supported")
// NoOpAllocator implements Allocator with no-op behavior
type NoOpAllocator struct{}
// GetPoolQuota returns the total available pool quota. This is always 0.
func (n *NoOpAllocator) GetPoolQuota() types.PoolQuotaMap {
return types.PoolQuotaMap{}
}
// FirstPoolWithAvailableQuota returns the first pool ID in the list of pools
// with available addresses. This function always returns types.PoolNotExists
func (n *NoOpAllocator) FirstPoolWithAvailableQuota(preferredPoolIDs []types.PoolID) (types.PoolID, int) {
return types.PoolNotExists, 0
}
// Allocate allocates a paritcular IP in a particular pool. This function
// always returns an error as this operation is not supported for the no-op
// allocator.
func (n *NoOpAllocator) Allocate(poolID types.PoolID, ip net.IP) error {
return errNotSupported
}
// AllocateMany allocates multiple IP addresses. The operation succeeds if all
// IPs can be allocated. On failure, all IPs are released again.
func (n *NoOpAllocator) AllocateMany(poolID types.PoolID, num int) ([]net.IP, error) {
return nil, errNotSupported
}
// ReleaseMany releases a slice of IP addresses. This function has no effect
func (n *NoOpAllocator) ReleaseMany(poolID types.PoolID, ips []net.IP) error {
return nil
}
// PoolExists returns true if an allocation pool exists. This function always
// returns false.
func (n *NoOpAllocator) PoolExists(poolID types.PoolID) bool {
return false
}