Admin Vaultwarden and Simple Bitwarden Python Client
Project description
python-vaultwarden
A python client library for vaultwarden.
Rationale
While there are numerous clients for bitwarden, its low-level Python client libraries ecosystem is not well stuffed yet.
We at Numberly are strong users (and supporters) of vaultwarden and needed a way to integrate admin operations into our automation stack.
We took inspiration from bitwardentools and leverage from it internally while adding some admin related features so that we can automate vaultwarden administration tasks.
Contributions welcomed!
Clients
There are 2 types of clients:
- One for the vaultwarden admin API, that needs to be authenticated with an admin token.
- One for the bitwarden API, that needs to be authenticated with the user api keys or user's mail and password. An Owner or Admin user is required to perform admin operations.
The reset_account
and transfer_account_rights
from the Admin client needs a valid Bitwarden client to re-invite the
target user.
Installation
pip install python-vaultwarden
Usage
Admin client
from vaultwarden.clients.vaultwarden import VaultwardenAdminClient
client = VaultwardenAdminClient(url="https://vaultwarden.example.com", admin_secret_token="admin_token")
client.invite("john.doe@example.com")
all_users = client.get_all_users()
client.delete(all_users[0].id)
Bitwarden client
from vaultwarden.clients.bitwarden import BitwardenAPIClient
from vaultwarden.models.bitwarden import Organization, OrganizationCollection, get_organization
bitwarden_client = BitwardenAPIClient(url="https://vaultwarden.example.com", email="admin@example", password="admin_password", client_id="client_id", client_secret="client_secret")
org_uuid = "550e8400-e29b-41d4-a716-446655440000"
orga= get_organization(bitwarden_client, org_uuid)
collection_id_list = ["666e8400-e29b-41d4-a716-446655440000", "888e8400-e29b-41d4-a716-446655440000", "770e8400-e29b-41d4-a716-446655440000" ]
orga.invite(email="new@example.com", collections=collection_id_list, default_readonly=True, default_hide_passwords=True)
org_users = orga.users()
org_collections: list[OrganizationCollection] = orga.collections()
org_collections_by_name: dict[str: OrganizationCollection] = orga.collections(as_dict=True)
new_coll = orga.create_collection("new_collection")
orga.delete_collection(new_coll.Id)
my_coll = orga.collection("my_collection")
if new_coll:
users_coll = my_coll.users()
my_coll_2 = org_collections_by_name["my_coll_2"]
my_user = orga.users(search="john.doe@example.com")
if my_user:
my_user = my_user[0]
print(my_user.Collections)
my_user.add_collections([my_coll_2.Id])
Credits
The crypto part originates from bitwardentools.
Contributing
Thank you for being interested in contributing to python-vaultwarden
. There are many ways you can contribute to the project:
- Try and report bugs/issues you find
- Implement new features
- Review Pull Requests of others
- Write documentation
- Participate in discussions
Development
To start developing create a fork of the python-vaultwarden repository on GitHub.
Then clone your fork with the following command replacing YOUR-USERNAME with your GitHub username:
git clone https://github.com/YOUR-USERNAME/python-vaultwarden
You can now install the project and its dependencies using:
pip install -e .[test]
Testing
To run the tests, use:
bash tests/e2e/run_tests.sh
License
Python-vaultwarden is distributed under the terms of the Apache-2.0 license.
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 python_vaultwarden-1.0.1.tar.gz
.
File metadata
- Download URL: python_vaultwarden-1.0.1.tar.gz
- Upload date:
- Size: 18.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: python-httpx/0.27.2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | dc0c2ca92d83e26adcc3aa2d96b8bda81b9aa74479605ed54ad93dfea92cb245 |
|
MD5 | 3e69e295d5e873a96c199c5526321177 |
|
BLAKE2b-256 | c44bcf4b35e0e52d01fc97d8e17feec6938329896ce6b22abcffddf95a23a6e9 |
File details
Details for the file python_vaultwarden-1.0.1-py3-none-any.whl
.
File metadata
- Download URL: python_vaultwarden-1.0.1-py3-none-any.whl
- Upload date:
- Size: 20.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: python-httpx/0.27.2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | ff06b8a61047cc3e1669ef5a8cf26c5694811140073327feca5336c223f7a00a |
|
MD5 | 4f43c81ff64c7a7fb96d1eff64a1ef12 |
|
BLAKE2b-256 | 81456a0bb616f96258e1f40fbf362cb8424444f89f1ac66f69a81874bfd5df55 |