Client library and tools for Bareos console access.
Project description
python-bareos
python-bareos is a Python module to access a https://www.bareos.com backup system.
Packages for python-bareos are included in the Bareos core distribution and available via https://pypi.org/.
Documentation is available at https://docs.bareos.org/DeveloperGuide/PythonBareos.html
Preparations
Create some named consoles for testing:
root@host:~# bconsole
*configure add console name=user1 password=secret profile=operator TlsEnable=no
*configure add console name=user-tls password=secret profile=operator
This creates a console user with name user1 and the profile operator. The operator profile is a default profile that comes with the Bareos Director. It does allow most commands, but deny some dangerous commands (see show profile=operator), so it is well suited for this purpose. Futhermore, TLS enforcement is disabled for this console user.
For testing with TLS-PSK, we also create the user user-tls.
Examples
Calling bareos-director console commands
>>> import bareos.bsock
>>> directorconsole=bareos.bsock.DirectorConsole(address='localhost', port=9101, name='user1', password='secret')
>>> print(directorconsole.call('help').decode("utf-8"))
This creates a console connection to a Bareos Director. This connection can be used to call commands. These are the same commands as available via bconsole.
To connect to the default console instead, omit the name parameter:
>>> directorconsole = bareos.bsock.DirectorConsole(address='localhost', port=9101, password='defaultconsolepassword')
The result of the call method is a bytes object. In most cases, it has to be decoded to UTF-8.
Simple version of the bconsole in Python
>>> import bareos.bsock
>>> directorconsole = bareos.bsock.DirectorConsole(address='localhost', port=9101, password='secret')
>>> directorconsole.interactive()
Or use the bconsole.py script:
bconsole.py --debug --name=user1 --password=secret localhost
Use JSON objects of the API mode 2
Requires: Bareos >= 15.2
The class DirectorConsoleJson is inherited from DirectorConsole and uses the Director Console API mode 2 (JSON).
For general information about API mode 2 and what data structures to expect, see https://docs.bareos.org/DeveloperGuide/api.html#api-mode-2-json
Example:
>>> import bareos.bsock
>>> directorconsole = bareos.bsock.DirectorConsoleJson(address='localhost', port=9101, password='secret')
>>> pools = directorconsole.call('list pools')
>>> for pool in pools["pools"]:
... print(pool["name"])
...
Scratch
Incremental
Full
Differential
The results the the call method is a dict object.
In case of an error, an exception, derived from bareos.exceptions.Error is raised.
Example:
>>> directorconsole.call("test it")
Traceback (most recent call last):
...
bareos.exceptions.JsonRpcErrorReceivedException: failed: test it: is an invalid command.
Transport Encryption (TLS-PSK)
Since Bareos >= 18.2.4, Bareos supports TLS-PSK (Transport-Layer-Security Pre-Shared-Key) to secure its network connections and uses this by default.
Unfortunately the Python core module ssl does support TLS-PSK only with Python >= 3.13. For some older versions of Python, the extra module sslpsk (see https://github.com/drbild/sslpsk) offers limited support.
Fallback To Unencrypted Connections
Normally DirectorConsole tries to connect using the latest known protocol version. In order to allow connections in more environments, the DirectorConsole can fall back to older protocol versions. Specify protocolversion = None (or 0 as command line argument) to enable automatic fall back. If connecting via TLS-PSK fails, it falls back to the old, unencrypted protocol version. Depending on your bareos-director configuration, unencrypted connections will be accepted:
>>> import bareos.bsock
/.../bareos/bsock/lowlevel.py:39: UserWarning: Connection encryption via TLS-PSK is not available (TLS-PSK is not available in the ssl module and the extra module sslpsk is not installed).
>>> directorconsole=bareos.bsock.DirectorConsole(address='localhost', port=9101, name='user-tls', password='secret', protocolversion=None)
socket error: Conversation terminated (-4)
Failed to connect using protocol version 2. Trying protocol version 1.
>>> print(directorconsole.call('help').decode("utf-8"))
To enforce a encrypted connection, use the tls_psk_require=True parameter:
>>> import bareos.bsock
/.../bareos/bsock/lowlevel.py:39: UserWarning: Connection encryption via TLS-PSK is not available, as the module sslpsk is not installed.
>>> directorconsole=bareos.bsock.DirectorConsole(address='localhost', port=9101, name='user-tls', password='secret', tls_psk_require=True)
Traceback (most recent call last):
...
bareos.exceptions.ConnectionError: TLS-PSK is required, but not available.
In this case, an exception is raised, if the connection can not be established via TLS-PSK.
sslpsk
The extra module sslpsk (see https://github.com/drbild/sslpsk) extends the core module ssl by TLS-PSK.
At the time of writing, the lasted version installable via pip is 1.0.0 (https://pypi.org/project/sslpsk/), which is not working with Python >= 3.
For using python-bareos with TLS-PSK with Python >= 3 and Python <= 3.9 the latest version must by installed manually. At the time of writing, even the latest version (https://github.com/drbild/sslpsk/commit/d88123a75786953f82f5e25d6c43d9d9259acb62) does not support Python >= 3.10. However, Python >= 3.13 has direct support for TLS-PSK in the core ssl module.
Installing the sslpsk module manually:
git clone https://github.com/drbild/sslpsk.git
cd sslpsk
python setup.py build
python setup.py install
python-bareos will detect, that sslpsk is available and will use it automatically. This can be verified by following command:
>>> import bareos.bsock
>>> bareos.bsock.DirectorConsole.is_tls_psk_available()
True
Another limitation of the current sslpsk version is, that it is not able to autodetect the TLS protocol version to use.
In order to use it, specify tls_version with an appropriate protocol version. In most cases this should be tls_version=ssl.PROTOCOL_TLSv1_2, like in the following example:
>>> import ssl
>>> import bareos.bsock
>>> directorconsole = bareos.bsock.DirectorConsoleJson(address='localhost', user='user-tls', password='secret', tls_version=ssl.PROTOCOL_TLSv1_2)
>>> print(directorconsole.call('help').decode("utf-8"))
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file python_bareos-25.0.1.tar.gz.
File metadata
- Download URL: python_bareos-25.0.1.tar.gz
- Upload date:
- Size: 37.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ad2ebb10b0451a9ee10f632c99f688a55caddfe849fd065fbd117bf7a5935217
|
|
| MD5 |
478b3edc7fea700b183576c1096e0d6d
|
|
| BLAKE2b-256 |
22495479b54169aba443f38358423a092d6be1d22e2b2fa477bed1159aad3f5d
|
Provenance
The following attestation bundles were made for python_bareos-25.0.1.tar.gz:
Publisher:
publish-python-packages-to-pypi.yml on bareos/bareos
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
python_bareos-25.0.1.tar.gz -
Subject digest:
ad2ebb10b0451a9ee10f632c99f688a55caddfe849fd065fbd117bf7a5935217 - Sigstore transparency entry: 740515105
- Sigstore integration time:
-
Permalink:
bareos/bareos@76dda6676d20513b4ee0f7c65fcd0a13d9324c6a -
Branch / Tag:
refs/tags/Release/25.0.1 - Owner: https://github.com/bareos
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-python-packages-to-pypi.yml@76dda6676d20513b4ee0f7c65fcd0a13d9324c6a -
Trigger Event:
push
-
Statement type:
File details
Details for the file python_bareos-25.0.1-py3-none-any.whl.
File metadata
- Download URL: python_bareos-25.0.1-py3-none-any.whl
- Upload date:
- Size: 56.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
5319736e8baf0d538204a58c2d3e159e390349f43aca1dda0158ace727b92772
|
|
| MD5 |
44b10f35b2be57353e94aaa5c54fa201
|
|
| BLAKE2b-256 |
e49af9a43d2313399eee6d34195537173b961874b866b8b5f40315b9760ea70d
|
Provenance
The following attestation bundles were made for python_bareos-25.0.1-py3-none-any.whl:
Publisher:
publish-python-packages-to-pypi.yml on bareos/bareos
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
python_bareos-25.0.1-py3-none-any.whl -
Subject digest:
5319736e8baf0d538204a58c2d3e159e390349f43aca1dda0158ace727b92772 - Sigstore transparency entry: 740515141
- Sigstore integration time:
-
Permalink:
bareos/bareos@76dda6676d20513b4ee0f7c65fcd0a13d9324c6a -
Branch / Tag:
refs/tags/Release/25.0.1 - Owner: https://github.com/bareos
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-python-packages-to-pypi.yml@76dda6676d20513b4ee0f7c65fcd0a13d9324c6a -
Trigger Event:
push
-
Statement type: