Library to communicate with remote servers over GMP or OSP
Project description
Greenbone Vulnerability Management Python Library
The Greenbone Vulnerability Management Python API library (python-gvm) is a collection of APIs that help with remote controlling a Greenbone Security Manager (GSM) appliance and its underlying Greenbone Vulnerability Manager (GVM). The library essentially abstracts accessing the communication protocols Greenbone Management Protocol (GMP) and Open Scanner Protocol (OSP).
Table of Contents
Documentation
The documentation for python-gvm can be found at https://python-gvm.readthedocs.io/. Please always take a look at the documentation for further details. This README just gives you a short overview.
Installation
Requirements
Python 3.5 and later is supported.
Install using pip
Note: All commands listed here use the general tool names. If some of these tools are provided by your distribution, you may need to explicitly use the Python 3 version of the tool, e.g.
pip3
.
You can install the latest stable release of python-gvm from the Python Package Index using pip:
pip install --user python-gvm
Example
from gvm.connections import UnixSocketConnection
from gvm.protocols.gmp import Gmp
from gvm.transforms import EtreeTransform
from gvm.xml import pretty_print
connection = UnixSocketConnection()
transform = EtreeTransform()
with Gmp(connection, transform=transform) as gmp:
# Retrieve GMP version supported by the remote daemon
version = gmp.get_version()
# Prints the XML in beautiful form
pretty_print(version)
# Login
gmp.authenticate('foo', 'bar')
# Retrieve all tasks
tasks = gmp.get_tasks()
# Get names of tasks
task_names = tasks.xpath('task/name/text()')
pretty_print(task_names)
Support
For any question on the usage of python-gvm please use the Greenbone Community Portal. If you found a problem with the software, please create an issue on GitHub.
Maintainer
This project is maintained by Greenbone Networks GmbH.
Contributing
Your contributions are highly appreciated. Please create a pull request on GitHub. For bigger changes, please discuss it first in the issues.
For development you should use pipenv to keep you python packages separated in different environments. First install pipenv via pip
pip install --user pipenv
Afterwards run
pipenv install --dev
in the checkout directory of python-gvm (the directory containing the Pipfile) to install all dependencies including the packages only required for development.
The python-gvm repository used autohooks to apply linting and auto formatting via git hooks. Please ensure the git hooks are active.
$ pipenv install --dev
$ pipenv shell
(python-gvm)$ autohooks activate
License
Copyright (C) 2017-2019 Greenbone Networks GmbH
Licensed under the GNU General Public License v3.0 or later.
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
Hashes for python_gvm-1.2.0-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | a5cc7179ba7485ac749a9197a56b8b500489434b7b354751a76fa0d364e41b48 |
|
MD5 | c8d38047148a37e1eb5e8e6d0edd23f6 |
|
BLAKE2b-256 | b0f075828128311c6eb7e280ebd3233bbf10fea1848574baca2b0a3f8bc87463 |