From fcf61646fe179d8c655ba009e0bf1a13c5207bac Mon Sep 17 00:00:00 2001 From: Thomas Date: Sat, 29 Aug 2020 20:41:26 +0200 Subject: [PATCH] Implemented Circuits --- netbox/circuits.py | 217 +++++++++++++++++++++++++++++++++++++++++++ netbox/connection.py | 4 +- netbox/netbox.py | 2 + 3 files changed, 221 insertions(+), 2 deletions(-) create mode 100644 netbox/circuits.py diff --git a/netbox/circuits.py b/netbox/circuits.py new file mode 100644 index 0000000..df1e0fa --- /dev/null +++ b/netbox/circuits.py @@ -0,0 +1,217 @@ +import netbox.exceptions as exceptions +from netbox.dcim import Dcim + + +class Circuits(object): + + def __init__(self, netbox_con): + self.netbox_con = netbox_con + self.dcim = Dcim(self.netbox_con) + + def get_circuits(self, **kwargs): + """Returns the circuits""" + return self.netbox_con.get('/circuits/circuits/', **kwargs) + + def create_circuit(self, circuit_provider, cid, circuit_type, status_id, **kwargs): + """Create a new circuits + + :param circuit_provider: provider name + :param cid: Unique circuit id + :param circuit_type: circuit type + :param status_id: see below for the status codes + :param kwargs: optional fields + :return: netbox object if successful otherwise exception raised + + circuit status codes: + 0: Deprovisioning + 1: Active + 2: Planned + 3: Provisioning + 4: Offline + 5: Decommissioned + + """ + try: + provider_id = self.get_providers(name=circuit_provider)[0]['id'] + except IndexError: + raise exceptions.NotFoundException('cirtcuit provider: {}'.format(circuit_provider)) from None + + try: + type_id = self.get_types(name=circuit_type)[0]['id'] + except IndexError: + raise exceptions.NotFoundException('circuit type: {}'.format(circuit_type)) from None + + required_fields = {"provider": provider_id, "circuit": cid, "type": type_id, + "status": status_id} + return self.netbox_con.post('/circuits/circuits/', required_fields, **kwargs) + + def delete_circuit(self, cid, provider): + """Delete circuits + + :param cid: circuit + :param provider: Name of the provider + :return: bool True if successful otherwise delete exception + """ + try: + circuits_id = self.get_circuits(cid=cid, provider=provider)[0]['id'] + except IndexError: + raise exceptions.NotFoundException('Circuit with circuit: {} and provider: {}'.format(cid, provider)) from None + return self.netbox_con.delete('/circuits/circuits/', circuits_id) + + def update_circuit(self, cid, provider, **kwargs): + """Update circuit + + :param cid: circuit + :param provider: provider name + :param kwargs: requests body dict + :return: bool True if successful otherwise raise UpdateException + """ + try: + circuits_id = self.get_circuits(cid=cid, provider=provider)[0]['id'] + except IndexError: + raise exceptions.NotFoundException('Circuit with circuit: {} and provider {}'.format(cid, provider)) from None + return self.netbox_con.patch('/circuits/circuits/', circuits_id, **kwargs) + + def get_providers(self, **kwargs): + """Returns circuit providers""" + return self.netbox_con.get('/circuits/providers/', **kwargs) + + def create_provider(self, name, slug): + """Create a new circuit provider + + :param name: provider name + :param slug: slug name + :return: netbox object if successful otherwise exception raised + """ + required_fields = {"name": name, "slug": slug} + return self.netbox_con.post('/circuits/providers/', required_fields) + + def delete_provider(self, provider_name): + """Delete circuit provider + + :param provider_name: circuit provider to delete + :return: bool True if successful otherwise delete exception + """ + try: + circuits_provider_id = self.get_providers(name=provider_name)[0]['id'] + except IndexError: + raise exceptions.NotFoundException('circuit provider: {}'.format(provider_name)) from None + return self.netbox_con.delete('/circuits/providers/', circuits_provider_id) + + def update_provider(self, provider_name, **kwargs): + """Update circuit provider + + :param provider_name: circuits role to update + :param kwargs: requests body dict + :return: bool True if successful otherwise raise UpdateException + """ + try: + circuits_provider_id = self.get_providers(name=provider_name)[0]['id'] + except IndexError: + raise exceptions.NotFoundException('circuit provider: {}'.format(provider_name)) from None + return self.netbox_con.patch('/circuits/providers/', circuits_provider_id, **kwargs) + + def get_types(self, **kwargs): + """Returns the circuit types""" + return self.netbox_con.get('/circuits/circuit-types/', **kwargs) + + def create_type(self, name, slug): + """Create a new circuit type + + :param name: type name + :param slug: slug name + :return: netbox object if successful otherwise exception raised + """ + required_fields = {"name": name, "slug": slug} + return self.netbox_con.post('/circuits/circuit-types/', required_fields) + + def delete_type(self, type_name): + """Delete circuit type + + :param type_name: circuit type to delete + :return: bool True if succesful otherwase delete exception + """ + try: + circuits_type_id = self.get_types(name=type_name)[0]['id'] + except IndexError: + raise exceptions.NotFoundException('circuit type: {}'.format(type_name)) from None + return self.netbox_con.delete('/circuits/circuit-types/', circuits_type_id) + + def update_type(self, circuit_type_name, **kwargs): + """Update circuit role + + :param circuit_type_name: circuits type to update + :param kwargs: requests body dict + :return: bool True if successful otherwise raise UpdateException + """ + try: + type_id = self.get_types(name=circuit_type_name)[0]['id'] + except IndexError: + raise exceptions.NotFoundException('circuit type: {}'.format(circuit_type_name)) from None + return self.netbox_con.patch('/circuits/circuit-types/', type_id, **kwargs) + + def get_terminations(self, **kwargs): + """Returns the circuits""" + return self.netbox_con.get('/circuits/circuit-terminations/', **kwargs) + + def create_termination(self, circuit, term_side, site, port_speed, **kwargs): + """Create a new circuit termination + + :param circuit: circuit id + :param term_side: term side A or Z + :param site: Site name + :param port_speed: port speed value + :return: netbox object if successful otherwise exception raised + """ + try: + site_id = self.dcim.get_sites(name=site)[0]['id'] + except IndexError: + raise exceptions.NotFoundException('site: {}'.format(site)) from None + + required_fields = {"circuit": circuit, "term_side": term_side, "site": site_id, "port_speed": port_speed} + return self.netbox_con.post('/circuits/circuit-terminations/', required_fields, **kwargs) + + def delete_termination(self, circuit, term_side, site, port_speed): + """Delete circuit termination + + :param circuit: circuit id + :param term_side: term side A or Z + :param site: Site name + :param port_speed: port speed value + :return: bool True if successful otherwise delete exception + """ + try: + site_id = self.dcim.get_sites(name=site)[0]['id'] + except IndexError: + raise exceptions.NotFoundException('site: {}'.format(site)) from None + + try: + circuit_termination = self.get_terminations(circuit_id=circuit, term_side=term_side, site_id=site_id, + port_speed=port_speed)[0]['id'] + except IndexError: + raise exceptions.NotFoundException('circuit termination with given arguments') from None + + return self.netbox_con.delete('/circuits/circuit-terminations/', circuit_termination) + + def update_termination(self, circuit, term_side, site, port_speed, **kwargs): + """Update circuit termination + + :param circuit: circuit id + :param term_side: Termination side + :param site: Dcim Site + :param port_speed: Port speed (Kbps). maximum: 2147483647 + :param kwargs: requests body dict + :return: bool True if successful otherwise raise UpdateException + """ + try: + site_id = self.dcim.get_sites(name=site)[0]['id'] + except IndexError: + raise exceptions.NotFoundException('site: {}'.format(site)) from None + + try: + circuit_termination_id = self.get_terminations(circuit_id=circuit, term_side=term_side, site_id=site_id, + port_speed=port_speed)[0]['id'] + except IndexError: + raise exceptions.NotFoundException('circuit termination with given arguments') from None + + return self.netbox_con.patch('/circuits/circuit-terminations/', circuit_termination_id, **kwargs) diff --git a/netbox/connection.py b/netbox/connection.py index f132ee6..58438aa 100644 --- a/netbox/connection.py +++ b/netbox/connection.py @@ -106,7 +106,7 @@ def patch(self, params, key, **kwargs): body_data = {key: value for (key, value) in kwargs.items()} resp_ok, resp_status, resp_data = self.__request('PATCH', params=params, key=key, body=body_data) if resp_ok and resp_status == 200: - return True + return resp_data else: raise exceptions.UpdateException(resp_data) @@ -134,4 +134,4 @@ def delete(self, params, del_id): def close(self): - self.session.close() \ No newline at end of file + self.session.close() diff --git a/netbox/netbox.py b/netbox/netbox.py index bfd507c..7ee0880 100644 --- a/netbox/netbox.py +++ b/netbox/netbox.py @@ -5,6 +5,7 @@ import netbox.exceptions as exceptions import netbox.tenancy as tenancy import netbox.extras as extras +import netbox.circuits as circuits class NetBox(object): @@ -12,6 +13,7 @@ def __init__(self, host, **kwargs): self.connection = connection.NetboxConnection(host=host, **kwargs) self.ipam = ipam.Ipam(self.connection) self.dcim = dcim.Dcim(self.connection) + self.circuits = circuits.Circuits(self.connection) self.virtualization = virtualization.Virtualization(self.connection) self.tenancy = tenancy.Tenancy(self.connection) self.extras = extras.Extras(self.connection)