Asynchronous Python client library for the Habitica API
Project description
Habiticalib
Modern asynchronous Python client library for the Habitica API
Habiticalib is a Python library for interacting with the Habitica API. It provides an organized, typed interface to work with Habitica’s features, including tasks, user data, and avatars. The goal of this library is to simplify integration with Habitica.
Key features
- Asynchronous: The library is fully asynchronous, allowing non-blocking API calls.
- Fully typed with Dataclasses: The library is fully typed using Python
dataclasses
. It handles serialization withmashumaro
andorjson
for efficient conversion between Habitica API JSON data and Python objects. - Dynamic avatar image generation: Habiticalib can fetch all necessary assets (like equipped items, pets, and mounts) and combine them into a single avatar image. This image can be saved to disk or returned as a byte buffer for further processing. Fetch user data: Retrieve and manage user data such as stats, preferences, and items. User data is structured with dataclasses to make it easy to work with.
- Task management: Support for creating, updating, and retrieving Habitica tasks (to-dos, dailies, habits, rewards) is provided.
- Task status updates: The library allows updates for task statuses, habit scoring, and daily completion.
- Tags: Habiticalib supports the creation, updating and deletion of tags.
- Stat allocation, class cystem and sleep: The library offers methods for stat point allocation and switching between Habitica classes. It also provides the ability to disable the class system and pausing damage(resting in the inn)
Installation
pip install habiticalib
Getting started
Here’s an example to demonstrate basic usage:
import asyncio
from aiohttp import ClientSession
from habiticalib import Habitica, TaskType
async def main():
async with ClientSession() as session:
habitica = Habitica(session)
# Login to Habitica
habitica.login(username="your_username", password="your_password")
# Fetch user data
user_data = await habitica.user()
print(f"Your current health: {user_data.stats.hp}")
# Fetch all tasks (to-dos, dailies, habits, and rewards)
tasks = await habitica.get_tasks()
print("All tasks:")
for task in tasks:
print(f"- {task.text} (type: {task.type})")
# Fetch only to-dos
todos = await habitica.get_tasks(task_type=TaskType.TODO)
print("\nTo-Do tasks:")
for todo in todos:
print(f"- {todo.text} (due: {todo.date})")
# Fetch only dailies
dailies = await habitica.tasks(task_type=TaskType.DAILY)
print("\nDailies:")
for daily in dailies:
print(f"- {daily.text}")
asyncio.run(main())
Documentation
For full documentation and detailed usage examples, please visit the Habiticalib documentation.
License
This project is licensed under the terms of the MIT 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 habiticalib-0.1.0a3.tar.gz
.
File metadata
- Download URL: habiticalib-0.1.0a3.tar.gz
- Upload date:
- Size: 67.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: python-httpx/0.27.2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | ebd97ed5ee915b44fd3b83f565cb9054a7d0841f32cc496bf30570e50d001219 |
|
MD5 | f7055a3ea3e7af75e250690a81d458a4 |
|
BLAKE2b-256 | ffba4cf5b7845f874a416c479a7ecfc7d09f8d3a78ee55417127f346bc53dbc4 |
File details
Details for the file habiticalib-0.1.0a3-py3-none-any.whl
.
File metadata
- Download URL: habiticalib-0.1.0a3-py3-none-any.whl
- Upload date:
- Size: 23.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: python-httpx/0.27.2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 7fb944e5055b219759340f9966518e9d9ea7bf45dbff0f89ef777801e6f4f0b5 |
|
MD5 | 32e40b4d44652c9791ac93e8351e7218 |
|
BLAKE2b-256 | d7af47ecdc0ca50f4811d313fa1b44573b0d5884f0dc4644fe93798089116ebd |