network/salt/collectd/dhcpcount.rb

41 lines
814 B
Ruby
Raw Normal View History

2020-05-15 17:59:32 +02:00
#!/usr/bin/env ruby
require 'date'
2020-05-15 18:09:54 +02:00
INTERVAL = 10
2020-05-15 17:59:32 +02:00
hostname = `hostname`.strip
2020-05-15 18:36:48 +02:00
STDOUT.sync = true
2020-05-15 17:59:32 +02:00
loop do
2020-05-15 18:36:48 +02:00
seen = {}
count = 0
2020-05-15 17:59:32 +02:00
2020-05-15 18:36:48 +02:00
starts = nil
ends = nil
ignore = false
2020-05-15 17:59:32 +02:00
2020-05-15 18:36:48 +02:00
IO::readlines("/var/lib/dhcp/dhcpd.leases").each do |line|
if line =~ /^lease (.+) \{/
addr = $1
ignore = seen[addr]
seen[addr] = true
starts = nil
ends = nil
elsif line =~ /starts \d+ (.+?);/
starts = DateTime.parse $1
elsif line =~ /ends \d+ (.+?);/
ends = DateTime.parse $1
elsif line =~ /^\}/
now = DateTime.now
if (not ignore) and starts and ends and
starts <= now and ends >= now and
count += 1
end
end
end
puts "PUTVAL \"#{hostname}/exec-dhcpd/current_sessions-leases\" interval=#{INTERVAL} N:#{count}"
sleep INTERVAL
2020-05-15 17:59:32 +02:00
end