A unified REST API to provide vendor-agnostic network automation
Project description
Netman
Netman is a unified REST API that provides vendor-agnostic network automation. It abstracts the vendor-specific bits and leaves you with a clean and simplified API.
Python code usage
switch_factory = SwitchFactory(MemoryStorage(), ThreadingLockFactory())
switch = switch_factory.get_anonymous_switch(
model="cisco",
hostname="hostname_or_ip",
username="username",
password="password",
)
switch.add_vlan(1000, name="myvlan")
REST API usage
First, start the service
tox
.tox/py27/bin/python netman/main.py
* Running on http://127.0.0.1:5000/ (Press CTRL+C to quit)
Then you can access it by http
curl -X POST http://127.0.0.1:5000/switches/hostname_or_ip/vlans -d '{"number": 1000, "name": "myvlan"}'
-H "Content-Type: application/json"
-H "Netman-model: cisco"
-H "Netman-username: username"
-H "Netman-password: password"
Disaggregated mode
Netman supports a disaggregated mode. This is a special mode of operation where netman will use a remote netman server to access the network equipment. This mode is particularly useful in the case where your network equipment is not available to your main netman server. You can start a server somewhere, let's say at 192.168.1.1, running netman as described above. And use the proxy like this for direct code usage :
switch_factory = SwitchFactory(MemoryStorage(), ThreadingLockFactory())
switch = switch_factory.get_anonymous_switch(
model="cisco",
hostname="hostname_or_ip",
username="username",
password="password",
netman_server="http://192.168.1.1")
switch.add_vlan(1000, name="myvlan")
Or when invoked using the REST API, you can call the main server and provide the proxy netman server to be used.
curl -X POST http://127.0.0.1:5000/switches/hostname_or_ip/vlans -d '{"number": 1000, "name": "myvlan"}'
-H "Content-Type: application/json"
-H "Netman-model: cisco"
-H "Netman-username: username"
-H "Netman-password: password"
-H "Netman-Proxy-Server: http://192.168.1.1"
Docker usage
From your computer, start a Netman container and a fake-switch container in order to mock a switch Netman will configure.
$ docker-compose up -d
Create a Vlan
curl -X POST http://localhost:32771/switches/netman_tsr1.yul1.example.net_1/vlans -d '{"number": 1000, "name": "myvlan"}'
-H "Content-Type: application/json"
-H "Netman-model: cisco"
-H "Netman-username: root"
-H "Netman-password: root"
Get information of an existing Vlan
curl -X GET http://localhost:32771/switches/netman_tsr1.yul1.example.net_1/vlans/1000
-H "Content-Type: application/json"
-H "Netman-model: cisco"
-H "Netman-username: root"
-H "Netman-password: root"
Contributing
Feel free to raise issues and send some pull request, we'll be happy to look at them!
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file netman-1.5.1.tar.gz
.
File metadata
- Download URL: netman-1.5.1.tar.gz
- Upload date:
- Size: 184.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.9.13
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 6aca8c9bb99f80dd2da4b5deb791a693439d8ce549e7a518572894fd2fda5589 |
|
MD5 | 77ab663e237a175d9e19681f038e8a5d |
|
BLAKE2b-256 | 1988fd5138d3efb573d49287245c24b6ef603a3197725de1be40731f44e22fa3 |
File details
Details for the file netman-1.5.1-py2-none-any.whl
.
File metadata
- Download URL: netman-1.5.1-py2-none-any.whl
- Upload date:
- Size: 121.4 kB
- Tags: Python 2
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.9.13
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 5e00b6417aec5b4710aec5e89a1686f128bcff980fbb9b2450676623c3eb4352 |
|
MD5 | a831d47d17fb2e74ba477296b1174191 |
|
BLAKE2b-256 | 20db9cd5a49bb2411eab56fa0417f7ea0d6f1a0474f6c04ecd759cadbc210199 |