pingable_ipam_plugin 0.0.6 → 0.0.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/app/services/ipam/ping_random_db.rb +17 -10
- data/lib/pingable_ipam_plugin/version.rb +1 -1
- metadata +2 -2
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: afb4f76ebb1e0b6ba231a0a52e696e78728abd2eb38ef75946397fc3531e4114
|
4
|
+
data.tar.gz: 402d327725e8605041658ba455b869f38ab09edc327d359e81b89155850c4194
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 5755029b6b0c67cd28260d1e05715ac34fd04317cff271d9db4067e4f5094159c515da6a9bda1664586b95ba4deca91809542a080551ad49d3d521ec5fde4170
|
7
|
+
data.tar.gz: 2a8ccfb8448d928be6bd31a20a3db1a531c3fbe32e8baeabacc266570fe026f98035fbbdba9984e5e000d736b09f923d8faff018edc02b56ddbd96baeb604c32
|
@@ -46,7 +46,7 @@ module IPAM
|
|
46
46
|
end
|
47
47
|
|
48
48
|
if bool
|
49
|
-
logger.info "Succesful telnet ping #{ip}, port #{port}"
|
49
|
+
logger.info "[IPAM] Succesful telnet ping #{ip}, port #{port}"
|
50
50
|
end
|
51
51
|
|
52
52
|
bool
|
@@ -64,14 +64,14 @@ module IPAM
|
|
64
64
|
system("ping -c 2 -W 1 #{ip} > /dev/null")
|
65
65
|
end
|
66
66
|
rescue => err
|
67
|
-
logger.
|
67
|
+
logger.warn "[IPAM] Unable to icmp ping #{ip} because #{err.inspect}."
|
68
68
|
true
|
69
69
|
end
|
70
70
|
|
71
71
|
def ns_resolvable? ip
|
72
72
|
begin
|
73
73
|
name = Resolv.getname ip
|
74
|
-
logger.warn "Found a DNS resolvable IP #{ip}, resolved name: #{name}."
|
74
|
+
logger.warn "[IPAM] Found a DNS resolvable IP #{ip}, resolved name: #{name}."
|
75
75
|
true
|
76
76
|
rescue StandardError
|
77
77
|
false
|
@@ -88,12 +88,16 @@ module IPAM
|
|
88
88
|
range = subnet_range.to_a - excluded_ips.to_a
|
89
89
|
range -= subnet.known_ips.to_a
|
90
90
|
|
91
|
-
|
92
|
-
|
93
|
-
return nil
|
91
|
+
unless range.empty?
|
92
|
+
logger.info "[IPAM] IP range from #{range.first.to_s} to #{range.last.to_s}"
|
94
93
|
end
|
95
94
|
|
96
95
|
loop do
|
96
|
+
if range.empty?
|
97
|
+
errors.add(:subnet, _('no free IP could be found in our DB, enlarge subnet range'))
|
98
|
+
return nil
|
99
|
+
end
|
100
|
+
|
97
101
|
# next random IP from the sequence generated by MAC seed
|
98
102
|
candidate = random_ip(range)
|
99
103
|
iterations += 1
|
@@ -102,18 +106,21 @@ module IPAM
|
|
102
106
|
ip = candidate.to_s
|
103
107
|
# Check again if something has been changed.
|
104
108
|
if !excluded_ips.include?(ip) && !subnet.known_ips.include?(ip)
|
105
|
-
logger.
|
109
|
+
logger.info "[IPAM] Searching for free IP - resolving #{ip}"
|
106
110
|
if tcp_pingable?(ip) || icmp_pingable?(ip)
|
107
|
-
logger.warn("Found a pingable IP (#{ip}) address which not marked as known. Skipping it...")
|
111
|
+
logger.warn("[IPAM] Found a pingable IP (#{ip}) address which not marked as known. Skipping it...")
|
108
112
|
else
|
109
113
|
unless ns_resolvable?(ip)
|
110
|
-
logger.
|
114
|
+
logger.info("[IPAM] Found #{ip} in #{iterations} iterations")
|
111
115
|
return ip
|
112
116
|
end
|
113
117
|
end
|
114
118
|
end
|
119
|
+
|
120
|
+
range -= [ip]
|
115
121
|
end
|
116
|
-
|
122
|
+
|
123
|
+
logger.warn("[IPAM] Not suggesting IP Address for #{subnet} as no free IP found in reasonable time (#{iterations} iterations)")
|
117
124
|
errors.add(:subnet, _('no random free IP could be found in our DB, enlarge subnet range'))
|
118
125
|
nil
|
119
126
|
end
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: pingable_ipam_plugin
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.0.
|
4
|
+
version: 0.0.7
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Pavel Parshin
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date:
|
11
|
+
date: 2021-03-25 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: rubocop
|