Python client for the PlayerData GraphQL API
Project description
PlayerDataPy
A python package for interacting with the PlayerData GraphQL API.
Folder Structure
playerdata_api: The main package for interacting with the PlayerData API.gqlauth: The main package for authenticating with the PlayerData API.gqlclient: The main package for interacting with the PlayerData GraphQL API.custom_queries: Custom queries for the PlayerData GraphQL API.custom_mutations: Custom mutations for the PlayerData GraphQL API.custom_fields: Custom fields for the PlayerData GraphQL API.input_types: Input types for the PlayerData GraphQL API.enums: Enums for the PlayerData GraphQL API.custom_typing_fields: Custom typing fields for the PlayerData GraphQL API.custom_responses: Custom responses for the PlayerData GraphQL API.
Installation
uv is the tool we use to build and manage the playerdatapy Python package.
Make sure you install uv using pipx or the official installer. Installing with pip or other methods will lead to unexpected behavior.
We recommend using the official installer.
Then you can install the required dependencies, in a virtual environment if required.
uv sync
Usage
To use the GraphqlClient, you need to provide your client id, this will be provided to you by PlayerData. To request API credentials, please contact the PlayerData team at support@playerdata.co.uk.
Option 1: Use generated types with PlayerDataAPI
Example usage of this option is provided in the examples/pydantic/ folder.
The basic flow is to create a PlayerDataAPI instance, build the query objects using the code-generated Pydantic models (generated by ariadne-codegen), and then call the run_queries method.
For more detailed documentation, see examples/pydantic/README.md.
To run an example of this option, you can use the following command:
python examples/pydantic/quick_start.py
To run this you will need to set the following environment variables or hardcode them in the file:
export CLIENT_ID=your_client_id
export CLIENT_SECRET=your_client_secret
export CLUB_ID=your_club_id
For a more in-depth example, please see the examples/pydantic/example_use.ipynb notebook.
This notebook demonstrates how to use the PlayerData API with Pydantic to query specifics such as session details, session metrics, and raw data.
Option 2: Use the GraphqlClient class directly
Example usage of this option is provided in the examples/direct/ folder.
The basic flow is to create a GraphqlClient instance, build the query string, and then call the query method.
For more detailed documentation, see examples/direct/README.md.
To run an example of this option, you can use the following command:
python examples/direct/quick_start.py
To run this you will need to set the following environment variables or hardcode them in the file:
export CLIENT_ID=your_client_id
export CLIENT_SECRET=your_client_secret
export CLUB_ID=your_club_id
Authentication Types
These authentication types are set out in the playerdatapy.gqlauth.AuthenticationType enum.
The default authentication type is AuthenticationType.AUTHORISATION_CODE_FLOW.
These authentication types are used to set the authentication type in the GraphqlAuth class.
Authorisation Code Flow (PKCE)
Authorisation code flow with PKCE is used to authenticate users with non_confidential credentials.
Authorisation Code Flow
Authorisation code flow is used to authenticate users with confidential credentials.
Client Credentials Flow
Client credentials flow is used to authenticate backend to backend communication.
Updates to the API Fields and Mutations
To update the API fields and mutations, you need to set an AUTH_TOKEN environment variable.
This code is auto-generated by Ariadne, so any changes to the API fields and mutations will be reflected in the code.
export AUTH_TOKEN=f"Bearer {your_auth_token}"
python -m ariadne-codegen
This will generate code and update files in the playerdatapy package.
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 playerdatapy-1.8.2.tar.gz.
File metadata
- Download URL: playerdatapy-1.8.2.tar.gz
- Upload date:
- Size: 185.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.10.4 {"installer":{"name":"uv","version":"0.10.4","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c29799a06ce37d34440afbf216d042e953d67fa7d2fa41234caf6e0a36a0420c
|
|
| MD5 |
34fa589860d42c7ecb7c2b0b3c3efda1
|
|
| BLAKE2b-256 |
97ac97525300caf3cb2d13bcc3e2bda89fa2b59cdbea948493183d9f9123c1fb
|
File details
Details for the file playerdatapy-1.8.2-py3-none-any.whl.
File metadata
- Download URL: playerdatapy-1.8.2-py3-none-any.whl
- Upload date:
- Size: 121.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.10.4 {"installer":{"name":"uv","version":"0.10.4","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
cc193f88a056ee7ffa14a1a93b52ac9dcb4efdbbeda3255cbc03e9344a62235e
|
|
| MD5 |
8967177465dc2261c2a5de53c80248cf
|
|
| BLAKE2b-256 |
e59111b9854f3e87a7567e1eb2ed614c91e9d263f6073df915e6bbd3eaeb68ef
|