Check and update need_regen info

This commit is contained in:
Maël Kervella 2018-05-26 21:04:14 +00:00
parent 0a8c6243ad
commit cea539b5d5
2 changed files with 37 additions and 32 deletions

67
main.py
View file

@ -1,43 +1,48 @@
import time
t1 = time.time()
from configparser import ConfigParser from configparser import ConfigParser
import socket
from re2oapi import Re2oAPIClient from re2oapi import Re2oAPIClient
config = ConfigParser() config = ConfigParser()
config.read('config.ini') config.read('config.ini')
hostname = config.get('Re2o', 'hostname') api_hostname = config.get('Re2o', 'hostname')
password = config.get('Re2o', 'password') api_password = config.get('Re2o', 'password')
username = config.get('Re2o', 'username') api_username = config.get('Re2o', 'username')
def regen_dhcp(api_client):
for hmi in api_client.list_hostmacip():
if hmi['extension'] not in host_mac_ip.keys():
host_mac_ip[hmi['extension']] = []
host_mac_ip[hmi['extension']].append((hmi['hostname'],
hmi['mac_address'],
hmi['ipv4']))
template = ("host {hostname}{extension} {{\n"
" hardware ethernet {mac_address};\n"
" fixed-address {ipv4};\n"
"}}")
for extension, hmi_list in host_mac_ip.items():
dhcp_leases_content = '\n\n'.join(template.format(
hostname=hostname,
extension=extension,
mac_address=mac_address,
ipv4=ipv4
) for hostname, mac_address, ipv4 in hmi_list)
filename = 'dhcp{extension}.list'.format(extension=extension)
with open(filename, 'w+') as f:
f.write(dhcp_leases_content)
host_mac_ip = {} host_mac_ip = {}
api_client = Re2oAPIClient(hostname, username, password) api_client = Re2oAPIClient(api_hostname, api_username, api_password)
for hmi in api_client.list_hostmacip(params={'page_size': 'all'}): client_hostname = socket.gethostname().split('.', 1)[0]
if hmi['extension'] not in host_mac_ip.keys():
host_mac_ip[hmi['extension']] = []
host_mac_ip[hmi['extension']].append((hmi['hostname'],
hmi['mac_address'],
hmi['ipv4']))
template = ("host {hostname}{extension} {{\n" for service in api_client.list_servicesregen():
" hardware ethernet {mac_address};\n" if service['hostname'] == client_hostname and \
" fixed-address {ipv4};\n" service['service_name'] == 'dhcp' and \
"}}") service['need_regen']:
regen_dhcp(api_client)
for extension, hmi_list in host_mac_ip.items(): api_client.patch(service['api_url'], data={'need_regen': False})
dhcp_leases_content = '\n\n'.join(template.format(
hostname=hostname,
extension=extension,
mac_address=mac_address,
ipv4=ipv4
) for hostname, mac_address, ipv4 in hmi_list)
filename = 'dhcp{extension}.list'.format(extension=extension)
with open(filename, 'w+') as f:
f.write(dhcp_leases_content)
print(time.time() - t1)

@ -1 +1 @@
Subproject commit 74fa513e9a0348e6d4ce030c2364a40268c8eef0 Subproject commit 7bcd0924b823cc11a5714b96cc96fe26638ac9c7