Python client library for the Hudu API
Project description
hudu-magic
A tiny, enum-driven, class-based Python API client for Hudu.
- Minimal dependencies (requests)
- Generated from OpenAPI
- Low Maintenance
- Designed for clarity and maintainability
Quick Start
from hudu_magic import HuduClient
client = HuduClient(
api_key="your_api_key",
instance_url="https://yourinstance.huducloud.com"
)
company = client.companies.create(name="Test Company")
# Use a real asset_layout_id from your Hudu instance (e.g. from client.asset_layouts.list()).
asset = client.assets.create(
company_id=company.id,
name="Router",
asset_layout_id=1,
)
asset.name = "Updated Router"
asset.save()
asset.delete()
Installation
Install package
pip install hudu-magic
Usage Info and Guide
There are several examples in the examples folder that might be helpful if you're just starting out
Core Concepts
Client
Handles auth, requests, pagination, wrapping.
client.assets.list()
Collections
Collection-level operations:
- list()
- get()
- create()
- delete()
- archive()
- unarchive()
assetsforcompany.save()
assetsforcompany.delete()
assetsforcompany.archive()
Models (HuduObject)
Instance-level operations:
- save()
- delete()
- refresh()
- relate_to()
- list_photos()
- list_uploads()
- relate_to()
- upload_to()
asset.save()
asset.delete()
Special Model Methods
Companies
mycompany.list_assets()
mycompany.list_articles()
mycompany.list_passwords()
mycompany.list_procedures()
mycompany.list_websites()
mycompany.create_website()
Creating Objects
The create base method for all objects is simple. you can specify properties in either the payload object (standard dictionary) or as kwargs (just propertyname=value)
This means you can use either:
kwargs (recommended)
client.assets.create(name="Router", company_id=1, asset_layout_id=10)
dict payload
client.assets.create(payload={"name": "Router", "company_id": 1, "asset_layout_id": 10})
Updating Objects
asset.name = "New Name"
asset.save()
or
asset.update(name="New Name")
Relations
asset.relate_to(website)
or
client.relations.create(from_obj=asset, to_obj=website)
Uploads
asset.upload_to("file.zip")
uploads = asset.list_uploads()
Photos
asset.add_photo("image.png")
photos = asset.list_photos()
Generating builds for new Hudu versions or previous versions
-
Place openapi spec file https://yoururl.huducloud.com/api-docs.json in project directory as hudu-openapiv1.json
-
run
python generate_endpoints.pyafter sourcing virtual environment (that has dev dependencies installed) -
run
./build.sh
todo: .\build.ps1
this is designed to be super simple so that subsequent releases can eventually just be automatically generated, tested, validated, and pushed to pypi.
Note on building and tests
- Run tests with
./build.sh --test(orpytestfrom a dev environment withpip install -e ".[dev]"). - Integration tests are skipped unless you set
HUDU_RUN_INTEGRATION=1. With that set, copytestenv.exampletotestenvand fill inHUDU_TEST_API_KEYandHUDU_TEST_INSTANCE.
Error Handling, Additional Info / Help
If more information is needed, you can call this method on class members to get all associated info from hudu's API spec-
huduobject.help()
For resources such as client.assets, you can call:
client.assets.describe()
or for more verbose info:
client.assets.help()
if an object type or resource doesnt support a method call or payload param, you'll be notified of which one(s), if any, are invalid.
Special Class Methods
Advanced Use Possibilities
Multi-Client
You can instantiate two or more client objects, like above, to transfer data from, say, your dev instance to production. This hasn't been extensively tested expecially for objects dependent on companies (assets, passwordfolders)
client2.assets.create(
**client1.assets.get(6).to_dict()
)
Philosophy
- Simple > clever
- Explicit > implicit
- Thin wrapper over Hudu API
License
MIT
Versioning convention
PyPI releases use a library SemVer prefix and a numeric suffix derived from the Hudu OpenAPI spec used to generate HuduEndpoint and related code:
MAJOR.MINOR.HUDUSPECVERSION
-
MAJOR/MINOR— reserved for this Python package (breaking API changes, larger feature sets, and so on). -
HUDUSPECVERSION— encodes the spec’s(major, minor, patch)as a single integer:hudu_spec_major * 1000 + hudu_spec_minor * 10 + hudu_spec_patchExample: OpenAPI 2.41.0 →
2 * 1000 + 41 * 10 + 0= 2410 → package segment 0.1.2410 (with0.1as the current library prefix).
When Hudu publishes a new spec, regenerate and bump HUDUSPECVERSION accordingly. For Python-only fixes (same spec, no regeneration), prefer a PEP 440 suffix such as 0.1.2410.post1 so the encoded spec stays honest.
Spec used for the current release: Hudu OpenAPI 2.41.0 (as of 2026-04-06). The canonical package version is in pyproject.toml.
History
Hudu 2.41.0 Spec
- v0.1.2410 - Apr 6, 2026
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 hudu_magic-0.1.2410.tar.gz.
File metadata
- Download URL: hudu_magic-0.1.2410.tar.gz
- Upload date:
- Size: 41.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e8e2a1d8d6a7970eba085a867310450f94cc3f7518c59cdb8fc0223395517dfe
|
|
| MD5 |
7efa8728a2aa98951342d3ddbc1d6928
|
|
| BLAKE2b-256 |
6af572cf869d0eaa76a624c4841035ce916c182df69c18be65fe3139f89cb64d
|
Provenance
The following attestation bundles were made for hudu_magic-0.1.2410.tar.gz:
Publisher:
publish-pypi.yml on Hudu-Technologies-Inc/hudu-magic
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
hudu_magic-0.1.2410.tar.gz -
Subject digest:
e8e2a1d8d6a7970eba085a867310450f94cc3f7518c59cdb8fc0223395517dfe - Sigstore transparency entry: 1244719326
- Sigstore integration time:
-
Permalink:
Hudu-Technologies-Inc/hudu-magic@479167fc273b8bef2b13de1972807a2e2370e94d -
Branch / Tag:
refs/tags/0.1.2410 - Owner: https://github.com/Hudu-Technologies-Inc
-
Access:
private
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-pypi.yml@479167fc273b8bef2b13de1972807a2e2370e94d -
Trigger Event:
release
-
Statement type:
File details
Details for the file hudu_magic-0.1.2410-py3-none-any.whl.
File metadata
- Download URL: hudu_magic-0.1.2410-py3-none-any.whl
- Upload date:
- Size: 42.8 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 |
d6a6708a050ea6fc4aedcb3a07cca984145124e0d4c5c75ed785f43a1a50b716
|
|
| MD5 |
f6de8161832f8209665db3bd63854d8a
|
|
| BLAKE2b-256 |
7500b970c4c344f63bb45a9b14b30a57039408672ca11097b90629de00d9332b
|
Provenance
The following attestation bundles were made for hudu_magic-0.1.2410-py3-none-any.whl:
Publisher:
publish-pypi.yml on Hudu-Technologies-Inc/hudu-magic
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
hudu_magic-0.1.2410-py3-none-any.whl -
Subject digest:
d6a6708a050ea6fc4aedcb3a07cca984145124e0d4c5c75ed785f43a1a50b716 - Sigstore transparency entry: 1244719626
- Sigstore integration time:
-
Permalink:
Hudu-Technologies-Inc/hudu-magic@479167fc273b8bef2b13de1972807a2e2370e94d -
Branch / Tag:
refs/tags/0.1.2410 - Owner: https://github.com/Hudu-Technologies-Inc
-
Access:
private
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-pypi.yml@479167fc273b8bef2b13de1972807a2e2370e94d -
Trigger Event:
release
-
Statement type: