Skip to main content

A Python and Asyncio API wrapper for Bungie's API.

Project description

aiobungie

An ergonomic, statically typed, asynchronous API wrapper that supports Bungie's REST API for Python 3.

aiobungie is built to be extensible and reusable, allowing its users to freely switch parts of core implementations with their own incase of future circumstances.

Installing

Currently Python 3.10, 3.11, 3.12 and 3.13 are supported.

Stable pip.

pip install aiobungie

unstable releases via GitHub master.

pip install git+https://github.com/nxtlo/aiobungie@master

Quick Look

See Examples for advance usage.

import aiobungie
import asyncio

client = aiobungie.Client('YOUR_API_KEY')

async def main() -> None:
    # Search for Destiny 2 players.
    async with client.rest:
        users = await client.search_users("Fate")

      for user in users:
        # Print all Destiny 2 memberships for this user.
        print(user.memberships)


asyncio.run(main())

RESTful clients

aiobungie also provides a stand-alone RESTClient / RESTPool clients which are the foundation of Client, These clients just provide a lower-level abstraction.

a Client based user may access the RESTClient instance bound to it with .rest property.

Example

import aiobungie
import asyncio

# Single REST client connection.
client = aiobungie.RESTClient("YOUR_API_KEY")

async def main() -> None:
    async with client:
        # Download and open the JSON manifest.
        manifest = await client.download_json_manifest(name="latest_manifest")
        with manifest.open("r") as file:
            data = file.read()

        # two simple methods for fetching and refreshing tokens.
        tokens = await client.fetch_oauth2_tokens('code')
        refreshed_tokens = await client.refresh_access_token(tokens.refresh_token)

        # making your own requests.
        response = await client.static_request(
            "GET", # Method.
            "Destiny2/path/to/route", # Route.
            auth="optional_access_token", # If the method requires OAuth2.
            json={"some_key": "some_value"} # If you need to pass JSON data.
        )

asyncio.run(main())

When to use which?

  • Use Client when:
    • You want a high-level interface.
    • You're building a Bot, i.e, Discord Bot, Chat Bot.
    • You're building a CLI tool.
    • In a single script file.
  • Use RESTClient when:
    • You want an interface similar to Client but with extra functionalities.
    • You want raw JSON responses instead of data-classes.
    • You want REST API functionalities.
    • You want full ownership of the requests/responses.
  • Use RESTPool when:
    • everything RESTClient provides.
    • You want to spawn multiple RESTClients.
    • You're building a distributed backend.

Dependencies

  • aiohttp
  • attrs
  • sain, this is a dependency free utility package.
  • backports.datetime_fromisoformat, required for Python 3.10 only.

Features

aiobungie features are extra dependencies that replaces the standard library with either faster/neater pkgs.

  • speedup This will include and use orjson as the default json parser. It provide faster JSON serialization and de-serialization than the standard Python JSON pkg.
  • full: This will include all of the features above.

For installing the specified feature, type pip install aiobungie[feature-name]

Optimizations

  • runtime-assertion: You can disable runtime assertions by passing a -O flag python app.py -O, the API responses won't get asserted at runtime which may boost the return speeds by a bit.
  • uvloop (unix systems only): uvloop is an ultra-fast drop in replacement library for the built-in asyncio event loop.

Contributing

Please read this manual

Related Projects

If you have used aiobungie and want to show your work, Feel free to Open a PR including it.

  • Fated: A Discord BOT that uses aiobungie.

Useful Resources

  • Discord Username: vfate
  • aiobungie Documentation: Here.
  • BungieAPI Discord: Here
  • Official Bungie Documentation: Here
  • Bungie Developer Portal: Here

Notes

  • If you need help with something related to this project: Consider opening a blank issue, discussion or checkout the useful resources above.
  • aiobungie doesn't support X update, what now? aiobungie's REST client has a method called static_request which allows you to make your own requests, check out examples/custom_client example.
  • aiobungie's release cycles are slow, It takes a couple of months between each release, Some features / routes may not be available on stable version, though, it is still possible to define your own routes on top of aiobungie's clients foundation.

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

aiobungie-0.5.0.tar.gz (114.7 kB view details)

Uploaded Source

Built Distribution

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

aiobungie-0.5.0-py3-none-any.whl (144.4 kB view details)

Uploaded Python 3

File details

Details for the file aiobungie-0.5.0.tar.gz.

File metadata

  • Download URL: aiobungie-0.5.0.tar.gz
  • Upload date:
  • Size: 114.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.7.1 CPython/3.12.3 Linux/6.11.0-1018-azure

File hashes

Hashes for aiobungie-0.5.0.tar.gz
Algorithm Hash digest
SHA256 fd048af40545b2354ff8d4be91c0c9d162dfe34d2f4414244a057ee30e0c0b76
MD5 709720b43352ec9ab38905af4e4fad75
BLAKE2b-256 3b22d4a2f06b65838223ef1b8cc2fa7dc9a82449293d4b2cfb5e3bd48548af02

See more details on using hashes here.

File details

Details for the file aiobungie-0.5.0-py3-none-any.whl.

File metadata

  • Download URL: aiobungie-0.5.0-py3-none-any.whl
  • Upload date:
  • Size: 144.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.7.1 CPython/3.12.3 Linux/6.11.0-1018-azure

File hashes

Hashes for aiobungie-0.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 58841a080b45193af3430d98d3f51ad49261768ecf503665b70bf9cd88f9f870
MD5 17fbd78c7b9e570e3cbf1ab7b5ad8af7
BLAKE2b-256 30b203d43088af14b1c1685b75cb8e86d54a3f08fef610e708d28a0990f3bedc

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