Skip to main content

Library to communicate with remote servers over GMP or OSP

Project description

Greenbone Logo

Greenbone Vulnerability Management Python Library

GitHub releases PyPI release Scrutinizer Code Quality code test coverage CircleCI

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.latest import Gmp
from gvm.transforms import EtreeTransform
from gvm.xml import pretty_print

connection = UnixSocketConnection()
transform = EtreeTransform()
gmp = Gmp(connection, transform=transform)

# 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.

Please create your git commits from within the Python environment to apply our git hooks.

$ pipenv install --dev
$ pipenv shell
(python-gvm)$ git commit

License

Copyright (C) 2017-2019 Greenbone Networks GmbH

Licensed under the GNU General Public License v3.0 or later.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

python-gvm-1.1.0.tar.gz (101.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

python_gvm-1.1.0-py3-none-any.whl (318.5 kB view details)

Uploaded Python 3

File details

Details for the file python-gvm-1.1.0.tar.gz.

File metadata

  • Download URL: python-gvm-1.1.0.tar.gz
  • Upload date:
  • Size: 101.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.0.0 pkginfo/1.5.0.1 requests/2.21.0 setuptools/41.6.0 requests-toolbelt/0.9.1 tqdm/4.38.0 CPython/3.7.3

File hashes

Hashes for python-gvm-1.1.0.tar.gz
Algorithm Hash digest
SHA256 338095add45b499fb5758e8bf7c87b809c09581244578c338b2f521e60453d63
MD5 c3d85c6917b3d2fcf9019f29f5e2511a
BLAKE2b-256 c6016a3758ecba7f2d52f72223eb14d335e61071e6d6f3221a899d521b77d6b2

See more details on using hashes here.

File details

Details for the file python_gvm-1.1.0-py3-none-any.whl.

File metadata

  • Download URL: python_gvm-1.1.0-py3-none-any.whl
  • Upload date:
  • Size: 318.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.0.0 pkginfo/1.5.0.1 requests/2.21.0 setuptools/41.6.0 requests-toolbelt/0.9.1 tqdm/4.38.0 CPython/3.7.3

File hashes

Hashes for python_gvm-1.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 7af7aa5050b01b7c8a1f6fb38659827f22b5c68217e0b5c8b809fae06f91910b
MD5 f3a14e06a525398afac0282c750b729b
BLAKE2b-256 d759b854cb30679c1d6551a2cc7a4bd4d51ab73685ecb12cfe6ca6ae59abf158

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page