This framework povides efficient and easier ways to perform common operational tasks in the service provider edge and core network.
The functionality offered provides simple means to execute common time consuming; when caried out with conventional methods; and critical tasks. Embeded subsystems that consume API to interface with some popular network systems such as Solarwinds Orion NMS and Netdot help to bridge the gap between systems and databases hence forth providing seemless workflows.
A service activation tickets would require an operator to
- Check an IP Address Management (IPAM) tool for available address space
- Reserve an address space in IP Address Management (IPAM) tool
- Consult existing vlan database to make sure you get a free vlan-id
- Configure the L3 gateway interface
- Configure traffic policing to ensure access to/from the service is billed accordingly
- Update monitoring system
It is obvious here that some kind of automation would be beneficial for this repetitive task. The best part is, the user does not need to know the underlying CLI command for any particular vendor, everything is a mouse click away.
- Quickly deploy new service by collecting data from your IT infrastructure in a few minutes.
- Maintain consistent configuration and data records for your infrastructure databases
- Issue commands to all network devices at once via centralized interface to quickly pinpoint issues or gather information.
- Automatically schedule bandwidth changes for different services at any time
- Get email alerts on bandwidth changes performed automatically
- Store and archive logs for audit and tracking purposes
- Interface with existing systems with supported APIs
- Get simple access to relevant data from your entire network
- Easy to setup and requires no costly training for installation and user education
- Service search
- VLAN operations
- IPv4 operations
- Service provisioning
- BGP session monitoring
- Services auditing
- Burst packages management
- Bandwidth on demand management
- Network diagram generation for link state protocols (ISIS & OSPF)
- Report generation for customers services availbale on PE routers
- Configuration archiving
The search can be performed against a vlan-id, service description or ipv4 address. The tool uses an algorithm to search for interesting sections of running/active configuration in each active edge router in the network.
Offers the ability to query all active edge routers in the network and find out if an IPv4 prefix or its subnet has been used. Helps in identifying rogue IPv4 addresses configured in the network consequently resolving address and routing conflicts in the network. Allows an operator to locate the edge at which a certain vlan-id has been used. On edge routers with high customer density this tools automates the task of finding free vlans to use for new service provisioning.
Auto provisioning of internet and L2MPLS services on edge routers on a single click. Automatically assigns a vlan-id and IPv4 addresses from IPAM and adds node to NPM for monitoring. Drastically reduces the amount of time (at least 50%) an administrator would use to gather config details and extra time to update documentation/monitoring databases
Offers a client-server relation between the client application running on admin workstation and the server hosting the clients database and config changes. Network admin can easily make use of this unified interface to manage burst clients in a user friendly manner. Offers ability to view clients and their packages, add or remove clients and moving clients between packages.
Admin can add and schedule bandwidth changes to be carried out or reverted at a later time without requiring manual intervention. User has the ability to view scheduled bandwidth changes and to delete or modify them. Offloads manual tracking of temporary bandwidth change requests that is not very efficient.
- Cisco IOS 12 and later, IOS XE
- JunOS 11.4R9 and later
- NETCONF is required for all devices except those running native IOS where SSH is used.
- Solarwinds Orion Swis
- Netdot REST
These instructions assume you already have python installed and python vitual environment module installed
- Python 3.7 or later
- Python virtual environment
Clone this repository
basondole → c:\Users\u\Desktop\basohub\github git clone https://github.com/basondole/bitnoc Cloning into 'bitnoc'... remote: Enumerating objects: 116, done. remote: Counting objects: 100% (116/116), done. remote: Compressing objects: 100% (85/85), done. remote: Total 116 (delta 28), reused 113 (delta 25), pack-reused 0 Receiving objects: 100% (116/116), 639.25 KiB | 824.00 KiB/s, done. Resolving deltas: 100% (28/28), done.
Verify the file structure
basondole → c:\Users\u\Desktop\basohub\github cd bitnoc basondole → c:\Users\u\Desktop\basohub\github\bitnoc ls app.py application core other requirements.txt windows basondole → c:\Users\u\Desktop\basohub\github\bitnoc tree . ├── README.md ├── application │ ├── __init__.py │ ├── database │ │ ├── devices.yml │ │ └── user.db │ ├── forms.py │ ├── models.py │ ├── static │ │ ├── css │ │ │ ├── bootstrap.min.css │ │ │ ├── docs.min.css │ │ │ └── fontawesome.all.css │ │ ├── images │ │ │ ├── default │ │ │ │ └── router.gif │ │ │ ├── paul-icon.ico │ │ │ └── svg │ │ │ └── bootstrap.svg │ │ ├── jquery │ │ │ ├── jquery-3.3.1.min.js │ │ │ └── jquery-ui.js │ │ ├── js │ │ │ ├── bootstrap.min.js │ │ │ ├── d3.v4.min.js │ │ │ ├── jquery.validate.min.js │ │ │ └── popper.min.js │ │ └── miserables.json │ └── templates │ ├── home.html │ ├── html │ │ └── bgp-neighbor-monitor-table.html │ ├── json │ │ └── rasimu.json │ ├── layout.html │ ├── login.html │ ├── register.html │ ├── renders │ │ └── text-output.html │ ├── view-bgp-neighbor-monitor.html │ ├── view-network-diagram.html │ ├── view-service-audit.html │ └── view-text-output.html ├── core │ ├── NetdotOrion.py │ ├── __init__.py │ ├── bgp_summary.py │ ├── config_backup.py │ ├── find_vlan_duo.py │ ├── find_vlan_uno.py │ ├── get_intf_cisco_summary.py │ ├── get_intf_summary.py │ ├── link_state.py │ ├── locate_ip.py │ ├── locate_name.py │ ├── locate_vlan.py │ ├── send_command.py │ └── service_provision.py ├── other │ ├── Essential.py │ ├── __init__.py │ └── getDeviceData.py ├── requirements.txt ├── run.py └── windows ├── Command.py ├── Devices.py ├── Settings.py └── __init__.py 16 directories, 54 files
Create a python virtual environment
basondole → c:\Users\u\Desktop\basohub\github\bitnoc python -m venv bitnoc basondole → c:\Users\u\Desktop\basohub\github\bitnoc ls app.py application bitnoc core other requirements.txt windows basondole → c:\Users\u\Desktop\basohub\github\bitnoc bitnoc\Scripts\activate
Install the required python packages
(bitnoc) basondole → c:\Users\u\Desktop\basohub\github\bitnoc pip install -r requirements.txt Collecting bcrypt==3.1.7 (from -r requirements.txt (line 1)) . . Successfully installed Flask-1.1.1 Flask-Bcrypt-0.7.1 ...
Run the application with python
(bitnoc) basondole → c:\Users\u\Desktop\basohub\github\bitnoc python run.py * Serving Flask app "application" (lazy loading) * Environment: development * Debug mode: on * Restarting with stat * Debugger is active! * Debugger PIN: XXX-XXX-XXX * Running on http://127.0.0.1:5000/ (Press CTRL+C to quit)
Open the browser and access http://127.0.0.1:5000/
or http://localhost:5000/
Once the web portal loads complete the setup by
- Click sign up to create a user account and you will be redirected to a settings page.
- Set Path to device database: as
./application/database/
- Specify the ssh authentication server with its port number.
- Save the settings and you will be redirected back to the login page
- Create a user account via the sign up link.
Note: The username and password must be the same as the credentials used for ssh access to your network.
It may take a minute for a user to be registered as the server tries to verify the user credentials against the specified authentication server.
Note: this installation will only be availbale on local host, further windows firewall tweaking must be done to allow external connection to access the server
Clone the git repo
[root@basondole ~]# git clone https://github.com/basondole/bitnoc Cloning into 'bitnoc'... remote: Enumerating objects: 175, done. remote: Counting objects: 100% (175/175), done. remote: Compressing objects: 100% (123/123), done. remote: Total 175 (delta 67), reused 147 (delta 45), pack-reused 0 Receiving objects: 100% (175/175), 659.23 KiB | 710.00 KiB/s, done. Resolving deltas: 100% (67/67), done.
Create a virtual environment and install required packages
[root@basondole ~]# cd bitnoc/ [root@basondole bitnoc]# python3 -m venv bitnoc [root@basondole bitnoc]# source bitnoc/bin/activate (bitnoc) [root@basondole bitnoc]# pip3 install -r requirements.txt Collecting bcrypt==3.1.7 (from -r requirements.txt (line 1)) . . Running setup.py install for PyYAML ... done Running setup.py install for Flask-Bcrypt ... done Running setup.py install for SQLAlchemy ... done Running setup.py install for future ... done Running setup.py install for ipaddr ... done Running setup.py install for IPy ... done Running setup.py install for ncclient ... done Running setup.py install for nxapi-plumbing ... done Running setup.py install for pyIOSXR ... done Running setup.py install for pyeapi ... done Running setup.py install for orionsdk ... done Running setup.py install for pynetdot ... done Running setup.py install for yamlordereddictloader ... done Successfully installed Flask-1.1.1 Flask-Bcrypt-0.7.1 Flask-Login-0.5.0 ... (bitnoc) [root@basondole bitnoc]#
If you run the server at this point as
python run.py
, you will notice that the server is only available from your own computer, not from any other in the network. This is the default because in debugging mode a user of the application can execute arbitrary Python code on your computer. If you have debug disabled or trust the users on your network, you can make the server publicly available.
You need to make some changes to make it run on your machines IP address.
Edit the file run.py
and change the line app.run(debug=True)
to app.run(host= '0.0.0.0',debug=True)
Bitnoc runs on port 5000. You need to allow external connection to your server on this port for the app to be available on other hosts in your network. By default centos wont be listening to this port, to change this default behavior
Add the port by editing the file /etc/services
[root@basondole bitnoc]# cat /etc/services | grep bitnoc flask-bitnoc 5000/tcp # Flask Bitnoc
Open firewall ports. In this installation, the app will only be accessible from the host 10.18.17.28/32
Therefore the port 5000
will only be opened for this host
[root@basondole bitnoc]# firewall-cmd --permanent --zone=public --add-rich-rule=' > rule family="ipv4" > source address="10.18.17.28/32" > port protocol="tcp" port="5000" accept' success [root@basondole bitnoc]# firewall-cmd --reload success
Verify the zone
[root@basondole bitnoc]# cat /etc/firewalld/zones/public.xml <?xml version="1.0" encoding="utf-8"?> <zone> <short>Public</short> <description> For use in public areas. You do not trust the other computers on networks to not harm your computer. Only selected incoming connections are accepted. </description> <service name="tftp"/> <service name="dhcpv6-client"/> <service name="ssh"/> <rule family="ipv4"> <source address="10.18.17.28/32"/> <port protocol="tcp" port="5000"/> <accept/> </rule> </zone> [root@basondole bitnoc]#
Check newly added port status
[root@basondole bitnoc]# iptables-save | grep 5000 -A IN_public_allow -p tcp -m tcp --dport 5000 -m conntrack --ctstate NEW,UNTRACKED -j ACCEPT
Confirm the port is open by doing a nmap scan from the host 10.18.17.28
to the server 10.21.2.8
basondole → C:\Users\u nmap -n -p 5000 10.21.2.8 Starting Nmap 7.80 ( https://nmap.org ) at 2020-03-13 19:29 E. Africa Standard Time Nmap scan report for 10.21.2.8 Host is up (0.0021s latency). PORT STATE SERVICE 5000/tcp open upnp Nmap done: 1 IP address (1 host up) scanned in 2.59 seconds
Run the app
(bitnoc) [root@basondole bitnoc]# python run.py * Serving Flask app "application" (lazy loading) * Environment: development * Debug mode: on * Running on http://0.0.0.0:5000/ (Press CTRL+C to quit) * Restarting with stat * Debugger is active! * Debugger PIN: XXX-XXX-XXX
Browse any of the IP configured on this server to access the application from the host 10.18.17.28
http://10.21.2.8:5000
sudo yum install supervisor sudo nano /etc/supervisor/conf.d/bitnoc.conf or sudo nano /etc/supervisord.conf [program:bitnoc] directory=/home/paul/bitnoc command=/home/paul/bitnoc/bitnoc/bin/python3 run.py user=Paul autostart=True autorestart=true stopasgroup=true killasgroup=true stderr_logfile=/var/log/bitnoc/bitnoc.err.log stdout_logfile=/var/log/bitnoc/bitnoc.out.log sudo mkdir -p /var/log/bitnoc/ sudo touch /var/log/bitnoc/bitnoc.err.log sudo touch /var/log/bitnoc/bitnoc.out.log sudo supervisorctl reload or sudo service supervisord start sudo systemctl status supervisord.service sudo systemctl enable supervisord