Skip to main content

Async library for Audiobookshelf

Project description

aioaudiobookshelf

Async python library to interact with Audiobookshelf (ABS).

This lib's primary goal is to be used within the Audiobookshelf music provider in Music Assistant, but it can be used independently. Calls to endpoints not needed for the provider will be added over time.

Not all endpoints are yet implemented.

Releases

Releases can be found on pypi, and are tagged.

Basic usage

ABS has a rest api, documented here and additionally uses socket.io, see here for some event driven functionality. Accessibility to the endpoints is determined by the user types, which may be root, admin, user, guest. This lib is not tested with a guest user.

As of 0.1.2 this lib has two different clients, the UserClient and the SocketClient. Admin endpoints are not yet implemented. The user client handles calls to the Rest API, the socket client allows to subscribe to certain events.

To authenticate the socket client, you always need the user's token, username and password are not enough. The user client can be authenticated by username and password, which yields the token.

Usage example:

import asyncio
import logging
import os

import aiohttp

from aioaudiobookshelf import SessionConfiguration, get_user_client
from aioaudiobookshelf.schema.library import LibraryItemMinifiedBook, LibraryItemMinifiedPodcast

ABS_HOST = os.environ.get("ABS_HOST")
ABS_USER = os.environ.get("ABS_USER")
ABS_PASSWORD = os.environ.get("ABS_PASSWORD")


async def abs_basics():
    assert ABS_HOST is not None
    assert ABS_USER is not None
    assert ABS_PASSWORD is not None

    logger = logging.getLogger()
    logger.setLevel(logging.INFO)

    async with aiohttp.ClientSession() as session:
        client = await get_user_client(
            session_config=SessionConfiguration(
                session=session, url=ABS_HOST, logger=logger, pagination_items_per_page=30
            ),
            username=ABS_USER,
            password=ABS_PASSWORD,
        )

        # get libraries
        libraries = await client.get_all_libraries()

        # get library items
        for library in libraries:
            async for response in client.get_library_items(library_id=library.id_):
                if not response.results:
                    break
                for lib_item_minified in response.results:
                    if isinstance(lib_item_minified, LibraryItemMinifiedPodcast):
                        ...
                    if isinstance(lib_item_minified, LibraryItemMinifiedBook):
                        ...

        # get a single podcast
        podcast_id = "dda96167-eaad-4012-83e1-149c6700d3e8"
        podcast_expanded = await client.get_library_item_podcast(podcast_id=podcast_id, expanded=True)


asyncio.run(abs_basics())

Have a look into aioaudiobookshelf/client/*.py to see which endpoints are currently implemented. And the provider implementation shows, how the lib can potentially be used.

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

aioaudiobookshelf-0.1.7.tar.gz (26.8 kB view details)

Uploaded Source

Built Distribution

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

aioaudiobookshelf-0.1.7-py3-none-any.whl (39.1 kB view details)

Uploaded Python 3

File details

Details for the file aioaudiobookshelf-0.1.7.tar.gz.

File metadata

  • Download URL: aioaudiobookshelf-0.1.7.tar.gz
  • Upload date:
  • Size: 26.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.3

File hashes

Hashes for aioaudiobookshelf-0.1.7.tar.gz
Algorithm Hash digest
SHA256 62c88e1d6d46cdb1dc754ee871ab45830b61629f9d2f6468088cba59106cabc8
MD5 8d2348edbd0adcf6613f3bd6a5d9aad5
BLAKE2b-256 9c1f1395cbd6f586ff0e7451352d1afe872af58a7c6f0297260a9845a722488b

See more details on using hashes here.

File details

Details for the file aioaudiobookshelf-0.1.7-py3-none-any.whl.

File metadata

File hashes

Hashes for aioaudiobookshelf-0.1.7-py3-none-any.whl
Algorithm Hash digest
SHA256 8d29527f51e8a8e9157ad12a42ad88d11e139f800dc962c3c7e7189a592e64dd
MD5 a5711baf31a3c619ee53ea83828c48e8
BLAKE2b-256 e5e244d4b8587aa42bacd3e9b03177dcc6f6ee7c8831ddfb73c4e7fb4236e69e

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