Skip to main content

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


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

playerdatapy-1.10.0.tar.gz (1.4 MB view details)

Uploaded Source

Built Distribution

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

playerdatapy-1.10.0-py3-none-any.whl (1.3 MB view details)

Uploaded Python 3

File details

Details for the file playerdatapy-1.10.0.tar.gz.

File metadata

  • Download URL: playerdatapy-1.10.0.tar.gz
  • Upload date:
  • Size: 1.4 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.10.11 {"installer":{"name":"uv","version":"0.10.11","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

Hashes for playerdatapy-1.10.0.tar.gz
Algorithm Hash digest
SHA256 c03297b501515067defa924eb27b0e5b8ae2290da2a86fe14bedf5a2d9983cb2
MD5 08af00ac9882bf6b3e694b9fa091bc17
BLAKE2b-256 1762dd9162a861f572510b813fc43ce6dac9db3dbb8ae932a727c269758ff462

See more details on using hashes here.

File details

Details for the file playerdatapy-1.10.0-py3-none-any.whl.

File metadata

  • Download URL: playerdatapy-1.10.0-py3-none-any.whl
  • Upload date:
  • Size: 1.3 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.10.11 {"installer":{"name":"uv","version":"0.10.11","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

Hashes for playerdatapy-1.10.0-py3-none-any.whl
Algorithm Hash digest
SHA256 22019431ec2094bd79fb1b467b83209243b0881b56664d33de112c95a4d09bc8
MD5 8ab9b66b9171d6209b574289ccaf2219
BLAKE2b-256 f6e9dc6872bd910ccd037e281fed81312b8975719ec98921fa1a93ea0a361ce0

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