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
Clientwhen:- 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
RESTClientwhen:- You want an interface similar to
Clientbut 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.
- You want an interface similar to
- Use
RESTPoolwhen:- everything
RESTClientprovides. - You want to spawn multiple
RESTClients. - You're building a distributed backend.
- everything
Dependencies
- aiohttp
- attrs
sain, this is a dependency free utility package.backports.datetime_fromisoformat, required forPython 3.10only.
Features
aiobungie features are extra dependencies that replaces the standard library with either faster/neater pkgs.
speedupThis will include and use orjson as the defaultjsonparser. 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
-Oflagpython 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 resourcesabove. aiobungiedoesn't supportXupdate, what now?aiobungie's REST client has a method calledstatic_requestwhich allows you to make your own requests, check outexamples/custom_clientexample.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 ofaiobungie's clients foundation.
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 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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
fd048af40545b2354ff8d4be91c0c9d162dfe34d2f4414244a057ee30e0c0b76
|
|
| MD5 |
709720b43352ec9ab38905af4e4fad75
|
|
| BLAKE2b-256 |
3b22d4a2f06b65838223ef1b8cc2fa7dc9a82449293d4b2cfb5e3bd48548af02
|
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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
58841a080b45193af3430d98d3f51ad49261768ecf503665b70bf9cd88f9f870
|
|
| MD5 |
17fbd78c7b9e570e3cbf1ab7b5ad8af7
|
|
| BLAKE2b-256 |
30b203d43088af14b1c1685b75cb8e86d54a3f08fef610e708d28a0990f3bedc
|