Python API to RouterBoard devices produced by MikroTik.
Project description
RouterOS-api
Python API to RouterBoard devices produced by MikroTik written by Social WiFi.
Usage
Connection
#!/usr/bin/python
import routeros_api
connection = routeros_api.RouterOsApiPool('IP', username='admin', password='')
api = connection.get_api()
Connect Options
routeros_api.RouterOsApiPool(
host,
username='admin',
password='',
port=8728,
use_ssl=False,
ssl_verify=True,
ssl_verify_hostname=True,
ssl_context=None,
)
Parameters:
host
- String - Hostname or IP of device
Optional Parameters:
username
- String - Login username - Default 'admin'password
- String - Login password - Default empty stringport
- Integer - TCP Port for API - Default 8728 or 8729 when using SSLplaintext_login
- Boolean - Try plaintext login (for RouterOS 6.43 onwards) - Default Falseuse_ssl
- Boolean - Use SSL or not? - Default Falsessl_verify
- Boolean - Verify the SSL certificate? - Default Truessl_verify_hostname
- Boolean - Verify the SSL certificate hostname matches? - Default Truessl_context
- Object - Pass in a custom SSL context object. Overrides other options. - Default None
Using SSL
If we want to use SSL, we can simply specify use_ssl
as True
:
connection = routeros_api.RouterOsApiPool('<IP>', username='admin', password='', use_ssl=True)
This will automatically verify SSL certificate and hostname.
The most flexible way to modify SSL parameters is to provide an SSL Context object using the
ssl_context
parameter, but for typical use-cases with self-signed certificates, the shorthand options of
ssl_verify
and ssl_verify_hostname
are provided.
e.g. if using a self-signed certificate, you can (but probably shouldn't) use:
connection = routeros_api.RouterOsApiPool(
'<IP>',
username='admin',
password='',
use_ssl=True,
ssl_verify=False,
ssl_verify_hostname=False,
)
Login for RouterOS v6.43 onwards
RouterOS Versions v6.43 onwards now use a different login method.
The disadvantage is that it passes the password in plain text.
For security we only attempt the plaintext login if requested using the plaintext_login
parameter.
It is highly recommended only to use this option with SSL enabled.
routeros_api.RouterOsApiPool(host, username='admin', password='', plaintext_login=True)
Execute Commands
Call this with a resource and parameters as name/value pairs.
api.get_binary_resource('/').call('<resource>',{ <dict of params> })
Examples
api.get_binary_resource('/').call('tool/fetch',{ 'url': "https://dummy.url" })
api.get_binary_resource('/').call('ping', { 'address': '192.168.56.1', 'count': '4' })
Fetch List/Resource
list = api.get_resource('/command')
Example
list_queues = api.get_resource('/queue/simple')
Show all elements
list_queues.get()
Add rules
list.add(attribute="vale", attribute_n="value")
NOTE: Atributes with -
, like max-limit
use underscore _
: max_limit
Example:
list_queues.add(name="001", max_limit="512k/4M", target="192.168.10.1/32")
Update Values
list.set(id, attributes)
Example:
list_queues.set(id="*2", name="jhon")
Get element:
list.get(attribute=value)
Example:
list_queues.get(name="jhon")
Remove element:
list.remove(id)
Example:
list_queues.remove(id="*2")
Close conection:
connection.disconnect()
Other Example:
list_address = api.get_resource('/ip/firewall/address-list')
list_address.add(address="192.168.0.1",comment="P1",list="10M")
list_address.get(comment="P1")
list_address.remove(id="*7")
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 routeros_api-0.18.0.tar.gz
.
File metadata
- Download URL: routeros_api-0.18.0.tar.gz
- Upload date:
- Size: 12.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.0.0 CPython/3.9.12
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | a2680b1dadebb5f93f501b3a531937717c7307dedb66dd35b987bedeb984e517 |
|
MD5 | 07813621c7bb9806f8a0fe9472f08753 |
|
BLAKE2b-256 | 77f26b4b0cadcff891df5041744971384f7ab9f1072ac2cfa491ca2f5e869525 |
File details
Details for the file RouterOS_api-0.18.0-py2.py3-none-any.whl
.
File metadata
- Download URL: RouterOS_api-0.18.0-py2.py3-none-any.whl
- Upload date:
- Size: 20.7 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.0.0 CPython/3.9.12
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 0f232b190859d2fbe74667a0e37d44d9e611086bd467b5f15ce463f8da26d8ff |
|
MD5 | 1c1103fffb47576beb2b0d43908c3286 |
|
BLAKE2b-256 | e2fbda352a380c15cd931a0fbd44822591bbd84d8a62a94ee5c314515b957b1c |