# sendou.py
An async Python client for Sendou.ink
[![Documentation Status](https://readthedocs.org/projects/sendoupy/badge/?version=latest)](https://sendoupy.readthedocs.io/latest/?badge=latest)
- [Documentation](https://sendou.opensource.iplabs.work/)
- [PyPi](https://pypi.org/project/sendou.py/)
## Maintainers
- Vincent Lee
## Dependencies
- aiohttp
- [aiohttp-client-cache](https://pypi.org/project/aiohttp-client-cache/)
- python-dateutil
## Installation
`pip install sendou.py`
## Supported Endpoints
- [x] Get user
- [x] Get Calendar Entries
- [x] Get Tournament Info
- [x] Get Tournament Teams
- [X] Get Tournament Brackets
- [x] Get Tournament Match Info
## Usage
```python
import sendou
import asyncio
async def run():
client = sendou.Client("API_KEY")
player = await client.get_user("USER_ID")
print(player.name)
asyncio.run(run())
```
## Getting an API Key
To use this library, you must have an API key. You need to DM Sendou for an API Key currently.
## Development
For development, you'll need [Poetry](https://python-poetry.org) installed for dependency management and building distributions
### Dev Dependencies
When install dependencies for development run
```bash
poetry install --with=dev
```
*In CI you way want to run `poetry install --with=dev,ci` that includes CI dependencies for GitHub Actions*
### Testing
This package has *some* tests, these are written with pytest and can be run with
```bash
pytest
```
*You likely need to run `poetry install` before executing pytest*
### Tracking Upstream Schema
This package uses sendou.ink's [Public API Schema](https://github.com/Sendouc/sendou.ink/blob/rewrite/app/features/api-public/schema.ts)
file to design the models uses in the package. To keep track of where the package is in relation to the upstream schema,
the commit sha of the upstream schema is kept in the `pyproject.toml` file under `tool.sendou-py.source`.
There are 2 scripts that help keep this package inline with the upstream schema.
#### Upstream Schema Commit SHA checker
This script uses the GitHub API to check that the SHA stored in `tool.sendou-py.source` matches the latest commit for
for the upstream schema.
```bash
python3 scripts/checkUpstreamSchema.py
```
#### Update local SHA with Upstream Schema Commit SHA
This script pulls down the latest SHA hash for the upstream schema and saves it to the `pyproject.toml` file
```bash
python3 scripts/updateUpstreamSchema.py
```
**This should only be run after dev has checked their changes match the upstream schema**
Raw data
{
"_id": null,
"home_page": "https://github.com/IPLSplatoon/sendou.py/",
"name": "sendou-py",
"maintainer": null,
"docs_url": null,
"requires_python": "<4.0,>=3.10",
"maintainer_email": null,
"keywords": "splatoon, sendou.ink",
"author": "Vincent Lee",
"author_email": "vlee@iplabs.ink",
"download_url": "https://files.pythonhosted.org/packages/69/f3/260d34d18df94467b628bc44f0d22d56e64188e3b3cc9df149bf8384dfd3/sendou_py-1.2.12.tar.gz",
"platform": null,
"description": "# sendou.py\nAn async Python client for Sendou.ink\n\n[![Documentation Status](https://readthedocs.org/projects/sendoupy/badge/?version=latest)](https://sendoupy.readthedocs.io/latest/?badge=latest)\n\n- [Documentation](https://sendou.opensource.iplabs.work/)\n- [PyPi](https://pypi.org/project/sendou.py/)\n\n## Maintainers\n- Vincent Lee\n\n## Dependencies\n- aiohttp\n- [aiohttp-client-cache](https://pypi.org/project/aiohttp-client-cache/)\n- python-dateutil\n\n## Installation\n`pip install sendou.py`\n\n## Supported Endpoints\n- [x] Get user\n- [x] Get Calendar Entries\n- [x] Get Tournament Info\n - [x] Get Tournament Teams\n - [X] Get Tournament Brackets\n - [x] Get Tournament Match Info\n\n## Usage\n```python\nimport sendou\nimport asyncio\n\nasync def run():\n client = sendou.Client(\"API_KEY\")\n player = await client.get_user(\"USER_ID\")\n print(player.name)\n\nasyncio.run(run())\n```\n\n## Getting an API Key\nTo use this library, you must have an API key. You need to DM Sendou for an API Key currently.\n\n## Development\nFor development, you'll need [Poetry](https://python-poetry.org) installed for dependency management and building distributions\n\n### Dev Dependencies\nWhen install dependencies for development run\n\n```bash\npoetry install --with=dev\n```\n\n*In CI you way want to run `poetry install --with=dev,ci` that includes CI dependencies for GitHub Actions*\n\n### Testing\nThis package has *some* tests, these are written with pytest and can be run with\n\n```bash\npytest\n```\n\n*You likely need to run `poetry install` before executing pytest*\n\n### Tracking Upstream Schema\nThis package uses sendou.ink's [Public API Schema](https://github.com/Sendouc/sendou.ink/blob/rewrite/app/features/api-public/schema.ts) \nfile to design the models uses in the package. To keep track of where the package is in relation to the upstream schema, \nthe commit sha of the upstream schema is kept in the `pyproject.toml` file under `tool.sendou-py.source`.\n\nThere are 2 scripts that help keep this package inline with the upstream schema.\n\n#### Upstream Schema Commit SHA checker\nThis script uses the GitHub API to check that the SHA stored in `tool.sendou-py.source` matches the latest commit for \nfor the upstream schema.\n\n```bash\npython3 scripts/checkUpstreamSchema.py\n```\n\n\n#### Update local SHA with Upstream Schema Commit SHA\nThis script pulls down the latest SHA hash for the upstream schema and saves it to the `pyproject.toml` file\n\n```bash\npython3 scripts/updateUpstreamSchema.py\n```\n\n**This should only be run after dev has checked their changes match the upstream schema**",
"bugtrack_url": null,
"license": "MIT",
"summary": "An async Python library for Sendou.ink",
"version": "1.2.12",
"project_urls": {
"Documentation": "https://sendou.opensource.iplabs.work/",
"Homepage": "https://github.com/IPLSplatoon/sendou.py/",
"Repository": "https://github.com/IPLSplatoon/sendou.py/"
},
"split_keywords": [
"splatoon",
" sendou.ink"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "d173bbb9715f85d9720a43156a9a77454b962debe82dda460d06c1c7fddf12df",
"md5": "692a127befe8972c06c4989255472a4b",
"sha256": "a955ec0395405d0d57a51282ed92a8fec01c98af430dd1711901f7fad8bd09d1"
},
"downloads": -1,
"filename": "sendou_py-1.2.12-py3-none-any.whl",
"has_sig": false,
"md5_digest": "692a127befe8972c06c4989255472a4b",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": "<4.0,>=3.10",
"size": 18759,
"upload_time": "2024-12-13T22:03:31",
"upload_time_iso_8601": "2024-12-13T22:03:31.675099Z",
"url": "https://files.pythonhosted.org/packages/d1/73/bbb9715f85d9720a43156a9a77454b962debe82dda460d06c1c7fddf12df/sendou_py-1.2.12-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "69f3260d34d18df94467b628bc44f0d22d56e64188e3b3cc9df149bf8384dfd3",
"md5": "cc23cc8f4d887b5740f704789c2c7173",
"sha256": "7fb3aca92ba402ade8beb4eb3e5b69ee0c986f14b3e685f4ac299ec914bdd2b7"
},
"downloads": -1,
"filename": "sendou_py-1.2.12.tar.gz",
"has_sig": false,
"md5_digest": "cc23cc8f4d887b5740f704789c2c7173",
"packagetype": "sdist",
"python_version": "source",
"requires_python": "<4.0,>=3.10",
"size": 13181,
"upload_time": "2024-12-13T22:03:32",
"upload_time_iso_8601": "2024-12-13T22:03:32.814280Z",
"url": "https://files.pythonhosted.org/packages/69/f3/260d34d18df94467b628bc44f0d22d56e64188e3b3cc9df149bf8384dfd3/sendou_py-1.2.12.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-12-13 22:03:32",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "IPLSplatoon",
"github_project": "sendou.py",
"travis_ci": false,
"coveralls": false,
"github_actions": true,
"lcname": "sendou-py"
}