Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/nxtlo/aiobungie
Python and asyncio Bungie API wrapper.
https://github.com/nxtlo/aiobungie
aiobungie bungie-api bungie-destiny-api destiny2 hacktoberfest python3
Last synced: 6 days ago
JSON representation
Python and asyncio Bungie API wrapper.
- Host: GitHub
- URL: https://github.com/nxtlo/aiobungie
- Owner: nxtlo
- License: mit
- Created: 2021-02-15T08:18:51.000Z (almost 4 years ago)
- Default Branch: master
- Last Pushed: 2024-10-29T20:04:45.000Z (2 months ago)
- Last Synced: 2024-10-29T22:40:20.957Z (2 months ago)
- Topics: aiobungie, bungie-api, bungie-destiny-api, destiny2, hacktoberfest, python3
- Language: Python
- Homepage: https://nxtlo.github.io/aiobungie/
- Size: 25.7 MB
- Stars: 51
- Watchers: 1
- Forks: 10
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
- Codeowners: .github/CODEOWNERS
Awesome Lists containing this project
README
# aiobungie
A statically typed, asynchronous API wrapper that supports Bungie's REST API for Python 3.
## Installing
Currently Python 3.10, 3.11, 3.12 and 3.13 are supported.
Latest Release using `pip`.
```sh
pip install aiobungie
```Development via github master.
```sh
pip install git+https://github.com/nxtlo/aiobungie@master
```## Quick Example
See [Examples for advance usage](https://github.com/nxtlo/aiobungie/tree/master/examples)
```py
import aiobungie
import asyncioclient = 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` which's what `Client` built on top of, These clients just provide a lower-level abstraction.
A key note is that any `Client` based user can access the `RESTClient` instance bound to it with `.rest` property.
### Key features
* Lower level, allows to read and deserialize the JSON objects yourself.
* `RESTClient`s do not turn response payloads into one of `aiobungie.crates` object.
* RESTful, You can use this as your REST API client in backend directly.
* Both manifest and OAuth2 methods are usable directly.### Example
```py
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()# OAuth2 API. 2 simple methods for fetching and refreshing tokens.
tokens = await client.fetch_oauth2_tokens('code')
refreshed_tokens = await client.refresh_access_token(tokens.refresh_token)# Testing 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())
```## Dependencies
* aiohttp
* attrs
* [`sain`](https://github.com/nxtlo/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 uses [orjson](https://github.com/ijl/orjson)
as the default `json` parser. They 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](https://github.com/MagicStack/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](https://github.com/nxtlo/aiobungie/blob/master/CONTRIBUTING.md)
## Related Projects
If you have used aiobungie and want to show your work, Feel free to Open a PR including it.
* [Fated](https://github.com/nxtlo/Fated/blob/master/core/components/destiny.py): A Discord BOT that uses aiobungie.
## Useful Resources
* Discord Username: `vfate`
* aiobungie Documentation: [Here](https://nxtlo.github.io/aiobungie/).
* BungieAPI Discord: [Here](https://discord.gg/vP7VC7TKUG)
* Official Bungie Documentation: [Here](https://bungie-net.github.io/multi/index.html)
* Bungie Developer Portal: [Here](https://www.bungie.net/en/Application)## FaQ
* I need help with something related to this project: Consider opening a blank issue, discussion or checkout the `useful resources` above.
* aiobungie doesn't support `fetch_xxx` route, what now? aiobungie's REST client exposes a method called `static_request` which allows you
to make your own requests, check out `examples/custom_client` example.