Compare commits

..

10 Commits

326 changed files with 45761 additions and 692 deletions

1
.env Normal file
View File

@ -0,0 +1 @@
#LOG_LEVEL=DEBUG

4
.gitignore vendored
View File

@ -1,4 +1,5 @@
.venv .venv
.cache
.DS_Store/ .DS_Store/
__pycache__/ __pycache__/
*.pyc *.pyc
@ -7,3 +8,6 @@ dist/
*.json *.json
archive/ archive/
*.bplist *.bplist
covers/
comfyui-output/
temp_covers

109
README.md
View File

@ -1,81 +1,52 @@
# playlist helper # SaberList
SaberList is a tool for generating custom Beat Saber playlists based on a player's performance data from Beat Leader.
TODO: use https://github.com/megamaz/beatsaver-python
## Usage
```sh
pipx install pleb-saberlist
player_scores_by_stars
leaderboard_songs_by_stars
```
### Examples
```sh
leaderboard_songs_by_stars
Enter the minimum starlevel to include on the playlist (Default: 6.0): 6.2
Enter the maximum starlevel to include on the playlist (Default: 6.3):
Enter the filename for the playlist (Default: SS Leaderboard 6.2★):
2024-07-09 16:06:13 DEBUG: Using selector: EpollSelector
2024-07-09 16:06:13 INFO: Fetching page 1/-1 of leaderboards
2024-07-09 16:06:13 INFO: Got 14 songs from leaderboard page 1
2024-07-09 16:06:13 INFO: Fetching page 2/3 of leaderboards
2024-07-09 16:06:14 INFO: Got 14 songs from leaderboard page 2
2024-07-09 16:06:14 INFO: Fetching page 3/3 of leaderboards
2024-07-09 16:06:14 INFO: Got 3 songs from leaderboard page 3
2024-07-09 16:06:14 INFO: Playlist written to SS Leaderboard 6.2★.bplist
```
Player songs by stars:
```sh
player_scores_by_stars
2024-07-09 16:07:04 DEBUG: Using selector: EpollSelector
Enter the playerid (Default: 76561199407393962):
Enter the minimum starlevel to include on the playlist (Default: 5):
Enter the maximum starlevel to include on the playlist (Default: 6.0): 5.5
Enter the filename for the playlist (Default: Replay SS 5.0★):
2024-07-09 16:07:14 INFO: Fetching page 1/-1 of player scores
2024-07-09 16:07:15 INFO: Got 100 scores from page 1
...
2024-07-09 16:07:19 INFO: Fetching page 8/9 of player scores
2024-07-09 16:07:20 INFO: Got 96 scores from page 8
2024-07-09 16:07:20 INFO: Playlist written to Replay SS 5.0★.bplist
```
## Development
Clone the repo and install dependencies into a local virtual environment:
```bash
pip install --upgrade pip
pip install --editable .
```
## Resources ## Resources
* [Beatleader API](https://beatleader.xyz/developer) * Beat Leader [swagger](https://api.beatleader.xyz/swagger/index.html), [GitHub](https://github.com/BeatLeader)
* [ScoreSaber API](https://docs.scoresaber.com/) * Score Saber [swagger](https://docs.scoresaber.com/), [Github](https://github.com/ScoreSaber) (backend remains closed-source)
* Beat Saver [swagger](https://api.beatsaver.com/docs/), [GitHub](https://github.com/beatmaps-io/beatsaver-main)
## Tips ## Features
Count results - Fetches player scores from Beat Leader API
- Generates difficulty-based playlists
- Automatically selects a random cover image for each playlist
- Avoids duplicating songs across multiple playlist generations
- Caches player data for faster subsequent runs
```shell ## Playlist generations
jq '.songs | length' < playlist.bplist
The program has the following playlist generation modes:
### Replay songs by age
```sh
saberlist_replay_bl
``` ```
Avoid printing covers in console. This will generate a playlist of oldest songs that you have previously played, ostensibly because you probably can improve your score. It will add low star songs, mid star songs, and high star songs to the playlist. That way you can warm up on the low star songs, and then move on to the harder songs. Each time you run this command it will generate a completely new playlist.
```shell ## Covers
jq 'del(.image)' < playlist.bplist
```
Find the most common mappers the player has played: The program will automatically select a random cover image for each playlist. The cover image is selected from the `covers` directory. We suggest using a latent diffusion model to generate random cover images for your playlists.
```shell ## Configuration
jq -r '.songs[].levelAuthorName' *.bplist | sort | uniq -c | sort -rn | head -n 10
``` The program uses a `playlist_history.json` file to keep track of previously used songs and cover images. This ensures that subsequent runs generate fresh playlists without duplicates.
## Output
The program generates:
1. A `.bplist` file containing the playlist data in JSON format
2. Console output listing the songs included in the playlist
## Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
## License
This project is licensed under the MIT License - see the [LICENSE](LICENSE) file for details.

54
convert-comyfui-outupt.sh Executable file
View File

@ -0,0 +1,54 @@
#!/usr/bin/env bash
set -e
# ===============================================================
# PNG to JPEG Converter for ComfyUI Output
# ===============================================================
#
# Purpose:
# This script converts PNG images generated by ComfyUI to JPEG format.
# It's designed to process images in the 'comfyui-output/dev-dancing'
# directory and save the converted files in a './covers' directory.
#
# Features:
# - Converts PNG to JPEG using ImageMagick (magick convert)
# - Applies '-strip' to remove metadata and '-quality 90' for compression
# - Skips already converted images to allow for incremental processing
# - Creates the output directory if it doesn't exist
#
# Usage:
# ./convert_to_jpg.sh
#
# Note: Ensure ImageMagick is installed on your system before running.
#
# Author: [Your Name]
# Date: [Current Date]
# Version: 1.0
#
# ===============================================================
if [ $(hostname) = "litten" ]; then
rsync -tap roar:/opt/comfyui/output/dev-dancing comfyui-output/
fi
# Create the output directory if it doesn't exist
mkdir -p ./covers
# Loop through all PNG files in the comfyui-output/dev-dancing directory
for png_file in comfyui-output/dev-dancing/*.png; do
# Get the base filename without extension
base_name=$(basename "$png_file" .png)
# Define the output JPEG filename
jpg_file="./covers/${base_name}.jpg"
# Check if the JPEG file already exists
if [ ! -f "$jpg_file" ]; then
# Convert PNG to JPEG using magick with specified options
magick "$png_file" -strip -quality 90 "$jpg_file"
echo "Converted: $png_file -> $jpg_file"
else
echo "Skipped: $jpg_file already exists"
fi
done
echo "Conversion complete!"

27
docs/ClientUsage.md Normal file
View File

@ -0,0 +1,27 @@
# openapi-python-client usage
Here's how to use the generated client for the BeatSaver API.
```python
import json
import os
import logging
from datetime import datetime, timedelta
from typing import Optional, Dict, Any
from clients.beatsaver.client import Client as beatsaver_client
from clients.beatsaver.api.maps import get_maps_latest
from clients.beatsaver.models import MapDetail, GetMapsLatestSort
logging.basicConfig(
format='%(asctime)s %(levelname)s: %(message)s',
datefmt='%Y-%m-%d %H:%M:%S',
level=logging.DEBUG
)
BASE_URL = "https://api.beatsaver.com"
beatsaver_client = beatsaver_client(base_url=BASE_URL)
maps = get_maps_latest.sync(client=beatsaver_client)
```

View File

@ -0,0 +1,34 @@
# API Client Wrapper Usage
## BeatLeaderClient
```python
from helpers.BeatLeaderAPI import BeatLeaderAPI
from clients.beatleader.models.scores_sort_by import ScoresSortBy
from clients.beatleader.models.order import Order
# Instantiate the API client
beatleader_api = BeatLeaderAPI()
# Specify the player ID you want to fetch scores for
player_id = "76561199407393962"
# Fetch player scores
scores_data = beatleader_api.get_player_scores(
player_id=player_id,
use_cache=True, # Use cached data if available
count=100, # Number of scores per page
sort_by=ScoresSortBy.DATE, # Sort scores by date
order=Order.DESC, # In descending order
max_pages=2 # Maximum number of pages to fetch
)
print(f"Got {len(scores_data.get('playerScores'))} scores for player {player_id}")
```
## BeatSaverClient
```python
from helpers.BeatSaverAPI import BeatSaverAPI
beatsaver_api = BeatSaverAPI()
map_data = beatsaver_api.get_maps(year=2024, month=9)
```

157
docs/PlaylistBuilder.md Normal file
View File

@ -0,0 +1,157 @@
# PlaylistBuilder Class - Quick Reference
## Overview
The **PlaylistBuilder** class is a Python utility designed to create customized playlists efficiently. It manages cover images, tracks usage history to prevent duplication, and structures playlist data in a standardized JSON format. Ideal for applications requiring organized and visually appealing playlists, `PlaylistBuilder` simplifies the playlist creation process.
## Key Data Structures
### Difficulty
Represents the difficulty level of a song.
- **Attributes:**
- `name` (str): Difficulty name (e.g., "normal", "hard").
- `characteristic` (str): Mode or characteristic (e.g., "Standard").
### Song
Encapsulates song details within a playlist.
- **Attributes:**
- `hash` (str): Unique identifier for the song.
- `difficulties` (List[Difficulty]): Available difficulty levels.
- `key` (Optional[str]): Optional key identifier.
- `levelId` (Optional[str]): Optional custom level ID.
- `songName` (Optional[str]): Optional name of the song.
### CustomData
Holds additional metadata for the playlist.
- **Attributes:**
- `syncURL` (Optional[str])
- `owner` (Optional[str])
- `id` (Optional[str])
- `hash` (Optional[str])
- `shared` (Optional[bool])
### Playlist
Represents the complete playlist structure.
- **Attributes:**
- `playlistTitle` (str): Title of the playlist.
- `songs` (List[Song]): List of songs included.
- `playlistAuthor` (Optional[str]): Author of the playlist.
- `image` (Optional[str]): Base64-encoded cover image.
- `coverImage` (Optional[str]): File path to the cover image.
- `description` (Optional[str]): Description of the playlist.
- `allowDuplicates` (Optional[bool]): Flag to allow duplicate songs.
- `customData` (Optional[CustomData]): Additional metadata.
## PlaylistBuilder Class
### Initialization
```python
def __init__(self, covers_dir="./covers", history_file="./playlist_history.json", output_dir=None):
```
- **Parameters:**
- `covers_dir` (str): Directory containing cover images.
- `history_file` (str): Path to the JSON file tracking used covers.
- `output_dir` (Optional[str]): Directory to save generated playlists. Defaults to current working directory.
- **Behavior:**
- Ensures the covers directory exists.
- Loads or initializes the history of used covers.
### Methods
#### `create_playlist`
Generates a playlist based on provided song data.
```python
def create_playlist(self, playlist_data: List[Dict], playlist_title: str = "playlist", playlist_author: str = "SaberList Tool") -> str:
```
- **Parameters:**
- `playlist_data` (List[Dict]): List of song dictionaries.
- `playlist_title` (str): Title of the playlist.
- `playlist_author` (str): Author of the playlist.
- **Returns:**
- `str`: File path to the created playlist.
- **Behavior:**
- Converts song dictionaries to `Song` instances.
- Selects a random unused cover image.
- Encodes the cover image to Base64.
- Constructs a `Playlist` instance.
- Saves the playlist as a `.bplist` JSON file.
- Updates the history of used covers.
## Usage Example
```python
from src.saberlist.PlaylistBuilder import PlaylistBuilder
# Initialize PlaylistBuilder
builder = PlaylistBuilder(
covers_dir="./covers",
history_file="./playlist_history.json",
output_dir="./playlists"
)
# Define song data
sample_song = {
"hash": "7c9e0a7c523395c7ef9d79006b9d42dc6ab8b44a",
"key": "2a44e",
"levelId": "custom_level_7c9e0a7c523395c7ef9d79006b9d42dc6ab8b44a",
"songName": "Gleodream",
"difficulties": [
{
"name": "normal",
"characteristic": "Standard"
}
]
}
# Create the playlist
playlist_path = builder.create_playlist(
playlist_data=[sample_song],
playlist_title="Chill Vibes",
playlist_author="Alice Smith"
)
print(f"Playlist created at: {playlist_path}")
```
## Handling Cover Images
- **Adding Covers:** Place `.jpg` images in the `covers_dir`. The `PlaylistBuilder` selects an unused cover for each playlist.
- **Preventing Duplicates:** The `history_file` tracks used covers to avoid repetition until all covers are utilized.
- **Resetting History:** Delete or modify `playlist_history.json` to reset cover usage history.
## File Structures
### Playlist File (`.bplist`)
- **Format:** JSON
- **Contents:**
- Playlist metadata (title, author, description).
- List of songs with details.
- Base64-encoded cover image.
- Path to the cover image file.
### History File (`playlist_history.json`)
- **Format:** JSON
- **Contents:**
- `used_covers`: Array of filenames that have been used as covers.
## Additional Information
- **Logging:** The class logs important actions, such as creating directories and handling missing covers.
- **Extensibility:** Easily extendable to support more image formats or additional metadata fields.
- **Dependencies:** Utilizes Python's standard libraries (`os`, `json`, `random`, etc.) and `dataclasses` for structured data.
---

11
docs/Python.md Normal file
View File

@ -0,0 +1,11 @@
# Python
Paginate a large dictionary:
```python
from IPython.core.page import page
from pprint import pformat
def paged_print(obj):
page(pformat(obj))
paged_print(scores)
```

View File

@ -1,6 +1,6 @@
# BeatLeaderAPI Python Wrapper # SimpleBeatLeaderAPI Python Wrapper
This Python class provides a convenient wrapper for interacting with the BeatLeader API, specifically for retrieving player scores and song data for the game Beat Saber. This simple Python class provides a convenient wrapper for interacting with the BeatLeader API, specifically for retrieving player scores and song data for the game Beat Saber.
## Features ## Features
@ -15,20 +15,20 @@ This Python class provides a convenient wrapper for interacting with the BeatLea
### Basic Usage ### Basic Usage
```python ```python
from saberlist.beatleaderAPI import BeatLeaderAPI from saberlist.SimpleBeatLeaderAPI import BeatLeaderAPI
# Initialize the API wrapper # Initialize the API wrapper
api = BeatLeaderAPI(cache_expiry_days=1) api = SimpleBeatLeaderAPI(cache_expiry_days=1)
# Fetch player scores # Fetch player scores
player_id = '76561199407393962' player_id = '76561199407393962'
scores = api.get_player_scores(player_id) scores = api.get_player_scores(player_id)
scores.keys()
scores['data'][0]
# Get full song data # Get full song data
songs = api.get_player_songs(player_id) songs = api.get_player_songs(player_id)
# Get minimal song data
minimal_songs = api.get_player_songs_minimal(player_id)
``` ```
### Caching ### Caching
@ -42,7 +42,7 @@ You can control cache behavior:
```python ```python
# Set cache expiry (in days) # Set cache expiry (in days)
api = BeatLeaderAPI(cache_expiry_days=7) api = SimpleBeatLeaderAPI(cache_expiry_days=7)
# Force a fresh API call (ignore cache) # Force a fresh API call (ignore cache)
fresh_scores = api.get_player_scores(player_id, use_cache=False) fresh_scores = api.get_player_scores(player_id, use_cache=False)

81
docs/api.md Normal file
View File

@ -0,0 +1,81 @@
# API Libraries
Libraries were generated using [openapi-python-client](https://github.com/openapi-generators/openapi-python-client) for interacting with various REST APIs:
```sh
nix-shell -p ruff --run "openapi-python-client generate --path archive/scoresaber.com.swagger.json"
nix-shell -p ruff --run "openapi-python-client generate --path archive/beatleader.xyz.swagger.json"
```
To convert beatsaver, we had to convert it from openapi 2.0 to 3.0:
```sh
npm set prefix ~/.npm-global
export PATH=$HOME/.npm-global/bin:$PATH
npm install -g swagger2openapi
swagger2openapi --patch archive/beatsaver.com.swagger.json > archive/beatsaver.com.swagger_openapi3.json
```
Then we had to run some python code to fix up the mapping after the conversion:
```python
import json
# Load the OpenAPI spec
with open('archive/beatsaver.com.swagger_openapi3.json', 'r') as f:
spec = json.load(f)
# Fix tags in the main spec
if 'tags' in spec:
spec['tags'] = [tag['name'] if isinstance(tag, dict) else tag for tag in spec['tags']]
# Fix tags in each path
for path in spec['paths'].values():
for method in path.values():
if 'tags' in method:
method['tags'] = [tag['name'] if isinstance(tag, dict) else tag for tag in method['tags']]
# Save the fixed spec
with open('archive/beatsaver.com.swagger_openapi3_fixed.json', 'w') as f:
json.dump(spec, f, indent=2)
```
And we ran this one too:
```python
import json
# Load the OpenAPI spec
with open('archive/beatsaver.com.swagger_openapi3_fixed.json', 'r') as f:
spec = json.load(f)
# Fix tags in the main spec
if 'tags' in spec:
spec['tags'] = [tag['name'] if isinstance(tag, dict) else tag for tag in spec['tags']]
# Fix tags and content types in each path
for path in spec['paths'].values():
for method in path.values():
if 'tags' in method:
method['tags'] = [tag['name'] if isinstance(tag, dict) else tag for tag in method['tags']]
if 'responses' in method:
for response in method['responses'].values():
if 'content' in response:
if '*/*' in response['content']:
content = response['content']['*/*']
response['content'] = {'application/json': content}
# Save the fixed spec
with open('archive/beatsaver.com.swagger_openapi3_fixed2.json', 'w') as f:
json.dump(spec, f, indent=2)
```
```sh
nix-shell -p ruff --run "openapi-python-client generate --path archive/beatsaver.com.swagger_openapi3_fixed2.json"
```
## Resources
* Beat Leader [swagger](https://api.beatleader.xyz/swagger/index.html), [GitHub](https://github.com/BeatLeader)
* Score Saber [swagger](https://docs.scoresaber.com/), [Github](https://github.com/ScoreSaber) (backend remains closed-source)
* Beat Saver [swagger](https://api.beatsaver.com/docs/), [GitHub](https://github.com/beatmaps-io/beatsaver-main)

226
docs/capture.md Normal file
View File

@ -0,0 +1,226 @@
# Notes
Sample bplist (playlist file) for [PlaylistManager](https://github.com/rithik-b/PlaylistManager):
```json
{
"playlistTitle": "My Enhanced Playlist",
"playlistAuthor": "SaberList Tool",
"image": "",
"coverImage": "https://example.com/playlist-cover.jpg",
"description": "This is an enhanced version of my playlist with additional fields.",
"allowDuplicates": false,
"songs": [
{
"hash": "7c9e0a7c523395c7ef9d79006b9d42dc6ab8b44a",
"key": "2a44e",
"levelId": "custom_level_7c9e0a7c523395c7ef9d79006b9d42dc6ab8b44a",
"songName": "Gleodream",
"difficulties": [
{
"name": "normal",
"characteristic": "Standard"
}
]
},
{
"hash": "18ef469f44b0fa93327f9d193d10bdfe7401e5a0",
"key": "1b3f7",
"levelId": "custom_level_18ef469f44b0fa93327f9d193d10bdfe7401e5a0",
"songName": "Dual Fractal",
"difficulties": [
{
"name": "expert",
"characteristic": "Standard"
}
]
},
{
"hash": "a51425319d892986a4867388153bce45b3c28483",
"key": "3c8d9",
"levelId": "custom_level_a51425319d892986a4867388153bce45b3c28483",
"songName": "Shake The Ground",
"difficulties": [
{
"name": "expert",
"characteristic": "Standard"
}
]
}
],
"customData": {
"syncURL": "https://api.beatleader.xyz/playlist/guid/fc1000d77d0f4ed19611043367248ee0",
"owner": "76561199407393962",
"id": "80650",
"hash": "279a9c66ed021b8ef75ff9db848b28ad6c48d3c770bd26f1a586e8d489c728b3",
"shared": false
}
}
```
Sample Scoresaber score:
```python
data = {
'metadata': {'itemsPerPage': 100, 'page': 10, 'total': 961},
'playerScores': [{
'leaderboard': {
'coverImage': 'https://cdn.scoresaber.com/covers/09F8BEE6908E3A9CD724B3DB3162A5C381ECB156.png',
'createdDate': '2020-12-04T12:52:24.000Z',
'dailyPlays': 7,
'difficulties': None,
'difficulty': {
'difficulty': 9,
'difficultyRaw': '_ExpertPlus_SoloStandard',
'gameMode': 'SoloStandard',
'leaderboardId': 311333
},
'id': 311333,
'levelAuthorName': 'FatBeanzoop & ExUnReal',
'loved': False,
'lovedDate': None,
'maxPP': -1,
'maxScore': 1476715,
'playerScore': None,
'plays': 13701,
'positiveModifiers': False,
'qualified': False,
'qualifiedDate': '2020-12-05T18:16:56.000Z',
'ranked': True,
'rankedDate': '2020-12-20T17:15:39.000Z',
'songAuthorName': 'Pegboard Nerds',
'songHash': '09F8BEE6908E3A9CD724B3DB3162A5C381ECB156',
'songName': 'Purple People Eater',
'songSubName': '',
'stars': 7.05
},
'score': {
'badCuts': 4,
'baseScore': 1362341,
'deviceControllerLeft': 'Touch',
'deviceControllerRight': 'Touch',
'deviceHmd': 'Vive',
'fullCombo': False,
'hasReplay': False,
'hmd': 0,
'id': 85113198,
'leaderboardPlayerInfo': None,
'maxCombo': 741,
'missedNotes': 4,
'modifiedScore': 1362341,
'modifiers': '',
'multiplier': 1,
'pp': 261.6251,
'rank': 2711,
'timeSet': '2024-09-28T22:02:02.000Z',
'weight': 0.04670344831503159
}
}]
}
```
Sample BeatLeader score:
```python
scores = [{
'accLeft': 110.32343,
'accPP': 366.7179,
'accRight': 110.67913,
'accuracy': 0.95488137,
'badCuts': 1,
'baseScore': 1090317,
'bombCuts': 1,
'bonusPp': 63.974487,
'controller': 64,
'country': 'NL',
'fcAccuracy': 0.95854264,
'fcPp': 510.75574,
'fullCombo': False,
'hmd': 64,
'id': 2800090,
'lastTryTime': 0,
'leaderboard': {'difficulty': {'accRating': 10.151069,
'bombs': 666,
'difficultyName': 'ExpertPlus',
'duration': 227,
'featureTags': 0,
'id': 115,
'maxScore': 1141835,
'mode': 1,
'modeName': 'Standard',
'modifierValues': {'da': 0,
'ez': -0.4,
'fs': 0.22,
'gn': 0.08,
'hd': 0.05,
'modifierId': 3203,
'na': -0.3,
'nb': -0.2,
'nf': -1,
'no': -0.2,
'ohp': 0,
'op': -0.5,
'pm': 0,
'sa': 0,
'sc': 0,
'sf': 0.5,
'smc': 0.07,
'ss': -0.3},
'modifiersRating': {'bfsAccRating': 10.946411,
'bfsPassRating': 6.827801,
'bfsPredictedAcc': 0.97209585,
'bfsStars': 9.858454,
'bfsTechRating': 6.3452663,
'bsfAccRating': 11.91756,
'bsfPassRating': 9.088728,
'bsfPredictedAcc': 0.96791214,
'bsfStars': 11.616207,
'bsfTechRating': 6.8890166,
'fsAccRating': 11.0798855,
'fsPassRating': 6.8595705,
'fsPredictedAcc': 0.9715599,
'fsStars': 9.968003,
'fsTechRating': 6.22683,
'id': 6456,
'sfAccRating': 12.244068,
'sfPassRating': 9.434687,
'sfPredictedAcc': 0.9660631,
'sfStars': 12.006947,
'sfTechRating': 6.655377,
'ssAccRating': 9.436057,
'ssPassRating': 4.4481916,
'ssPredictedAcc': 0.97730374,
'ssStars': 7.6588736,
'ssTechRating': 5.366563},
'njs': 19,
'nominatedTime': 0,
'notes': 1249,
'nps': 5.66,
'passRating': 5.48632,
'predictedAcc': 0.9749072,
'qualifiedTime': 0,
'rankedTime': 0,
'requirements': 0,
'speedTags': 0,
'stars': 8.681121,
'status': 3,
'styleTags': 0,
'techRating': 6.0219316,
'type': 2,
'value': 9,
'walls': 666},
'id': '138da91',
'song': {'author': 'Desmeon',
'bpm': 174,
'collaboratorIds': None,
'coverImage': 'https://eu.cdn.beatsaver.com/bdf85d5d575a992139eff968a8348b3e6f03eefe.jpg',
'duration': 227,
'fullCoverImage': 'https://cdn.assets.beatleader.xyz/songcover-138da-cover.png',
'hash': 'bdf85d5d575a992139eff968a8348b3e6f03eefe',
'id': '138da',
'mapper': 'CyanSnow',
'mapperId': 4235138,
'name': 'Hellcat',
'subName': ''}},
}]
```

View File

@ -4,7 +4,7 @@ build-backend = "setuptools.build_meta"
[project] [project]
name = "pleb-saberlist" name = "pleb-saberlist"
version = "0.1.0" version = "0.2.0"
description = "Beat Saber playlist tool" description = "Beat Saber playlist tool"
readme = "README.md" readme = "README.md"
authors = [{ name = "blee", email = "git@blee.tube" }] authors = [{ name = "blee", email = "git@blee.tube" }]
@ -12,10 +12,11 @@ license = { file = "LICENSE" }
keywords = ["reddit"] keywords = ["reddit"]
dependencies = [ dependencies = [
'build>=1.2.1', 'build>=1.2.1',
'requests>=2.31.0',
'pytest>=8.1.1', 'pytest>=8.1.1',
'PyScoreSaber>=1.0.10', 'python-dotenv>=1.0.1',
'beatsaver>=1.0.1' 'requests>=2.31.0',
# 'PyScoreSaber>=1.0.10',
# 'beatsaver>=1.0.1'
] ]
requires-python = ">=3.8.10" requires-python = ">=3.8.10"
classifiers = [ classifiers = [
@ -34,10 +35,11 @@ Homepage = "https://git.satstack.dev/blee/beatsaber-playlist-tool"
# https://setuptools.pypa.io/en/latest/userguide/entry_point.html # https://setuptools.pypa.io/en/latest/userguide/entry_point.html
[project.scripts] [project.scripts]
player_scores_by_stars = "saberlist.scoresaber:replay_ranked" #player_scores_by_stars = "saberlist.scoresaber:replay_ranked"
replay_all_by_acc = "saberlist.scoresaber:replay_all_by_acc" #replay_all_by_acc = "saberlist.scoresaber:replay_all_by_acc"
leaderboard_songs_by_stars = "saberlist.scoresaber:leaderboard_songs" #leaderboard_songs_by_stars = "saberlist.scoresaber:leaderboard_songs"
star_ladder = "saberlist.beatleader:star_ladder" #saberlist_replay_bl = "saberlist.beatleader:saberlist_replay_bl"
saberlist = "saberlist.make:saberlist"
[tool.pytest.ini_options] [tool.pytest.ini_options]
pythonpath = ["src"] pythonpath = ["src"]

35
src/clients/__init__.py Normal file
View File

@ -0,0 +1,35 @@
"""
from .beatleader.client import Client as BeatLeaderClient
from .beatleader.models import (
Player as BeatLeaderPlayer,
Leaderboard as BeatLeaderLeaderboard,
)
from .beatsaver.client import Client as BeatSaverClient
from .beatsaver.models import (
MapDetail as BeatSaverMapDetail,
UserDetail as BeatSaverUserDetail,
SearchResponse as BeatSaverSearchResponse,
)
"""
from .scoresaber.client import Client as ScoreSaberClient
from .scoresaber.models import (
Player as ScoreSaberPlayer,
Score as ScoreSaberScore,
LeaderboardInfo as ScoreSaberLeaderboardInfo,
)
__all__ = [
# "BeatLeaderClient",
# "BeatLeaderPlayer",
# "BeatLeaderScore",
# "BeatLeaderLeaderboard",
# "BeatSaverClient",
# "BeatSaverMapDetail",
# "BeatSaverUserDetail",
# "BeatSaverSearchResponse",
"ScoreSaberClient",
"ScoreSaberPlayer",
"ScoreSaberScore",
"ScoreSaberLeaderboardInfo",
]

View File

@ -0,0 +1,8 @@
"""A client library for accessing BeatLeader API. Get various Beat Saber information."""
from .client import AuthenticatedClient, Client
__all__ = (
"AuthenticatedClient",
"Client",
)

View File

@ -0,0 +1 @@
"""Contains methods for accessing the API"""

View File

@ -0,0 +1,177 @@
from http import HTTPStatus
from typing import Any, Dict, List, Optional, Union, cast
import httpx
from ... import errors
from ...client import AuthenticatedClient, Client
from ...models.beasties_nomination import BeastiesNomination
from ...types import UNSET, Response, Unset
def _get_kwargs(
*,
leaderboard_id: Union[Unset, str] = UNSET,
) -> Dict[str, Any]:
params: Dict[str, Any] = {}
params["leaderboardId"] = leaderboard_id
params = {k: v for k, v in params.items() if v is not UNSET and v is not None}
_kwargs: Dict[str, Any] = {
"method": "get",
"url": "/beasties/nominations",
"params": params,
}
return _kwargs
def _parse_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Optional[Union[Any, List["BeastiesNomination"]]]:
if response.status_code == HTTPStatus.OK:
response_200 = []
_response_200 = response.text
for response_200_item_data in _response_200:
response_200_item = BeastiesNomination.from_dict(response_200_item_data)
response_200.append(response_200_item)
return response_200
if response.status_code == HTTPStatus.BAD_REQUEST:
response_400 = cast(Any, None)
return response_400
if response.status_code == HTTPStatus.UNAUTHORIZED:
response_401 = cast(Any, None)
return response_401
if client.raise_on_unexpected_status:
raise errors.UnexpectedStatus(response.status_code, response.content)
else:
return None
def _build_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Response[Union[Any, List["BeastiesNomination"]]]:
return Response(
status_code=HTTPStatus(response.status_code),
content=response.content,
headers=response.headers,
parsed=_parse_response(client=client, response=response),
)
def sync_detailed(
*,
client: Union[AuthenticatedClient, Client],
leaderboard_id: Union[Unset, str] = UNSET,
) -> Response[Union[Any, List["BeastiesNomination"]]]:
"""Retrieve a list of nominations for particular leaderboard
Authenticated player Beasties nominations.
Args:
leaderboard_id (Union[Unset, str]):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, List['BeastiesNomination']]]
"""
kwargs = _get_kwargs(
leaderboard_id=leaderboard_id,
)
response = client.get_httpx_client().request(
**kwargs,
)
return _build_response(client=client, response=response)
def sync(
*,
client: Union[AuthenticatedClient, Client],
leaderboard_id: Union[Unset, str] = UNSET,
) -> Optional[Union[Any, List["BeastiesNomination"]]]:
"""Retrieve a list of nominations for particular leaderboard
Authenticated player Beasties nominations.
Args:
leaderboard_id (Union[Unset, str]):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, List['BeastiesNomination']]
"""
return sync_detailed(
client=client,
leaderboard_id=leaderboard_id,
).parsed
async def asyncio_detailed(
*,
client: Union[AuthenticatedClient, Client],
leaderboard_id: Union[Unset, str] = UNSET,
) -> Response[Union[Any, List["BeastiesNomination"]]]:
"""Retrieve a list of nominations for particular leaderboard
Authenticated player Beasties nominations.
Args:
leaderboard_id (Union[Unset, str]):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, List['BeastiesNomination']]]
"""
kwargs = _get_kwargs(
leaderboard_id=leaderboard_id,
)
response = await client.get_async_httpx_client().request(**kwargs)
return _build_response(client=client, response=response)
async def asyncio(
*,
client: Union[AuthenticatedClient, Client],
leaderboard_id: Union[Unset, str] = UNSET,
) -> Optional[Union[Any, List["BeastiesNomination"]]]:
"""Retrieve a list of nominations for particular leaderboard
Authenticated player Beasties nominations.
Args:
leaderboard_id (Union[Unset, str]):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, List['BeastiesNomination']]
"""
return (
await asyncio_detailed(
client=client,
leaderboard_id=leaderboard_id,
)
).parsed

View File

@ -0,0 +1,187 @@
from http import HTTPStatus
from typing import Any, Dict, Optional, Union, cast
import httpx
from ... import errors
from ...client import AuthenticatedClient, Client
from ...models.besties_nomination_response import BestiesNominationResponse
from ...types import UNSET, Response, Unset
def _get_kwargs(
*,
leaderboard_id: Union[Unset, str] = UNSET,
category: Union[Unset, str] = UNSET,
) -> Dict[str, Any]:
params: Dict[str, Any] = {}
params["leaderboardId"] = leaderboard_id
params["category"] = category
params = {k: v for k, v in params.items() if v is not UNSET and v is not None}
_kwargs: Dict[str, Any] = {
"method": "post",
"url": "/beasties/nominate",
"params": params,
}
return _kwargs
def _parse_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Optional[Union[Any, BestiesNominationResponse]]:
if response.status_code == HTTPStatus.OK:
response_200 = BestiesNominationResponse.from_dict(response.text)
return response_200
if response.status_code == HTTPStatus.BAD_REQUEST:
response_400 = cast(Any, None)
return response_400
if response.status_code == HTTPStatus.UNAUTHORIZED:
response_401 = cast(Any, None)
return response_401
if client.raise_on_unexpected_status:
raise errors.UnexpectedStatus(response.status_code, response.content)
else:
return None
def _build_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Response[Union[Any, BestiesNominationResponse]]:
return Response(
status_code=HTTPStatus(response.status_code),
content=response.content,
headers=response.headers,
parsed=_parse_response(client=client, response=response),
)
def sync_detailed(
*,
client: Union[AuthenticatedClient, Client],
leaderboard_id: Union[Unset, str] = UNSET,
category: Union[Unset, str] = UNSET,
) -> Response[Union[Any, BestiesNominationResponse]]:
"""Nominate a map for Besties Awards
Nominates provided leaderboard map for mapping awards in selected category
Args:
leaderboard_id (Union[Unset, str]):
category (Union[Unset, str]):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, BestiesNominationResponse]]
"""
kwargs = _get_kwargs(
leaderboard_id=leaderboard_id,
category=category,
)
response = client.get_httpx_client().request(
**kwargs,
)
return _build_response(client=client, response=response)
def sync(
*,
client: Union[AuthenticatedClient, Client],
leaderboard_id: Union[Unset, str] = UNSET,
category: Union[Unset, str] = UNSET,
) -> Optional[Union[Any, BestiesNominationResponse]]:
"""Nominate a map for Besties Awards
Nominates provided leaderboard map for mapping awards in selected category
Args:
leaderboard_id (Union[Unset, str]):
category (Union[Unset, str]):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, BestiesNominationResponse]
"""
return sync_detailed(
client=client,
leaderboard_id=leaderboard_id,
category=category,
).parsed
async def asyncio_detailed(
*,
client: Union[AuthenticatedClient, Client],
leaderboard_id: Union[Unset, str] = UNSET,
category: Union[Unset, str] = UNSET,
) -> Response[Union[Any, BestiesNominationResponse]]:
"""Nominate a map for Besties Awards
Nominates provided leaderboard map for mapping awards in selected category
Args:
leaderboard_id (Union[Unset, str]):
category (Union[Unset, str]):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, BestiesNominationResponse]]
"""
kwargs = _get_kwargs(
leaderboard_id=leaderboard_id,
category=category,
)
response = await client.get_async_httpx_client().request(**kwargs)
return _build_response(client=client, response=response)
async def asyncio(
*,
client: Union[AuthenticatedClient, Client],
leaderboard_id: Union[Unset, str] = UNSET,
category: Union[Unset, str] = UNSET,
) -> Optional[Union[Any, BestiesNominationResponse]]:
"""Nominate a map for Besties Awards
Nominates provided leaderboard map for mapping awards in selected category
Args:
leaderboard_id (Union[Unset, str]):
category (Union[Unset, str]):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, BestiesNominationResponse]
"""
return (
await asyncio_detailed(
client=client,
leaderboard_id=leaderboard_id,
category=category,
)
).parsed

View File

@ -0,0 +1,265 @@
from http import HTTPStatus
from typing import Any, Dict, Optional, Union, cast
import httpx
from ... import errors
from ...client import AuthenticatedClient, Client
from ...models.clan_response_full_response_with_metadata import ClanResponseFullResponseWithMetadata
from ...models.clan_sort_by import ClanSortBy
from ...models.order import Order
from ...types import UNSET, Response, Unset
def _get_kwargs(
*,
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 10,
sort: Union[Unset, ClanSortBy] = UNSET,
order: Union[Unset, Order] = UNSET,
search: Union[Unset, str] = UNSET,
sort_by: Union[Unset, ClanSortBy] = UNSET,
) -> Dict[str, Any]:
params: Dict[str, Any] = {}
params["page"] = page
params["count"] = count
json_sort: Union[Unset, str] = UNSET
if not isinstance(sort, Unset):
json_sort = sort.value
params["sort"] = json_sort
json_order: Union[Unset, str] = UNSET
if not isinstance(order, Unset):
json_order = order.value
params["order"] = json_order
params["search"] = search
json_sort_by: Union[Unset, str] = UNSET
if not isinstance(sort_by, Unset):
json_sort_by = sort_by.value
params["sortBy"] = json_sort_by
params = {k: v for k, v in params.items() if v is not UNSET and v is not None}
_kwargs: Dict[str, Any] = {
"method": "get",
"url": "/clans",
"params": params,
}
return _kwargs
def _parse_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Optional[Union[Any, ClanResponseFullResponseWithMetadata]]:
if response.status_code == HTTPStatus.OK:
response_200 = ClanResponseFullResponseWithMetadata.from_dict(response.text)
return response_200
if response.status_code == HTTPStatus.BAD_REQUEST:
response_400 = cast(Any, None)
return response_400
if response.status_code == HTTPStatus.NOT_FOUND:
response_404 = cast(Any, None)
return response_404
if client.raise_on_unexpected_status:
raise errors.UnexpectedStatus(response.status_code, response.content)
else:
return None
def _build_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Response[Union[Any, ClanResponseFullResponseWithMetadata]]:
return Response(
status_code=HTTPStatus(response.status_code),
content=response.content,
headers=response.headers,
parsed=_parse_response(client=client, response=response),
)
def sync_detailed(
*,
client: Union[AuthenticatedClient, Client],
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 10,
sort: Union[Unset, ClanSortBy] = UNSET,
order: Union[Unset, Order] = UNSET,
search: Union[Unset, str] = UNSET,
sort_by: Union[Unset, ClanSortBy] = UNSET,
) -> Response[Union[Any, ClanResponseFullResponseWithMetadata]]:
"""Retrieve a list of clans
Fetches a paginated and optionally filtered list of clans (group of players). Filters include
sorting by performance points, search, name, rank, and more.
Args:
page (Union[Unset, int]): Default: 1.
count (Union[Unset, int]): Default: 10.
sort (Union[Unset, ClanSortBy]):
order (Union[Unset, Order]): Represents the order in which values will be sorted.
search (Union[Unset, str]):
sort_by (Union[Unset, ClanSortBy]):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, ClanResponseFullResponseWithMetadata]]
"""
kwargs = _get_kwargs(
page=page,
count=count,
sort=sort,
order=order,
search=search,
sort_by=sort_by,
)
response = client.get_httpx_client().request(
**kwargs,
)
return _build_response(client=client, response=response)
def sync(
*,
client: Union[AuthenticatedClient, Client],
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 10,
sort: Union[Unset, ClanSortBy] = UNSET,
order: Union[Unset, Order] = UNSET,
search: Union[Unset, str] = UNSET,
sort_by: Union[Unset, ClanSortBy] = UNSET,
) -> Optional[Union[Any, ClanResponseFullResponseWithMetadata]]:
"""Retrieve a list of clans
Fetches a paginated and optionally filtered list of clans (group of players). Filters include
sorting by performance points, search, name, rank, and more.
Args:
page (Union[Unset, int]): Default: 1.
count (Union[Unset, int]): Default: 10.
sort (Union[Unset, ClanSortBy]):
order (Union[Unset, Order]): Represents the order in which values will be sorted.
search (Union[Unset, str]):
sort_by (Union[Unset, ClanSortBy]):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, ClanResponseFullResponseWithMetadata]
"""
return sync_detailed(
client=client,
page=page,
count=count,
sort=sort,
order=order,
search=search,
sort_by=sort_by,
).parsed
async def asyncio_detailed(
*,
client: Union[AuthenticatedClient, Client],
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 10,
sort: Union[Unset, ClanSortBy] = UNSET,
order: Union[Unset, Order] = UNSET,
search: Union[Unset, str] = UNSET,
sort_by: Union[Unset, ClanSortBy] = UNSET,
) -> Response[Union[Any, ClanResponseFullResponseWithMetadata]]:
"""Retrieve a list of clans
Fetches a paginated and optionally filtered list of clans (group of players). Filters include
sorting by performance points, search, name, rank, and more.
Args:
page (Union[Unset, int]): Default: 1.
count (Union[Unset, int]): Default: 10.
sort (Union[Unset, ClanSortBy]):
order (Union[Unset, Order]): Represents the order in which values will be sorted.
search (Union[Unset, str]):
sort_by (Union[Unset, ClanSortBy]):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, ClanResponseFullResponseWithMetadata]]
"""
kwargs = _get_kwargs(
page=page,
count=count,
sort=sort,
order=order,
search=search,
sort_by=sort_by,
)
response = await client.get_async_httpx_client().request(**kwargs)
return _build_response(client=client, response=response)
async def asyncio(
*,
client: Union[AuthenticatedClient, Client],
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 10,
sort: Union[Unset, ClanSortBy] = UNSET,
order: Union[Unset, Order] = UNSET,
search: Union[Unset, str] = UNSET,
sort_by: Union[Unset, ClanSortBy] = UNSET,
) -> Optional[Union[Any, ClanResponseFullResponseWithMetadata]]:
"""Retrieve a list of clans
Fetches a paginated and optionally filtered list of clans (group of players). Filters include
sorting by performance points, search, name, rank, and more.
Args:
page (Union[Unset, int]): Default: 1.
count (Union[Unset, int]): Default: 10.
sort (Union[Unset, ClanSortBy]):
order (Union[Unset, Order]): Represents the order in which values will be sorted.
search (Union[Unset, str]):
sort_by (Union[Unset, ClanSortBy]):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, ClanResponseFullResponseWithMetadata]
"""
return (
await asyncio_detailed(
client=client,
page=page,
count=count,
sort=sort,
order=order,
search=search,
sort_by=sort_by,
)
).parsed

View File

@ -0,0 +1,254 @@
from http import HTTPStatus
from typing import Any, Dict, Optional, Union, cast
import httpx
from ... import errors
from ...client import AuthenticatedClient, Client
from ...models.order import Order
from ...models.player_response_clan_response_full_response_with_metadata_and_container import (
PlayerResponseClanResponseFullResponseWithMetadataAndContainer,
)
from ...models.player_sort_by import PlayerSortBy
from ...types import UNSET, Response, Unset
def _get_kwargs(
tag: str,
*,
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 10,
sort_by: Union[Unset, PlayerSortBy] = UNSET,
order: Union[Unset, Order] = UNSET,
primary: Union[Unset, bool] = False,
) -> Dict[str, Any]:
params: Dict[str, Any] = {}
params["page"] = page
params["count"] = count
json_sort_by: Union[Unset, str] = UNSET
if not isinstance(sort_by, Unset):
json_sort_by = sort_by.value
params["sortBy"] = json_sort_by
json_order: Union[Unset, str] = UNSET
if not isinstance(order, Unset):
json_order = order.value
params["order"] = json_order
params["primary"] = primary
params = {k: v for k, v in params.items() if v is not UNSET and v is not None}
_kwargs: Dict[str, Any] = {
"method": "get",
"url": f"/clan/{tag}",
"params": params,
}
return _kwargs
def _parse_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Optional[Union[Any, PlayerResponseClanResponseFullResponseWithMetadataAndContainer]]:
if response.status_code == HTTPStatus.OK:
response_200 = PlayerResponseClanResponseFullResponseWithMetadataAndContainer.from_dict(response.text)
return response_200
if response.status_code == HTTPStatus.NOT_FOUND:
response_404 = cast(Any, None)
return response_404
if client.raise_on_unexpected_status:
raise errors.UnexpectedStatus(response.status_code, response.content)
else:
return None
def _build_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Response[Union[Any, PlayerResponseClanResponseFullResponseWithMetadataAndContainer]]:
return Response(
status_code=HTTPStatus(response.status_code),
content=response.content,
headers=response.headers,
parsed=_parse_response(client=client, response=response),
)
def sync_detailed(
tag: str,
*,
client: Union[AuthenticatedClient, Client],
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 10,
sort_by: Union[Unset, PlayerSortBy] = UNSET,
order: Union[Unset, Order] = UNSET,
primary: Union[Unset, bool] = False,
) -> Response[Union[Any, PlayerResponseClanResponseFullResponseWithMetadataAndContainer]]:
"""Retrieve details of a specific clan by tag
Fetches details of a specific clan identified by its tag.
Args:
tag (str):
page (Union[Unset, int]): Default: 1.
count (Union[Unset, int]): Default: 10.
sort_by (Union[Unset, PlayerSortBy]):
order (Union[Unset, Order]): Represents the order in which values will be sorted.
primary (Union[Unset, bool]): Default: False.
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, PlayerResponseClanResponseFullResponseWithMetadataAndContainer]]
"""
kwargs = _get_kwargs(
tag=tag,
page=page,
count=count,
sort_by=sort_by,
order=order,
primary=primary,
)
response = client.get_httpx_client().request(
**kwargs,
)
return _build_response(client=client, response=response)
def sync(
tag: str,
*,
client: Union[AuthenticatedClient, Client],
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 10,
sort_by: Union[Unset, PlayerSortBy] = UNSET,
order: Union[Unset, Order] = UNSET,
primary: Union[Unset, bool] = False,
) -> Optional[Union[Any, PlayerResponseClanResponseFullResponseWithMetadataAndContainer]]:
"""Retrieve details of a specific clan by tag
Fetches details of a specific clan identified by its tag.
Args:
tag (str):
page (Union[Unset, int]): Default: 1.
count (Union[Unset, int]): Default: 10.
sort_by (Union[Unset, PlayerSortBy]):
order (Union[Unset, Order]): Represents the order in which values will be sorted.
primary (Union[Unset, bool]): Default: False.
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, PlayerResponseClanResponseFullResponseWithMetadataAndContainer]
"""
return sync_detailed(
tag=tag,
client=client,
page=page,
count=count,
sort_by=sort_by,
order=order,
primary=primary,
).parsed
async def asyncio_detailed(
tag: str,
*,
client: Union[AuthenticatedClient, Client],
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 10,
sort_by: Union[Unset, PlayerSortBy] = UNSET,
order: Union[Unset, Order] = UNSET,
primary: Union[Unset, bool] = False,
) -> Response[Union[Any, PlayerResponseClanResponseFullResponseWithMetadataAndContainer]]:
"""Retrieve details of a specific clan by tag
Fetches details of a specific clan identified by its tag.
Args:
tag (str):
page (Union[Unset, int]): Default: 1.
count (Union[Unset, int]): Default: 10.
sort_by (Union[Unset, PlayerSortBy]):
order (Union[Unset, Order]): Represents the order in which values will be sorted.
primary (Union[Unset, bool]): Default: False.
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, PlayerResponseClanResponseFullResponseWithMetadataAndContainer]]
"""
kwargs = _get_kwargs(
tag=tag,
page=page,
count=count,
sort_by=sort_by,
order=order,
primary=primary,
)
response = await client.get_async_httpx_client().request(**kwargs)
return _build_response(client=client, response=response)
async def asyncio(
tag: str,
*,
client: Union[AuthenticatedClient, Client],
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 10,
sort_by: Union[Unset, PlayerSortBy] = UNSET,
order: Union[Unset, Order] = UNSET,
primary: Union[Unset, bool] = False,
) -> Optional[Union[Any, PlayerResponseClanResponseFullResponseWithMetadataAndContainer]]:
"""Retrieve details of a specific clan by tag
Fetches details of a specific clan identified by its tag.
Args:
tag (str):
page (Union[Unset, int]): Default: 1.
count (Union[Unset, int]): Default: 10.
sort_by (Union[Unset, PlayerSortBy]):
order (Union[Unset, Order]): Represents the order in which values will be sorted.
primary (Union[Unset, bool]): Default: False.
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, PlayerResponseClanResponseFullResponseWithMetadataAndContainer]
"""
return (
await asyncio_detailed(
tag=tag,
client=client,
page=page,
count=count,
sort_by=sort_by,
order=order,
primary=primary,
)
).parsed

View File

@ -0,0 +1,254 @@
from http import HTTPStatus
from typing import Any, Dict, Optional, Union, cast
import httpx
from ... import errors
from ...client import AuthenticatedClient, Client
from ...models.order import Order
from ...models.player_response_clan_response_full_response_with_metadata_and_container import (
PlayerResponseClanResponseFullResponseWithMetadataAndContainer,
)
from ...models.player_sort_by import PlayerSortBy
from ...types import UNSET, Response, Unset
def _get_kwargs(
id: int,
*,
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 10,
sort_by: Union[Unset, PlayerSortBy] = UNSET,
order: Union[Unset, Order] = UNSET,
primary: Union[Unset, bool] = False,
) -> Dict[str, Any]:
params: Dict[str, Any] = {}
params["page"] = page
params["count"] = count
json_sort_by: Union[Unset, str] = UNSET
if not isinstance(sort_by, Unset):
json_sort_by = sort_by.value
params["sortBy"] = json_sort_by
json_order: Union[Unset, str] = UNSET
if not isinstance(order, Unset):
json_order = order.value
params["order"] = json_order
params["primary"] = primary
params = {k: v for k, v in params.items() if v is not UNSET and v is not None}
_kwargs: Dict[str, Any] = {
"method": "get",
"url": f"/clan/id/{id}",
"params": params,
}
return _kwargs
def _parse_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Optional[Union[Any, PlayerResponseClanResponseFullResponseWithMetadataAndContainer]]:
if response.status_code == HTTPStatus.OK:
response_200 = PlayerResponseClanResponseFullResponseWithMetadataAndContainer.from_dict(response.text)
return response_200
if response.status_code == HTTPStatus.NOT_FOUND:
response_404 = cast(Any, None)
return response_404
if client.raise_on_unexpected_status:
raise errors.UnexpectedStatus(response.status_code, response.content)
else:
return None
def _build_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Response[Union[Any, PlayerResponseClanResponseFullResponseWithMetadataAndContainer]]:
return Response(
status_code=HTTPStatus(response.status_code),
content=response.content,
headers=response.headers,
parsed=_parse_response(client=client, response=response),
)
def sync_detailed(
id: int,
*,
client: Union[AuthenticatedClient, Client],
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 10,
sort_by: Union[Unset, PlayerSortBy] = UNSET,
order: Union[Unset, Order] = UNSET,
primary: Union[Unset, bool] = False,
) -> Response[Union[Any, PlayerResponseClanResponseFullResponseWithMetadataAndContainer]]:
"""Retrieve details of a specific clan by ID
Fetches details of a specific clan identified by its ID.
Args:
id (int):
page (Union[Unset, int]): Default: 1.
count (Union[Unset, int]): Default: 10.
sort_by (Union[Unset, PlayerSortBy]):
order (Union[Unset, Order]): Represents the order in which values will be sorted.
primary (Union[Unset, bool]): Default: False.
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, PlayerResponseClanResponseFullResponseWithMetadataAndContainer]]
"""
kwargs = _get_kwargs(
id=id,
page=page,
count=count,
sort_by=sort_by,
order=order,
primary=primary,
)
response = client.get_httpx_client().request(
**kwargs,
)
return _build_response(client=client, response=response)
def sync(
id: int,
*,
client: Union[AuthenticatedClient, Client],
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 10,
sort_by: Union[Unset, PlayerSortBy] = UNSET,
order: Union[Unset, Order] = UNSET,
primary: Union[Unset, bool] = False,
) -> Optional[Union[Any, PlayerResponseClanResponseFullResponseWithMetadataAndContainer]]:
"""Retrieve details of a specific clan by ID
Fetches details of a specific clan identified by its ID.
Args:
id (int):
page (Union[Unset, int]): Default: 1.
count (Union[Unset, int]): Default: 10.
sort_by (Union[Unset, PlayerSortBy]):
order (Union[Unset, Order]): Represents the order in which values will be sorted.
primary (Union[Unset, bool]): Default: False.
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, PlayerResponseClanResponseFullResponseWithMetadataAndContainer]
"""
return sync_detailed(
id=id,
client=client,
page=page,
count=count,
sort_by=sort_by,
order=order,
primary=primary,
).parsed
async def asyncio_detailed(
id: int,
*,
client: Union[AuthenticatedClient, Client],
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 10,
sort_by: Union[Unset, PlayerSortBy] = UNSET,
order: Union[Unset, Order] = UNSET,
primary: Union[Unset, bool] = False,
) -> Response[Union[Any, PlayerResponseClanResponseFullResponseWithMetadataAndContainer]]:
"""Retrieve details of a specific clan by ID
Fetches details of a specific clan identified by its ID.
Args:
id (int):
page (Union[Unset, int]): Default: 1.
count (Union[Unset, int]): Default: 10.
sort_by (Union[Unset, PlayerSortBy]):
order (Union[Unset, Order]): Represents the order in which values will be sorted.
primary (Union[Unset, bool]): Default: False.
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, PlayerResponseClanResponseFullResponseWithMetadataAndContainer]]
"""
kwargs = _get_kwargs(
id=id,
page=page,
count=count,
sort_by=sort_by,
order=order,
primary=primary,
)
response = await client.get_async_httpx_client().request(**kwargs)
return _build_response(client=client, response=response)
async def asyncio(
id: int,
*,
client: Union[AuthenticatedClient, Client],
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 10,
sort_by: Union[Unset, PlayerSortBy] = UNSET,
order: Union[Unset, Order] = UNSET,
primary: Union[Unset, bool] = False,
) -> Optional[Union[Any, PlayerResponseClanResponseFullResponseWithMetadataAndContainer]]:
"""Retrieve details of a specific clan by ID
Fetches details of a specific clan identified by its ID.
Args:
id (int):
page (Union[Unset, int]): Default: 1.
count (Union[Unset, int]): Default: 10.
sort_by (Union[Unset, PlayerSortBy]):
order (Union[Unset, Order]): Represents the order in which values will be sorted.
primary (Union[Unset, bool]): Default: False.
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, PlayerResponseClanResponseFullResponseWithMetadataAndContainer]
"""
return (
await asyncio_detailed(
id=id,
client=client,
page=page,
count=count,
sort_by=sort_by,
order=order,
primary=primary,
)
).parsed

View File

@ -0,0 +1,263 @@
from http import HTTPStatus
from typing import Any, Dict, Optional, Union, cast
import httpx
from ... import errors
from ...client import AuthenticatedClient, Client
from ...models.clan_maps_sort_by import ClanMapsSortBy
from ...models.clan_ranking_response_clan_response_full_response_with_metadata_and_container import (
ClanRankingResponseClanResponseFullResponseWithMetadataAndContainer,
)
from ...models.leaderboard_contexts import LeaderboardContexts
from ...models.order import Order
from ...types import UNSET, Response, Unset
def _get_kwargs(
tag: str,
*,
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 10,
sort_by: Union[Unset, ClanMapsSortBy] = UNSET,
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
order: Union[Unset, Order] = UNSET,
) -> Dict[str, Any]:
params: Dict[str, Any] = {}
params["page"] = page
params["count"] = count
json_sort_by: Union[Unset, str] = UNSET
if not isinstance(sort_by, Unset):
json_sort_by = sort_by.value
params["sortBy"] = json_sort_by
json_leaderboard_context: Union[Unset, str] = UNSET
if not isinstance(leaderboard_context, Unset):
json_leaderboard_context = leaderboard_context.value
params["leaderboardContext"] = json_leaderboard_context
json_order: Union[Unset, str] = UNSET
if not isinstance(order, Unset):
json_order = order.value
params["order"] = json_order
params = {k: v for k, v in params.items() if v is not UNSET and v is not None}
_kwargs: Dict[str, Any] = {
"method": "get",
"url": f"/clan/{tag}/maps",
"params": params,
}
return _kwargs
def _parse_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Optional[Union[Any, ClanRankingResponseClanResponseFullResponseWithMetadataAndContainer]]:
if response.status_code == HTTPStatus.OK:
response_200 = ClanRankingResponseClanResponseFullResponseWithMetadataAndContainer.from_dict(response.text)
return response_200
if response.status_code == HTTPStatus.NOT_FOUND:
response_404 = cast(Any, None)
return response_404
if client.raise_on_unexpected_status:
raise errors.UnexpectedStatus(response.status_code, response.content)
else:
return None
def _build_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Response[Union[Any, ClanRankingResponseClanResponseFullResponseWithMetadataAndContainer]]:
return Response(
status_code=HTTPStatus(response.status_code),
content=response.content,
headers=response.headers,
parsed=_parse_response(client=client, response=response),
)
def sync_detailed(
tag: str,
*,
client: Union[AuthenticatedClient, Client],
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 10,
sort_by: Union[Unset, ClanMapsSortBy] = UNSET,
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
order: Union[Unset, Order] = UNSET,
) -> Response[Union[Any, ClanRankingResponseClanResponseFullResponseWithMetadataAndContainer]]:
"""Retrieve clan maps by tag
Fetches ranked maps(maps that can be captured on the global map) for where players of clan made
scores identified by its tag, with optional sorting and filtering.
Args:
tag (str):
page (Union[Unset, int]): Default: 1.
count (Union[Unset, int]): Default: 10.
sort_by (Union[Unset, ClanMapsSortBy]):
leaderboard_context (Union[Unset, LeaderboardContexts]):
order (Union[Unset, Order]): Represents the order in which values will be sorted.
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, ClanRankingResponseClanResponseFullResponseWithMetadataAndContainer]]
"""
kwargs = _get_kwargs(
tag=tag,
page=page,
count=count,
sort_by=sort_by,
leaderboard_context=leaderboard_context,
order=order,
)
response = client.get_httpx_client().request(
**kwargs,
)
return _build_response(client=client, response=response)
def sync(
tag: str,
*,
client: Union[AuthenticatedClient, Client],
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 10,
sort_by: Union[Unset, ClanMapsSortBy] = UNSET,
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
order: Union[Unset, Order] = UNSET,
) -> Optional[Union[Any, ClanRankingResponseClanResponseFullResponseWithMetadataAndContainer]]:
"""Retrieve clan maps by tag
Fetches ranked maps(maps that can be captured on the global map) for where players of clan made
scores identified by its tag, with optional sorting and filtering.
Args:
tag (str):
page (Union[Unset, int]): Default: 1.
count (Union[Unset, int]): Default: 10.
sort_by (Union[Unset, ClanMapsSortBy]):
leaderboard_context (Union[Unset, LeaderboardContexts]):
order (Union[Unset, Order]): Represents the order in which values will be sorted.
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, ClanRankingResponseClanResponseFullResponseWithMetadataAndContainer]
"""
return sync_detailed(
tag=tag,
client=client,
page=page,
count=count,
sort_by=sort_by,
leaderboard_context=leaderboard_context,
order=order,
).parsed
async def asyncio_detailed(
tag: str,
*,
client: Union[AuthenticatedClient, Client],
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 10,
sort_by: Union[Unset, ClanMapsSortBy] = UNSET,
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
order: Union[Unset, Order] = UNSET,
) -> Response[Union[Any, ClanRankingResponseClanResponseFullResponseWithMetadataAndContainer]]:
"""Retrieve clan maps by tag
Fetches ranked maps(maps that can be captured on the global map) for where players of clan made
scores identified by its tag, with optional sorting and filtering.
Args:
tag (str):
page (Union[Unset, int]): Default: 1.
count (Union[Unset, int]): Default: 10.
sort_by (Union[Unset, ClanMapsSortBy]):
leaderboard_context (Union[Unset, LeaderboardContexts]):
order (Union[Unset, Order]): Represents the order in which values will be sorted.
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, ClanRankingResponseClanResponseFullResponseWithMetadataAndContainer]]
"""
kwargs = _get_kwargs(
tag=tag,
page=page,
count=count,
sort_by=sort_by,
leaderboard_context=leaderboard_context,
order=order,
)
response = await client.get_async_httpx_client().request(**kwargs)
return _build_response(client=client, response=response)
async def asyncio(
tag: str,
*,
client: Union[AuthenticatedClient, Client],
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 10,
sort_by: Union[Unset, ClanMapsSortBy] = UNSET,
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
order: Union[Unset, Order] = UNSET,
) -> Optional[Union[Any, ClanRankingResponseClanResponseFullResponseWithMetadataAndContainer]]:
"""Retrieve clan maps by tag
Fetches ranked maps(maps that can be captured on the global map) for where players of clan made
scores identified by its tag, with optional sorting and filtering.
Args:
tag (str):
page (Union[Unset, int]): Default: 1.
count (Union[Unset, int]): Default: 10.
sort_by (Union[Unset, ClanMapsSortBy]):
leaderboard_context (Union[Unset, LeaderboardContexts]):
order (Union[Unset, Order]): Represents the order in which values will be sorted.
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, ClanRankingResponseClanResponseFullResponseWithMetadataAndContainer]
"""
return (
await asyncio_detailed(
tag=tag,
client=client,
page=page,
count=count,
sort_by=sort_by,
leaderboard_context=leaderboard_context,
order=order,
)
).parsed

View File

@ -0,0 +1,263 @@
from http import HTTPStatus
from typing import Any, Dict, Optional, Union, cast
import httpx
from ... import errors
from ...client import AuthenticatedClient, Client
from ...models.clan_maps_sort_by import ClanMapsSortBy
from ...models.clan_ranking_response_clan_response_full_response_with_metadata_and_container import (
ClanRankingResponseClanResponseFullResponseWithMetadataAndContainer,
)
from ...models.leaderboard_contexts import LeaderboardContexts
from ...models.order import Order
from ...types import UNSET, Response, Unset
def _get_kwargs(
id: int,
*,
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 10,
sort_by: Union[Unset, ClanMapsSortBy] = UNSET,
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
order: Union[Unset, Order] = UNSET,
) -> Dict[str, Any]:
params: Dict[str, Any] = {}
params["page"] = page
params["count"] = count
json_sort_by: Union[Unset, str] = UNSET
if not isinstance(sort_by, Unset):
json_sort_by = sort_by.value
params["sortBy"] = json_sort_by
json_leaderboard_context: Union[Unset, str] = UNSET
if not isinstance(leaderboard_context, Unset):
json_leaderboard_context = leaderboard_context.value
params["leaderboardContext"] = json_leaderboard_context
json_order: Union[Unset, str] = UNSET
if not isinstance(order, Unset):
json_order = order.value
params["order"] = json_order
params = {k: v for k, v in params.items() if v is not UNSET and v is not None}
_kwargs: Dict[str, Any] = {
"method": "get",
"url": f"/clan/id/{id}/maps",
"params": params,
}
return _kwargs
def _parse_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Optional[Union[Any, ClanRankingResponseClanResponseFullResponseWithMetadataAndContainer]]:
if response.status_code == HTTPStatus.OK:
response_200 = ClanRankingResponseClanResponseFullResponseWithMetadataAndContainer.from_dict(response.text)
return response_200
if response.status_code == HTTPStatus.NOT_FOUND:
response_404 = cast(Any, None)
return response_404
if client.raise_on_unexpected_status:
raise errors.UnexpectedStatus(response.status_code, response.content)
else:
return None
def _build_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Response[Union[Any, ClanRankingResponseClanResponseFullResponseWithMetadataAndContainer]]:
return Response(
status_code=HTTPStatus(response.status_code),
content=response.content,
headers=response.headers,
parsed=_parse_response(client=client, response=response),
)
def sync_detailed(
id: int,
*,
client: Union[AuthenticatedClient, Client],
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 10,
sort_by: Union[Unset, ClanMapsSortBy] = UNSET,
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
order: Union[Unset, Order] = UNSET,
) -> Response[Union[Any, ClanRankingResponseClanResponseFullResponseWithMetadataAndContainer]]:
"""Retrieve clan maps by ID
Fetches ranked maps(maps that can be captured on the global map) for where players of clan made
scores identified by its ID, with optional sorting and filtering.
Args:
id (int):
page (Union[Unset, int]): Default: 1.
count (Union[Unset, int]): Default: 10.
sort_by (Union[Unset, ClanMapsSortBy]):
leaderboard_context (Union[Unset, LeaderboardContexts]):
order (Union[Unset, Order]): Represents the order in which values will be sorted.
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, ClanRankingResponseClanResponseFullResponseWithMetadataAndContainer]]
"""
kwargs = _get_kwargs(
id=id,
page=page,
count=count,
sort_by=sort_by,
leaderboard_context=leaderboard_context,
order=order,
)
response = client.get_httpx_client().request(
**kwargs,
)
return _build_response(client=client, response=response)
def sync(
id: int,
*,
client: Union[AuthenticatedClient, Client],
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 10,
sort_by: Union[Unset, ClanMapsSortBy] = UNSET,
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
order: Union[Unset, Order] = UNSET,
) -> Optional[Union[Any, ClanRankingResponseClanResponseFullResponseWithMetadataAndContainer]]:
"""Retrieve clan maps by ID
Fetches ranked maps(maps that can be captured on the global map) for where players of clan made
scores identified by its ID, with optional sorting and filtering.
Args:
id (int):
page (Union[Unset, int]): Default: 1.
count (Union[Unset, int]): Default: 10.
sort_by (Union[Unset, ClanMapsSortBy]):
leaderboard_context (Union[Unset, LeaderboardContexts]):
order (Union[Unset, Order]): Represents the order in which values will be sorted.
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, ClanRankingResponseClanResponseFullResponseWithMetadataAndContainer]
"""
return sync_detailed(
id=id,
client=client,
page=page,
count=count,
sort_by=sort_by,
leaderboard_context=leaderboard_context,
order=order,
).parsed
async def asyncio_detailed(
id: int,
*,
client: Union[AuthenticatedClient, Client],
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 10,
sort_by: Union[Unset, ClanMapsSortBy] = UNSET,
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
order: Union[Unset, Order] = UNSET,
) -> Response[Union[Any, ClanRankingResponseClanResponseFullResponseWithMetadataAndContainer]]:
"""Retrieve clan maps by ID
Fetches ranked maps(maps that can be captured on the global map) for where players of clan made
scores identified by its ID, with optional sorting and filtering.
Args:
id (int):
page (Union[Unset, int]): Default: 1.
count (Union[Unset, int]): Default: 10.
sort_by (Union[Unset, ClanMapsSortBy]):
leaderboard_context (Union[Unset, LeaderboardContexts]):
order (Union[Unset, Order]): Represents the order in which values will be sorted.
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, ClanRankingResponseClanResponseFullResponseWithMetadataAndContainer]]
"""
kwargs = _get_kwargs(
id=id,
page=page,
count=count,
sort_by=sort_by,
leaderboard_context=leaderboard_context,
order=order,
)
response = await client.get_async_httpx_client().request(**kwargs)
return _build_response(client=client, response=response)
async def asyncio(
id: int,
*,
client: Union[AuthenticatedClient, Client],
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 10,
sort_by: Union[Unset, ClanMapsSortBy] = UNSET,
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
order: Union[Unset, Order] = UNSET,
) -> Optional[Union[Any, ClanRankingResponseClanResponseFullResponseWithMetadataAndContainer]]:
"""Retrieve clan maps by ID
Fetches ranked maps(maps that can be captured on the global map) for where players of clan made
scores identified by its ID, with optional sorting and filtering.
Args:
id (int):
page (Union[Unset, int]): Default: 1.
count (Union[Unset, int]): Default: 10.
sort_by (Union[Unset, ClanMapsSortBy]):
leaderboard_context (Union[Unset, LeaderboardContexts]):
order (Union[Unset, Order]): Represents the order in which values will be sorted.
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, ClanRankingResponseClanResponseFullResponseWithMetadataAndContainer]
"""
return (
await asyncio_detailed(
id=id,
client=client,
page=page,
count=count,
sort_by=sort_by,
leaderboard_context=leaderboard_context,
order=order,
)
).parsed

View File

@ -0,0 +1,190 @@
from http import HTTPStatus
from typing import Any, Dict, List, Optional, Union, cast
import httpx
from ... import errors
from ...client import AuthenticatedClient, Client
from ...models.global_map_history import GlobalMapHistory
from ...types import UNSET, Response, Unset
def _get_kwargs(
id: int,
*,
count: Union[Unset, int] = 50,
) -> Dict[str, Any]:
params: Dict[str, Any] = {}
params["count"] = count
params = {k: v for k, v in params.items() if v is not UNSET and v is not None}
_kwargs: Dict[str, Any] = {
"method": "get",
"url": f"/clan/{id}/history",
"params": params,
}
return _kwargs
def _parse_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Optional[Union[Any, List["GlobalMapHistory"]]]:
if response.status_code == HTTPStatus.OK:
response_200 = []
_response_200 = response.text
for response_200_item_data in _response_200:
response_200_item = GlobalMapHistory.from_dict(response_200_item_data)
response_200.append(response_200_item)
return response_200
if response.status_code == HTTPStatus.BAD_REQUEST:
response_400 = cast(Any, None)
return response_400
if response.status_code == HTTPStatus.NOT_FOUND:
response_404 = cast(Any, None)
return response_404
if client.raise_on_unexpected_status:
raise errors.UnexpectedStatus(response.status_code, response.content)
else:
return None
def _build_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Response[Union[Any, List["GlobalMapHistory"]]]:
return Response(
status_code=HTTPStatus(response.status_code),
content=response.content,
headers=response.headers,
parsed=_parse_response(client=client, response=response),
)
def sync_detailed(
id: int,
*,
client: Union[AuthenticatedClient, Client],
count: Union[Unset, int] = 50,
) -> Response[Union[Any, List["GlobalMapHistory"]]]:
"""Retrieve clan's statistic history
Fetches a list of player's performance metrics and various stats saved daily
Args:
id (int):
count (Union[Unset, int]): Default: 50.
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, List['GlobalMapHistory']]]
"""
kwargs = _get_kwargs(
id=id,
count=count,
)
response = client.get_httpx_client().request(
**kwargs,
)
return _build_response(client=client, response=response)
def sync(
id: int,
*,
client: Union[AuthenticatedClient, Client],
count: Union[Unset, int] = 50,
) -> Optional[Union[Any, List["GlobalMapHistory"]]]:
"""Retrieve clan's statistic history
Fetches a list of player's performance metrics and various stats saved daily
Args:
id (int):
count (Union[Unset, int]): Default: 50.
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, List['GlobalMapHistory']]
"""
return sync_detailed(
id=id,
client=client,
count=count,
).parsed
async def asyncio_detailed(
id: int,
*,
client: Union[AuthenticatedClient, Client],
count: Union[Unset, int] = 50,
) -> Response[Union[Any, List["GlobalMapHistory"]]]:
"""Retrieve clan's statistic history
Fetches a list of player's performance metrics and various stats saved daily
Args:
id (int):
count (Union[Unset, int]): Default: 50.
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, List['GlobalMapHistory']]]
"""
kwargs = _get_kwargs(
id=id,
count=count,
)
response = await client.get_async_httpx_client().request(**kwargs)
return _build_response(client=client, response=response)
async def asyncio(
id: int,
*,
client: Union[AuthenticatedClient, Client],
count: Union[Unset, int] = 50,
) -> Optional[Union[Any, List["GlobalMapHistory"]]]:
"""Retrieve clan's statistic history
Fetches a list of player's performance metrics and various stats saved daily
Args:
id (int):
count (Union[Unset, int]): Default: 50.
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, List['GlobalMapHistory']]
"""
return (
await asyncio_detailed(
id=id,
client=client,
count=count,
)
).parsed

View File

@ -0,0 +1,137 @@
from http import HTTPStatus
from typing import Any, Dict, Optional, Union, cast
import httpx
from ... import errors
from ...client import AuthenticatedClient, Client
from ...models.clan_global_map import ClanGlobalMap
from ...types import Response
def _get_kwargs() -> Dict[str, Any]:
_kwargs: Dict[str, Any] = {
"method": "get",
"url": "/clans/globalmap",
}
return _kwargs
def _parse_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Optional[Union[Any, ClanGlobalMap]]:
if response.status_code == HTTPStatus.OK:
response_200 = ClanGlobalMap.from_dict(response.text)
return response_200
if response.status_code == HTTPStatus.NOT_FOUND:
response_404 = cast(Any, None)
return response_404
if client.raise_on_unexpected_status:
raise errors.UnexpectedStatus(response.status_code, response.content)
else:
return None
def _build_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Response[Union[Any, ClanGlobalMap]]:
return Response(
status_code=HTTPStatus(response.status_code),
content=response.content,
headers=response.headers,
parsed=_parse_response(client=client, response=response),
)
def sync_detailed(
*,
client: Union[AuthenticatedClient, Client],
) -> Response[Union[Any, ClanGlobalMap]]:
"""Retrieve the global clan map
Fetches a global map showing clan captured maps and rankings.
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, ClanGlobalMap]]
"""
kwargs = _get_kwargs()
response = client.get_httpx_client().request(
**kwargs,
)
return _build_response(client=client, response=response)
def sync(
*,
client: Union[AuthenticatedClient, Client],
) -> Optional[Union[Any, ClanGlobalMap]]:
"""Retrieve the global clan map
Fetches a global map showing clan captured maps and rankings.
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, ClanGlobalMap]
"""
return sync_detailed(
client=client,
).parsed
async def asyncio_detailed(
*,
client: Union[AuthenticatedClient, Client],
) -> Response[Union[Any, ClanGlobalMap]]:
"""Retrieve the global clan map
Fetches a global map showing clan captured maps and rankings.
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, ClanGlobalMap]]
"""
kwargs = _get_kwargs()
response = await client.get_async_httpx_client().request(**kwargs)
return _build_response(client=client, response=response)
async def asyncio(
*,
client: Union[AuthenticatedClient, Client],
) -> Optional[Union[Any, ClanGlobalMap]]:
"""Retrieve the global clan map
Fetches a global map showing clan captured maps and rankings.
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, ClanGlobalMap]
"""
return (
await asyncio_detailed(
client=client,
)
).parsed

View File

@ -0,0 +1,386 @@
from http import HTTPStatus
from typing import Any, Dict, Optional, Union, cast
import httpx
from ... import errors
from ...client import AuthenticatedClient, Client
from ...models.leaderboard_contexts import LeaderboardContexts
from ...models.leaderboard_response import LeaderboardResponse
from ...models.leaderboard_sort_by import LeaderboardSortBy
from ...models.order import Order
from ...models.score_filter_status import ScoreFilterStatus
from ...types import UNSET, Response, Unset
def _get_kwargs(
id: str,
*,
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 10,
sort_by: Union[Unset, LeaderboardSortBy] = UNSET,
order: Union[Unset, Order] = UNSET,
score_status: Union[Unset, ScoreFilterStatus] = UNSET,
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
countries: Union[Unset, str] = UNSET,
search: Union[Unset, str] = UNSET,
modifiers: Union[Unset, str] = UNSET,
friends: Union[Unset, bool] = False,
voters: Union[Unset, bool] = False,
clan_tag: Union[Unset, str] = UNSET,
prediction: Union[Unset, bool] = False,
) -> Dict[str, Any]:
params: Dict[str, Any] = {}
params["page"] = page
params["count"] = count
json_sort_by: Union[Unset, str] = UNSET
if not isinstance(sort_by, Unset):
json_sort_by = sort_by.value
params["sortBy"] = json_sort_by
json_order: Union[Unset, str] = UNSET
if not isinstance(order, Unset):
json_order = order.value
params["order"] = json_order
json_score_status: Union[Unset, str] = UNSET
if not isinstance(score_status, Unset):
json_score_status = score_status.value
params["scoreStatus"] = json_score_status
json_leaderboard_context: Union[Unset, str] = UNSET
if not isinstance(leaderboard_context, Unset):
json_leaderboard_context = leaderboard_context.value
params["leaderboardContext"] = json_leaderboard_context
params["countries"] = countries
params["search"] = search
params["modifiers"] = modifiers
params["friends"] = friends
params["voters"] = voters
params["clanTag"] = clan_tag
params["prediction"] = prediction
params = {k: v for k, v in params.items() if v is not UNSET and v is not None}
_kwargs: Dict[str, Any] = {
"method": "get",
"url": f"/leaderboard/{id}",
"params": params,
}
return _kwargs
def _parse_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Optional[Union[Any, LeaderboardResponse]]:
if response.status_code == HTTPStatus.OK:
response_200 = LeaderboardResponse.from_dict(response.text)
return response_200
if response.status_code == HTTPStatus.NOT_FOUND:
response_404 = cast(Any, None)
return response_404
if client.raise_on_unexpected_status:
raise errors.UnexpectedStatus(response.status_code, response.content)
else:
return None
def _build_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Response[Union[Any, LeaderboardResponse]]:
return Response(
status_code=HTTPStatus(response.status_code),
content=response.content,
headers=response.headers,
parsed=_parse_response(client=client, response=response),
)
def sync_detailed(
id: str,
*,
client: Union[AuthenticatedClient, Client],
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 10,
sort_by: Union[Unset, LeaderboardSortBy] = UNSET,
order: Union[Unset, Order] = UNSET,
score_status: Union[Unset, ScoreFilterStatus] = UNSET,
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
countries: Union[Unset, str] = UNSET,
search: Union[Unset, str] = UNSET,
modifiers: Union[Unset, str] = UNSET,
friends: Union[Unset, bool] = False,
voters: Union[Unset, bool] = False,
clan_tag: Union[Unset, str] = UNSET,
prediction: Union[Unset, bool] = False,
) -> Response[Union[Any, LeaderboardResponse]]:
"""Retrieve leaderboard details
Fetches details of a leaderboard identified by its ID, with optional sorting and filtering for
scores.
Args:
id (str):
page (Union[Unset, int]): Default: 1.
count (Union[Unset, int]): Default: 10.
sort_by (Union[Unset, LeaderboardSortBy]):
order (Union[Unset, Order]): Represents the order in which values will be sorted.
score_status (Union[Unset, ScoreFilterStatus]):
leaderboard_context (Union[Unset, LeaderboardContexts]):
countries (Union[Unset, str]):
search (Union[Unset, str]):
modifiers (Union[Unset, str]):
friends (Union[Unset, bool]): Default: False.
voters (Union[Unset, bool]): Default: False.
clan_tag (Union[Unset, str]):
prediction (Union[Unset, bool]): Default: False.
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, LeaderboardResponse]]
"""
kwargs = _get_kwargs(
id=id,
page=page,
count=count,
sort_by=sort_by,
order=order,
score_status=score_status,
leaderboard_context=leaderboard_context,
countries=countries,
search=search,
modifiers=modifiers,
friends=friends,
voters=voters,
clan_tag=clan_tag,
prediction=prediction,
)
response = client.get_httpx_client().request(
**kwargs,
)
return _build_response(client=client, response=response)
def sync(
id: str,
*,
client: Union[AuthenticatedClient, Client],
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 10,
sort_by: Union[Unset, LeaderboardSortBy] = UNSET,
order: Union[Unset, Order] = UNSET,
score_status: Union[Unset, ScoreFilterStatus] = UNSET,
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
countries: Union[Unset, str] = UNSET,
search: Union[Unset, str] = UNSET,
modifiers: Union[Unset, str] = UNSET,
friends: Union[Unset, bool] = False,
voters: Union[Unset, bool] = False,
clan_tag: Union[Unset, str] = UNSET,
prediction: Union[Unset, bool] = False,
) -> Optional[Union[Any, LeaderboardResponse]]:
"""Retrieve leaderboard details
Fetches details of a leaderboard identified by its ID, with optional sorting and filtering for
scores.
Args:
id (str):
page (Union[Unset, int]): Default: 1.
count (Union[Unset, int]): Default: 10.
sort_by (Union[Unset, LeaderboardSortBy]):
order (Union[Unset, Order]): Represents the order in which values will be sorted.
score_status (Union[Unset, ScoreFilterStatus]):
leaderboard_context (Union[Unset, LeaderboardContexts]):
countries (Union[Unset, str]):
search (Union[Unset, str]):
modifiers (Union[Unset, str]):
friends (Union[Unset, bool]): Default: False.
voters (Union[Unset, bool]): Default: False.
clan_tag (Union[Unset, str]):
prediction (Union[Unset, bool]): Default: False.
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, LeaderboardResponse]
"""
return sync_detailed(
id=id,
client=client,
page=page,
count=count,
sort_by=sort_by,
order=order,
score_status=score_status,
leaderboard_context=leaderboard_context,
countries=countries,
search=search,
modifiers=modifiers,
friends=friends,
voters=voters,
clan_tag=clan_tag,
prediction=prediction,
).parsed
async def asyncio_detailed(
id: str,
*,
client: Union[AuthenticatedClient, Client],
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 10,
sort_by: Union[Unset, LeaderboardSortBy] = UNSET,
order: Union[Unset, Order] = UNSET,
score_status: Union[Unset, ScoreFilterStatus] = UNSET,
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
countries: Union[Unset, str] = UNSET,
search: Union[Unset, str] = UNSET,
modifiers: Union[Unset, str] = UNSET,
friends: Union[Unset, bool] = False,
voters: Union[Unset, bool] = False,
clan_tag: Union[Unset, str] = UNSET,
prediction: Union[Unset, bool] = False,
) -> Response[Union[Any, LeaderboardResponse]]:
"""Retrieve leaderboard details
Fetches details of a leaderboard identified by its ID, with optional sorting and filtering for
scores.
Args:
id (str):
page (Union[Unset, int]): Default: 1.
count (Union[Unset, int]): Default: 10.
sort_by (Union[Unset, LeaderboardSortBy]):
order (Union[Unset, Order]): Represents the order in which values will be sorted.
score_status (Union[Unset, ScoreFilterStatus]):
leaderboard_context (Union[Unset, LeaderboardContexts]):
countries (Union[Unset, str]):
search (Union[Unset, str]):
modifiers (Union[Unset, str]):
friends (Union[Unset, bool]): Default: False.
voters (Union[Unset, bool]): Default: False.
clan_tag (Union[Unset, str]):
prediction (Union[Unset, bool]): Default: False.
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, LeaderboardResponse]]
"""
kwargs = _get_kwargs(
id=id,
page=page,
count=count,
sort_by=sort_by,
order=order,
score_status=score_status,
leaderboard_context=leaderboard_context,
countries=countries,
search=search,
modifiers=modifiers,
friends=friends,
voters=voters,
clan_tag=clan_tag,
prediction=prediction,
)
response = await client.get_async_httpx_client().request(**kwargs)
return _build_response(client=client, response=response)
async def asyncio(
id: str,
*,
client: Union[AuthenticatedClient, Client],
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 10,
sort_by: Union[Unset, LeaderboardSortBy] = UNSET,
order: Union[Unset, Order] = UNSET,
score_status: Union[Unset, ScoreFilterStatus] = UNSET,
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
countries: Union[Unset, str] = UNSET,
search: Union[Unset, str] = UNSET,
modifiers: Union[Unset, str] = UNSET,
friends: Union[Unset, bool] = False,
voters: Union[Unset, bool] = False,
clan_tag: Union[Unset, str] = UNSET,
prediction: Union[Unset, bool] = False,
) -> Optional[Union[Any, LeaderboardResponse]]:
"""Retrieve leaderboard details
Fetches details of a leaderboard identified by its ID, with optional sorting and filtering for
scores.
Args:
id (str):
page (Union[Unset, int]): Default: 1.
count (Union[Unset, int]): Default: 10.
sort_by (Union[Unset, LeaderboardSortBy]):
order (Union[Unset, Order]): Represents the order in which values will be sorted.
score_status (Union[Unset, ScoreFilterStatus]):
leaderboard_context (Union[Unset, LeaderboardContexts]):
countries (Union[Unset, str]):
search (Union[Unset, str]):
modifiers (Union[Unset, str]):
friends (Union[Unset, bool]): Default: False.
voters (Union[Unset, bool]): Default: False.
clan_tag (Union[Unset, str]):
prediction (Union[Unset, bool]): Default: False.
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, LeaderboardResponse]
"""
return (
await asyncio_detailed(
id=id,
client=client,
page=page,
count=count,
sort_by=sort_by,
order=order,
score_status=score_status,
leaderboard_context=leaderboard_context,
countries=countries,
search=search,
modifiers=modifiers,
friends=friends,
voters=voters,
clan_tag=clan_tag,
prediction=prediction,
)
).parsed

View File

@ -0,0 +1,603 @@
from http import HTTPStatus
from typing import Any, Dict, Optional, Union, cast
import httpx
from ... import errors
from ...client import AuthenticatedClient, Client
from ...models.leaderboard_contexts import LeaderboardContexts
from ...models.leaderboard_info_response_response_with_metadata import LeaderboardInfoResponseResponseWithMetadata
from ...models.map_sort_by import MapSortBy
from ...models.my_type import MyType
from ...models.operation import Operation
from ...models.order import Order
from ...models.requirements import Requirements
from ...models.song_status import SongStatus
from ...models.type import Type
from ...types import UNSET, Response, Unset
def _get_kwargs(
*,
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 10,
sort_by: Union[Unset, MapSortBy] = UNSET,
order: Union[Unset, Order] = UNSET,
search: Union[Unset, str] = UNSET,
type: Union[Unset, Type] = UNSET,
mode: Union[Unset, str] = UNSET,
difficulty: Union[Unset, str] = UNSET,
map_type: Union[Unset, int] = UNSET,
all_types: Union[Unset, Operation] = UNSET,
map_requirements: Union[Unset, Requirements] = UNSET,
all_requirements: Union[Unset, Operation] = UNSET,
song_status: Union[Unset, SongStatus] = UNSET,
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
mytype: Union[Unset, MyType] = UNSET,
stars_from: Union[Unset, float] = UNSET,
stars_to: Union[Unset, float] = UNSET,
accrating_from: Union[Unset, float] = UNSET,
accrating_to: Union[Unset, float] = UNSET,
passrating_from: Union[Unset, float] = UNSET,
passrating_to: Union[Unset, float] = UNSET,
techrating_from: Union[Unset, float] = UNSET,
techrating_to: Union[Unset, float] = UNSET,
date_from: Union[Unset, int] = UNSET,
date_to: Union[Unset, int] = UNSET,
mappers: Union[Unset, str] = UNSET,
override_current_id: Union[Unset, str] = UNSET,
) -> Dict[str, Any]:
params: Dict[str, Any] = {}
params["page"] = page
params["count"] = count
json_sort_by: Union[Unset, str] = UNSET
if not isinstance(sort_by, Unset):
json_sort_by = sort_by.value
params["sortBy"] = json_sort_by
json_order: Union[Unset, str] = UNSET
if not isinstance(order, Unset):
json_order = order.value
params["order"] = json_order
params["search"] = search
json_type: Union[Unset, str] = UNSET
if not isinstance(type, Unset):
json_type = type.value
params["type"] = json_type
params["mode"] = mode
params["difficulty"] = difficulty
params["mapType"] = map_type
json_all_types: Union[Unset, str] = UNSET
if not isinstance(all_types, Unset):
json_all_types = all_types.value
params["allTypes"] = json_all_types
json_map_requirements: Union[Unset, str] = UNSET
if not isinstance(map_requirements, Unset):
json_map_requirements = map_requirements.value
params["mapRequirements"] = json_map_requirements
json_all_requirements: Union[Unset, str] = UNSET
if not isinstance(all_requirements, Unset):
json_all_requirements = all_requirements.value
params["allRequirements"] = json_all_requirements
json_song_status: Union[Unset, str] = UNSET
if not isinstance(song_status, Unset):
json_song_status = song_status.value
params["songStatus"] = json_song_status
json_leaderboard_context: Union[Unset, str] = UNSET
if not isinstance(leaderboard_context, Unset):
json_leaderboard_context = leaderboard_context.value
params["leaderboardContext"] = json_leaderboard_context
json_mytype: Union[Unset, str] = UNSET
if not isinstance(mytype, Unset):
json_mytype = mytype.value
params["mytype"] = json_mytype
params["stars_from"] = stars_from
params["stars_to"] = stars_to
params["accrating_from"] = accrating_from
params["accrating_to"] = accrating_to
params["passrating_from"] = passrating_from
params["passrating_to"] = passrating_to
params["techrating_from"] = techrating_from
params["techrating_to"] = techrating_to
params["date_from"] = date_from
params["date_to"] = date_to
params["mappers"] = mappers
params["overrideCurrentId"] = override_current_id
params = {k: v for k, v in params.items() if v is not UNSET and v is not None}
_kwargs: Dict[str, Any] = {
"method": "get",
"url": "/leaderboards",
"params": params,
}
return _kwargs
def _parse_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Optional[Union[Any, LeaderboardInfoResponseResponseWithMetadata]]:
if response.status_code == HTTPStatus.OK:
response_200 = LeaderboardInfoResponseResponseWithMetadata.from_dict(response.text)
return response_200
if response.status_code == HTTPStatus.NOT_FOUND:
response_404 = cast(Any, None)
return response_404
if client.raise_on_unexpected_status:
raise errors.UnexpectedStatus(response.status_code, response.content)
else:
return None
def _build_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Response[Union[Any, LeaderboardInfoResponseResponseWithMetadata]]:
return Response(
status_code=HTTPStatus(response.status_code),
content=response.content,
headers=response.headers,
parsed=_parse_response(client=client, response=response),
)
def sync_detailed(
*,
client: Union[AuthenticatedClient, Client],
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 10,
sort_by: Union[Unset, MapSortBy] = UNSET,
order: Union[Unset, Order] = UNSET,
search: Union[Unset, str] = UNSET,
type: Union[Unset, Type] = UNSET,
mode: Union[Unset, str] = UNSET,
difficulty: Union[Unset, str] = UNSET,
map_type: Union[Unset, int] = UNSET,
all_types: Union[Unset, Operation] = UNSET,
map_requirements: Union[Unset, Requirements] = UNSET,
all_requirements: Union[Unset, Operation] = UNSET,
song_status: Union[Unset, SongStatus] = UNSET,
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
mytype: Union[Unset, MyType] = UNSET,
stars_from: Union[Unset, float] = UNSET,
stars_to: Union[Unset, float] = UNSET,
accrating_from: Union[Unset, float] = UNSET,
accrating_to: Union[Unset, float] = UNSET,
passrating_from: Union[Unset, float] = UNSET,
passrating_to: Union[Unset, float] = UNSET,
techrating_from: Union[Unset, float] = UNSET,
techrating_to: Union[Unset, float] = UNSET,
date_from: Union[Unset, int] = UNSET,
date_to: Union[Unset, int] = UNSET,
mappers: Union[Unset, str] = UNSET,
override_current_id: Union[Unset, str] = UNSET,
) -> Response[Union[Any, LeaderboardInfoResponseResponseWithMetadata]]:
"""Retrieve a list of leaderboards (maps)
Fetches a paginated and optionally filtered list of leaderboards (Beat Saber maps).
Args:
page (Union[Unset, int]): Default: 1.
count (Union[Unset, int]): Default: 10.
sort_by (Union[Unset, MapSortBy]):
order (Union[Unset, Order]): Represents the order in which values will be sorted.
search (Union[Unset, str]):
type (Union[Unset, Type]):
mode (Union[Unset, str]):
difficulty (Union[Unset, str]):
map_type (Union[Unset, int]):
all_types (Union[Unset, Operation]):
map_requirements (Union[Unset, Requirements]):
all_requirements (Union[Unset, Operation]):
song_status (Union[Unset, SongStatus]):
leaderboard_context (Union[Unset, LeaderboardContexts]):
mytype (Union[Unset, MyType]):
stars_from (Union[Unset, float]):
stars_to (Union[Unset, float]):
accrating_from (Union[Unset, float]):
accrating_to (Union[Unset, float]):
passrating_from (Union[Unset, float]):
passrating_to (Union[Unset, float]):
techrating_from (Union[Unset, float]):
techrating_to (Union[Unset, float]):
date_from (Union[Unset, int]):
date_to (Union[Unset, int]):
mappers (Union[Unset, str]):
override_current_id (Union[Unset, str]):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, LeaderboardInfoResponseResponseWithMetadata]]
"""
kwargs = _get_kwargs(
page=page,
count=count,
sort_by=sort_by,
order=order,
search=search,
type=type,
mode=mode,
difficulty=difficulty,
map_type=map_type,
all_types=all_types,
map_requirements=map_requirements,
all_requirements=all_requirements,
song_status=song_status,
leaderboard_context=leaderboard_context,
mytype=mytype,
stars_from=stars_from,
stars_to=stars_to,
accrating_from=accrating_from,
accrating_to=accrating_to,
passrating_from=passrating_from,
passrating_to=passrating_to,
techrating_from=techrating_from,
techrating_to=techrating_to,
date_from=date_from,
date_to=date_to,
mappers=mappers,
override_current_id=override_current_id,
)
response = client.get_httpx_client().request(
**kwargs,
)
return _build_response(client=client, response=response)
def sync(
*,
client: Union[AuthenticatedClient, Client],
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 10,
sort_by: Union[Unset, MapSortBy] = UNSET,
order: Union[Unset, Order] = UNSET,
search: Union[Unset, str] = UNSET,
type: Union[Unset, Type] = UNSET,
mode: Union[Unset, str] = UNSET,
difficulty: Union[Unset, str] = UNSET,
map_type: Union[Unset, int] = UNSET,
all_types: Union[Unset, Operation] = UNSET,
map_requirements: Union[Unset, Requirements] = UNSET,
all_requirements: Union[Unset, Operation] = UNSET,
song_status: Union[Unset, SongStatus] = UNSET,
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
mytype: Union[Unset, MyType] = UNSET,
stars_from: Union[Unset, float] = UNSET,
stars_to: Union[Unset, float] = UNSET,
accrating_from: Union[Unset, float] = UNSET,
accrating_to: Union[Unset, float] = UNSET,
passrating_from: Union[Unset, float] = UNSET,
passrating_to: Union[Unset, float] = UNSET,
techrating_from: Union[Unset, float] = UNSET,
techrating_to: Union[Unset, float] = UNSET,
date_from: Union[Unset, int] = UNSET,
date_to: Union[Unset, int] = UNSET,
mappers: Union[Unset, str] = UNSET,
override_current_id: Union[Unset, str] = UNSET,
) -> Optional[Union[Any, LeaderboardInfoResponseResponseWithMetadata]]:
"""Retrieve a list of leaderboards (maps)
Fetches a paginated and optionally filtered list of leaderboards (Beat Saber maps).
Args:
page (Union[Unset, int]): Default: 1.
count (Union[Unset, int]): Default: 10.
sort_by (Union[Unset, MapSortBy]):
order (Union[Unset, Order]): Represents the order in which values will be sorted.
search (Union[Unset, str]):
type (Union[Unset, Type]):
mode (Union[Unset, str]):
difficulty (Union[Unset, str]):
map_type (Union[Unset, int]):
all_types (Union[Unset, Operation]):
map_requirements (Union[Unset, Requirements]):
all_requirements (Union[Unset, Operation]):
song_status (Union[Unset, SongStatus]):
leaderboard_context (Union[Unset, LeaderboardContexts]):
mytype (Union[Unset, MyType]):
stars_from (Union[Unset, float]):
stars_to (Union[Unset, float]):
accrating_from (Union[Unset, float]):
accrating_to (Union[Unset, float]):
passrating_from (Union[Unset, float]):
passrating_to (Union[Unset, float]):
techrating_from (Union[Unset, float]):
techrating_to (Union[Unset, float]):
date_from (Union[Unset, int]):
date_to (Union[Unset, int]):
mappers (Union[Unset, str]):
override_current_id (Union[Unset, str]):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, LeaderboardInfoResponseResponseWithMetadata]
"""
return sync_detailed(
client=client,
page=page,
count=count,
sort_by=sort_by,
order=order,
search=search,
type=type,
mode=mode,
difficulty=difficulty,
map_type=map_type,
all_types=all_types,
map_requirements=map_requirements,
all_requirements=all_requirements,
song_status=song_status,
leaderboard_context=leaderboard_context,
mytype=mytype,
stars_from=stars_from,
stars_to=stars_to,
accrating_from=accrating_from,
accrating_to=accrating_to,
passrating_from=passrating_from,
passrating_to=passrating_to,
techrating_from=techrating_from,
techrating_to=techrating_to,
date_from=date_from,
date_to=date_to,
mappers=mappers,
override_current_id=override_current_id,
).parsed
async def asyncio_detailed(
*,
client: Union[AuthenticatedClient, Client],
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 10,
sort_by: Union[Unset, MapSortBy] = UNSET,
order: Union[Unset, Order] = UNSET,
search: Union[Unset, str] = UNSET,
type: Union[Unset, Type] = UNSET,
mode: Union[Unset, str] = UNSET,
difficulty: Union[Unset, str] = UNSET,
map_type: Union[Unset, int] = UNSET,
all_types: Union[Unset, Operation] = UNSET,
map_requirements: Union[Unset, Requirements] = UNSET,
all_requirements: Union[Unset, Operation] = UNSET,
song_status: Union[Unset, SongStatus] = UNSET,
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
mytype: Union[Unset, MyType] = UNSET,
stars_from: Union[Unset, float] = UNSET,
stars_to: Union[Unset, float] = UNSET,
accrating_from: Union[Unset, float] = UNSET,
accrating_to: Union[Unset, float] = UNSET,
passrating_from: Union[Unset, float] = UNSET,
passrating_to: Union[Unset, float] = UNSET,
techrating_from: Union[Unset, float] = UNSET,
techrating_to: Union[Unset, float] = UNSET,
date_from: Union[Unset, int] = UNSET,
date_to: Union[Unset, int] = UNSET,
mappers: Union[Unset, str] = UNSET,
override_current_id: Union[Unset, str] = UNSET,
) -> Response[Union[Any, LeaderboardInfoResponseResponseWithMetadata]]:
"""Retrieve a list of leaderboards (maps)
Fetches a paginated and optionally filtered list of leaderboards (Beat Saber maps).
Args:
page (Union[Unset, int]): Default: 1.
count (Union[Unset, int]): Default: 10.
sort_by (Union[Unset, MapSortBy]):
order (Union[Unset, Order]): Represents the order in which values will be sorted.
search (Union[Unset, str]):
type (Union[Unset, Type]):
mode (Union[Unset, str]):
difficulty (Union[Unset, str]):
map_type (Union[Unset, int]):
all_types (Union[Unset, Operation]):
map_requirements (Union[Unset, Requirements]):
all_requirements (Union[Unset, Operation]):
song_status (Union[Unset, SongStatus]):
leaderboard_context (Union[Unset, LeaderboardContexts]):
mytype (Union[Unset, MyType]):
stars_from (Union[Unset, float]):
stars_to (Union[Unset, float]):
accrating_from (Union[Unset, float]):
accrating_to (Union[Unset, float]):
passrating_from (Union[Unset, float]):
passrating_to (Union[Unset, float]):
techrating_from (Union[Unset, float]):
techrating_to (Union[Unset, float]):
date_from (Union[Unset, int]):
date_to (Union[Unset, int]):
mappers (Union[Unset, str]):
override_current_id (Union[Unset, str]):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, LeaderboardInfoResponseResponseWithMetadata]]
"""
kwargs = _get_kwargs(
page=page,
count=count,
sort_by=sort_by,
order=order,
search=search,
type=type,
mode=mode,
difficulty=difficulty,
map_type=map_type,
all_types=all_types,
map_requirements=map_requirements,
all_requirements=all_requirements,
song_status=song_status,
leaderboard_context=leaderboard_context,
mytype=mytype,
stars_from=stars_from,
stars_to=stars_to,
accrating_from=accrating_from,
accrating_to=accrating_to,
passrating_from=passrating_from,
passrating_to=passrating_to,
techrating_from=techrating_from,
techrating_to=techrating_to,
date_from=date_from,
date_to=date_to,
mappers=mappers,
override_current_id=override_current_id,
)
response = await client.get_async_httpx_client().request(**kwargs)
return _build_response(client=client, response=response)
async def asyncio(
*,
client: Union[AuthenticatedClient, Client],
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 10,
sort_by: Union[Unset, MapSortBy] = UNSET,
order: Union[Unset, Order] = UNSET,
search: Union[Unset, str] = UNSET,
type: Union[Unset, Type] = UNSET,
mode: Union[Unset, str] = UNSET,
difficulty: Union[Unset, str] = UNSET,
map_type: Union[Unset, int] = UNSET,
all_types: Union[Unset, Operation] = UNSET,
map_requirements: Union[Unset, Requirements] = UNSET,
all_requirements: Union[Unset, Operation] = UNSET,
song_status: Union[Unset, SongStatus] = UNSET,
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
mytype: Union[Unset, MyType] = UNSET,
stars_from: Union[Unset, float] = UNSET,
stars_to: Union[Unset, float] = UNSET,
accrating_from: Union[Unset, float] = UNSET,
accrating_to: Union[Unset, float] = UNSET,
passrating_from: Union[Unset, float] = UNSET,
passrating_to: Union[Unset, float] = UNSET,
techrating_from: Union[Unset, float] = UNSET,
techrating_to: Union[Unset, float] = UNSET,
date_from: Union[Unset, int] = UNSET,
date_to: Union[Unset, int] = UNSET,
mappers: Union[Unset, str] = UNSET,
override_current_id: Union[Unset, str] = UNSET,
) -> Optional[Union[Any, LeaderboardInfoResponseResponseWithMetadata]]:
"""Retrieve a list of leaderboards (maps)
Fetches a paginated and optionally filtered list of leaderboards (Beat Saber maps).
Args:
page (Union[Unset, int]): Default: 1.
count (Union[Unset, int]): Default: 10.
sort_by (Union[Unset, MapSortBy]):
order (Union[Unset, Order]): Represents the order in which values will be sorted.
search (Union[Unset, str]):
type (Union[Unset, Type]):
mode (Union[Unset, str]):
difficulty (Union[Unset, str]):
map_type (Union[Unset, int]):
all_types (Union[Unset, Operation]):
map_requirements (Union[Unset, Requirements]):
all_requirements (Union[Unset, Operation]):
song_status (Union[Unset, SongStatus]):
leaderboard_context (Union[Unset, LeaderboardContexts]):
mytype (Union[Unset, MyType]):
stars_from (Union[Unset, float]):
stars_to (Union[Unset, float]):
accrating_from (Union[Unset, float]):
accrating_to (Union[Unset, float]):
passrating_from (Union[Unset, float]):
passrating_to (Union[Unset, float]):
techrating_from (Union[Unset, float]):
techrating_to (Union[Unset, float]):
date_from (Union[Unset, int]):
date_to (Union[Unset, int]):
mappers (Union[Unset, str]):
override_current_id (Union[Unset, str]):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, LeaderboardInfoResponseResponseWithMetadata]
"""
return (
await asyncio_detailed(
client=client,
page=page,
count=count,
sort_by=sort_by,
order=order,
search=search,
type=type,
mode=mode,
difficulty=difficulty,
map_type=map_type,
all_types=all_types,
map_requirements=map_requirements,
all_requirements=all_requirements,
song_status=song_status,
leaderboard_context=leaderboard_context,
mytype=mytype,
stars_from=stars_from,
stars_to=stars_to,
accrating_from=accrating_from,
accrating_to=accrating_to,
passrating_from=passrating_from,
passrating_to=passrating_to,
techrating_from=techrating_from,
techrating_to=techrating_to,
date_from=date_from,
date_to=date_to,
mappers=mappers,
override_current_id=override_current_id,
)
).parsed

View File

@ -0,0 +1,197 @@
from http import HTTPStatus
from typing import Any, Dict, Optional, Union, cast
import httpx
from ... import errors
from ...client import AuthenticatedClient, Client
from ...models.leaderboard_clan_ranking_response import LeaderboardClanRankingResponse
from ...types import UNSET, Response, Unset
def _get_kwargs(
id: str,
*,
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 10,
) -> Dict[str, Any]:
params: Dict[str, Any] = {}
params["page"] = page
params["count"] = count
params = {k: v for k, v in params.items() if v is not UNSET and v is not None}
_kwargs: Dict[str, Any] = {
"method": "get",
"url": f"/leaderboard/clanRankings/{id}",
"params": params,
}
return _kwargs
def _parse_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Optional[Union[Any, LeaderboardClanRankingResponse]]:
if response.status_code == HTTPStatus.OK:
response_200 = LeaderboardClanRankingResponse.from_dict(response.text)
return response_200
if response.status_code == HTTPStatus.NOT_FOUND:
response_404 = cast(Any, None)
return response_404
if client.raise_on_unexpected_status:
raise errors.UnexpectedStatus(response.status_code, response.content)
else:
return None
def _build_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Response[Union[Any, LeaderboardClanRankingResponse]]:
return Response(
status_code=HTTPStatus(response.status_code),
content=response.content,
headers=response.headers,
parsed=_parse_response(client=client, response=response),
)
def sync_detailed(
id: str,
*,
client: Union[AuthenticatedClient, Client],
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 10,
) -> Response[Union[Any, LeaderboardClanRankingResponse]]:
"""Retrieve clan rankings for a leaderboard
Fetches clan rankings for a leaderboard identified by its ID.
Args:
id (str):
page (Union[Unset, int]): Default: 1.
count (Union[Unset, int]): Default: 10.
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, LeaderboardClanRankingResponse]]
"""
kwargs = _get_kwargs(
id=id,
page=page,
count=count,
)
response = client.get_httpx_client().request(
**kwargs,
)
return _build_response(client=client, response=response)
def sync(
id: str,
*,
client: Union[AuthenticatedClient, Client],
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 10,
) -> Optional[Union[Any, LeaderboardClanRankingResponse]]:
"""Retrieve clan rankings for a leaderboard
Fetches clan rankings for a leaderboard identified by its ID.
Args:
id (str):
page (Union[Unset, int]): Default: 1.
count (Union[Unset, int]): Default: 10.
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, LeaderboardClanRankingResponse]
"""
return sync_detailed(
id=id,
client=client,
page=page,
count=count,
).parsed
async def asyncio_detailed(
id: str,
*,
client: Union[AuthenticatedClient, Client],
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 10,
) -> Response[Union[Any, LeaderboardClanRankingResponse]]:
"""Retrieve clan rankings for a leaderboard
Fetches clan rankings for a leaderboard identified by its ID.
Args:
id (str):
page (Union[Unset, int]): Default: 1.
count (Union[Unset, int]): Default: 10.
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, LeaderboardClanRankingResponse]]
"""
kwargs = _get_kwargs(
id=id,
page=page,
count=count,
)
response = await client.get_async_httpx_client().request(**kwargs)
return _build_response(client=client, response=response)
async def asyncio(
id: str,
*,
client: Union[AuthenticatedClient, Client],
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 10,
) -> Optional[Union[Any, LeaderboardClanRankingResponse]]:
"""Retrieve clan rankings for a leaderboard
Fetches clan rankings for a leaderboard identified by its ID.
Args:
id (str):
page (Union[Unset, int]): Default: 1.
count (Union[Unset, int]): Default: 10.
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, LeaderboardClanRankingResponse]
"""
return (
await asyncio_detailed(
id=id,
client=client,
page=page,
count=count,
)
).parsed

View File

@ -0,0 +1,170 @@
from http import HTTPStatus
from typing import Any, Dict, List, Optional, Union, cast
import httpx
from ... import errors
from ...client import AuthenticatedClient, Client
from ...models.score_graph_entry import ScoreGraphEntry
from ...types import Response
def _get_kwargs(
id: str,
) -> Dict[str, Any]:
_kwargs: Dict[str, Any] = {
"method": "get",
"url": f"/leaderboard/{id}/scoregraph",
}
return _kwargs
def _parse_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Optional[Union[Any, List["ScoreGraphEntry"]]]:
if response.status_code == HTTPStatus.OK:
response_200 = []
_response_200 = response.text
for response_200_item_data in _response_200:
response_200_item = ScoreGraphEntry.from_dict(response_200_item_data)
response_200.append(response_200_item)
return response_200
if response.status_code == HTTPStatus.NOT_FOUND:
response_404 = cast(Any, None)
return response_404
if client.raise_on_unexpected_status:
raise errors.UnexpectedStatus(response.status_code, response.content)
else:
return None
def _build_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Response[Union[Any, List["ScoreGraphEntry"]]]:
return Response(
status_code=HTTPStatus(response.status_code),
content=response.content,
headers=response.headers,
parsed=_parse_response(client=client, response=response),
)
def sync_detailed(
id: str,
*,
client: Union[AuthenticatedClient, Client],
) -> Response[Union[Any, List["ScoreGraphEntry"]]]:
"""Retrieve scores graph for a leaderboard
Fetches the scores graph for a leaderboard identified by its ID. Compact endpoint to use in the
leaderboard data visualizations.
Args:
id (str):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, List['ScoreGraphEntry']]]
"""
kwargs = _get_kwargs(
id=id,
)
response = client.get_httpx_client().request(
**kwargs,
)
return _build_response(client=client, response=response)
def sync(
id: str,
*,
client: Union[AuthenticatedClient, Client],
) -> Optional[Union[Any, List["ScoreGraphEntry"]]]:
"""Retrieve scores graph for a leaderboard
Fetches the scores graph for a leaderboard identified by its ID. Compact endpoint to use in the
leaderboard data visualizations.
Args:
id (str):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, List['ScoreGraphEntry']]
"""
return sync_detailed(
id=id,
client=client,
).parsed
async def asyncio_detailed(
id: str,
*,
client: Union[AuthenticatedClient, Client],
) -> Response[Union[Any, List["ScoreGraphEntry"]]]:
"""Retrieve scores graph for a leaderboard
Fetches the scores graph for a leaderboard identified by its ID. Compact endpoint to use in the
leaderboard data visualizations.
Args:
id (str):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, List['ScoreGraphEntry']]]
"""
kwargs = _get_kwargs(
id=id,
)
response = await client.get_async_httpx_client().request(**kwargs)
return _build_response(client=client, response=response)
async def asyncio(
id: str,
*,
client: Union[AuthenticatedClient, Client],
) -> Optional[Union[Any, List["ScoreGraphEntry"]]]:
"""Retrieve scores graph for a leaderboard
Fetches the scores graph for a leaderboard identified by its ID. Compact endpoint to use in the
leaderboard data visualizations.
Args:
id (str):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, List['ScoreGraphEntry']]
"""
return (
await asyncio_detailed(
id=id,
client=client,
)
).parsed

View File

@ -0,0 +1,138 @@
from http import HTTPStatus
from typing import Any, Dict, Optional, Union
import httpx
from ... import errors
from ...client import AuthenticatedClient, Client
from ...models.legacy_modifiers import LegacyModifiers
from ...types import Response
def _get_kwargs() -> Dict[str, Any]:
_kwargs: Dict[str, Any] = {
"method": "get",
"url": "/modifiers",
}
return _kwargs
def _parse_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Optional[LegacyModifiers]:
if response.status_code == HTTPStatus.OK:
response_200 = LegacyModifiers.from_dict(response.text)
return response_200
if client.raise_on_unexpected_status:
raise errors.UnexpectedStatus(response.status_code, response.content)
else:
return None
def _build_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Response[LegacyModifiers]:
return Response(
status_code=HTTPStatus(response.status_code),
content=response.content,
headers=response.headers,
parsed=_parse_response(client=client, response=response),
)
def sync_detailed(
*,
client: Union[AuthenticatedClient, Client],
) -> Response[LegacyModifiers]:
"""Retrieve Legacy Modifiers
Provides a list of Beat Saber modifiers and their associated score multiplier values. This is legacy
support, for the recent values please use `modifierValues` and `modifierRatings` on leaderboards.
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[LegacyModifiers]
"""
kwargs = _get_kwargs()
response = client.get_httpx_client().request(
**kwargs,
)
return _build_response(client=client, response=response)
def sync(
*,
client: Union[AuthenticatedClient, Client],
) -> Optional[LegacyModifiers]:
"""Retrieve Legacy Modifiers
Provides a list of Beat Saber modifiers and their associated score multiplier values. This is legacy
support, for the recent values please use `modifierValues` and `modifierRatings` on leaderboards.
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
LegacyModifiers
"""
return sync_detailed(
client=client,
).parsed
async def asyncio_detailed(
*,
client: Union[AuthenticatedClient, Client],
) -> Response[LegacyModifiers]:
"""Retrieve Legacy Modifiers
Provides a list of Beat Saber modifiers and their associated score multiplier values. This is legacy
support, for the recent values please use `modifierValues` and `modifierRatings` on leaderboards.
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[LegacyModifiers]
"""
kwargs = _get_kwargs()
response = await client.get_async_httpx_client().request(**kwargs)
return _build_response(client=client, response=response)
async def asyncio(
*,
client: Union[AuthenticatedClient, Client],
) -> Optional[LegacyModifiers]:
"""Retrieve Legacy Modifiers
Provides a list of Beat Saber modifiers and their associated score multiplier values. This is legacy
support, for the recent values please use `modifierValues` and `modifierRatings` on leaderboards.
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
LegacyModifiers
"""
return (
await asyncio_detailed(
client=client,
)
).parsed

View File

@ -0,0 +1,89 @@
from http import HTTPStatus
from typing import Any, Dict, Optional, Union
import httpx
from ... import errors
from ...client import AuthenticatedClient, Client
from ...types import Response
def _get_kwargs() -> Dict[str, Any]:
_kwargs: Dict[str, Any] = {
"method": "get",
"url": "/refreshmypatreon",
}
return _kwargs
def _parse_response(*, client: Union[AuthenticatedClient, Client], response: httpx.Response) -> Optional[Any]:
if response.status_code == HTTPStatus.OK:
return None
if response.status_code == HTTPStatus.BAD_REQUEST:
return None
if response.status_code == HTTPStatus.UNAUTHORIZED:
return None
if client.raise_on_unexpected_status:
raise errors.UnexpectedStatus(response.status_code, response.content)
else:
return None
def _build_response(*, client: Union[AuthenticatedClient, Client], response: httpx.Response) -> Response[Any]:
return Response(
status_code=HTTPStatus(response.status_code),
content=response.content,
headers=response.headers,
parsed=_parse_response(client=client, response=response),
)
def sync_detailed(
*,
client: Union[AuthenticatedClient, Client],
) -> Response[Any]:
"""Refresh Patreon Link
Refreshes the Patreon link for the current user, updating their Patreon tier and roles based on the
latest information.
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Any]
"""
kwargs = _get_kwargs()
response = client.get_httpx_client().request(
**kwargs,
)
return _build_response(client=client, response=response)
async def asyncio_detailed(
*,
client: Union[AuthenticatedClient, Client],
) -> Response[Any]:
"""Refresh Patreon Link
Refreshes the Patreon link for the current user, updating their Patreon tier and roles based on the
latest information.
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Any]
"""
kwargs = _get_kwargs()
response = await client.get_async_httpx_client().request(**kwargs)
return _build_response(client=client, response=response)

View File

@ -0,0 +1,217 @@
from http import HTTPStatus
from typing import Any, Dict, Optional, Union, cast
import httpx
from ... import errors
from ...client import AuthenticatedClient, Client
from ...models.leaderboard_contexts import LeaderboardContexts
from ...models.player_response_full import PlayerResponseFull
from ...types import UNSET, Response, Unset
def _get_kwargs(
id: str,
*,
stats: Union[Unset, bool] = True,
keep_original_id: Union[Unset, bool] = False,
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
) -> Dict[str, Any]:
params: Dict[str, Any] = {}
params["stats"] = stats
params["keepOriginalId"] = keep_original_id
json_leaderboard_context: Union[Unset, str] = UNSET
if not isinstance(leaderboard_context, Unset):
json_leaderboard_context = leaderboard_context.value
params["leaderboardContext"] = json_leaderboard_context
params = {k: v for k, v in params.items() if v is not UNSET and v is not None}
_kwargs: Dict[str, Any] = {
"method": "get",
"url": f"/player/{id}",
"params": params,
}
return _kwargs
def _parse_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Optional[Union[Any, PlayerResponseFull]]:
if response.status_code == HTTPStatus.OK:
response_200 = PlayerResponseFull.from_dict(response.text)
return response_200
if response.status_code == HTTPStatus.NOT_FOUND:
response_404 = cast(Any, None)
return response_404
if client.raise_on_unexpected_status:
raise errors.UnexpectedStatus(response.status_code, response.content)
else:
return None
def _build_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Response[Union[Any, PlayerResponseFull]]:
return Response(
status_code=HTTPStatus(response.status_code),
content=response.content,
headers=response.headers,
parsed=_parse_response(client=client, response=response),
)
def sync_detailed(
id: str,
*,
client: Union[AuthenticatedClient, Client],
stats: Union[Unset, bool] = True,
keep_original_id: Union[Unset, bool] = False,
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
) -> Response[Union[Any, PlayerResponseFull]]:
"""Get player profile
Retrieves a Beat Saber profile data for a specific player ID.
Args:
id (str):
stats (Union[Unset, bool]): Default: True.
keep_original_id (Union[Unset, bool]): Default: False.
leaderboard_context (Union[Unset, LeaderboardContexts]):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, PlayerResponseFull]]
"""
kwargs = _get_kwargs(
id=id,
stats=stats,
keep_original_id=keep_original_id,
leaderboard_context=leaderboard_context,
)
response = client.get_httpx_client().request(
**kwargs,
)
return _build_response(client=client, response=response)
def sync(
id: str,
*,
client: Union[AuthenticatedClient, Client],
stats: Union[Unset, bool] = True,
keep_original_id: Union[Unset, bool] = False,
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
) -> Optional[Union[Any, PlayerResponseFull]]:
"""Get player profile
Retrieves a Beat Saber profile data for a specific player ID.
Args:
id (str):
stats (Union[Unset, bool]): Default: True.
keep_original_id (Union[Unset, bool]): Default: False.
leaderboard_context (Union[Unset, LeaderboardContexts]):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, PlayerResponseFull]
"""
return sync_detailed(
id=id,
client=client,
stats=stats,
keep_original_id=keep_original_id,
leaderboard_context=leaderboard_context,
).parsed
async def asyncio_detailed(
id: str,
*,
client: Union[AuthenticatedClient, Client],
stats: Union[Unset, bool] = True,
keep_original_id: Union[Unset, bool] = False,
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
) -> Response[Union[Any, PlayerResponseFull]]:
"""Get player profile
Retrieves a Beat Saber profile data for a specific player ID.
Args:
id (str):
stats (Union[Unset, bool]): Default: True.
keep_original_id (Union[Unset, bool]): Default: False.
leaderboard_context (Union[Unset, LeaderboardContexts]):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, PlayerResponseFull]]
"""
kwargs = _get_kwargs(
id=id,
stats=stats,
keep_original_id=keep_original_id,
leaderboard_context=leaderboard_context,
)
response = await client.get_async_httpx_client().request(**kwargs)
return _build_response(client=client, response=response)
async def asyncio(
id: str,
*,
client: Union[AuthenticatedClient, Client],
stats: Union[Unset, bool] = True,
keep_original_id: Union[Unset, bool] = False,
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
) -> Optional[Union[Any, PlayerResponseFull]]:
"""Get player profile
Retrieves a Beat Saber profile data for a specific player ID.
Args:
id (str):
stats (Union[Unset, bool]): Default: True.
keep_original_id (Union[Unset, bool]): Default: False.
leaderboard_context (Union[Unset, LeaderboardContexts]):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, PlayerResponseFull]
"""
return (
await asyncio_detailed(
id=id,
client=client,
stats=stats,
keep_original_id=keep_original_id,
leaderboard_context=leaderboard_context,
)
).parsed

View File

@ -0,0 +1,161 @@
from http import HTTPStatus
from typing import Any, Dict, Optional, Union, cast
import httpx
from ... import errors
from ...client import AuthenticatedClient, Client
from ...models.player_response_full import PlayerResponseFull
from ...types import Response
def _get_kwargs(
id: str,
) -> Dict[str, Any]:
_kwargs: Dict[str, Any] = {
"method": "get",
"url": f"/player/beatsaver/{id}",
}
return _kwargs
def _parse_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Optional[Union[Any, PlayerResponseFull]]:
if response.status_code == HTTPStatus.OK:
response_200 = PlayerResponseFull.from_dict(response.text)
return response_200
if response.status_code == HTTPStatus.NOT_FOUND:
response_404 = cast(Any, None)
return response_404
if client.raise_on_unexpected_status:
raise errors.UnexpectedStatus(response.status_code, response.content)
else:
return None
def _build_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Response[Union[Any, PlayerResponseFull]]:
return Response(
status_code=HTTPStatus(response.status_code),
content=response.content,
headers=response.headers,
parsed=_parse_response(client=client, response=response),
)
def sync_detailed(
id: str,
*,
client: Union[AuthenticatedClient, Client],
) -> Response[Union[Any, PlayerResponseFull]]:
"""Get player with BeatSaver
Retrieves a BeatLeader profile data with linked BeatSaver profile.
Args:
id (str):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, PlayerResponseFull]]
"""
kwargs = _get_kwargs(
id=id,
)
response = client.get_httpx_client().request(
**kwargs,
)
return _build_response(client=client, response=response)
def sync(
id: str,
*,
client: Union[AuthenticatedClient, Client],
) -> Optional[Union[Any, PlayerResponseFull]]:
"""Get player with BeatSaver
Retrieves a BeatLeader profile data with linked BeatSaver profile.
Args:
id (str):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, PlayerResponseFull]
"""
return sync_detailed(
id=id,
client=client,
).parsed
async def asyncio_detailed(
id: str,
*,
client: Union[AuthenticatedClient, Client],
) -> Response[Union[Any, PlayerResponseFull]]:
"""Get player with BeatSaver
Retrieves a BeatLeader profile data with linked BeatSaver profile.
Args:
id (str):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, PlayerResponseFull]]
"""
kwargs = _get_kwargs(
id=id,
)
response = await client.get_async_httpx_client().request(**kwargs)
return _build_response(client=client, response=response)
async def asyncio(
id: str,
*,
client: Union[AuthenticatedClient, Client],
) -> Optional[Union[Any, PlayerResponseFull]]:
"""Get player with BeatSaver
Retrieves a BeatLeader profile data with linked BeatSaver profile.
Args:
id (str):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, PlayerResponseFull]
"""
return (
await asyncio_detailed(
id=id,
client=client,
)
).parsed

View File

@ -0,0 +1,161 @@
from http import HTTPStatus
from typing import Any, Dict, Optional, Union, cast
import httpx
from ... import errors
from ...client import AuthenticatedClient, Client
from ...models.player_response_full import PlayerResponseFull
from ...types import Response
def _get_kwargs(
id: str,
) -> Dict[str, Any]:
_kwargs: Dict[str, Any] = {
"method": "get",
"url": f"/player/discord/{id}",
}
return _kwargs
def _parse_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Optional[Union[Any, PlayerResponseFull]]:
if response.status_code == HTTPStatus.OK:
response_200 = PlayerResponseFull.from_dict(response.text)
return response_200
if response.status_code == HTTPStatus.NOT_FOUND:
response_404 = cast(Any, None)
return response_404
if client.raise_on_unexpected_status:
raise errors.UnexpectedStatus(response.status_code, response.content)
else:
return None
def _build_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Response[Union[Any, PlayerResponseFull]]:
return Response(
status_code=HTTPStatus(response.status_code),
content=response.content,
headers=response.headers,
parsed=_parse_response(client=client, response=response),
)
def sync_detailed(
id: str,
*,
client: Union[AuthenticatedClient, Client],
) -> Response[Union[Any, PlayerResponseFull]]:
"""Get player with Discord
Retrieves a BeatLeader profile data with linked Discord profile.
Args:
id (str):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, PlayerResponseFull]]
"""
kwargs = _get_kwargs(
id=id,
)
response = client.get_httpx_client().request(
**kwargs,
)
return _build_response(client=client, response=response)
def sync(
id: str,
*,
client: Union[AuthenticatedClient, Client],
) -> Optional[Union[Any, PlayerResponseFull]]:
"""Get player with Discord
Retrieves a BeatLeader profile data with linked Discord profile.
Args:
id (str):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, PlayerResponseFull]
"""
return sync_detailed(
id=id,
client=client,
).parsed
async def asyncio_detailed(
id: str,
*,
client: Union[AuthenticatedClient, Client],
) -> Response[Union[Any, PlayerResponseFull]]:
"""Get player with Discord
Retrieves a BeatLeader profile data with linked Discord profile.
Args:
id (str):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, PlayerResponseFull]]
"""
kwargs = _get_kwargs(
id=id,
)
response = await client.get_async_httpx_client().request(**kwargs)
return _build_response(client=client, response=response)
async def asyncio(
id: str,
*,
client: Union[AuthenticatedClient, Client],
) -> Optional[Union[Any, PlayerResponseFull]]:
"""Get player with Discord
Retrieves a BeatLeader profile data with linked Discord profile.
Args:
id (str):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, PlayerResponseFull]
"""
return (
await asyncio_detailed(
id=id,
client=client,
)
).parsed

View File

@ -0,0 +1,222 @@
from http import HTTPStatus
from typing import Any, Dict, List, Optional, Union, cast
import httpx
from ... import errors
from ...client import AuthenticatedClient, Client
from ...models.follower_type import FollowerType
from ...models.player_follower import PlayerFollower
from ...types import UNSET, Response, Unset
def _get_kwargs(
id: str,
*,
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 10,
type: Union[Unset, FollowerType] = UNSET,
) -> Dict[str, Any]:
params: Dict[str, Any] = {}
params["page"] = page
params["count"] = count
json_type: Union[Unset, str] = UNSET
if not isinstance(type, Unset):
json_type = type.value
params["type"] = json_type
params = {k: v for k, v in params.items() if v is not UNSET and v is not None}
_kwargs: Dict[str, Any] = {
"method": "get",
"url": f"/player/{id}/followers",
"params": params,
}
return _kwargs
def _parse_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Optional[Union[Any, List["PlayerFollower"]]]:
if response.status_code == HTTPStatus.OK:
response_200 = []
_response_200 = response.text
for response_200_item_data in _response_200:
response_200_item = PlayerFollower.from_dict(response_200_item_data)
response_200.append(response_200_item)
return response_200
if response.status_code == HTTPStatus.NOT_FOUND:
response_404 = cast(Any, None)
return response_404
if client.raise_on_unexpected_status:
raise errors.UnexpectedStatus(response.status_code, response.content)
else:
return None
def _build_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Response[Union[Any, List["PlayerFollower"]]]:
return Response(
status_code=HTTPStatus(response.status_code),
content=response.content,
headers=response.headers,
parsed=_parse_response(client=client, response=response),
)
def sync_detailed(
id: str,
*,
client: Union[AuthenticatedClient, Client],
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 10,
type: Union[Unset, FollowerType] = UNSET,
) -> Response[Union[Any, List["PlayerFollower"]]]:
"""Get player's full follower list
Retrieves a full list of player' followers and players this player follow.
Args:
id (str):
page (Union[Unset, int]): Default: 1.
count (Union[Unset, int]): Default: 10.
type (Union[Unset, FollowerType]):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, List['PlayerFollower']]]
"""
kwargs = _get_kwargs(
id=id,
page=page,
count=count,
type=type,
)
response = client.get_httpx_client().request(
**kwargs,
)
return _build_response(client=client, response=response)
def sync(
id: str,
*,
client: Union[AuthenticatedClient, Client],
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 10,
type: Union[Unset, FollowerType] = UNSET,
) -> Optional[Union[Any, List["PlayerFollower"]]]:
"""Get player's full follower list
Retrieves a full list of player' followers and players this player follow.
Args:
id (str):
page (Union[Unset, int]): Default: 1.
count (Union[Unset, int]): Default: 10.
type (Union[Unset, FollowerType]):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, List['PlayerFollower']]
"""
return sync_detailed(
id=id,
client=client,
page=page,
count=count,
type=type,
).parsed
async def asyncio_detailed(
id: str,
*,
client: Union[AuthenticatedClient, Client],
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 10,
type: Union[Unset, FollowerType] = UNSET,
) -> Response[Union[Any, List["PlayerFollower"]]]:
"""Get player's full follower list
Retrieves a full list of player' followers and players this player follow.
Args:
id (str):
page (Union[Unset, int]): Default: 1.
count (Union[Unset, int]): Default: 10.
type (Union[Unset, FollowerType]):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, List['PlayerFollower']]]
"""
kwargs = _get_kwargs(
id=id,
page=page,
count=count,
type=type,
)
response = await client.get_async_httpx_client().request(**kwargs)
return _build_response(client=client, response=response)
async def asyncio(
id: str,
*,
client: Union[AuthenticatedClient, Client],
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 10,
type: Union[Unset, FollowerType] = UNSET,
) -> Optional[Union[Any, List["PlayerFollower"]]]:
"""Get player's full follower list
Retrieves a full list of player' followers and players this player follow.
Args:
id (str):
page (Union[Unset, int]): Default: 1.
count (Union[Unset, int]): Default: 10.
type (Union[Unset, FollowerType]):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, List['PlayerFollower']]
"""
return (
await asyncio_detailed(
id=id,
client=client,
page=page,
count=count,
type=type,
)
).parsed

View File

@ -0,0 +1,165 @@
from http import HTTPStatus
from typing import Any, Dict, Optional, Union, cast
import httpx
from ... import errors
from ...client import AuthenticatedClient, Client
from ...models.player_followers_info_response import PlayerFollowersInfoResponse
from ...types import Response
def _get_kwargs(
id: str,
) -> Dict[str, Any]:
_kwargs: Dict[str, Any] = {
"method": "get",
"url": f"/player/{id}/followersInfo",
}
return _kwargs
def _parse_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Optional[Union[Any, PlayerFollowersInfoResponse]]:
if response.status_code == HTTPStatus.OK:
response_200 = PlayerFollowersInfoResponse.from_dict(response.text)
return response_200
if response.status_code == HTTPStatus.NOT_FOUND:
response_404 = cast(Any, None)
return response_404
if client.raise_on_unexpected_status:
raise errors.UnexpectedStatus(response.status_code, response.content)
else:
return None
def _build_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Response[Union[Any, PlayerFollowersInfoResponse]]:
return Response(
status_code=HTTPStatus(response.status_code),
content=response.content,
headers=response.headers,
parsed=_parse_response(client=client, response=response),
)
def sync_detailed(
id: str,
*,
client: Union[AuthenticatedClient, Client],
) -> Response[Union[Any, PlayerFollowersInfoResponse]]:
"""Get player' followers and players they follow
Retrieves an info about player' followers such as count and 3 closest followers. Also 3 most
followed players this player follows
Args:
id (str):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, PlayerFollowersInfoResponse]]
"""
kwargs = _get_kwargs(
id=id,
)
response = client.get_httpx_client().request(
**kwargs,
)
return _build_response(client=client, response=response)
def sync(
id: str,
*,
client: Union[AuthenticatedClient, Client],
) -> Optional[Union[Any, PlayerFollowersInfoResponse]]:
"""Get player' followers and players they follow
Retrieves an info about player' followers such as count and 3 closest followers. Also 3 most
followed players this player follows
Args:
id (str):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, PlayerFollowersInfoResponse]
"""
return sync_detailed(
id=id,
client=client,
).parsed
async def asyncio_detailed(
id: str,
*,
client: Union[AuthenticatedClient, Client],
) -> Response[Union[Any, PlayerFollowersInfoResponse]]:
"""Get player' followers and players they follow
Retrieves an info about player' followers such as count and 3 closest followers. Also 3 most
followed players this player follows
Args:
id (str):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, PlayerFollowersInfoResponse]]
"""
kwargs = _get_kwargs(
id=id,
)
response = await client.get_async_httpx_client().request(**kwargs)
return _build_response(client=client, response=response)
async def asyncio(
id: str,
*,
client: Union[AuthenticatedClient, Client],
) -> Optional[Union[Any, PlayerFollowersInfoResponse]]:
"""Get player' followers and players they follow
Retrieves an info about player' followers such as count and 3 closest followers. Also 3 most
followed players this player follows
Args:
id (str):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, PlayerFollowersInfoResponse]
"""
return (
await asyncio_detailed(
id=id,
client=client,
)
).parsed

View File

@ -0,0 +1,161 @@
from http import HTTPStatus
from typing import Any, Dict, Optional, Union, cast
import httpx
from ... import errors
from ...client import AuthenticatedClient, Client
from ...models.clan_bigger_response import ClanBiggerResponse
from ...types import Response
def _get_kwargs(
id: str,
) -> Dict[str, Any]:
_kwargs: Dict[str, Any] = {
"method": "get",
"url": f"/player/{id}/foundedClan",
}
return _kwargs
def _parse_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Optional[Union[Any, ClanBiggerResponse]]:
if response.status_code == HTTPStatus.OK:
response_200 = ClanBiggerResponse.from_dict(response.text)
return response_200
if response.status_code == HTTPStatus.NOT_FOUND:
response_404 = cast(Any, None)
return response_404
if client.raise_on_unexpected_status:
raise errors.UnexpectedStatus(response.status_code, response.content)
else:
return None
def _build_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Response[Union[Any, ClanBiggerResponse]]:
return Response(
status_code=HTTPStatus(response.status_code),
content=response.content,
headers=response.headers,
parsed=_parse_response(client=client, response=response),
)
def sync_detailed(
id: str,
*,
client: Union[AuthenticatedClient, Client],
) -> Response[Union[Any, ClanBiggerResponse]]:
"""Get info about the clan this player founded
Retrieves an information about the clan this player created and manage.
Args:
id (str):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, ClanBiggerResponse]]
"""
kwargs = _get_kwargs(
id=id,
)
response = client.get_httpx_client().request(
**kwargs,
)
return _build_response(client=client, response=response)
def sync(
id: str,
*,
client: Union[AuthenticatedClient, Client],
) -> Optional[Union[Any, ClanBiggerResponse]]:
"""Get info about the clan this player founded
Retrieves an information about the clan this player created and manage.
Args:
id (str):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, ClanBiggerResponse]
"""
return sync_detailed(
id=id,
client=client,
).parsed
async def asyncio_detailed(
id: str,
*,
client: Union[AuthenticatedClient, Client],
) -> Response[Union[Any, ClanBiggerResponse]]:
"""Get info about the clan this player founded
Retrieves an information about the clan this player created and manage.
Args:
id (str):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, ClanBiggerResponse]]
"""
kwargs = _get_kwargs(
id=id,
)
response = await client.get_async_httpx_client().request(**kwargs)
return _build_response(client=client, response=response)
async def asyncio(
id: str,
*,
client: Union[AuthenticatedClient, Client],
) -> Optional[Union[Any, ClanBiggerResponse]]:
"""Get info about the clan this player founded
Retrieves an information about the clan this player created and manage.
Args:
id (str):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, ClanBiggerResponse]
"""
return (
await asyncio_detailed(
id=id,
client=client,
)
).parsed

View File

@ -0,0 +1,161 @@
from http import HTTPStatus
from typing import Any, Dict, Optional, Union, cast
import httpx
from ... import errors
from ...client import AuthenticatedClient, Client
from ...models.participating_event_response import ParticipatingEventResponse
from ...types import Response
def _get_kwargs(
id: str,
) -> Dict[str, Any]:
_kwargs: Dict[str, Any] = {
"method": "get",
"url": f"/player/{id}/eventsparticipating",
}
return _kwargs
def _parse_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Optional[Union[Any, ParticipatingEventResponse]]:
if response.status_code == HTTPStatus.OK:
response_200 = ParticipatingEventResponse.from_dict(response.text)
return response_200
if response.status_code == HTTPStatus.NOT_FOUND:
response_404 = cast(Any, None)
return response_404
if client.raise_on_unexpected_status:
raise errors.UnexpectedStatus(response.status_code, response.content)
else:
return None
def _build_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Response[Union[Any, ParticipatingEventResponse]]:
return Response(
status_code=HTTPStatus(response.status_code),
content=response.content,
headers=response.headers,
parsed=_parse_response(client=client, response=response),
)
def sync_detailed(
id: str,
*,
client: Union[AuthenticatedClient, Client],
) -> Response[Union[Any, ParticipatingEventResponse]]:
"""Get events where player participated
Retrieves a chronological list of events player with such ID took part of.
Args:
id (str):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, ParticipatingEventResponse]]
"""
kwargs = _get_kwargs(
id=id,
)
response = client.get_httpx_client().request(
**kwargs,
)
return _build_response(client=client, response=response)
def sync(
id: str,
*,
client: Union[AuthenticatedClient, Client],
) -> Optional[Union[Any, ParticipatingEventResponse]]:
"""Get events where player participated
Retrieves a chronological list of events player with such ID took part of.
Args:
id (str):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, ParticipatingEventResponse]
"""
return sync_detailed(
id=id,
client=client,
).parsed
async def asyncio_detailed(
id: str,
*,
client: Union[AuthenticatedClient, Client],
) -> Response[Union[Any, ParticipatingEventResponse]]:
"""Get events where player participated
Retrieves a chronological list of events player with such ID took part of.
Args:
id (str):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, ParticipatingEventResponse]]
"""
kwargs = _get_kwargs(
id=id,
)
response = await client.get_async_httpx_client().request(**kwargs)
return _build_response(client=client, response=response)
async def asyncio(
id: str,
*,
client: Union[AuthenticatedClient, Client],
) -> Optional[Union[Any, ParticipatingEventResponse]]:
"""Get events where player participated
Retrieves a chronological list of events player with such ID took part of.
Args:
id (str):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, ParticipatingEventResponse]
"""
return (
await asyncio_detailed(
id=id,
client=client,
)
).parsed

View File

@ -0,0 +1,161 @@
from http import HTTPStatus
from typing import Any, Dict, Optional, Union, cast
import httpx
from ... import errors
from ...client import AuthenticatedClient, Client
from ...models.player_response_full import PlayerResponseFull
from ...types import Response
def _get_kwargs(
id: str,
) -> Dict[str, Any]:
_kwargs: Dict[str, Any] = {
"method": "get",
"url": f"/player/patreon/{id}",
}
return _kwargs
def _parse_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Optional[Union[Any, PlayerResponseFull]]:
if response.status_code == HTTPStatus.OK:
response_200 = PlayerResponseFull.from_dict(response.text)
return response_200
if response.status_code == HTTPStatus.NOT_FOUND:
response_404 = cast(Any, None)
return response_404
if client.raise_on_unexpected_status:
raise errors.UnexpectedStatus(response.status_code, response.content)
else:
return None
def _build_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Response[Union[Any, PlayerResponseFull]]:
return Response(
status_code=HTTPStatus(response.status_code),
content=response.content,
headers=response.headers,
parsed=_parse_response(client=client, response=response),
)
def sync_detailed(
id: str,
*,
client: Union[AuthenticatedClient, Client],
) -> Response[Union[Any, PlayerResponseFull]]:
"""Get player with Patreon
Retrieves a BeatLeader profile data with linked Patreon profile.
Args:
id (str):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, PlayerResponseFull]]
"""
kwargs = _get_kwargs(
id=id,
)
response = client.get_httpx_client().request(
**kwargs,
)
return _build_response(client=client, response=response)
def sync(
id: str,
*,
client: Union[AuthenticatedClient, Client],
) -> Optional[Union[Any, PlayerResponseFull]]:
"""Get player with Patreon
Retrieves a BeatLeader profile data with linked Patreon profile.
Args:
id (str):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, PlayerResponseFull]
"""
return sync_detailed(
id=id,
client=client,
).parsed
async def asyncio_detailed(
id: str,
*,
client: Union[AuthenticatedClient, Client],
) -> Response[Union[Any, PlayerResponseFull]]:
"""Get player with Patreon
Retrieves a BeatLeader profile data with linked Patreon profile.
Args:
id (str):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, PlayerResponseFull]]
"""
kwargs = _get_kwargs(
id=id,
)
response = await client.get_async_httpx_client().request(**kwargs)
return _build_response(client=client, response=response)
async def asyncio(
id: str,
*,
client: Union[AuthenticatedClient, Client],
) -> Optional[Union[Any, PlayerResponseFull]]:
"""Get player with Patreon
Retrieves a BeatLeader profile data with linked Patreon profile.
Args:
id (str):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, PlayerResponseFull]
"""
return (
await asyncio_detailed(
id=id,
client=client,
)
).parsed

View File

@ -0,0 +1,441 @@
from http import HTTPStatus
from typing import Any, Dict, Optional, Union, cast
import httpx
from ... import errors
from ...client import AuthenticatedClient, Client
from ...models.leaderboard_contexts import LeaderboardContexts
from ...models.maps_type import MapsType
from ...models.order import Order
from ...models.player_response_with_stats_response_with_metadata import PlayerResponseWithStatsResponseWithMetadata
from ...models.player_sort_by import PlayerSortBy
from ...models.pp_type import PpType
from ...types import UNSET, Response, Unset
def _get_kwargs(
*,
sort_by: Union[Unset, PlayerSortBy] = UNSET,
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 50,
search: Union[Unset, str] = "",
order: Union[Unset, Order] = UNSET,
countries: Union[Unset, str] = "",
maps_type: Union[Unset, MapsType] = UNSET,
pp_type: Union[Unset, PpType] = UNSET,
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
friends: Union[Unset, bool] = False,
pp_range: Union[Unset, str] = UNSET,
score_range: Union[Unset, str] = UNSET,
platform: Union[Unset, str] = UNSET,
role: Union[Unset, str] = UNSET,
hmd: Union[Unset, str] = UNSET,
activity_period: Union[Unset, int] = UNSET,
banned: Union[Unset, bool] = UNSET,
) -> Dict[str, Any]:
params: Dict[str, Any] = {}
json_sort_by: Union[Unset, str] = UNSET
if not isinstance(sort_by, Unset):
json_sort_by = sort_by.value
params["sortBy"] = json_sort_by
params["page"] = page
params["count"] = count
params["search"] = search
json_order: Union[Unset, str] = UNSET
if not isinstance(order, Unset):
json_order = order.value
params["order"] = json_order
params["countries"] = countries
json_maps_type: Union[Unset, str] = UNSET
if not isinstance(maps_type, Unset):
json_maps_type = maps_type.value
params["mapsType"] = json_maps_type
json_pp_type: Union[Unset, str] = UNSET
if not isinstance(pp_type, Unset):
json_pp_type = pp_type.value
params["ppType"] = json_pp_type
json_leaderboard_context: Union[Unset, str] = UNSET
if not isinstance(leaderboard_context, Unset):
json_leaderboard_context = leaderboard_context.value
params["leaderboardContext"] = json_leaderboard_context
params["friends"] = friends
params["pp_range"] = pp_range
params["score_range"] = score_range
params["platform"] = platform
params["role"] = role
params["hmd"] = hmd
params["activityPeriod"] = activity_period
params["banned"] = banned
params = {k: v for k, v in params.items() if v is not UNSET and v is not None}
_kwargs: Dict[str, Any] = {
"method": "get",
"url": "/players",
"params": params,
}
return _kwargs
def _parse_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Optional[Union[Any, PlayerResponseWithStatsResponseWithMetadata]]:
if response.status_code == HTTPStatus.OK:
response_200 = PlayerResponseWithStatsResponseWithMetadata.from_dict(response.text)
return response_200
if response.status_code == HTTPStatus.BAD_REQUEST:
response_400 = cast(Any, None)
return response_400
if response.status_code == HTTPStatus.NOT_FOUND:
response_404 = cast(Any, None)
return response_404
if client.raise_on_unexpected_status:
raise errors.UnexpectedStatus(response.status_code, response.content)
else:
return None
def _build_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Response[Union[Any, PlayerResponseWithStatsResponseWithMetadata]]:
return Response(
status_code=HTTPStatus(response.status_code),
content=response.content,
headers=response.headers,
parsed=_parse_response(client=client, response=response),
)
def sync_detailed(
*,
client: Union[AuthenticatedClient, Client],
sort_by: Union[Unset, PlayerSortBy] = UNSET,
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 50,
search: Union[Unset, str] = "",
order: Union[Unset, Order] = UNSET,
countries: Union[Unset, str] = "",
maps_type: Union[Unset, MapsType] = UNSET,
pp_type: Union[Unset, PpType] = UNSET,
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
friends: Union[Unset, bool] = False,
pp_range: Union[Unset, str] = UNSET,
score_range: Union[Unset, str] = UNSET,
platform: Union[Unset, str] = UNSET,
role: Union[Unset, str] = UNSET,
hmd: Union[Unset, str] = UNSET,
activity_period: Union[Unset, int] = UNSET,
banned: Union[Unset, bool] = UNSET,
) -> Response[Union[Any, PlayerResponseWithStatsResponseWithMetadata]]:
"""Retrieve a list of players (ranking)
Fetches a paginated and optionally filtered list of players. Filters include sorting by performance
points, search, country, maps type, platform, and more.
Args:
sort_by (Union[Unset, PlayerSortBy]):
page (Union[Unset, int]): Default: 1.
count (Union[Unset, int]): Default: 50.
search (Union[Unset, str]): Default: ''.
order (Union[Unset, Order]): Represents the order in which values will be sorted.
countries (Union[Unset, str]): Default: ''.
maps_type (Union[Unset, MapsType]):
pp_type (Union[Unset, PpType]):
leaderboard_context (Union[Unset, LeaderboardContexts]):
friends (Union[Unset, bool]): Default: False.
pp_range (Union[Unset, str]):
score_range (Union[Unset, str]):
platform (Union[Unset, str]):
role (Union[Unset, str]):
hmd (Union[Unset, str]):
activity_period (Union[Unset, int]):
banned (Union[Unset, bool]):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, PlayerResponseWithStatsResponseWithMetadata]]
"""
kwargs = _get_kwargs(
sort_by=sort_by,
page=page,
count=count,
search=search,
order=order,
countries=countries,
maps_type=maps_type,
pp_type=pp_type,
leaderboard_context=leaderboard_context,
friends=friends,
pp_range=pp_range,
score_range=score_range,
platform=platform,
role=role,
hmd=hmd,
activity_period=activity_period,
banned=banned,
)
response = client.get_httpx_client().request(
**kwargs,
)
return _build_response(client=client, response=response)
def sync(
*,
client: Union[AuthenticatedClient, Client],
sort_by: Union[Unset, PlayerSortBy] = UNSET,
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 50,
search: Union[Unset, str] = "",
order: Union[Unset, Order] = UNSET,
countries: Union[Unset, str] = "",
maps_type: Union[Unset, MapsType] = UNSET,
pp_type: Union[Unset, PpType] = UNSET,
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
friends: Union[Unset, bool] = False,
pp_range: Union[Unset, str] = UNSET,
score_range: Union[Unset, str] = UNSET,
platform: Union[Unset, str] = UNSET,
role: Union[Unset, str] = UNSET,
hmd: Union[Unset, str] = UNSET,
activity_period: Union[Unset, int] = UNSET,
banned: Union[Unset, bool] = UNSET,
) -> Optional[Union[Any, PlayerResponseWithStatsResponseWithMetadata]]:
"""Retrieve a list of players (ranking)
Fetches a paginated and optionally filtered list of players. Filters include sorting by performance
points, search, country, maps type, platform, and more.
Args:
sort_by (Union[Unset, PlayerSortBy]):
page (Union[Unset, int]): Default: 1.
count (Union[Unset, int]): Default: 50.
search (Union[Unset, str]): Default: ''.
order (Union[Unset, Order]): Represents the order in which values will be sorted.
countries (Union[Unset, str]): Default: ''.
maps_type (Union[Unset, MapsType]):
pp_type (Union[Unset, PpType]):
leaderboard_context (Union[Unset, LeaderboardContexts]):
friends (Union[Unset, bool]): Default: False.
pp_range (Union[Unset, str]):
score_range (Union[Unset, str]):
platform (Union[Unset, str]):
role (Union[Unset, str]):
hmd (Union[Unset, str]):
activity_period (Union[Unset, int]):
banned (Union[Unset, bool]):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, PlayerResponseWithStatsResponseWithMetadata]
"""
return sync_detailed(
client=client,
sort_by=sort_by,
page=page,
count=count,
search=search,
order=order,
countries=countries,
maps_type=maps_type,
pp_type=pp_type,
leaderboard_context=leaderboard_context,
friends=friends,
pp_range=pp_range,
score_range=score_range,
platform=platform,
role=role,
hmd=hmd,
activity_period=activity_period,
banned=banned,
).parsed
async def asyncio_detailed(
*,
client: Union[AuthenticatedClient, Client],
sort_by: Union[Unset, PlayerSortBy] = UNSET,
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 50,
search: Union[Unset, str] = "",
order: Union[Unset, Order] = UNSET,
countries: Union[Unset, str] = "",
maps_type: Union[Unset, MapsType] = UNSET,
pp_type: Union[Unset, PpType] = UNSET,
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
friends: Union[Unset, bool] = False,
pp_range: Union[Unset, str] = UNSET,
score_range: Union[Unset, str] = UNSET,
platform: Union[Unset, str] = UNSET,
role: Union[Unset, str] = UNSET,
hmd: Union[Unset, str] = UNSET,
activity_period: Union[Unset, int] = UNSET,
banned: Union[Unset, bool] = UNSET,
) -> Response[Union[Any, PlayerResponseWithStatsResponseWithMetadata]]:
"""Retrieve a list of players (ranking)
Fetches a paginated and optionally filtered list of players. Filters include sorting by performance
points, search, country, maps type, platform, and more.
Args:
sort_by (Union[Unset, PlayerSortBy]):
page (Union[Unset, int]): Default: 1.
count (Union[Unset, int]): Default: 50.
search (Union[Unset, str]): Default: ''.
order (Union[Unset, Order]): Represents the order in which values will be sorted.
countries (Union[Unset, str]): Default: ''.
maps_type (Union[Unset, MapsType]):
pp_type (Union[Unset, PpType]):
leaderboard_context (Union[Unset, LeaderboardContexts]):
friends (Union[Unset, bool]): Default: False.
pp_range (Union[Unset, str]):
score_range (Union[Unset, str]):
platform (Union[Unset, str]):
role (Union[Unset, str]):
hmd (Union[Unset, str]):
activity_period (Union[Unset, int]):
banned (Union[Unset, bool]):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, PlayerResponseWithStatsResponseWithMetadata]]
"""
kwargs = _get_kwargs(
sort_by=sort_by,
page=page,
count=count,
search=search,
order=order,
countries=countries,
maps_type=maps_type,
pp_type=pp_type,
leaderboard_context=leaderboard_context,
friends=friends,
pp_range=pp_range,
score_range=score_range,
platform=platform,
role=role,
hmd=hmd,
activity_period=activity_period,
banned=banned,
)
response = await client.get_async_httpx_client().request(**kwargs)
return _build_response(client=client, response=response)
async def asyncio(
*,
client: Union[AuthenticatedClient, Client],
sort_by: Union[Unset, PlayerSortBy] = UNSET,
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 50,
search: Union[Unset, str] = "",
order: Union[Unset, Order] = UNSET,
countries: Union[Unset, str] = "",
maps_type: Union[Unset, MapsType] = UNSET,
pp_type: Union[Unset, PpType] = UNSET,
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
friends: Union[Unset, bool] = False,
pp_range: Union[Unset, str] = UNSET,
score_range: Union[Unset, str] = UNSET,
platform: Union[Unset, str] = UNSET,
role: Union[Unset, str] = UNSET,
hmd: Union[Unset, str] = UNSET,
activity_period: Union[Unset, int] = UNSET,
banned: Union[Unset, bool] = UNSET,
) -> Optional[Union[Any, PlayerResponseWithStatsResponseWithMetadata]]:
"""Retrieve a list of players (ranking)
Fetches a paginated and optionally filtered list of players. Filters include sorting by performance
points, search, country, maps type, platform, and more.
Args:
sort_by (Union[Unset, PlayerSortBy]):
page (Union[Unset, int]): Default: 1.
count (Union[Unset, int]): Default: 50.
search (Union[Unset, str]): Default: ''.
order (Union[Unset, Order]): Represents the order in which values will be sorted.
countries (Union[Unset, str]): Default: ''.
maps_type (Union[Unset, MapsType]):
pp_type (Union[Unset, PpType]):
leaderboard_context (Union[Unset, LeaderboardContexts]):
friends (Union[Unset, bool]): Default: False.
pp_range (Union[Unset, str]):
score_range (Union[Unset, str]):
platform (Union[Unset, str]):
role (Union[Unset, str]):
hmd (Union[Unset, str]):
activity_period (Union[Unset, int]):
banned (Union[Unset, bool]):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, PlayerResponseWithStatsResponseWithMetadata]
"""
return (
await asyncio_detailed(
client=client,
sort_by=sort_by,
page=page,
count=count,
search=search,
order=order,
countries=countries,
maps_type=maps_type,
pp_type=pp_type,
leaderboard_context=leaderboard_context,
friends=friends,
pp_range=pp_range,
score_range=score_range,
platform=platform,
role=role,
hmd=hmd,
activity_period=activity_period,
banned=banned,
)
).parsed

View File

@ -0,0 +1,182 @@
from http import HTTPStatus
from typing import Any, Dict, Optional, Union, cast
import httpx
from ... import errors
from ...client import AuthenticatedClient, Client
from ...models.ranked_mapper_response import RankedMapperResponse
from ...types import UNSET, Response, Unset
def _get_kwargs(
id: int,
*,
sort_by: Union[Unset, str] = UNSET,
) -> Dict[str, Any]:
params: Dict[str, Any] = {}
params["sortBy"] = sort_by
params = {k: v for k, v in params.items() if v is not UNSET and v is not None}
_kwargs: Dict[str, Any] = {
"method": "get",
"url": f"/player/{id}/rankedMaps",
"params": params,
}
return _kwargs
def _parse_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Optional[Union[Any, RankedMapperResponse]]:
if response.status_code == HTTPStatus.OK:
response_200 = RankedMapperResponse.from_dict(response.text)
return response_200
if response.status_code == HTTPStatus.NOT_FOUND:
response_404 = cast(Any, None)
return response_404
if client.raise_on_unexpected_status:
raise errors.UnexpectedStatus(response.status_code, response.content)
else:
return None
def _build_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Response[Union[Any, RankedMapperResponse]]:
return Response(
status_code=HTTPStatus(response.status_code),
content=response.content,
headers=response.headers,
parsed=_parse_response(client=client, response=response),
)
def sync_detailed(
id: int,
*,
client: Union[AuthenticatedClient, Client],
sort_by: Union[Unset, str] = UNSET,
) -> Response[Union[Any, RankedMapperResponse]]:
"""Get ranked maps this player mapped
Retrieves a list of maps this player created that later became ranked and give PP now.
Args:
id (int):
sort_by (Union[Unset, str]):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, RankedMapperResponse]]
"""
kwargs = _get_kwargs(
id=id,
sort_by=sort_by,
)
response = client.get_httpx_client().request(
**kwargs,
)
return _build_response(client=client, response=response)
def sync(
id: int,
*,
client: Union[AuthenticatedClient, Client],
sort_by: Union[Unset, str] = UNSET,
) -> Optional[Union[Any, RankedMapperResponse]]:
"""Get ranked maps this player mapped
Retrieves a list of maps this player created that later became ranked and give PP now.
Args:
id (int):
sort_by (Union[Unset, str]):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, RankedMapperResponse]
"""
return sync_detailed(
id=id,
client=client,
sort_by=sort_by,
).parsed
async def asyncio_detailed(
id: int,
*,
client: Union[AuthenticatedClient, Client],
sort_by: Union[Unset, str] = UNSET,
) -> Response[Union[Any, RankedMapperResponse]]:
"""Get ranked maps this player mapped
Retrieves a list of maps this player created that later became ranked and give PP now.
Args:
id (int):
sort_by (Union[Unset, str]):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, RankedMapperResponse]]
"""
kwargs = _get_kwargs(
id=id,
sort_by=sort_by,
)
response = await client.get_async_httpx_client().request(**kwargs)
return _build_response(client=client, response=response)
async def asyncio(
id: int,
*,
client: Union[AuthenticatedClient, Client],
sort_by: Union[Unset, str] = UNSET,
) -> Optional[Union[Any, RankedMapperResponse]]:
"""Get ranked maps this player mapped
Retrieves a list of maps this player created that later became ranked and give PP now.
Args:
id (int):
sort_by (Union[Unset, str]):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, RankedMapperResponse]
"""
return (
await asyncio_detailed(
id=id,
client=client,
sort_by=sort_by,
)
).parsed

View File

@ -0,0 +1,139 @@
from http import HTTPStatus
from typing import Any, Dict, Optional, Union
import httpx
from ... import errors
from ...client import AuthenticatedClient, Client
from ...models.leaderboard_contexts import LeaderboardContexts
from ...types import UNSET, Response, Unset
def _get_kwargs(
id: str,
*,
type: Union[Unset, str] = "acc",
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
no_unranked_stars: Union[Unset, bool] = False,
) -> Dict[str, Any]:
params: Dict[str, Any] = {}
params["type"] = type
json_leaderboard_context: Union[Unset, str] = UNSET
if not isinstance(leaderboard_context, Unset):
json_leaderboard_context = leaderboard_context.value
params["leaderboardContext"] = json_leaderboard_context
params["no_unranked_stars"] = no_unranked_stars
params = {k: v for k, v in params.items() if v is not UNSET and v is not None}
_kwargs: Dict[str, Any] = {
"method": "get",
"url": f"/player/{id}/accgraph",
"params": params,
}
return _kwargs
def _parse_response(*, client: Union[AuthenticatedClient, Client], response: httpx.Response) -> Optional[Any]:
if response.status_code == HTTPStatus.OK:
return None
if response.status_code == HTTPStatus.BAD_REQUEST:
return None
if response.status_code == HTTPStatus.NOT_FOUND:
return None
if client.raise_on_unexpected_status:
raise errors.UnexpectedStatus(response.status_code, response.content)
else:
return None
def _build_response(*, client: Union[AuthenticatedClient, Client], response: httpx.Response) -> Response[Any]:
return Response(
status_code=HTTPStatus(response.status_code),
content=response.content,
headers=response.headers,
parsed=_parse_response(client=client, response=response),
)
def sync_detailed(
id: str,
*,
client: Union[AuthenticatedClient, Client],
type: Union[Unset, str] = "acc",
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
no_unranked_stars: Union[Unset, bool] = False,
) -> Response[Any]:
"""Retrieve player's accuracy graph
Usefull to visualise player's performance relative to map's complexity
Args:
id (str):
type (Union[Unset, str]): Default: 'acc'.
leaderboard_context (Union[Unset, LeaderboardContexts]):
no_unranked_stars (Union[Unset, bool]): Default: False.
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Any]
"""
kwargs = _get_kwargs(
id=id,
type=type,
leaderboard_context=leaderboard_context,
no_unranked_stars=no_unranked_stars,
)
response = client.get_httpx_client().request(
**kwargs,
)
return _build_response(client=client, response=response)
async def asyncio_detailed(
id: str,
*,
client: Union[AuthenticatedClient, Client],
type: Union[Unset, str] = "acc",
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
no_unranked_stars: Union[Unset, bool] = False,
) -> Response[Any]:
"""Retrieve player's accuracy graph
Usefull to visualise player's performance relative to map's complexity
Args:
id (str):
type (Union[Unset, str]): Default: 'acc'.
leaderboard_context (Union[Unset, LeaderboardContexts]):
no_unranked_stars (Union[Unset, bool]): Default: False.
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Any]
"""
kwargs = _get_kwargs(
id=id,
type=type,
leaderboard_context=leaderboard_context,
no_unranked_stars=no_unranked_stars,
)
response = await client.get_async_httpx_client().request(**kwargs)
return _build_response(client=client, response=response)

View File

@ -0,0 +1,210 @@
from http import HTTPStatus
from typing import Any, Dict, List, Optional, Union, cast
import httpx
from ... import errors
from ...client import AuthenticatedClient, Client
from ...models.history_compact_response import HistoryCompactResponse
from ...models.leaderboard_contexts import LeaderboardContexts
from ...types import UNSET, Response, Unset
def _get_kwargs(
id: str,
*,
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
count: Union[Unset, int] = 50,
) -> Dict[str, Any]:
params: Dict[str, Any] = {}
json_leaderboard_context: Union[Unset, str] = UNSET
if not isinstance(leaderboard_context, Unset):
json_leaderboard_context = leaderboard_context.value
params["leaderboardContext"] = json_leaderboard_context
params["count"] = count
params = {k: v for k, v in params.items() if v is not UNSET and v is not None}
_kwargs: Dict[str, Any] = {
"method": "get",
"url": f"/player/{id}/history/compact",
"params": params,
}
return _kwargs
def _parse_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Optional[Union[Any, List["HistoryCompactResponse"]]]:
if response.status_code == HTTPStatus.OK:
response_200 = []
_response_200 = response.text
for response_200_item_data in _response_200:
response_200_item = HistoryCompactResponse.from_dict(response_200_item_data)
response_200.append(response_200_item)
return response_200
if response.status_code == HTTPStatus.BAD_REQUEST:
response_400 = cast(Any, None)
return response_400
if response.status_code == HTTPStatus.NOT_FOUND:
response_404 = cast(Any, None)
return response_404
if client.raise_on_unexpected_status:
raise errors.UnexpectedStatus(response.status_code, response.content)
else:
return None
def _build_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Response[Union[Any, List["HistoryCompactResponse"]]]:
return Response(
status_code=HTTPStatus(response.status_code),
content=response.content,
headers=response.headers,
parsed=_parse_response(client=client, response=response),
)
def sync_detailed(
id: str,
*,
client: Union[AuthenticatedClient, Client],
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
count: Union[Unset, int] = 50,
) -> Response[Union[Any, List["HistoryCompactResponse"]]]:
"""Retrieve player's statistic history in a compact form
Fetches a list of player's performance metrics subset. Use the main history endpoint for a full.
Args:
id (str):
leaderboard_context (Union[Unset, LeaderboardContexts]):
count (Union[Unset, int]): Default: 50.
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, List['HistoryCompactResponse']]]
"""
kwargs = _get_kwargs(
id=id,
leaderboard_context=leaderboard_context,
count=count,
)
response = client.get_httpx_client().request(
**kwargs,
)
return _build_response(client=client, response=response)
def sync(
id: str,
*,
client: Union[AuthenticatedClient, Client],
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
count: Union[Unset, int] = 50,
) -> Optional[Union[Any, List["HistoryCompactResponse"]]]:
"""Retrieve player's statistic history in a compact form
Fetches a list of player's performance metrics subset. Use the main history endpoint for a full.
Args:
id (str):
leaderboard_context (Union[Unset, LeaderboardContexts]):
count (Union[Unset, int]): Default: 50.
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, List['HistoryCompactResponse']]
"""
return sync_detailed(
id=id,
client=client,
leaderboard_context=leaderboard_context,
count=count,
).parsed
async def asyncio_detailed(
id: str,
*,
client: Union[AuthenticatedClient, Client],
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
count: Union[Unset, int] = 50,
) -> Response[Union[Any, List["HistoryCompactResponse"]]]:
"""Retrieve player's statistic history in a compact form
Fetches a list of player's performance metrics subset. Use the main history endpoint for a full.
Args:
id (str):
leaderboard_context (Union[Unset, LeaderboardContexts]):
count (Union[Unset, int]): Default: 50.
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, List['HistoryCompactResponse']]]
"""
kwargs = _get_kwargs(
id=id,
leaderboard_context=leaderboard_context,
count=count,
)
response = await client.get_async_httpx_client().request(**kwargs)
return _build_response(client=client, response=response)
async def asyncio(
id: str,
*,
client: Union[AuthenticatedClient, Client],
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
count: Union[Unset, int] = 50,
) -> Optional[Union[Any, List["HistoryCompactResponse"]]]:
"""Retrieve player's statistic history in a compact form
Fetches a list of player's performance metrics subset. Use the main history endpoint for a full.
Args:
id (str):
leaderboard_context (Union[Unset, LeaderboardContexts]):
count (Union[Unset, int]): Default: 50.
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, List['HistoryCompactResponse']]
"""
return (
await asyncio_detailed(
id=id,
client=client,
leaderboard_context=leaderboard_context,
count=count,
)
).parsed

View File

@ -0,0 +1,459 @@
from http import HTTPStatus
from typing import Any, Dict, Optional, Union, cast
import httpx
from ... import errors
from ...client import AuthenticatedClient, Client
from ...models.compact_score_response_response_with_metadata import CompactScoreResponseResponseWithMetadata
from ...models.difficulty_status import DifficultyStatus
from ...models.leaderboard_contexts import LeaderboardContexts
from ...models.order import Order
from ...models.requirements import Requirements
from ...models.score_filter_status import ScoreFilterStatus
from ...models.scores_sort_by import ScoresSortBy
from ...types import UNSET, Response, Unset
def _get_kwargs(
id: str,
*,
sort_by: Union[Unset, ScoresSortBy] = UNSET,
order: Union[Unset, Order] = UNSET,
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 8,
search: Union[Unset, str] = UNSET,
diff: Union[Unset, str] = UNSET,
mode: Union[Unset, str] = UNSET,
requirements: Union[Unset, Requirements] = UNSET,
score_status: Union[Unset, ScoreFilterStatus] = UNSET,
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
type: Union[Unset, DifficultyStatus] = UNSET,
modifiers: Union[Unset, str] = UNSET,
stars_from: Union[Unset, float] = UNSET,
stars_to: Union[Unset, float] = UNSET,
time_from: Union[Unset, int] = UNSET,
time_to: Union[Unset, int] = UNSET,
event_id: Union[Unset, int] = UNSET,
) -> Dict[str, Any]:
params: Dict[str, Any] = {}
json_sort_by: Union[Unset, str] = UNSET
if not isinstance(sort_by, Unset):
json_sort_by = sort_by.value
params["sortBy"] = json_sort_by
json_order: Union[Unset, str] = UNSET
if not isinstance(order, Unset):
json_order = order.value
params["order"] = json_order
params["page"] = page
params["count"] = count
params["search"] = search
params["diff"] = diff
params["mode"] = mode
json_requirements: Union[Unset, str] = UNSET
if not isinstance(requirements, Unset):
json_requirements = requirements.value
params["requirements"] = json_requirements
json_score_status: Union[Unset, str] = UNSET
if not isinstance(score_status, Unset):
json_score_status = score_status.value
params["scoreStatus"] = json_score_status
json_leaderboard_context: Union[Unset, str] = UNSET
if not isinstance(leaderboard_context, Unset):
json_leaderboard_context = leaderboard_context.value
params["leaderboardContext"] = json_leaderboard_context
json_type: Union[Unset, str] = UNSET
if not isinstance(type, Unset):
json_type = type.value
params["type"] = json_type
params["modifiers"] = modifiers
params["stars_from"] = stars_from
params["stars_to"] = stars_to
params["time_from"] = time_from
params["time_to"] = time_to
params["eventId"] = event_id
params = {k: v for k, v in params.items() if v is not UNSET and v is not None}
_kwargs: Dict[str, Any] = {
"method": "get",
"url": f"/player/{id}/scores/compact",
"params": params,
}
return _kwargs
def _parse_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Optional[Union[Any, CompactScoreResponseResponseWithMetadata]]:
if response.status_code == HTTPStatus.OK:
response_200 = CompactScoreResponseResponseWithMetadata.from_dict(response.json())
return response_200
if response.status_code == HTTPStatus.BAD_REQUEST:
response_400 = cast(Any, None)
return response_400
if response.status_code == HTTPStatus.NOT_FOUND:
response_404 = cast(Any, None)
return response_404
if client.raise_on_unexpected_status:
raise errors.UnexpectedStatus(response.status_code, response.content)
else:
return None
def _build_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Response[Union[Any, CompactScoreResponseResponseWithMetadata]]:
return Response(
status_code=HTTPStatus(response.status_code),
content=response.content,
headers=response.headers,
parsed=_parse_response(client=client, response=response),
)
def sync_detailed(
id: str,
*,
client: Union[AuthenticatedClient, Client],
sort_by: Union[Unset, ScoresSortBy] = UNSET,
order: Union[Unset, Order] = UNSET,
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 8,
search: Union[Unset, str] = UNSET,
diff: Union[Unset, str] = UNSET,
mode: Union[Unset, str] = UNSET,
requirements: Union[Unset, Requirements] = UNSET,
score_status: Union[Unset, ScoreFilterStatus] = UNSET,
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
type: Union[Unset, DifficultyStatus] = UNSET,
modifiers: Union[Unset, str] = UNSET,
stars_from: Union[Unset, float] = UNSET,
stars_to: Union[Unset, float] = UNSET,
time_from: Union[Unset, int] = UNSET,
time_to: Union[Unset, int] = UNSET,
event_id: Union[Unset, int] = UNSET,
) -> Response[Union[Any, CompactScoreResponseResponseWithMetadata]]:
"""Retrieve player's scores in a compact form
Fetches a paginated list of scores for a specified player ID. Returns less info to save bandwith or
processing time
Args:
id (str):
sort_by (Union[Unset, ScoresSortBy]):
order (Union[Unset, Order]): Represents the order in which values will be sorted.
page (Union[Unset, int]): Default: 1.
count (Union[Unset, int]): Default: 8.
search (Union[Unset, str]):
diff (Union[Unset, str]):
mode (Union[Unset, str]):
requirements (Union[Unset, Requirements]):
score_status (Union[Unset, ScoreFilterStatus]):
leaderboard_context (Union[Unset, LeaderboardContexts]):
type (Union[Unset, DifficultyStatus]): Represents the difficulty status of a map.
modifiers (Union[Unset, str]):
stars_from (Union[Unset, float]):
stars_to (Union[Unset, float]):
time_from (Union[Unset, int]):
time_to (Union[Unset, int]):
event_id (Union[Unset, int]):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, CompactScoreResponseResponseWithMetadata]]
"""
kwargs = _get_kwargs(
id=id,
sort_by=sort_by,
order=order,
page=page,
count=count,
search=search,
diff=diff,
mode=mode,
requirements=requirements,
score_status=score_status,
leaderboard_context=leaderboard_context,
type=type,
modifiers=modifiers,
stars_from=stars_from,
stars_to=stars_to,
time_from=time_from,
time_to=time_to,
event_id=event_id,
)
response = client.get_httpx_client().request(
**kwargs,
)
return _build_response(client=client, response=response)
def sync(
id: str,
*,
client: Union[AuthenticatedClient, Client],
sort_by: Union[Unset, ScoresSortBy] = UNSET,
order: Union[Unset, Order] = UNSET,
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 8,
search: Union[Unset, str] = UNSET,
diff: Union[Unset, str] = UNSET,
mode: Union[Unset, str] = UNSET,
requirements: Union[Unset, Requirements] = UNSET,
score_status: Union[Unset, ScoreFilterStatus] = UNSET,
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
type: Union[Unset, DifficultyStatus] = UNSET,
modifiers: Union[Unset, str] = UNSET,
stars_from: Union[Unset, float] = UNSET,
stars_to: Union[Unset, float] = UNSET,
time_from: Union[Unset, int] = UNSET,
time_to: Union[Unset, int] = UNSET,
event_id: Union[Unset, int] = UNSET,
) -> Optional[Union[Any, CompactScoreResponseResponseWithMetadata]]:
"""Retrieve player's scores in a compact form
Fetches a paginated list of scores for a specified player ID. Returns less info to save bandwith or
processing time
Args:
id (str):
sort_by (Union[Unset, ScoresSortBy]):
order (Union[Unset, Order]): Represents the order in which values will be sorted.
page (Union[Unset, int]): Default: 1.
count (Union[Unset, int]): Default: 8.
search (Union[Unset, str]):
diff (Union[Unset, str]):
mode (Union[Unset, str]):
requirements (Union[Unset, Requirements]):
score_status (Union[Unset, ScoreFilterStatus]):
leaderboard_context (Union[Unset, LeaderboardContexts]):
type (Union[Unset, DifficultyStatus]): Represents the difficulty status of a map.
modifiers (Union[Unset, str]):
stars_from (Union[Unset, float]):
stars_to (Union[Unset, float]):
time_from (Union[Unset, int]):
time_to (Union[Unset, int]):
event_id (Union[Unset, int]):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, CompactScoreResponseResponseWithMetadata]
"""
return sync_detailed(
id=id,
client=client,
sort_by=sort_by,
order=order,
page=page,
count=count,
search=search,
diff=diff,
mode=mode,
requirements=requirements,
score_status=score_status,
leaderboard_context=leaderboard_context,
type=type,
modifiers=modifiers,
stars_from=stars_from,
stars_to=stars_to,
time_from=time_from,
time_to=time_to,
event_id=event_id,
).parsed
async def asyncio_detailed(
id: str,
*,
client: Union[AuthenticatedClient, Client],
sort_by: Union[Unset, ScoresSortBy] = UNSET,
order: Union[Unset, Order] = UNSET,
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 8,
search: Union[Unset, str] = UNSET,
diff: Union[Unset, str] = UNSET,
mode: Union[Unset, str] = UNSET,
requirements: Union[Unset, Requirements] = UNSET,
score_status: Union[Unset, ScoreFilterStatus] = UNSET,
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
type: Union[Unset, DifficultyStatus] = UNSET,
modifiers: Union[Unset, str] = UNSET,
stars_from: Union[Unset, float] = UNSET,
stars_to: Union[Unset, float] = UNSET,
time_from: Union[Unset, int] = UNSET,
time_to: Union[Unset, int] = UNSET,
event_id: Union[Unset, int] = UNSET,
) -> Response[Union[Any, CompactScoreResponseResponseWithMetadata]]:
"""Retrieve player's scores in a compact form
Fetches a paginated list of scores for a specified player ID. Returns less info to save bandwith or
processing time
Args:
id (str):
sort_by (Union[Unset, ScoresSortBy]):
order (Union[Unset, Order]): Represents the order in which values will be sorted.
page (Union[Unset, int]): Default: 1.
count (Union[Unset, int]): Default: 8.
search (Union[Unset, str]):
diff (Union[Unset, str]):
mode (Union[Unset, str]):
requirements (Union[Unset, Requirements]):
score_status (Union[Unset, ScoreFilterStatus]):
leaderboard_context (Union[Unset, LeaderboardContexts]):
type (Union[Unset, DifficultyStatus]): Represents the difficulty status of a map.
modifiers (Union[Unset, str]):
stars_from (Union[Unset, float]):
stars_to (Union[Unset, float]):
time_from (Union[Unset, int]):
time_to (Union[Unset, int]):
event_id (Union[Unset, int]):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, CompactScoreResponseResponseWithMetadata]]
"""
kwargs = _get_kwargs(
id=id,
sort_by=sort_by,
order=order,
page=page,
count=count,
search=search,
diff=diff,
mode=mode,
requirements=requirements,
score_status=score_status,
leaderboard_context=leaderboard_context,
type=type,
modifiers=modifiers,
stars_from=stars_from,
stars_to=stars_to,
time_from=time_from,
time_to=time_to,
event_id=event_id,
)
response = await client.get_async_httpx_client().request(**kwargs)
return _build_response(client=client, response=response)
async def asyncio(
id: str,
*,
client: Union[AuthenticatedClient, Client],
sort_by: Union[Unset, ScoresSortBy] = UNSET,
order: Union[Unset, Order] = UNSET,
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 8,
search: Union[Unset, str] = UNSET,
diff: Union[Unset, str] = UNSET,
mode: Union[Unset, str] = UNSET,
requirements: Union[Unset, Requirements] = UNSET,
score_status: Union[Unset, ScoreFilterStatus] = UNSET,
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
type: Union[Unset, DifficultyStatus] = UNSET,
modifiers: Union[Unset, str] = UNSET,
stars_from: Union[Unset, float] = UNSET,
stars_to: Union[Unset, float] = UNSET,
time_from: Union[Unset, int] = UNSET,
time_to: Union[Unset, int] = UNSET,
event_id: Union[Unset, int] = UNSET,
) -> Optional[Union[Any, CompactScoreResponseResponseWithMetadata]]:
"""Retrieve player's scores in a compact form
Fetches a paginated list of scores for a specified player ID. Returns less info to save bandwith or
processing time
Args:
id (str):
sort_by (Union[Unset, ScoresSortBy]):
order (Union[Unset, Order]): Represents the order in which values will be sorted.
page (Union[Unset, int]): Default: 1.
count (Union[Unset, int]): Default: 8.
search (Union[Unset, str]):
diff (Union[Unset, str]):
mode (Union[Unset, str]):
requirements (Union[Unset, Requirements]):
score_status (Union[Unset, ScoreFilterStatus]):
leaderboard_context (Union[Unset, LeaderboardContexts]):
type (Union[Unset, DifficultyStatus]): Represents the difficulty status of a map.
modifiers (Union[Unset, str]):
stars_from (Union[Unset, float]):
stars_to (Union[Unset, float]):
time_from (Union[Unset, int]):
time_to (Union[Unset, int]):
event_id (Union[Unset, int]):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, CompactScoreResponseResponseWithMetadata]
"""
return (
await asyncio_detailed(
id=id,
client=client,
sort_by=sort_by,
order=order,
page=page,
count=count,
search=search,
diff=diff,
mode=mode,
requirements=requirements,
score_status=score_status,
leaderboard_context=leaderboard_context,
type=type,
modifiers=modifiers,
stars_from=stars_from,
stars_to=stars_to,
time_from=time_from,
time_to=time_to,
event_id=event_id,
)
).parsed

View File

@ -0,0 +1,210 @@
from http import HTTPStatus
from typing import Any, Dict, List, Optional, Union, cast
import httpx
from ... import errors
from ...client import AuthenticatedClient, Client
from ...models.leaderboard_contexts import LeaderboardContexts
from ...models.player_score_stats_history import PlayerScoreStatsHistory
from ...types import UNSET, Response, Unset
def _get_kwargs(
id: str,
*,
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
count: Union[Unset, int] = 50,
) -> Dict[str, Any]:
params: Dict[str, Any] = {}
json_leaderboard_context: Union[Unset, str] = UNSET
if not isinstance(leaderboard_context, Unset):
json_leaderboard_context = leaderboard_context.value
params["leaderboardContext"] = json_leaderboard_context
params["count"] = count
params = {k: v for k, v in params.items() if v is not UNSET and v is not None}
_kwargs: Dict[str, Any] = {
"method": "get",
"url": f"/player/{id}/history",
"params": params,
}
return _kwargs
def _parse_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Optional[Union[Any, List["PlayerScoreStatsHistory"]]]:
if response.status_code == HTTPStatus.OK:
response_200 = []
_response_200 = response.text
for response_200_item_data in _response_200:
response_200_item = PlayerScoreStatsHistory.from_dict(response_200_item_data)
response_200.append(response_200_item)
return response_200
if response.status_code == HTTPStatus.BAD_REQUEST:
response_400 = cast(Any, None)
return response_400
if response.status_code == HTTPStatus.NOT_FOUND:
response_404 = cast(Any, None)
return response_404
if client.raise_on_unexpected_status:
raise errors.UnexpectedStatus(response.status_code, response.content)
else:
return None
def _build_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Response[Union[Any, List["PlayerScoreStatsHistory"]]]:
return Response(
status_code=HTTPStatus(response.status_code),
content=response.content,
headers=response.headers,
parsed=_parse_response(client=client, response=response),
)
def sync_detailed(
id: str,
*,
client: Union[AuthenticatedClient, Client],
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
count: Union[Unset, int] = 50,
) -> Response[Union[Any, List["PlayerScoreStatsHistory"]]]:
"""Retrieve player's statistic history
Fetches a list of player's performance metrics and various stats saved daily
Args:
id (str):
leaderboard_context (Union[Unset, LeaderboardContexts]):
count (Union[Unset, int]): Default: 50.
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, List['PlayerScoreStatsHistory']]]
"""
kwargs = _get_kwargs(
id=id,
leaderboard_context=leaderboard_context,
count=count,
)
response = client.get_httpx_client().request(
**kwargs,
)
return _build_response(client=client, response=response)
def sync(
id: str,
*,
client: Union[AuthenticatedClient, Client],
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
count: Union[Unset, int] = 50,
) -> Optional[Union[Any, List["PlayerScoreStatsHistory"]]]:
"""Retrieve player's statistic history
Fetches a list of player's performance metrics and various stats saved daily
Args:
id (str):
leaderboard_context (Union[Unset, LeaderboardContexts]):
count (Union[Unset, int]): Default: 50.
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, List['PlayerScoreStatsHistory']]
"""
return sync_detailed(
id=id,
client=client,
leaderboard_context=leaderboard_context,
count=count,
).parsed
async def asyncio_detailed(
id: str,
*,
client: Union[AuthenticatedClient, Client],
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
count: Union[Unset, int] = 50,
) -> Response[Union[Any, List["PlayerScoreStatsHistory"]]]:
"""Retrieve player's statistic history
Fetches a list of player's performance metrics and various stats saved daily
Args:
id (str):
leaderboard_context (Union[Unset, LeaderboardContexts]):
count (Union[Unset, int]): Default: 50.
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, List['PlayerScoreStatsHistory']]]
"""
kwargs = _get_kwargs(
id=id,
leaderboard_context=leaderboard_context,
count=count,
)
response = await client.get_async_httpx_client().request(**kwargs)
return _build_response(client=client, response=response)
async def asyncio(
id: str,
*,
client: Union[AuthenticatedClient, Client],
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
count: Union[Unset, int] = 50,
) -> Optional[Union[Any, List["PlayerScoreStatsHistory"]]]:
"""Retrieve player's statistic history
Fetches a list of player's performance metrics and various stats saved daily
Args:
id (str):
leaderboard_context (Union[Unset, LeaderboardContexts]):
count (Union[Unset, int]): Default: 50.
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, List['PlayerScoreStatsHistory']]
"""
return (
await asyncio_detailed(
id=id,
client=client,
leaderboard_context=leaderboard_context,
count=count,
)
).parsed

View File

@ -0,0 +1,195 @@
from http import HTTPStatus
from typing import Any, Dict, List, Optional, Union, cast
import httpx
from ... import errors
from ...client import AuthenticatedClient, Client
from ...models.leaderboard_contexts import LeaderboardContexts
from ...models.score_response_with_my_score import ScoreResponseWithMyScore
from ...types import UNSET, Response, Unset
def _get_kwargs(
id: str,
*,
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
) -> Dict[str, Any]:
params: Dict[str, Any] = {}
json_leaderboard_context: Union[Unset, str] = UNSET
if not isinstance(leaderboard_context, Unset):
json_leaderboard_context = leaderboard_context.value
params["leaderboardContext"] = json_leaderboard_context
params = {k: v for k, v in params.items() if v is not UNSET and v is not None}
_kwargs: Dict[str, Any] = {
"method": "get",
"url": f"/player/{id}/pinnedScores",
"params": params,
}
return _kwargs
def _parse_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Optional[Union[Any, List["ScoreResponseWithMyScore"]]]:
if response.status_code == HTTPStatus.OK:
response_200 = []
_response_200 = response.text
for response_200_item_data in _response_200:
response_200_item = ScoreResponseWithMyScore.from_dict(response_200_item_data)
response_200.append(response_200_item)
return response_200
if response.status_code == HTTPStatus.BAD_REQUEST:
response_400 = cast(Any, None)
return response_400
if response.status_code == HTTPStatus.NOT_FOUND:
response_404 = cast(Any, None)
return response_404
if client.raise_on_unexpected_status:
raise errors.UnexpectedStatus(response.status_code, response.content)
else:
return None
def _build_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Response[Union[Any, List["ScoreResponseWithMyScore"]]]:
return Response(
status_code=HTTPStatus(response.status_code),
content=response.content,
headers=response.headers,
parsed=_parse_response(client=client, response=response),
)
def sync_detailed(
id: str,
*,
client: Union[AuthenticatedClient, Client],
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
) -> Response[Union[Any, List["ScoreResponseWithMyScore"]]]:
"""Retrieve player's pinned scores
Fetches a paginated list of scores pinned by player for their ID.
Args:
id (str):
leaderboard_context (Union[Unset, LeaderboardContexts]):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, List['ScoreResponseWithMyScore']]]
"""
kwargs = _get_kwargs(
id=id,
leaderboard_context=leaderboard_context,
)
response = client.get_httpx_client().request(
**kwargs,
)
return _build_response(client=client, response=response)
def sync(
id: str,
*,
client: Union[AuthenticatedClient, Client],
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
) -> Optional[Union[Any, List["ScoreResponseWithMyScore"]]]:
"""Retrieve player's pinned scores
Fetches a paginated list of scores pinned by player for their ID.
Args:
id (str):
leaderboard_context (Union[Unset, LeaderboardContexts]):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, List['ScoreResponseWithMyScore']]
"""
return sync_detailed(
id=id,
client=client,
leaderboard_context=leaderboard_context,
).parsed
async def asyncio_detailed(
id: str,
*,
client: Union[AuthenticatedClient, Client],
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
) -> Response[Union[Any, List["ScoreResponseWithMyScore"]]]:
"""Retrieve player's pinned scores
Fetches a paginated list of scores pinned by player for their ID.
Args:
id (str):
leaderboard_context (Union[Unset, LeaderboardContexts]):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, List['ScoreResponseWithMyScore']]]
"""
kwargs = _get_kwargs(
id=id,
leaderboard_context=leaderboard_context,
)
response = await client.get_async_httpx_client().request(**kwargs)
return _build_response(client=client, response=response)
async def asyncio(
id: str,
*,
client: Union[AuthenticatedClient, Client],
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
) -> Optional[Union[Any, List["ScoreResponseWithMyScore"]]]:
"""Retrieve player's pinned scores
Fetches a paginated list of scores pinned by player for their ID.
Args:
id (str):
leaderboard_context (Union[Unset, LeaderboardContexts]):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, List['ScoreResponseWithMyScore']]
"""
return (
await asyncio_detailed(
id=id,
client=client,
leaderboard_context=leaderboard_context,
)
).parsed

View File

@ -0,0 +1,201 @@
from http import HTTPStatus
from typing import Any, Dict, Optional, Union, cast
import httpx
from ... import errors
from ...client import AuthenticatedClient, Client
from ...types import Response
def _get_kwargs(
id: str,
hash_: str,
difficulty: str,
mode: str,
) -> Dict[str, Any]:
_kwargs: Dict[str, Any] = {
"method": "get",
"url": f"/player/{id}/scorevalue/{hash_}/{difficulty}/{mode}",
}
return _kwargs
def _parse_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Optional[Union[Any, int]]:
if response.status_code == HTTPStatus.OK:
response_200 = cast(int, response.text)
return response_200
if response.status_code == HTTPStatus.BAD_REQUEST:
response_400 = cast(Any, None)
return response_400
if response.status_code == HTTPStatus.NOT_FOUND:
response_404 = cast(Any, None)
return response_404
if client.raise_on_unexpected_status:
raise errors.UnexpectedStatus(response.status_code, response.content)
else:
return None
def _build_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Response[Union[Any, int]]:
return Response(
status_code=HTTPStatus(response.status_code),
content=response.content,
headers=response.headers,
parsed=_parse_response(client=client, response=response),
)
def sync_detailed(
id: str,
hash_: str,
difficulty: str,
mode: str,
*,
client: Union[AuthenticatedClient, Client],
) -> Response[Union[Any, int]]:
"""Retrieve player's score for a specific map
Fetches a score made by a Player with ID for a map specified by Hash and difficulty
Args:
id (str):
hash_ (str):
difficulty (str):
mode (str):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, int]]
"""
kwargs = _get_kwargs(
id=id,
hash_=hash_,
difficulty=difficulty,
mode=mode,
)
response = client.get_httpx_client().request(
**kwargs,
)
return _build_response(client=client, response=response)
def sync(
id: str,
hash_: str,
difficulty: str,
mode: str,
*,
client: Union[AuthenticatedClient, Client],
) -> Optional[Union[Any, int]]:
"""Retrieve player's score for a specific map
Fetches a score made by a Player with ID for a map specified by Hash and difficulty
Args:
id (str):
hash_ (str):
difficulty (str):
mode (str):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, int]
"""
return sync_detailed(
id=id,
hash_=hash_,
difficulty=difficulty,
mode=mode,
client=client,
).parsed
async def asyncio_detailed(
id: str,
hash_: str,
difficulty: str,
mode: str,
*,
client: Union[AuthenticatedClient, Client],
) -> Response[Union[Any, int]]:
"""Retrieve player's score for a specific map
Fetches a score made by a Player with ID for a map specified by Hash and difficulty
Args:
id (str):
hash_ (str):
difficulty (str):
mode (str):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, int]]
"""
kwargs = _get_kwargs(
id=id,
hash_=hash_,
difficulty=difficulty,
mode=mode,
)
response = await client.get_async_httpx_client().request(**kwargs)
return _build_response(client=client, response=response)
async def asyncio(
id: str,
hash_: str,
difficulty: str,
mode: str,
*,
client: Union[AuthenticatedClient, Client],
) -> Optional[Union[Any, int]]:
"""Retrieve player's score for a specific map
Fetches a score made by a Player with ID for a map specified by Hash and difficulty
Args:
id (str):
hash_ (str):
difficulty (str):
mode (str):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, int]
"""
return (
await asyncio_detailed(
id=id,
hash_=hash_,
difficulty=difficulty,
mode=mode,
client=client,
)
).parsed

View File

@ -0,0 +1,459 @@
from http import HTTPStatus
from typing import Any, Dict, Optional, Union, cast
import httpx
from ... import errors
from ...client import AuthenticatedClient, Client
from ...models.difficulty_status import DifficultyStatus
from ...models.leaderboard_contexts import LeaderboardContexts
from ...models.order import Order
from ...models.requirements import Requirements
from ...models.score_filter_status import ScoreFilterStatus
from ...models.score_response_with_my_score_response_with_metadata import ScoreResponseWithMyScoreResponseWithMetadata
from ...models.scores_sort_by import ScoresSortBy
from ...types import UNSET, Response, Unset
def _get_kwargs(
id: str,
*,
sort_by: Union[Unset, ScoresSortBy] = UNSET,
order: Union[Unset, Order] = UNSET,
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 8,
search: Union[Unset, str] = UNSET,
diff: Union[Unset, str] = UNSET,
mode: Union[Unset, str] = UNSET,
requirements: Union[Unset, Requirements] = UNSET,
score_status: Union[Unset, ScoreFilterStatus] = UNSET,
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
type: Union[Unset, DifficultyStatus] = UNSET,
modifiers: Union[Unset, str] = UNSET,
stars_from: Union[Unset, float] = UNSET,
stars_to: Union[Unset, float] = UNSET,
time_from: Union[Unset, int] = UNSET,
time_to: Union[Unset, int] = UNSET,
event_id: Union[Unset, int] = UNSET,
) -> Dict[str, Any]:
params: Dict[str, Any] = {}
json_sort_by: Union[Unset, str] = UNSET
if not isinstance(sort_by, Unset):
json_sort_by = sort_by.value
params["sortBy"] = json_sort_by
json_order: Union[Unset, str] = UNSET
if not isinstance(order, Unset):
json_order = order.value
params["order"] = json_order
params["page"] = page
params["count"] = count
params["search"] = search
params["diff"] = diff
params["mode"] = mode
json_requirements: Union[Unset, str] = UNSET
if not isinstance(requirements, Unset):
json_requirements = requirements.value
params["requirements"] = json_requirements
json_score_status: Union[Unset, str] = UNSET
if not isinstance(score_status, Unset):
json_score_status = score_status.value
params["scoreStatus"] = json_score_status
json_leaderboard_context: Union[Unset, str] = UNSET
if not isinstance(leaderboard_context, Unset):
json_leaderboard_context = leaderboard_context.value
params["leaderboardContext"] = json_leaderboard_context
json_type: Union[Unset, str] = UNSET
if not isinstance(type, Unset):
json_type = type.value
params["type"] = json_type
params["modifiers"] = modifiers
params["stars_from"] = stars_from
params["stars_to"] = stars_to
params["time_from"] = time_from
params["time_to"] = time_to
params["eventId"] = event_id
params = {k: v for k, v in params.items() if v is not UNSET and v is not None}
_kwargs: Dict[str, Any] = {
"method": "get",
"url": f"/player/{id}/scores",
"params": params,
}
return _kwargs
def _parse_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Optional[Union[Any, ScoreResponseWithMyScoreResponseWithMetadata]]:
if response.status_code == HTTPStatus.OK:
response_200 = ScoreResponseWithMyScoreResponseWithMetadata.from_dict(response.json())
return response_200
if response.status_code == HTTPStatus.BAD_REQUEST:
response_400 = cast(Any, None)
return response_400
if response.status_code == HTTPStatus.NOT_FOUND:
response_404 = cast(Any, None)
return response_404
if client.raise_on_unexpected_status:
raise errors.UnexpectedStatus(response.status_code, response.content)
else:
return None
def _build_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Response[Union[Any, ScoreResponseWithMyScoreResponseWithMetadata]]:
return Response(
status_code=HTTPStatus(response.status_code),
content=response.content,
headers=response.headers,
parsed=_parse_response(client=client, response=response),
)
def sync_detailed(
id: str,
*,
client: Union[AuthenticatedClient, Client],
sort_by: Union[Unset, ScoresSortBy] = UNSET,
order: Union[Unset, Order] = UNSET,
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 8,
search: Union[Unset, str] = UNSET,
diff: Union[Unset, str] = UNSET,
mode: Union[Unset, str] = UNSET,
requirements: Union[Unset, Requirements] = UNSET,
score_status: Union[Unset, ScoreFilterStatus] = UNSET,
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
type: Union[Unset, DifficultyStatus] = UNSET,
modifiers: Union[Unset, str] = UNSET,
stars_from: Union[Unset, float] = UNSET,
stars_to: Union[Unset, float] = UNSET,
time_from: Union[Unset, int] = UNSET,
time_to: Union[Unset, int] = UNSET,
event_id: Union[Unset, int] = UNSET,
) -> Response[Union[Any, ScoreResponseWithMyScoreResponseWithMetadata]]:
"""Retrieve player's scores
Fetches a paginated list of scores for a specified player ID. Allows filtering by various criteria
like date, difficulty, mode, and more.
Args:
id (str):
sort_by (Union[Unset, ScoresSortBy]):
order (Union[Unset, Order]): Represents the order in which values will be sorted.
page (Union[Unset, int]): Default: 1.
count (Union[Unset, int]): Default: 8.
search (Union[Unset, str]):
diff (Union[Unset, str]):
mode (Union[Unset, str]):
requirements (Union[Unset, Requirements]):
score_status (Union[Unset, ScoreFilterStatus]):
leaderboard_context (Union[Unset, LeaderboardContexts]):
type (Union[Unset, DifficultyStatus]): Represents the difficulty status of a map.
modifiers (Union[Unset, str]):
stars_from (Union[Unset, float]):
stars_to (Union[Unset, float]):
time_from (Union[Unset, int]):
time_to (Union[Unset, int]):
event_id (Union[Unset, int]):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, ScoreResponseWithMyScoreResponseWithMetadata]]
"""
kwargs = _get_kwargs(
id=id,
sort_by=sort_by,
order=order,
page=page,
count=count,
search=search,
diff=diff,
mode=mode,
requirements=requirements,
score_status=score_status,
leaderboard_context=leaderboard_context,
type=type,
modifiers=modifiers,
stars_from=stars_from,
stars_to=stars_to,
time_from=time_from,
time_to=time_to,
event_id=event_id,
)
response = client.get_httpx_client().request(
**kwargs,
)
return _build_response(client=client, response=response)
def sync(
id: str,
*,
client: Union[AuthenticatedClient, Client],
sort_by: Union[Unset, ScoresSortBy] = UNSET,
order: Union[Unset, Order] = UNSET,
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 8,
search: Union[Unset, str] = UNSET,
diff: Union[Unset, str] = UNSET,
mode: Union[Unset, str] = UNSET,
requirements: Union[Unset, Requirements] = UNSET,
score_status: Union[Unset, ScoreFilterStatus] = UNSET,
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
type: Union[Unset, DifficultyStatus] = UNSET,
modifiers: Union[Unset, str] = UNSET,
stars_from: Union[Unset, float] = UNSET,
stars_to: Union[Unset, float] = UNSET,
time_from: Union[Unset, int] = UNSET,
time_to: Union[Unset, int] = UNSET,
event_id: Union[Unset, int] = UNSET,
) -> Optional[Union[Any, ScoreResponseWithMyScoreResponseWithMetadata]]:
"""Retrieve player's scores
Fetches a paginated list of scores for a specified player ID. Allows filtering by various criteria
like date, difficulty, mode, and more.
Args:
id (str):
sort_by (Union[Unset, ScoresSortBy]):
order (Union[Unset, Order]): Represents the order in which values will be sorted.
page (Union[Unset, int]): Default: 1.
count (Union[Unset, int]): Default: 8.
search (Union[Unset, str]):
diff (Union[Unset, str]):
mode (Union[Unset, str]):
requirements (Union[Unset, Requirements]):
score_status (Union[Unset, ScoreFilterStatus]):
leaderboard_context (Union[Unset, LeaderboardContexts]):
type (Union[Unset, DifficultyStatus]): Represents the difficulty status of a map.
modifiers (Union[Unset, str]):
stars_from (Union[Unset, float]):
stars_to (Union[Unset, float]):
time_from (Union[Unset, int]):
time_to (Union[Unset, int]):
event_id (Union[Unset, int]):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, ScoreResponseWithMyScoreResponseWithMetadata]
"""
return sync_detailed(
id=id,
client=client,
sort_by=sort_by,
order=order,
page=page,
count=count,
search=search,
diff=diff,
mode=mode,
requirements=requirements,
score_status=score_status,
leaderboard_context=leaderboard_context,
type=type,
modifiers=modifiers,
stars_from=stars_from,
stars_to=stars_to,
time_from=time_from,
time_to=time_to,
event_id=event_id,
).parsed
async def asyncio_detailed(
id: str,
*,
client: Union[AuthenticatedClient, Client],
sort_by: Union[Unset, ScoresSortBy] = UNSET,
order: Union[Unset, Order] = UNSET,
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 8,
search: Union[Unset, str] = UNSET,
diff: Union[Unset, str] = UNSET,
mode: Union[Unset, str] = UNSET,
requirements: Union[Unset, Requirements] = UNSET,
score_status: Union[Unset, ScoreFilterStatus] = UNSET,
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
type: Union[Unset, DifficultyStatus] = UNSET,
modifiers: Union[Unset, str] = UNSET,
stars_from: Union[Unset, float] = UNSET,
stars_to: Union[Unset, float] = UNSET,
time_from: Union[Unset, int] = UNSET,
time_to: Union[Unset, int] = UNSET,
event_id: Union[Unset, int] = UNSET,
) -> Response[Union[Any, ScoreResponseWithMyScoreResponseWithMetadata]]:
"""Retrieve player's scores
Fetches a paginated list of scores for a specified player ID. Allows filtering by various criteria
like date, difficulty, mode, and more.
Args:
id (str):
sort_by (Union[Unset, ScoresSortBy]):
order (Union[Unset, Order]): Represents the order in which values will be sorted.
page (Union[Unset, int]): Default: 1.
count (Union[Unset, int]): Default: 8.
search (Union[Unset, str]):
diff (Union[Unset, str]):
mode (Union[Unset, str]):
requirements (Union[Unset, Requirements]):
score_status (Union[Unset, ScoreFilterStatus]):
leaderboard_context (Union[Unset, LeaderboardContexts]):
type (Union[Unset, DifficultyStatus]): Represents the difficulty status of a map.
modifiers (Union[Unset, str]):
stars_from (Union[Unset, float]):
stars_to (Union[Unset, float]):
time_from (Union[Unset, int]):
time_to (Union[Unset, int]):
event_id (Union[Unset, int]):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, ScoreResponseWithMyScoreResponseWithMetadata]]
"""
kwargs = _get_kwargs(
id=id,
sort_by=sort_by,
order=order,
page=page,
count=count,
search=search,
diff=diff,
mode=mode,
requirements=requirements,
score_status=score_status,
leaderboard_context=leaderboard_context,
type=type,
modifiers=modifiers,
stars_from=stars_from,
stars_to=stars_to,
time_from=time_from,
time_to=time_to,
event_id=event_id,
)
response = await client.get_async_httpx_client().request(**kwargs)
return _build_response(client=client, response=response)
async def asyncio(
id: str,
*,
client: Union[AuthenticatedClient, Client],
sort_by: Union[Unset, ScoresSortBy] = UNSET,
order: Union[Unset, Order] = UNSET,
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 8,
search: Union[Unset, str] = UNSET,
diff: Union[Unset, str] = UNSET,
mode: Union[Unset, str] = UNSET,
requirements: Union[Unset, Requirements] = UNSET,
score_status: Union[Unset, ScoreFilterStatus] = UNSET,
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
type: Union[Unset, DifficultyStatus] = UNSET,
modifiers: Union[Unset, str] = UNSET,
stars_from: Union[Unset, float] = UNSET,
stars_to: Union[Unset, float] = UNSET,
time_from: Union[Unset, int] = UNSET,
time_to: Union[Unset, int] = UNSET,
event_id: Union[Unset, int] = UNSET,
) -> Optional[Union[Any, ScoreResponseWithMyScoreResponseWithMetadata]]:
"""Retrieve player's scores
Fetches a paginated list of scores for a specified player ID. Allows filtering by various criteria
like date, difficulty, mode, and more.
Args:
id (str):
sort_by (Union[Unset, ScoresSortBy]):
order (Union[Unset, Order]): Represents the order in which values will be sorted.
page (Union[Unset, int]): Default: 1.
count (Union[Unset, int]): Default: 8.
search (Union[Unset, str]):
diff (Union[Unset, str]):
mode (Union[Unset, str]):
requirements (Union[Unset, Requirements]):
score_status (Union[Unset, ScoreFilterStatus]):
leaderboard_context (Union[Unset, LeaderboardContexts]):
type (Union[Unset, DifficultyStatus]): Represents the difficulty status of a map.
modifiers (Union[Unset, str]):
stars_from (Union[Unset, float]):
stars_to (Union[Unset, float]):
time_from (Union[Unset, int]):
time_to (Union[Unset, int]):
event_id (Union[Unset, int]):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, ScoreResponseWithMyScoreResponseWithMetadata]
"""
return (
await asyncio_detailed(
id=id,
client=client,
sort_by=sort_by,
order=order,
page=page,
count=count,
search=search,
diff=diff,
mode=mode,
requirements=requirements,
score_status=score_status,
leaderboard_context=leaderboard_context,
type=type,
modifiers=modifiers,
stars_from=stars_from,
stars_to=stars_to,
time_from=time_from,
time_to=time_to,
event_id=event_id,
)
).parsed

View File

@ -0,0 +1,603 @@
from http import HTTPStatus
from typing import Any, Dict, Optional, Union, cast
import httpx
from ... import errors
from ...client import AuthenticatedClient, Client
from ...models.leaderboard_contexts import LeaderboardContexts
from ...models.map_info_response_response_with_metadata import MapInfoResponseResponseWithMetadata
from ...models.map_sort_by import MapSortBy
from ...models.my_type import MyType
from ...models.operation import Operation
from ...models.order import Order
from ...models.requirements import Requirements
from ...models.song_status import SongStatus
from ...models.type import Type
from ...types import UNSET, Response, Unset
def _get_kwargs(
*,
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 10,
sort_by: Union[Unset, MapSortBy] = UNSET,
order: Union[Unset, Order] = UNSET,
search: Union[Unset, str] = UNSET,
type: Union[Unset, Type] = UNSET,
mode: Union[Unset, str] = UNSET,
difficulty: Union[Unset, str] = UNSET,
map_type: Union[Unset, int] = UNSET,
all_types: Union[Unset, Operation] = UNSET,
map_requirements: Union[Unset, Requirements] = UNSET,
all_requirements: Union[Unset, Operation] = UNSET,
song_status: Union[Unset, SongStatus] = UNSET,
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
mytype: Union[Unset, MyType] = UNSET,
stars_from: Union[Unset, float] = UNSET,
stars_to: Union[Unset, float] = UNSET,
accrating_from: Union[Unset, float] = UNSET,
accrating_to: Union[Unset, float] = UNSET,
passrating_from: Union[Unset, float] = UNSET,
passrating_to: Union[Unset, float] = UNSET,
techrating_from: Union[Unset, float] = UNSET,
techrating_to: Union[Unset, float] = UNSET,
date_from: Union[Unset, int] = UNSET,
date_to: Union[Unset, int] = UNSET,
mappers: Union[Unset, str] = UNSET,
override_current_id: Union[Unset, str] = UNSET,
) -> Dict[str, Any]:
params: Dict[str, Any] = {}
params["page"] = page
params["count"] = count
json_sort_by: Union[Unset, str] = UNSET
if not isinstance(sort_by, Unset):
json_sort_by = sort_by.value
params["sortBy"] = json_sort_by
json_order: Union[Unset, str] = UNSET
if not isinstance(order, Unset):
json_order = order.value
params["order"] = json_order
params["search"] = search
json_type: Union[Unset, str] = UNSET
if not isinstance(type, Unset):
json_type = type.value
params["type"] = json_type
params["mode"] = mode
params["difficulty"] = difficulty
params["mapType"] = map_type
json_all_types: Union[Unset, str] = UNSET
if not isinstance(all_types, Unset):
json_all_types = all_types.value
params["allTypes"] = json_all_types
json_map_requirements: Union[Unset, str] = UNSET
if not isinstance(map_requirements, Unset):
json_map_requirements = map_requirements.value
params["mapRequirements"] = json_map_requirements
json_all_requirements: Union[Unset, str] = UNSET
if not isinstance(all_requirements, Unset):
json_all_requirements = all_requirements.value
params["allRequirements"] = json_all_requirements
json_song_status: Union[Unset, str] = UNSET
if not isinstance(song_status, Unset):
json_song_status = song_status.value
params["songStatus"] = json_song_status
json_leaderboard_context: Union[Unset, str] = UNSET
if not isinstance(leaderboard_context, Unset):
json_leaderboard_context = leaderboard_context.value
params["leaderboardContext"] = json_leaderboard_context
json_mytype: Union[Unset, str] = UNSET
if not isinstance(mytype, Unset):
json_mytype = mytype.value
params["mytype"] = json_mytype
params["stars_from"] = stars_from
params["stars_to"] = stars_to
params["accrating_from"] = accrating_from
params["accrating_to"] = accrating_to
params["passrating_from"] = passrating_from
params["passrating_to"] = passrating_to
params["techrating_from"] = techrating_from
params["techrating_to"] = techrating_to
params["date_from"] = date_from
params["date_to"] = date_to
params["mappers"] = mappers
params["overrideCurrentId"] = override_current_id
params = {k: v for k, v in params.items() if v is not UNSET and v is not None}
_kwargs: Dict[str, Any] = {
"method": "get",
"url": "/maps",
"params": params,
}
return _kwargs
def _parse_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Optional[Union[Any, MapInfoResponseResponseWithMetadata]]:
if response.status_code == HTTPStatus.OK:
response_200 = MapInfoResponseResponseWithMetadata.from_dict(response.text)
return response_200
if response.status_code == HTTPStatus.NOT_FOUND:
response_404 = cast(Any, None)
return response_404
if client.raise_on_unexpected_status:
raise errors.UnexpectedStatus(response.status_code, response.content)
else:
return None
def _build_response(
*, client: Union[AuthenticatedClient, Client], response: httpx.Response
) -> Response[Union[Any, MapInfoResponseResponseWithMetadata]]:
return Response(
status_code=HTTPStatus(response.status_code),
content=response.content,
headers=response.headers,
parsed=_parse_response(client=client, response=response),
)
def sync_detailed(
*,
client: Union[AuthenticatedClient, Client],
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 10,
sort_by: Union[Unset, MapSortBy] = UNSET,
order: Union[Unset, Order] = UNSET,
search: Union[Unset, str] = UNSET,
type: Union[Unset, Type] = UNSET,
mode: Union[Unset, str] = UNSET,
difficulty: Union[Unset, str] = UNSET,
map_type: Union[Unset, int] = UNSET,
all_types: Union[Unset, Operation] = UNSET,
map_requirements: Union[Unset, Requirements] = UNSET,
all_requirements: Union[Unset, Operation] = UNSET,
song_status: Union[Unset, SongStatus] = UNSET,
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
mytype: Union[Unset, MyType] = UNSET,
stars_from: Union[Unset, float] = UNSET,
stars_to: Union[Unset, float] = UNSET,
accrating_from: Union[Unset, float] = UNSET,
accrating_to: Union[Unset, float] = UNSET,
passrating_from: Union[Unset, float] = UNSET,
passrating_to: Union[Unset, float] = UNSET,
techrating_from: Union[Unset, float] = UNSET,
techrating_to: Union[Unset, float] = UNSET,
date_from: Union[Unset, int] = UNSET,
date_to: Union[Unset, int] = UNSET,
mappers: Union[Unset, str] = UNSET,
override_current_id: Union[Unset, str] = UNSET,
) -> Response[Union[Any, MapInfoResponseResponseWithMetadata]]:
"""Retrieve a list of leaderboards (maps)
Fetches a paginated and optionally filtered list of leaderboards (Beat Saber maps).
Args:
page (Union[Unset, int]): Default: 1.
count (Union[Unset, int]): Default: 10.
sort_by (Union[Unset, MapSortBy]):
order (Union[Unset, Order]): Represents the order in which values will be sorted.
search (Union[Unset, str]):
type (Union[Unset, Type]):
mode (Union[Unset, str]):
difficulty (Union[Unset, str]):
map_type (Union[Unset, int]):
all_types (Union[Unset, Operation]):
map_requirements (Union[Unset, Requirements]):
all_requirements (Union[Unset, Operation]):
song_status (Union[Unset, SongStatus]):
leaderboard_context (Union[Unset, LeaderboardContexts]):
mytype (Union[Unset, MyType]):
stars_from (Union[Unset, float]):
stars_to (Union[Unset, float]):
accrating_from (Union[Unset, float]):
accrating_to (Union[Unset, float]):
passrating_from (Union[Unset, float]):
passrating_to (Union[Unset, float]):
techrating_from (Union[Unset, float]):
techrating_to (Union[Unset, float]):
date_from (Union[Unset, int]):
date_to (Union[Unset, int]):
mappers (Union[Unset, str]):
override_current_id (Union[Unset, str]):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, MapInfoResponseResponseWithMetadata]]
"""
kwargs = _get_kwargs(
page=page,
count=count,
sort_by=sort_by,
order=order,
search=search,
type=type,
mode=mode,
difficulty=difficulty,
map_type=map_type,
all_types=all_types,
map_requirements=map_requirements,
all_requirements=all_requirements,
song_status=song_status,
leaderboard_context=leaderboard_context,
mytype=mytype,
stars_from=stars_from,
stars_to=stars_to,
accrating_from=accrating_from,
accrating_to=accrating_to,
passrating_from=passrating_from,
passrating_to=passrating_to,
techrating_from=techrating_from,
techrating_to=techrating_to,
date_from=date_from,
date_to=date_to,
mappers=mappers,
override_current_id=override_current_id,
)
response = client.get_httpx_client().request(
**kwargs,
)
return _build_response(client=client, response=response)
def sync(
*,
client: Union[AuthenticatedClient, Client],
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 10,
sort_by: Union[Unset, MapSortBy] = UNSET,
order: Union[Unset, Order] = UNSET,
search: Union[Unset, str] = UNSET,
type: Union[Unset, Type] = UNSET,
mode: Union[Unset, str] = UNSET,
difficulty: Union[Unset, str] = UNSET,
map_type: Union[Unset, int] = UNSET,
all_types: Union[Unset, Operation] = UNSET,
map_requirements: Union[Unset, Requirements] = UNSET,
all_requirements: Union[Unset, Operation] = UNSET,
song_status: Union[Unset, SongStatus] = UNSET,
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
mytype: Union[Unset, MyType] = UNSET,
stars_from: Union[Unset, float] = UNSET,
stars_to: Union[Unset, float] = UNSET,
accrating_from: Union[Unset, float] = UNSET,
accrating_to: Union[Unset, float] = UNSET,
passrating_from: Union[Unset, float] = UNSET,
passrating_to: Union[Unset, float] = UNSET,
techrating_from: Union[Unset, float] = UNSET,
techrating_to: Union[Unset, float] = UNSET,
date_from: Union[Unset, int] = UNSET,
date_to: Union[Unset, int] = UNSET,
mappers: Union[Unset, str] = UNSET,
override_current_id: Union[Unset, str] = UNSET,
) -> Optional[Union[Any, MapInfoResponseResponseWithMetadata]]:
"""Retrieve a list of leaderboards (maps)
Fetches a paginated and optionally filtered list of leaderboards (Beat Saber maps).
Args:
page (Union[Unset, int]): Default: 1.
count (Union[Unset, int]): Default: 10.
sort_by (Union[Unset, MapSortBy]):
order (Union[Unset, Order]): Represents the order in which values will be sorted.
search (Union[Unset, str]):
type (Union[Unset, Type]):
mode (Union[Unset, str]):
difficulty (Union[Unset, str]):
map_type (Union[Unset, int]):
all_types (Union[Unset, Operation]):
map_requirements (Union[Unset, Requirements]):
all_requirements (Union[Unset, Operation]):
song_status (Union[Unset, SongStatus]):
leaderboard_context (Union[Unset, LeaderboardContexts]):
mytype (Union[Unset, MyType]):
stars_from (Union[Unset, float]):
stars_to (Union[Unset, float]):
accrating_from (Union[Unset, float]):
accrating_to (Union[Unset, float]):
passrating_from (Union[Unset, float]):
passrating_to (Union[Unset, float]):
techrating_from (Union[Unset, float]):
techrating_to (Union[Unset, float]):
date_from (Union[Unset, int]):
date_to (Union[Unset, int]):
mappers (Union[Unset, str]):
override_current_id (Union[Unset, str]):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, MapInfoResponseResponseWithMetadata]
"""
return sync_detailed(
client=client,
page=page,
count=count,
sort_by=sort_by,
order=order,
search=search,
type=type,
mode=mode,
difficulty=difficulty,
map_type=map_type,
all_types=all_types,
map_requirements=map_requirements,
all_requirements=all_requirements,
song_status=song_status,
leaderboard_context=leaderboard_context,
mytype=mytype,
stars_from=stars_from,
stars_to=stars_to,
accrating_from=accrating_from,
accrating_to=accrating_to,
passrating_from=passrating_from,
passrating_to=passrating_to,
techrating_from=techrating_from,
techrating_to=techrating_to,
date_from=date_from,
date_to=date_to,
mappers=mappers,
override_current_id=override_current_id,
).parsed
async def asyncio_detailed(
*,
client: Union[AuthenticatedClient, Client],
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 10,
sort_by: Union[Unset, MapSortBy] = UNSET,
order: Union[Unset, Order] = UNSET,
search: Union[Unset, str] = UNSET,
type: Union[Unset, Type] = UNSET,
mode: Union[Unset, str] = UNSET,
difficulty: Union[Unset, str] = UNSET,
map_type: Union[Unset, int] = UNSET,
all_types: Union[Unset, Operation] = UNSET,
map_requirements: Union[Unset, Requirements] = UNSET,
all_requirements: Union[Unset, Operation] = UNSET,
song_status: Union[Unset, SongStatus] = UNSET,
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
mytype: Union[Unset, MyType] = UNSET,
stars_from: Union[Unset, float] = UNSET,
stars_to: Union[Unset, float] = UNSET,
accrating_from: Union[Unset, float] = UNSET,
accrating_to: Union[Unset, float] = UNSET,
passrating_from: Union[Unset, float] = UNSET,
passrating_to: Union[Unset, float] = UNSET,
techrating_from: Union[Unset, float] = UNSET,
techrating_to: Union[Unset, float] = UNSET,
date_from: Union[Unset, int] = UNSET,
date_to: Union[Unset, int] = UNSET,
mappers: Union[Unset, str] = UNSET,
override_current_id: Union[Unset, str] = UNSET,
) -> Response[Union[Any, MapInfoResponseResponseWithMetadata]]:
"""Retrieve a list of leaderboards (maps)
Fetches a paginated and optionally filtered list of leaderboards (Beat Saber maps).
Args:
page (Union[Unset, int]): Default: 1.
count (Union[Unset, int]): Default: 10.
sort_by (Union[Unset, MapSortBy]):
order (Union[Unset, Order]): Represents the order in which values will be sorted.
search (Union[Unset, str]):
type (Union[Unset, Type]):
mode (Union[Unset, str]):
difficulty (Union[Unset, str]):
map_type (Union[Unset, int]):
all_types (Union[Unset, Operation]):
map_requirements (Union[Unset, Requirements]):
all_requirements (Union[Unset, Operation]):
song_status (Union[Unset, SongStatus]):
leaderboard_context (Union[Unset, LeaderboardContexts]):
mytype (Union[Unset, MyType]):
stars_from (Union[Unset, float]):
stars_to (Union[Unset, float]):
accrating_from (Union[Unset, float]):
accrating_to (Union[Unset, float]):
passrating_from (Union[Unset, float]):
passrating_to (Union[Unset, float]):
techrating_from (Union[Unset, float]):
techrating_to (Union[Unset, float]):
date_from (Union[Unset, int]):
date_to (Union[Unset, int]):
mappers (Union[Unset, str]):
override_current_id (Union[Unset, str]):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Response[Union[Any, MapInfoResponseResponseWithMetadata]]
"""
kwargs = _get_kwargs(
page=page,
count=count,
sort_by=sort_by,
order=order,
search=search,
type=type,
mode=mode,
difficulty=difficulty,
map_type=map_type,
all_types=all_types,
map_requirements=map_requirements,
all_requirements=all_requirements,
song_status=song_status,
leaderboard_context=leaderboard_context,
mytype=mytype,
stars_from=stars_from,
stars_to=stars_to,
accrating_from=accrating_from,
accrating_to=accrating_to,
passrating_from=passrating_from,
passrating_to=passrating_to,
techrating_from=techrating_from,
techrating_to=techrating_to,
date_from=date_from,
date_to=date_to,
mappers=mappers,
override_current_id=override_current_id,
)
response = await client.get_async_httpx_client().request(**kwargs)
return _build_response(client=client, response=response)
async def asyncio(
*,
client: Union[AuthenticatedClient, Client],
page: Union[Unset, int] = 1,
count: Union[Unset, int] = 10,
sort_by: Union[Unset, MapSortBy] = UNSET,
order: Union[Unset, Order] = UNSET,
search: Union[Unset, str] = UNSET,
type: Union[Unset, Type] = UNSET,
mode: Union[Unset, str] = UNSET,
difficulty: Union[Unset, str] = UNSET,
map_type: Union[Unset, int] = UNSET,
all_types: Union[Unset, Operation] = UNSET,
map_requirements: Union[Unset, Requirements] = UNSET,
all_requirements: Union[Unset, Operation] = UNSET,
song_status: Union[Unset, SongStatus] = UNSET,
leaderboard_context: Union[Unset, LeaderboardContexts] = UNSET,
mytype: Union[Unset, MyType] = UNSET,
stars_from: Union[Unset, float] = UNSET,
stars_to: Union[Unset, float] = UNSET,
accrating_from: Union[Unset, float] = UNSET,
accrating_to: Union[Unset, float] = UNSET,
passrating_from: Union[Unset, float] = UNSET,
passrating_to: Union[Unset, float] = UNSET,
techrating_from: Union[Unset, float] = UNSET,
techrating_to: Union[Unset, float] = UNSET,
date_from: Union[Unset, int] = UNSET,
date_to: Union[Unset, int] = UNSET,
mappers: Union[Unset, str] = UNSET,
override_current_id: Union[Unset, str] = UNSET,
) -> Optional[Union[Any, MapInfoResponseResponseWithMetadata]]:
"""Retrieve a list of leaderboards (maps)
Fetches a paginated and optionally filtered list of leaderboards (Beat Saber maps).
Args:
page (Union[Unset, int]): Default: 1.
count (Union[Unset, int]): Default: 10.
sort_by (Union[Unset, MapSortBy]):
order (Union[Unset, Order]): Represents the order in which values will be sorted.
search (Union[Unset, str]):
type (Union[Unset, Type]):
mode (Union[Unset, str]):
difficulty (Union[Unset, str]):
map_type (Union[Unset, int]):
all_types (Union[Unset, Operation]):
map_requirements (Union[Unset, Requirements]):
all_requirements (Union[Unset, Operation]):
song_status (Union[Unset, SongStatus]):
leaderboard_context (Union[Unset, LeaderboardContexts]):
mytype (Union[Unset, MyType]):
stars_from (Union[Unset, float]):
stars_to (Union[Unset, float]):
accrating_from (Union[Unset, float]):
accrating_to (Union[Unset, float]):
passrating_from (Union[Unset, float]):
passrating_to (Union[Unset, float]):
techrating_from (Union[Unset, float]):
techrating_to (Union[Unset, float]):
date_from (Union[Unset, int]):
date_to (Union[Unset, int]):
mappers (Union[Unset, str]):
override_current_id (Union[Unset, str]):
Raises:
errors.UnexpectedStatus: If the server returns an undocumented status code and Client.raise_on_unexpected_status is True.
httpx.TimeoutException: If the request takes longer than Client.timeout.
Returns:
Union[Any, MapInfoResponseResponseWithMetadata]
"""
return (
await asyncio_detailed(
client=client,
page=page,
count=count,
sort_by=sort_by,
order=order,
search=search,
type=type,
mode=mode,
difficulty=difficulty,
map_type=map_type,
all_types=all_types,
map_requirements=map_requirements,
all_requirements=all_requirements,
song_status=song_status,
leaderboard_context=leaderboard_context,
mytype=mytype,
stars_from=stars_from,
stars_to=stars_to,
accrating_from=accrating_from,
accrating_to=accrating_to,
passrating_from=passrating_from,
passrating_to=passrating_to,
techrating_from=techrating_from,
techrating_to=techrating_to,
date_from=date_from,
date_to=date_to,
mappers=mappers,
override_current_id=override_current_id,
)
).parsed

View File

@ -0,0 +1,268 @@
import ssl
from typing import Any, Dict, Optional, Union
import httpx
from attrs import define, evolve, field
@define
class Client:
"""A class for keeping track of data related to the API
The following are accepted as keyword arguments and will be used to construct httpx Clients internally:
``base_url``: The base URL for the API, all requests are made to a relative path to this URL
``cookies``: A dictionary of cookies to be sent with every request
``headers``: A dictionary of headers to be sent with every request
``timeout``: The maximum amount of a time a request can take. API functions will raise
httpx.TimeoutException if this is exceeded.
``verify_ssl``: Whether or not to verify the SSL certificate of the API server. This should be True in production,
but can be set to False for testing purposes.
``follow_redirects``: Whether or not to follow redirects. Default value is False.
``httpx_args``: A dictionary of additional arguments to be passed to the ``httpx.Client`` and ``httpx.AsyncClient`` constructor.
Attributes:
raise_on_unexpected_status: Whether or not to raise an errors.UnexpectedStatus if the API returns a
status code that was not documented in the source OpenAPI document. Can also be provided as a keyword
argument to the constructor.
"""
raise_on_unexpected_status: bool = field(default=False, kw_only=True)
_base_url: str = field(alias="base_url")
_cookies: Dict[str, str] = field(factory=dict, kw_only=True, alias="cookies")
_headers: Dict[str, str] = field(factory=dict, kw_only=True, alias="headers")
_timeout: Optional[httpx.Timeout] = field(default=None, kw_only=True, alias="timeout")
_verify_ssl: Union[str, bool, ssl.SSLContext] = field(default=True, kw_only=True, alias="verify_ssl")
_follow_redirects: bool = field(default=False, kw_only=True, alias="follow_redirects")
_httpx_args: Dict[str, Any] = field(factory=dict, kw_only=True, alias="httpx_args")
_client: Optional[httpx.Client] = field(default=None, init=False)
_async_client: Optional[httpx.AsyncClient] = field(default=None, init=False)
def with_headers(self, headers: Dict[str, str]) -> "Client":
"""Get a new client matching this one with additional headers"""
if self._client is not None:
self._client.headers.update(headers)
if self._async_client is not None:
self._async_client.headers.update(headers)
return evolve(self, headers={**self._headers, **headers})
def with_cookies(self, cookies: Dict[str, str]) -> "Client":
"""Get a new client matching this one with additional cookies"""
if self._client is not None:
self._client.cookies.update(cookies)
if self._async_client is not None:
self._async_client.cookies.update(cookies)
return evolve(self, cookies={**self._cookies, **cookies})
def with_timeout(self, timeout: httpx.Timeout) -> "Client":
"""Get a new client matching this one with a new timeout (in seconds)"""
if self._client is not None:
self._client.timeout = timeout
if self._async_client is not None:
self._async_client.timeout = timeout
return evolve(self, timeout=timeout)
def set_httpx_client(self, client: httpx.Client) -> "Client":
"""Manually the underlying httpx.Client
**NOTE**: This will override any other settings on the client, including cookies, headers, and timeout.
"""
self._client = client
return self
def get_httpx_client(self) -> httpx.Client:
"""Get the underlying httpx.Client, constructing a new one if not previously set"""
if self._client is None:
self._client = httpx.Client(
base_url=self._base_url,
cookies=self._cookies,
headers=self._headers,
timeout=self._timeout,
verify=self._verify_ssl,
follow_redirects=self._follow_redirects,
**self._httpx_args,
)
return self._client
def __enter__(self) -> "Client":
"""Enter a context manager for self.client—you cannot enter twice (see httpx docs)"""
self.get_httpx_client().__enter__()
return self
def __exit__(self, *args: Any, **kwargs: Any) -> None:
"""Exit a context manager for internal httpx.Client (see httpx docs)"""
self.get_httpx_client().__exit__(*args, **kwargs)
def set_async_httpx_client(self, async_client: httpx.AsyncClient) -> "Client":
"""Manually the underlying httpx.AsyncClient
**NOTE**: This will override any other settings on the client, including cookies, headers, and timeout.
"""
self._async_client = async_client
return self
def get_async_httpx_client(self) -> httpx.AsyncClient:
"""Get the underlying httpx.AsyncClient, constructing a new one if not previously set"""
if self._async_client is None:
self._async_client = httpx.AsyncClient(
base_url=self._base_url,
cookies=self._cookies,
headers=self._headers,
timeout=self._timeout,
verify=self._verify_ssl,
follow_redirects=self._follow_redirects,
**self._httpx_args,
)
return self._async_client
async def __aenter__(self) -> "Client":
"""Enter a context manager for underlying httpx.AsyncClient—you cannot enter twice (see httpx docs)"""
await self.get_async_httpx_client().__aenter__()
return self
async def __aexit__(self, *args: Any, **kwargs: Any) -> None:
"""Exit a context manager for underlying httpx.AsyncClient (see httpx docs)"""
await self.get_async_httpx_client().__aexit__(*args, **kwargs)
@define
class AuthenticatedClient:
"""A Client which has been authenticated for use on secured endpoints
The following are accepted as keyword arguments and will be used to construct httpx Clients internally:
``base_url``: The base URL for the API, all requests are made to a relative path to this URL
``cookies``: A dictionary of cookies to be sent with every request
``headers``: A dictionary of headers to be sent with every request
``timeout``: The maximum amount of a time a request can take. API functions will raise
httpx.TimeoutException if this is exceeded.
``verify_ssl``: Whether or not to verify the SSL certificate of the API server. This should be True in production,
but can be set to False for testing purposes.
``follow_redirects``: Whether or not to follow redirects. Default value is False.
``httpx_args``: A dictionary of additional arguments to be passed to the ``httpx.Client`` and ``httpx.AsyncClient`` constructor.
Attributes:
raise_on_unexpected_status: Whether or not to raise an errors.UnexpectedStatus if the API returns a
status code that was not documented in the source OpenAPI document. Can also be provided as a keyword
argument to the constructor.
token: The token to use for authentication
prefix: The prefix to use for the Authorization header
auth_header_name: The name of the Authorization header
"""
raise_on_unexpected_status: bool = field(default=False, kw_only=True)
_base_url: str = field(alias="base_url")
_cookies: Dict[str, str] = field(factory=dict, kw_only=True, alias="cookies")
_headers: Dict[str, str] = field(factory=dict, kw_only=True, alias="headers")
_timeout: Optional[httpx.Timeout] = field(default=None, kw_only=True, alias="timeout")
_verify_ssl: Union[str, bool, ssl.SSLContext] = field(default=True, kw_only=True, alias="verify_ssl")
_follow_redirects: bool = field(default=False, kw_only=True, alias="follow_redirects")
_httpx_args: Dict[str, Any] = field(factory=dict, kw_only=True, alias="httpx_args")
_client: Optional[httpx.Client] = field(default=None, init=False)
_async_client: Optional[httpx.AsyncClient] = field(default=None, init=False)
token: str
prefix: str = "Bearer"
auth_header_name: str = "Authorization"
def with_headers(self, headers: Dict[str, str]) -> "AuthenticatedClient":
"""Get a new client matching this one with additional headers"""
if self._client is not None:
self._client.headers.update(headers)
if self._async_client is not None:
self._async_client.headers.update(headers)
return evolve(self, headers={**self._headers, **headers})
def with_cookies(self, cookies: Dict[str, str]) -> "AuthenticatedClient":
"""Get a new client matching this one with additional cookies"""
if self._client is not None:
self._client.cookies.update(cookies)
if self._async_client is not None:
self._async_client.cookies.update(cookies)
return evolve(self, cookies={**self._cookies, **cookies})
def with_timeout(self, timeout: httpx.Timeout) -> "AuthenticatedClient":
"""Get a new client matching this one with a new timeout (in seconds)"""
if self._client is not None:
self._client.timeout = timeout
if self._async_client is not None:
self._async_client.timeout = timeout
return evolve(self, timeout=timeout)
def set_httpx_client(self, client: httpx.Client) -> "AuthenticatedClient":
"""Manually the underlying httpx.Client
**NOTE**: This will override any other settings on the client, including cookies, headers, and timeout.
"""
self._client = client
return self
def get_httpx_client(self) -> httpx.Client:
"""Get the underlying httpx.Client, constructing a new one if not previously set"""
if self._client is None:
self._headers[self.auth_header_name] = f"{self.prefix} {self.token}" if self.prefix else self.token
self._client = httpx.Client(
base_url=self._base_url,
cookies=self._cookies,
headers=self._headers,
timeout=self._timeout,
verify=self._verify_ssl,
follow_redirects=self._follow_redirects,
**self._httpx_args,
)
return self._client
def __enter__(self) -> "AuthenticatedClient":
"""Enter a context manager for self.client—you cannot enter twice (see httpx docs)"""
self.get_httpx_client().__enter__()
return self
def __exit__(self, *args: Any, **kwargs: Any) -> None:
"""Exit a context manager for internal httpx.Client (see httpx docs)"""
self.get_httpx_client().__exit__(*args, **kwargs)
def set_async_httpx_client(self, async_client: httpx.AsyncClient) -> "AuthenticatedClient":
"""Manually the underlying httpx.AsyncClient
**NOTE**: This will override any other settings on the client, including cookies, headers, and timeout.
"""
self._async_client = async_client
return self
def get_async_httpx_client(self) -> httpx.AsyncClient:
"""Get the underlying httpx.AsyncClient, constructing a new one if not previously set"""
if self._async_client is None:
self._headers[self.auth_header_name] = f"{self.prefix} {self.token}" if self.prefix else self.token
self._async_client = httpx.AsyncClient(
base_url=self._base_url,
cookies=self._cookies,
headers=self._headers,
timeout=self._timeout,
verify=self._verify_ssl,
follow_redirects=self._follow_redirects,
**self._httpx_args,
)
return self._async_client
async def __aenter__(self) -> "AuthenticatedClient":
"""Enter a context manager for underlying httpx.AsyncClient—you cannot enter twice (see httpx docs)"""
await self.get_async_httpx_client().__aenter__()
return self
async def __aexit__(self, *args: Any, **kwargs: Any) -> None:
"""Exit a context manager for underlying httpx.AsyncClient (see httpx docs)"""
await self.get_async_httpx_client().__aexit__(*args, **kwargs)

View File

@ -0,0 +1,16 @@
"""Contains shared errors types that can be raised from API functions"""
class UnexpectedStatus(Exception):
"""Raised by api functions when the response status an undocumented status and Client.raise_on_unexpected_status is True"""
def __init__(self, status_code: int, content: bytes):
self.status_code = status_code
self.content = content
super().__init__(
f"Unexpected status code: {status_code}\n\nResponse content:\n{content.decode(errors='ignore')}"
)
__all__ = ["UnexpectedStatus"]

View File

@ -0,0 +1,229 @@
"""Contains all the data models used in inputs/outputs"""
from .achievement import Achievement
from .achievement_description import AchievementDescription
from .achievement_level import AchievementLevel
from .badge import Badge
from .ban import Ban
from .beasties_nomination import BeastiesNomination
from .besties_nomination_response import BestiesNominationResponse
from .clan import Clan
from .clan_bigger_response import ClanBiggerResponse
from .clan_global_map import ClanGlobalMap
from .clan_global_map_point import ClanGlobalMapPoint
from .clan_map_connection import ClanMapConnection
from .clan_maps_sort_by import ClanMapsSortBy
from .clan_point import ClanPoint
from .clan_ranking_response import ClanRankingResponse
from .clan_ranking_response_clan_response_full_response_with_metadata_and_container import (
ClanRankingResponseClanResponseFullResponseWithMetadataAndContainer,
)
from .clan_response import ClanResponse
from .clan_response_full import ClanResponseFull
from .clan_response_full_response_with_metadata import ClanResponseFullResponseWithMetadata
from .clan_sort_by import ClanSortBy
from .compact_leaderboard import CompactLeaderboard
from .compact_leaderboard_response import CompactLeaderboardResponse
from .compact_score import CompactScore
from .compact_score_response import CompactScoreResponse
from .compact_score_response_response_with_metadata import CompactScoreResponseResponseWithMetadata
from .compact_song_response import CompactSongResponse
from .controller_enum import ControllerEnum
from .criteria_commentary import CriteriaCommentary
from .difficulty_description import DifficultyDescription
from .difficulty_response import DifficultyResponse
from .difficulty_status import DifficultyStatus
from .event_player import EventPlayer
from .event_ranking import EventRanking
from .external_status import ExternalStatus
from .featured_playlist import FeaturedPlaylist
from .featured_playlist_response import FeaturedPlaylistResponse
from .follower_type import FollowerType
from .global_map_history import GlobalMapHistory
from .history_compact_response import HistoryCompactResponse
from .hmd import HMD
from .info_to_highlight import InfoToHighlight
from .leaderboard import Leaderboard
from .leaderboard_change import LeaderboardChange
from .leaderboard_clan_ranking_response import LeaderboardClanRankingResponse
from .leaderboard_contexts import LeaderboardContexts
from .leaderboard_group_entry import LeaderboardGroupEntry
from .leaderboard_info_response import LeaderboardInfoResponse
from .leaderboard_info_response_response_with_metadata import LeaderboardInfoResponseResponseWithMetadata
from .leaderboard_response import LeaderboardResponse
from .leaderboard_sort_by import LeaderboardSortBy
from .legacy_modifiers import LegacyModifiers
from .link_response import LinkResponse
from .map_diff_response import MapDiffResponse
from .map_info_response import MapInfoResponse
from .map_info_response_response_with_metadata import MapInfoResponseResponseWithMetadata
from .map_quality import MapQuality
from .map_sort_by import MapSortBy
from .mapper import Mapper
from .mapper_response import MapperResponse
from .maps_type import MapsType
from .metadata import Metadata
from .modifiers_map import ModifiersMap
from .modifiers_rating import ModifiersRating
from .my_type import MyType
from .operation import Operation
from .order import Order
from .participating_event_response import ParticipatingEventResponse
from .patreon_features import PatreonFeatures
from .player import Player
from .player_change import PlayerChange
from .player_context_extension import PlayerContextExtension
from .player_follower import PlayerFollower
from .player_followers_info_response import PlayerFollowersInfoResponse
from .player_response import PlayerResponse
from .player_response_clan_response_full_response_with_metadata_and_container import (
PlayerResponseClanResponseFullResponseWithMetadataAndContainer,
)
from .player_response_full import PlayerResponseFull
from .player_response_with_stats import PlayerResponseWithStats
from .player_response_with_stats_response_with_metadata import PlayerResponseWithStatsResponseWithMetadata
from .player_score_stats import PlayerScoreStats
from .player_score_stats_history import PlayerScoreStatsHistory
from .player_search import PlayerSearch
from .player_social import PlayerSocial
from .player_sort_by import PlayerSortBy
from .pp_type import PpType
from .profile_settings import ProfileSettings
from .qualification_change import QualificationChange
from .qualification_commentary import QualificationCommentary
from .qualification_vote import QualificationVote
from .rank_qualification import RankQualification
from .rank_update import RankUpdate
from .rank_update_change import RankUpdateChange
from .rank_voting import RankVoting
from .ranked_map import RankedMap
from .ranked_mapper_response import RankedMapperResponse
from .replay_offsets import ReplayOffsets
from .requirements import Requirements
from .score_filter_status import ScoreFilterStatus
from .score_graph_entry import ScoreGraphEntry
from .score_improvement import ScoreImprovement
from .score_metadata import ScoreMetadata
from .score_response import ScoreResponse
from .score_response_with_acc import ScoreResponseWithAcc
from .score_response_with_my_score import ScoreResponseWithMyScore
from .score_response_with_my_score_response_with_metadata import ScoreResponseWithMyScoreResponseWithMetadata
from .scores_sort_by import ScoresSortBy
from .song import Song
from .song_response import SongResponse
from .song_status import SongStatus
from .type import Type
from .voter_feedback import VoterFeedback
__all__ = (
"Achievement",
"AchievementDescription",
"AchievementLevel",
"Badge",
"Ban",
"BeastiesNomination",
"BestiesNominationResponse",
"Clan",
"ClanBiggerResponse",
"ClanGlobalMap",
"ClanGlobalMapPoint",
"ClanMapConnection",
"ClanMapsSortBy",
"ClanPoint",
"ClanRankingResponse",
"ClanRankingResponseClanResponseFullResponseWithMetadataAndContainer",
"ClanResponse",
"ClanResponseFull",
"ClanResponseFullResponseWithMetadata",
"ClanSortBy",
"CompactLeaderboard",
"CompactLeaderboardResponse",
"CompactScore",
"CompactScoreResponse",
"CompactScoreResponseResponseWithMetadata",
"CompactSongResponse",
"ControllerEnum",
"CriteriaCommentary",
"DifficultyDescription",
"DifficultyResponse",
"DifficultyStatus",
"EventPlayer",
"EventRanking",
"ExternalStatus",
"FeaturedPlaylist",
"FeaturedPlaylistResponse",
"FollowerType",
"GlobalMapHistory",
"HistoryCompactResponse",
"HMD",
"InfoToHighlight",
"Leaderboard",
"LeaderboardChange",
"LeaderboardClanRankingResponse",
"LeaderboardContexts",
"LeaderboardGroupEntry",
"LeaderboardInfoResponse",
"LeaderboardInfoResponseResponseWithMetadata",
"LeaderboardResponse",
"LeaderboardSortBy",
"LegacyModifiers",
"LinkResponse",
"MapDiffResponse",
"MapInfoResponse",
"MapInfoResponseResponseWithMetadata",
"Mapper",
"MapperResponse",
"MapQuality",
"MapSortBy",
"MapsType",
"Metadata",
"ModifiersMap",
"ModifiersRating",
"MyType",
"Operation",
"Order",
"ParticipatingEventResponse",
"PatreonFeatures",
"Player",
"PlayerChange",
"PlayerContextExtension",
"PlayerFollower",
"PlayerFollowersInfoResponse",
"PlayerResponse",
"PlayerResponseClanResponseFullResponseWithMetadataAndContainer",
"PlayerResponseFull",
"PlayerResponseWithStats",
"PlayerResponseWithStatsResponseWithMetadata",
"PlayerScoreStats",
"PlayerScoreStatsHistory",
"PlayerSearch",
"PlayerSocial",
"PlayerSortBy",
"PpType",
"ProfileSettings",
"QualificationChange",
"QualificationCommentary",
"QualificationVote",
"RankedMap",
"RankedMapperResponse",
"RankQualification",
"RankUpdate",
"RankUpdateChange",
"RankVoting",
"ReplayOffsets",
"Requirements",
"ScoreFilterStatus",
"ScoreGraphEntry",
"ScoreImprovement",
"ScoreMetadata",
"ScoreResponse",
"ScoreResponseWithAcc",
"ScoreResponseWithMyScore",
"ScoreResponseWithMyScoreResponseWithMetadata",
"ScoresSortBy",
"Song",
"SongResponse",
"SongStatus",
"Type",
"VoterFeedback",
)

View File

@ -0,0 +1,125 @@
from typing import TYPE_CHECKING, Any, Dict, Type, TypeVar, Union, cast
from attrs import define as _attrs_define
from ..types import UNSET, Unset
if TYPE_CHECKING:
from ..models.achievement_description import AchievementDescription
from ..models.achievement_level import AchievementLevel
T = TypeVar("T", bound="Achievement")
@_attrs_define
class Achievement:
"""
Attributes:
id (Union[Unset, int]):
player_id (Union[None, Unset, str]):
achievement_description_id (Union[Unset, int]):
achievement_description (Union[Unset, AchievementDescription]):
level (Union[Unset, AchievementLevel]):
timeset (Union[Unset, int]):
count (Union[Unset, int]):
"""
id: Union[Unset, int] = UNSET
player_id: Union[None, Unset, str] = UNSET
achievement_description_id: Union[Unset, int] = UNSET
achievement_description: Union[Unset, "AchievementDescription"] = UNSET
level: Union[Unset, "AchievementLevel"] = UNSET
timeset: Union[Unset, int] = UNSET
count: Union[Unset, int] = UNSET
def to_dict(self) -> Dict[str, Any]:
id = self.id
player_id: Union[None, Unset, str]
if isinstance(self.player_id, Unset):
player_id = UNSET
else:
player_id = self.player_id
achievement_description_id = self.achievement_description_id
achievement_description: Union[Unset, Dict[str, Any]] = UNSET
if not isinstance(self.achievement_description, Unset):
achievement_description = self.achievement_description.to_dict()
level: Union[Unset, Dict[str, Any]] = UNSET
if not isinstance(self.level, Unset):
level = self.level.to_dict()
timeset = self.timeset
count = self.count
field_dict: Dict[str, Any] = {}
field_dict.update({})
if id is not UNSET:
field_dict["id"] = id
if player_id is not UNSET:
field_dict["playerId"] = player_id
if achievement_description_id is not UNSET:
field_dict["achievementDescriptionId"] = achievement_description_id
if achievement_description is not UNSET:
field_dict["achievementDescription"] = achievement_description
if level is not UNSET:
field_dict["level"] = level
if timeset is not UNSET:
field_dict["timeset"] = timeset
if count is not UNSET:
field_dict["count"] = count
return field_dict
@classmethod
def from_dict(cls: Type[T], src_dict: Dict[str, Any]) -> T:
from ..models.achievement_description import AchievementDescription
from ..models.achievement_level import AchievementLevel
d = src_dict.copy()
id = d.pop("id", UNSET)
def _parse_player_id(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
player_id = _parse_player_id(d.pop("playerId", UNSET))
achievement_description_id = d.pop("achievementDescriptionId", UNSET)
_achievement_description = d.pop("achievementDescription", UNSET)
achievement_description: Union[Unset, AchievementDescription]
if isinstance(_achievement_description, Unset):
achievement_description = UNSET
else:
achievement_description = AchievementDescription.from_dict(_achievement_description)
_level = d.pop("level", UNSET)
level: Union[Unset, AchievementLevel]
if isinstance(_level, Unset):
level = UNSET
else:
level = AchievementLevel.from_dict(_level)
timeset = d.pop("timeset", UNSET)
count = d.pop("count", UNSET)
achievement = cls(
id=id,
player_id=player_id,
achievement_description_id=achievement_description_id,
achievement_description=achievement_description,
level=level,
timeset=timeset,
count=count,
)
return achievement

View File

@ -0,0 +1,143 @@
from typing import TYPE_CHECKING, Any, Dict, List, Type, TypeVar, Union, cast
from attrs import define as _attrs_define
from ..types import UNSET, Unset
if TYPE_CHECKING:
from ..models.achievement_level import AchievementLevel
T = TypeVar("T", bound="AchievementDescription")
@_attrs_define
class AchievementDescription:
"""
Attributes:
id (Union[Unset, int]):
name (Union[None, Unset, str]):
description (Union[None, Unset, str]):
link (Union[None, Unset, str]):
levels (Union[List['AchievementLevel'], None, Unset]):
"""
id: Union[Unset, int] = UNSET
name: Union[None, Unset, str] = UNSET
description: Union[None, Unset, str] = UNSET
link: Union[None, Unset, str] = UNSET
levels: Union[List["AchievementLevel"], None, Unset] = UNSET
def to_dict(self) -> Dict[str, Any]:
id = self.id
name: Union[None, Unset, str]
if isinstance(self.name, Unset):
name = UNSET
else:
name = self.name
description: Union[None, Unset, str]
if isinstance(self.description, Unset):
description = UNSET
else:
description = self.description
link: Union[None, Unset, str]
if isinstance(self.link, Unset):
link = UNSET
else:
link = self.link
levels: Union[List[Dict[str, Any]], None, Unset]
if isinstance(self.levels, Unset):
levels = UNSET
elif isinstance(self.levels, list):
levels = []
for levels_type_0_item_data in self.levels:
levels_type_0_item = levels_type_0_item_data.to_dict()
levels.append(levels_type_0_item)
else:
levels = self.levels
field_dict: Dict[str, Any] = {}
field_dict.update({})
if id is not UNSET:
field_dict["id"] = id
if name is not UNSET:
field_dict["name"] = name
if description is not UNSET:
field_dict["description"] = description
if link is not UNSET:
field_dict["link"] = link
if levels is not UNSET:
field_dict["levels"] = levels
return field_dict
@classmethod
def from_dict(cls: Type[T], src_dict: Dict[str, Any]) -> T:
from ..models.achievement_level import AchievementLevel
d = src_dict.copy()
id = d.pop("id", UNSET)
def _parse_name(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
name = _parse_name(d.pop("name", UNSET))
def _parse_description(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
description = _parse_description(d.pop("description", UNSET))
def _parse_link(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
link = _parse_link(d.pop("link", UNSET))
def _parse_levels(data: object) -> Union[List["AchievementLevel"], None, Unset]:
if data is None:
return data
if isinstance(data, Unset):
return data
try:
if not isinstance(data, list):
raise TypeError()
levels_type_0 = []
_levels_type_0 = data
for levels_type_0_item_data in _levels_type_0:
levels_type_0_item = AchievementLevel.from_dict(levels_type_0_item_data)
levels_type_0.append(levels_type_0_item)
return levels_type_0
except: # noqa: E722
pass
return cast(Union[List["AchievementLevel"], None, Unset], data)
levels = _parse_levels(d.pop("levels", UNSET))
achievement_description = cls(
id=id,
name=name,
description=description,
link=link,
levels=levels,
)
return achievement_description

View File

@ -0,0 +1,196 @@
from typing import Any, Dict, Type, TypeVar, Union, cast
from attrs import define as _attrs_define
from ..types import UNSET, Unset
T = TypeVar("T", bound="AchievementLevel")
@_attrs_define
class AchievementLevel:
"""
Attributes:
id (Union[Unset, int]):
image (Union[None, Unset, str]):
small_image (Union[None, Unset, str]):
name (Union[None, Unset, str]):
description (Union[None, Unset, str]):
detailed_description (Union[None, Unset, str]):
color (Union[None, Unset, str]):
value (Union[None, Unset, float]):
level (Union[Unset, int]):
achievement_description_id (Union[Unset, int]):
"""
id: Union[Unset, int] = UNSET
image: Union[None, Unset, str] = UNSET
small_image: Union[None, Unset, str] = UNSET
name: Union[None, Unset, str] = UNSET
description: Union[None, Unset, str] = UNSET
detailed_description: Union[None, Unset, str] = UNSET
color: Union[None, Unset, str] = UNSET
value: Union[None, Unset, float] = UNSET
level: Union[Unset, int] = UNSET
achievement_description_id: Union[Unset, int] = UNSET
def to_dict(self) -> Dict[str, Any]:
id = self.id
image: Union[None, Unset, str]
if isinstance(self.image, Unset):
image = UNSET
else:
image = self.image
small_image: Union[None, Unset, str]
if isinstance(self.small_image, Unset):
small_image = UNSET
else:
small_image = self.small_image
name: Union[None, Unset, str]
if isinstance(self.name, Unset):
name = UNSET
else:
name = self.name
description: Union[None, Unset, str]
if isinstance(self.description, Unset):
description = UNSET
else:
description = self.description
detailed_description: Union[None, Unset, str]
if isinstance(self.detailed_description, Unset):
detailed_description = UNSET
else:
detailed_description = self.detailed_description
color: Union[None, Unset, str]
if isinstance(self.color, Unset):
color = UNSET
else:
color = self.color
value: Union[None, Unset, float]
if isinstance(self.value, Unset):
value = UNSET
else:
value = self.value
level = self.level
achievement_description_id = self.achievement_description_id
field_dict: Dict[str, Any] = {}
field_dict.update({})
if id is not UNSET:
field_dict["id"] = id
if image is not UNSET:
field_dict["image"] = image
if small_image is not UNSET:
field_dict["smallImage"] = small_image
if name is not UNSET:
field_dict["name"] = name
if description is not UNSET:
field_dict["description"] = description
if detailed_description is not UNSET:
field_dict["detailedDescription"] = detailed_description
if color is not UNSET:
field_dict["color"] = color
if value is not UNSET:
field_dict["value"] = value
if level is not UNSET:
field_dict["level"] = level
if achievement_description_id is not UNSET:
field_dict["achievementDescriptionId"] = achievement_description_id
return field_dict
@classmethod
def from_dict(cls: Type[T], src_dict: Dict[str, Any]) -> T:
d = src_dict.copy()
id = d.pop("id", UNSET)
def _parse_image(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
image = _parse_image(d.pop("image", UNSET))
def _parse_small_image(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
small_image = _parse_small_image(d.pop("smallImage", UNSET))
def _parse_name(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
name = _parse_name(d.pop("name", UNSET))
def _parse_description(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
description = _parse_description(d.pop("description", UNSET))
def _parse_detailed_description(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
detailed_description = _parse_detailed_description(d.pop("detailedDescription", UNSET))
def _parse_color(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
color = _parse_color(d.pop("color", UNSET))
def _parse_value(data: object) -> Union[None, Unset, float]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, float], data)
value = _parse_value(d.pop("value", UNSET))
level = d.pop("level", UNSET)
achievement_description_id = d.pop("achievementDescriptionId", UNSET)
achievement_level = cls(
id=id,
image=image,
small_image=small_image,
name=name,
description=description,
detailed_description=detailed_description,
color=color,
value=value,
level=level,
achievement_description_id=achievement_description_id,
)
return achievement_level

View File

@ -0,0 +1,116 @@
from typing import Any, Dict, Type, TypeVar, Union, cast
from attrs import define as _attrs_define
from ..types import UNSET, Unset
T = TypeVar("T", bound="Badge")
@_attrs_define
class Badge:
"""
Attributes:
id (Union[Unset, int]):
description (Union[None, Unset, str]):
image (Union[None, Unset, str]):
link (Union[None, Unset, str]):
timeset (Union[Unset, int]):
hidden (Union[Unset, bool]):
"""
id: Union[Unset, int] = UNSET
description: Union[None, Unset, str] = UNSET
image: Union[None, Unset, str] = UNSET
link: Union[None, Unset, str] = UNSET
timeset: Union[Unset, int] = UNSET
hidden: Union[Unset, bool] = UNSET
def to_dict(self) -> Dict[str, Any]:
id = self.id
description: Union[None, Unset, str]
if isinstance(self.description, Unset):
description = UNSET
else:
description = self.description
image: Union[None, Unset, str]
if isinstance(self.image, Unset):
image = UNSET
else:
image = self.image
link: Union[None, Unset, str]
if isinstance(self.link, Unset):
link = UNSET
else:
link = self.link
timeset = self.timeset
hidden = self.hidden
field_dict: Dict[str, Any] = {}
field_dict.update({})
if id is not UNSET:
field_dict["id"] = id
if description is not UNSET:
field_dict["description"] = description
if image is not UNSET:
field_dict["image"] = image
if link is not UNSET:
field_dict["link"] = link
if timeset is not UNSET:
field_dict["timeset"] = timeset
if hidden is not UNSET:
field_dict["hidden"] = hidden
return field_dict
@classmethod
def from_dict(cls: Type[T], src_dict: Dict[str, Any]) -> T:
d = src_dict.copy()
id = d.pop("id", UNSET)
def _parse_description(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
description = _parse_description(d.pop("description", UNSET))
def _parse_image(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
image = _parse_image(d.pop("image", UNSET))
def _parse_link(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
link = _parse_link(d.pop("link", UNSET))
timeset = d.pop("timeset", UNSET)
hidden = d.pop("hidden", UNSET)
badge = cls(
id=id,
description=description,
image=image,
link=link,
timeset=timeset,
hidden=hidden,
)
return badge

View File

@ -0,0 +1,116 @@
from typing import Any, Dict, Type, TypeVar, Union, cast
from attrs import define as _attrs_define
from ..types import UNSET, Unset
T = TypeVar("T", bound="Ban")
@_attrs_define
class Ban:
"""
Attributes:
id (Union[Unset, int]):
player_id (Union[None, Unset, str]):
banned_by (Union[None, Unset, str]):
ban_reason (Union[None, Unset, str]):
timeset (Union[Unset, int]):
duration (Union[Unset, int]):
"""
id: Union[Unset, int] = UNSET
player_id: Union[None, Unset, str] = UNSET
banned_by: Union[None, Unset, str] = UNSET
ban_reason: Union[None, Unset, str] = UNSET
timeset: Union[Unset, int] = UNSET
duration: Union[Unset, int] = UNSET
def to_dict(self) -> Dict[str, Any]:
id = self.id
player_id: Union[None, Unset, str]
if isinstance(self.player_id, Unset):
player_id = UNSET
else:
player_id = self.player_id
banned_by: Union[None, Unset, str]
if isinstance(self.banned_by, Unset):
banned_by = UNSET
else:
banned_by = self.banned_by
ban_reason: Union[None, Unset, str]
if isinstance(self.ban_reason, Unset):
ban_reason = UNSET
else:
ban_reason = self.ban_reason
timeset = self.timeset
duration = self.duration
field_dict: Dict[str, Any] = {}
field_dict.update({})
if id is not UNSET:
field_dict["id"] = id
if player_id is not UNSET:
field_dict["playerId"] = player_id
if banned_by is not UNSET:
field_dict["bannedBy"] = banned_by
if ban_reason is not UNSET:
field_dict["banReason"] = ban_reason
if timeset is not UNSET:
field_dict["timeset"] = timeset
if duration is not UNSET:
field_dict["duration"] = duration
return field_dict
@classmethod
def from_dict(cls: Type[T], src_dict: Dict[str, Any]) -> T:
d = src_dict.copy()
id = d.pop("id", UNSET)
def _parse_player_id(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
player_id = _parse_player_id(d.pop("playerId", UNSET))
def _parse_banned_by(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
banned_by = _parse_banned_by(d.pop("bannedBy", UNSET))
def _parse_ban_reason(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
ban_reason = _parse_ban_reason(d.pop("banReason", UNSET))
timeset = d.pop("timeset", UNSET)
duration = d.pop("duration", UNSET)
ban = cls(
id=id,
player_id=player_id,
banned_by=banned_by,
ban_reason=ban_reason,
timeset=timeset,
duration=duration,
)
return ban

View File

@ -0,0 +1,107 @@
from typing import Any, Dict, Type, TypeVar, Union, cast
from attrs import define as _attrs_define
from ..types import UNSET, Unset
T = TypeVar("T", bound="BeastiesNomination")
@_attrs_define
class BeastiesNomination:
"""
Attributes:
id (Union[Unset, int]):
player_id (Union[None, Unset, str]):
leaderboard_id (Union[None, Unset, str]):
category (Union[None, Unset, str]):
timepost (Union[Unset, int]):
"""
id: Union[Unset, int] = UNSET
player_id: Union[None, Unset, str] = UNSET
leaderboard_id: Union[None, Unset, str] = UNSET
category: Union[None, Unset, str] = UNSET
timepost: Union[Unset, int] = UNSET
def to_dict(self) -> Dict[str, Any]:
id = self.id
player_id: Union[None, Unset, str]
if isinstance(self.player_id, Unset):
player_id = UNSET
else:
player_id = self.player_id
leaderboard_id: Union[None, Unset, str]
if isinstance(self.leaderboard_id, Unset):
leaderboard_id = UNSET
else:
leaderboard_id = self.leaderboard_id
category: Union[None, Unset, str]
if isinstance(self.category, Unset):
category = UNSET
else:
category = self.category
timepost = self.timepost
field_dict: Dict[str, Any] = {}
field_dict.update({})
if id is not UNSET:
field_dict["id"] = id
if player_id is not UNSET:
field_dict["playerId"] = player_id
if leaderboard_id is not UNSET:
field_dict["leaderboardId"] = leaderboard_id
if category is not UNSET:
field_dict["category"] = category
if timepost is not UNSET:
field_dict["timepost"] = timepost
return field_dict
@classmethod
def from_dict(cls: Type[T], src_dict: Dict[str, Any]) -> T:
d = src_dict.copy()
id = d.pop("id", UNSET)
def _parse_player_id(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
player_id = _parse_player_id(d.pop("playerId", UNSET))
def _parse_leaderboard_id(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
leaderboard_id = _parse_leaderboard_id(d.pop("leaderboardId", UNSET))
def _parse_category(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
category = _parse_category(d.pop("category", UNSET))
timepost = d.pop("timepost", UNSET)
beasties_nomination = cls(
id=id,
player_id=player_id,
leaderboard_id=leaderboard_id,
category=category,
timepost=timepost,
)
return beasties_nomination

View File

@ -0,0 +1,50 @@
from typing import Any, Dict, Type, TypeVar, Union, cast
from attrs import define as _attrs_define
from ..types import UNSET, Unset
T = TypeVar("T", bound="BestiesNominationResponse")
@_attrs_define
class BestiesNominationResponse:
"""
Attributes:
message (Union[None, Unset, str]):
"""
message: Union[None, Unset, str] = UNSET
def to_dict(self) -> Dict[str, Any]:
message: Union[None, Unset, str]
if isinstance(self.message, Unset):
message = UNSET
else:
message = self.message
field_dict: Dict[str, Any] = {}
field_dict.update({})
if message is not UNSET:
field_dict["message"] = message
return field_dict
@classmethod
def from_dict(cls: Type[T], src_dict: Dict[str, Any]) -> T:
d = src_dict.copy()
def _parse_message(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
message = _parse_message(d.pop("message", UNSET))
besties_nomination_response = cls(
message=message,
)
return besties_nomination_response

View File

@ -0,0 +1,354 @@
from typing import TYPE_CHECKING, Any, Dict, List, Type, TypeVar, Union, cast
from attrs import define as _attrs_define
from ..types import UNSET, Unset
if TYPE_CHECKING:
from ..models.featured_playlist import FeaturedPlaylist
from ..models.leaderboard import Leaderboard
T = TypeVar("T", bound="Clan")
@_attrs_define
class Clan:
"""
Attributes:
id (Union[Unset, int]):
name (Union[None, Unset, str]):
color (Union[None, Unset, str]):
icon (Union[None, Unset, str]):
tag (Union[None, Unset, str]):
leader_id (Union[None, Unset, str]):
description (Union[None, Unset, str]):
bio (Union[None, Unset, str]):
rich_bio_timeset (Union[Unset, int]):
players_count (Union[Unset, int]):
pp (Union[Unset, float]):
rank (Union[Unset, int]):
average_rank (Union[Unset, float]):
average_accuracy (Union[Unset, float]):
featured_playlists (Union[List['FeaturedPlaylist'], None, Unset]):
ranked_pool_percent_captured (Union[Unset, float]):
capture_leaderboards_count (Union[Unset, int]):
captured_leaderboards (Union[List['Leaderboard'], None, Unset]):
global_map_x (Union[Unset, float]):
global_map_y (Union[Unset, float]):
"""
id: Union[Unset, int] = UNSET
name: Union[None, Unset, str] = UNSET
color: Union[None, Unset, str] = UNSET
icon: Union[None, Unset, str] = UNSET
tag: Union[None, Unset, str] = UNSET
leader_id: Union[None, Unset, str] = UNSET
description: Union[None, Unset, str] = UNSET
bio: Union[None, Unset, str] = UNSET
rich_bio_timeset: Union[Unset, int] = UNSET
players_count: Union[Unset, int] = UNSET
pp: Union[Unset, float] = UNSET
rank: Union[Unset, int] = UNSET
average_rank: Union[Unset, float] = UNSET
average_accuracy: Union[Unset, float] = UNSET
featured_playlists: Union[List["FeaturedPlaylist"], None, Unset] = UNSET
ranked_pool_percent_captured: Union[Unset, float] = UNSET
capture_leaderboards_count: Union[Unset, int] = UNSET
captured_leaderboards: Union[List["Leaderboard"], None, Unset] = UNSET
global_map_x: Union[Unset, float] = UNSET
global_map_y: Union[Unset, float] = UNSET
def to_dict(self) -> Dict[str, Any]:
id = self.id
name: Union[None, Unset, str]
if isinstance(self.name, Unset):
name = UNSET
else:
name = self.name
color: Union[None, Unset, str]
if isinstance(self.color, Unset):
color = UNSET
else:
color = self.color
icon: Union[None, Unset, str]
if isinstance(self.icon, Unset):
icon = UNSET
else:
icon = self.icon
tag: Union[None, Unset, str]
if isinstance(self.tag, Unset):
tag = UNSET
else:
tag = self.tag
leader_id: Union[None, Unset, str]
if isinstance(self.leader_id, Unset):
leader_id = UNSET
else:
leader_id = self.leader_id
description: Union[None, Unset, str]
if isinstance(self.description, Unset):
description = UNSET
else:
description = self.description
bio: Union[None, Unset, str]
if isinstance(self.bio, Unset):
bio = UNSET
else:
bio = self.bio
rich_bio_timeset = self.rich_bio_timeset
players_count = self.players_count
pp = self.pp
rank = self.rank
average_rank = self.average_rank
average_accuracy = self.average_accuracy
featured_playlists: Union[List[Dict[str, Any]], None, Unset]
if isinstance(self.featured_playlists, Unset):
featured_playlists = UNSET
elif isinstance(self.featured_playlists, list):
featured_playlists = []
for featured_playlists_type_0_item_data in self.featured_playlists:
featured_playlists_type_0_item = featured_playlists_type_0_item_data.to_dict()
featured_playlists.append(featured_playlists_type_0_item)
else:
featured_playlists = self.featured_playlists
ranked_pool_percent_captured = self.ranked_pool_percent_captured
capture_leaderboards_count = self.capture_leaderboards_count
captured_leaderboards: Union[List[Dict[str, Any]], None, Unset]
if isinstance(self.captured_leaderboards, Unset):
captured_leaderboards = UNSET
elif isinstance(self.captured_leaderboards, list):
captured_leaderboards = []
for captured_leaderboards_type_0_item_data in self.captured_leaderboards:
captured_leaderboards_type_0_item = captured_leaderboards_type_0_item_data.to_dict()
captured_leaderboards.append(captured_leaderboards_type_0_item)
else:
captured_leaderboards = self.captured_leaderboards
global_map_x = self.global_map_x
global_map_y = self.global_map_y
field_dict: Dict[str, Any] = {}
field_dict.update({})
if id is not UNSET:
field_dict["id"] = id
if name is not UNSET:
field_dict["name"] = name
if color is not UNSET:
field_dict["color"] = color
if icon is not UNSET:
field_dict["icon"] = icon
if tag is not UNSET:
field_dict["tag"] = tag
if leader_id is not UNSET:
field_dict["leaderID"] = leader_id
if description is not UNSET:
field_dict["description"] = description
if bio is not UNSET:
field_dict["bio"] = bio
if rich_bio_timeset is not UNSET:
field_dict["richBioTimeset"] = rich_bio_timeset
if players_count is not UNSET:
field_dict["playersCount"] = players_count
if pp is not UNSET:
field_dict["pp"] = pp
if rank is not UNSET:
field_dict["rank"] = rank
if average_rank is not UNSET:
field_dict["averageRank"] = average_rank
if average_accuracy is not UNSET:
field_dict["averageAccuracy"] = average_accuracy
if featured_playlists is not UNSET:
field_dict["featuredPlaylists"] = featured_playlists
if ranked_pool_percent_captured is not UNSET:
field_dict["rankedPoolPercentCaptured"] = ranked_pool_percent_captured
if capture_leaderboards_count is not UNSET:
field_dict["captureLeaderboardsCount"] = capture_leaderboards_count
if captured_leaderboards is not UNSET:
field_dict["capturedLeaderboards"] = captured_leaderboards
if global_map_x is not UNSET:
field_dict["globalMapX"] = global_map_x
if global_map_y is not UNSET:
field_dict["globalMapY"] = global_map_y
return field_dict
@classmethod
def from_dict(cls: Type[T], src_dict: Dict[str, Any]) -> T:
from ..models.featured_playlist import FeaturedPlaylist
from ..models.leaderboard import Leaderboard
d = src_dict.copy()
id = d.pop("id", UNSET)
def _parse_name(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
name = _parse_name(d.pop("name", UNSET))
def _parse_color(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
color = _parse_color(d.pop("color", UNSET))
def _parse_icon(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
icon = _parse_icon(d.pop("icon", UNSET))
def _parse_tag(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
tag = _parse_tag(d.pop("tag", UNSET))
def _parse_leader_id(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
leader_id = _parse_leader_id(d.pop("leaderID", UNSET))
def _parse_description(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
description = _parse_description(d.pop("description", UNSET))
def _parse_bio(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
bio = _parse_bio(d.pop("bio", UNSET))
rich_bio_timeset = d.pop("richBioTimeset", UNSET)
players_count = d.pop("playersCount", UNSET)
pp = d.pop("pp", UNSET)
rank = d.pop("rank", UNSET)
average_rank = d.pop("averageRank", UNSET)
average_accuracy = d.pop("averageAccuracy", UNSET)
def _parse_featured_playlists(data: object) -> Union[List["FeaturedPlaylist"], None, Unset]:
if data is None:
return data
if isinstance(data, Unset):
return data
try:
if not isinstance(data, list):
raise TypeError()
featured_playlists_type_0 = []
_featured_playlists_type_0 = data
for featured_playlists_type_0_item_data in _featured_playlists_type_0:
featured_playlists_type_0_item = FeaturedPlaylist.from_dict(featured_playlists_type_0_item_data)
featured_playlists_type_0.append(featured_playlists_type_0_item)
return featured_playlists_type_0
except: # noqa: E722
pass
return cast(Union[List["FeaturedPlaylist"], None, Unset], data)
featured_playlists = _parse_featured_playlists(d.pop("featuredPlaylists", UNSET))
ranked_pool_percent_captured = d.pop("rankedPoolPercentCaptured", UNSET)
capture_leaderboards_count = d.pop("captureLeaderboardsCount", UNSET)
def _parse_captured_leaderboards(data: object) -> Union[List["Leaderboard"], None, Unset]:
if data is None:
return data
if isinstance(data, Unset):
return data
try:
if not isinstance(data, list):
raise TypeError()
captured_leaderboards_type_0 = []
_captured_leaderboards_type_0 = data
for captured_leaderboards_type_0_item_data in _captured_leaderboards_type_0:
captured_leaderboards_type_0_item = Leaderboard.from_dict(captured_leaderboards_type_0_item_data)
captured_leaderboards_type_0.append(captured_leaderboards_type_0_item)
return captured_leaderboards_type_0
except: # noqa: E722
pass
return cast(Union[List["Leaderboard"], None, Unset], data)
captured_leaderboards = _parse_captured_leaderboards(d.pop("capturedLeaderboards", UNSET))
global_map_x = d.pop("globalMapX", UNSET)
global_map_y = d.pop("globalMapY", UNSET)
clan = cls(
id=id,
name=name,
color=color,
icon=icon,
tag=tag,
leader_id=leader_id,
description=description,
bio=bio,
rich_bio_timeset=rich_bio_timeset,
players_count=players_count,
pp=pp,
rank=rank,
average_rank=average_rank,
average_accuracy=average_accuracy,
featured_playlists=featured_playlists,
ranked_pool_percent_captured=ranked_pool_percent_captured,
capture_leaderboards_count=capture_leaderboards_count,
captured_leaderboards=captured_leaderboards,
global_map_x=global_map_x,
global_map_y=global_map_y,
)
return clan

View File

@ -0,0 +1,145 @@
from typing import Any, Dict, Type, TypeVar, Union, cast
from attrs import define as _attrs_define
from ..types import UNSET, Unset
T = TypeVar("T", bound="ClanBiggerResponse")
@_attrs_define
class ClanBiggerResponse:
"""
Attributes:
id (Union[Unset, int]):
tag (Union[None, Unset, str]):
color (Union[None, Unset, str]):
name (Union[None, Unset, str]):
icon (Union[None, Unset, str]):
ranked_pool_percent_captured (Union[Unset, float]):
players_count (Union[Unset, int]):
joined (Union[Unset, bool]):
"""
id: Union[Unset, int] = UNSET
tag: Union[None, Unset, str] = UNSET
color: Union[None, Unset, str] = UNSET
name: Union[None, Unset, str] = UNSET
icon: Union[None, Unset, str] = UNSET
ranked_pool_percent_captured: Union[Unset, float] = UNSET
players_count: Union[Unset, int] = UNSET
joined: Union[Unset, bool] = UNSET
def to_dict(self) -> Dict[str, Any]:
id = self.id
tag: Union[None, Unset, str]
if isinstance(self.tag, Unset):
tag = UNSET
else:
tag = self.tag
color: Union[None, Unset, str]
if isinstance(self.color, Unset):
color = UNSET
else:
color = self.color
name: Union[None, Unset, str]
if isinstance(self.name, Unset):
name = UNSET
else:
name = self.name
icon: Union[None, Unset, str]
if isinstance(self.icon, Unset):
icon = UNSET
else:
icon = self.icon
ranked_pool_percent_captured = self.ranked_pool_percent_captured
players_count = self.players_count
joined = self.joined
field_dict: Dict[str, Any] = {}
field_dict.update({})
if id is not UNSET:
field_dict["id"] = id
if tag is not UNSET:
field_dict["tag"] = tag
if color is not UNSET:
field_dict["color"] = color
if name is not UNSET:
field_dict["name"] = name
if icon is not UNSET:
field_dict["icon"] = icon
if ranked_pool_percent_captured is not UNSET:
field_dict["rankedPoolPercentCaptured"] = ranked_pool_percent_captured
if players_count is not UNSET:
field_dict["playersCount"] = players_count
if joined is not UNSET:
field_dict["joined"] = joined
return field_dict
@classmethod
def from_dict(cls: Type[T], src_dict: Dict[str, Any]) -> T:
d = src_dict.copy()
id = d.pop("id", UNSET)
def _parse_tag(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
tag = _parse_tag(d.pop("tag", UNSET))
def _parse_color(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
color = _parse_color(d.pop("color", UNSET))
def _parse_name(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
name = _parse_name(d.pop("name", UNSET))
def _parse_icon(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
icon = _parse_icon(d.pop("icon", UNSET))
ranked_pool_percent_captured = d.pop("rankedPoolPercentCaptured", UNSET)
players_count = d.pop("playersCount", UNSET)
joined = d.pop("joined", UNSET)
clan_bigger_response = cls(
id=id,
tag=tag,
color=color,
name=name,
icon=icon,
ranked_pool_percent_captured=ranked_pool_percent_captured,
players_count=players_count,
joined=joined,
)
return clan_bigger_response

View File

@ -0,0 +1,116 @@
from typing import TYPE_CHECKING, Any, Dict, List, Type, TypeVar, Union, cast
from attrs import define as _attrs_define
from ..types import UNSET, Unset
if TYPE_CHECKING:
from ..models.clan_global_map_point import ClanGlobalMapPoint
from ..models.clan_point import ClanPoint
T = TypeVar("T", bound="ClanGlobalMap")
@_attrs_define
class ClanGlobalMap:
"""
Attributes:
points (Union[List['ClanGlobalMapPoint'], None, Unset]):
clans (Union[List['ClanPoint'], None, Unset]):
"""
points: Union[List["ClanGlobalMapPoint"], None, Unset] = UNSET
clans: Union[List["ClanPoint"], None, Unset] = UNSET
def to_dict(self) -> Dict[str, Any]:
points: Union[List[Dict[str, Any]], None, Unset]
if isinstance(self.points, Unset):
points = UNSET
elif isinstance(self.points, list):
points = []
for points_type_0_item_data in self.points:
points_type_0_item = points_type_0_item_data.to_dict()
points.append(points_type_0_item)
else:
points = self.points
clans: Union[List[Dict[str, Any]], None, Unset]
if isinstance(self.clans, Unset):
clans = UNSET
elif isinstance(self.clans, list):
clans = []
for clans_type_0_item_data in self.clans:
clans_type_0_item = clans_type_0_item_data.to_dict()
clans.append(clans_type_0_item)
else:
clans = self.clans
field_dict: Dict[str, Any] = {}
field_dict.update({})
if points is not UNSET:
field_dict["points"] = points
if clans is not UNSET:
field_dict["clans"] = clans
return field_dict
@classmethod
def from_dict(cls: Type[T], src_dict: Dict[str, Any]) -> T:
from ..models.clan_global_map_point import ClanGlobalMapPoint
from ..models.clan_point import ClanPoint
d = src_dict.copy()
def _parse_points(data: object) -> Union[List["ClanGlobalMapPoint"], None, Unset]:
if data is None:
return data
if isinstance(data, Unset):
return data
try:
if not isinstance(data, list):
raise TypeError()
points_type_0 = []
_points_type_0 = data
for points_type_0_item_data in _points_type_0:
points_type_0_item = ClanGlobalMapPoint.from_dict(points_type_0_item_data)
points_type_0.append(points_type_0_item)
return points_type_0
except: # noqa: E722
pass
return cast(Union[List["ClanGlobalMapPoint"], None, Unset], data)
points = _parse_points(d.pop("points", UNSET))
def _parse_clans(data: object) -> Union[List["ClanPoint"], None, Unset]:
if data is None:
return data
if isinstance(data, Unset):
return data
try:
if not isinstance(data, list):
raise TypeError()
clans_type_0 = []
_clans_type_0 = data
for clans_type_0_item_data in _clans_type_0:
clans_type_0_item = ClanPoint.from_dict(clans_type_0_item_data)
clans_type_0.append(clans_type_0_item)
return clans_type_0
except: # noqa: E722
pass
return cast(Union[List["ClanPoint"], None, Unset], data)
clans = _parse_clans(d.pop("clans", UNSET))
clan_global_map = cls(
points=points,
clans=clans,
)
return clan_global_map

View File

@ -0,0 +1,144 @@
from typing import TYPE_CHECKING, Any, Dict, List, Type, TypeVar, Union, cast
from attrs import define as _attrs_define
from ..types import UNSET, Unset
if TYPE_CHECKING:
from ..models.clan_map_connection import ClanMapConnection
T = TypeVar("T", bound="ClanGlobalMapPoint")
@_attrs_define
class ClanGlobalMapPoint:
"""
Attributes:
leaderboard_id (Union[None, Unset, str]):
cover_image (Union[None, Unset, str]):
stars (Union[None, Unset, float]):
tie (Union[Unset, bool]):
clans (Union[List['ClanMapConnection'], None, Unset]):
"""
leaderboard_id: Union[None, Unset, str] = UNSET
cover_image: Union[None, Unset, str] = UNSET
stars: Union[None, Unset, float] = UNSET
tie: Union[Unset, bool] = UNSET
clans: Union[List["ClanMapConnection"], None, Unset] = UNSET
def to_dict(self) -> Dict[str, Any]:
leaderboard_id: Union[None, Unset, str]
if isinstance(self.leaderboard_id, Unset):
leaderboard_id = UNSET
else:
leaderboard_id = self.leaderboard_id
cover_image: Union[None, Unset, str]
if isinstance(self.cover_image, Unset):
cover_image = UNSET
else:
cover_image = self.cover_image
stars: Union[None, Unset, float]
if isinstance(self.stars, Unset):
stars = UNSET
else:
stars = self.stars
tie = self.tie
clans: Union[List[Dict[str, Any]], None, Unset]
if isinstance(self.clans, Unset):
clans = UNSET
elif isinstance(self.clans, list):
clans = []
for clans_type_0_item_data in self.clans:
clans_type_0_item = clans_type_0_item_data.to_dict()
clans.append(clans_type_0_item)
else:
clans = self.clans
field_dict: Dict[str, Any] = {}
field_dict.update({})
if leaderboard_id is not UNSET:
field_dict["leaderboardId"] = leaderboard_id
if cover_image is not UNSET:
field_dict["coverImage"] = cover_image
if stars is not UNSET:
field_dict["stars"] = stars
if tie is not UNSET:
field_dict["tie"] = tie
if clans is not UNSET:
field_dict["clans"] = clans
return field_dict
@classmethod
def from_dict(cls: Type[T], src_dict: Dict[str, Any]) -> T:
from ..models.clan_map_connection import ClanMapConnection
d = src_dict.copy()
def _parse_leaderboard_id(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
leaderboard_id = _parse_leaderboard_id(d.pop("leaderboardId", UNSET))
def _parse_cover_image(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
cover_image = _parse_cover_image(d.pop("coverImage", UNSET))
def _parse_stars(data: object) -> Union[None, Unset, float]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, float], data)
stars = _parse_stars(d.pop("stars", UNSET))
tie = d.pop("tie", UNSET)
def _parse_clans(data: object) -> Union[List["ClanMapConnection"], None, Unset]:
if data is None:
return data
if isinstance(data, Unset):
return data
try:
if not isinstance(data, list):
raise TypeError()
clans_type_0 = []
_clans_type_0 = data
for clans_type_0_item_data in _clans_type_0:
clans_type_0_item = ClanMapConnection.from_dict(clans_type_0_item_data)
clans_type_0.append(clans_type_0_item)
return clans_type_0
except: # noqa: E722
pass
return cast(Union[List["ClanMapConnection"], None, Unset], data)
clans = _parse_clans(d.pop("clans", UNSET))
clan_global_map_point = cls(
leaderboard_id=leaderboard_id,
cover_image=cover_image,
stars=stars,
tie=tie,
clans=clans,
)
return clan_global_map_point

View File

@ -0,0 +1,59 @@
from typing import Any, Dict, Type, TypeVar, Union, cast
from attrs import define as _attrs_define
from ..types import UNSET, Unset
T = TypeVar("T", bound="ClanMapConnection")
@_attrs_define
class ClanMapConnection:
"""
Attributes:
id (Union[None, Unset, int]):
pp (Union[Unset, float]):
"""
id: Union[None, Unset, int] = UNSET
pp: Union[Unset, float] = UNSET
def to_dict(self) -> Dict[str, Any]:
id: Union[None, Unset, int]
if isinstance(self.id, Unset):
id = UNSET
else:
id = self.id
pp = self.pp
field_dict: Dict[str, Any] = {}
field_dict.update({})
if id is not UNSET:
field_dict["id"] = id
if pp is not UNSET:
field_dict["pp"] = pp
return field_dict
@classmethod
def from_dict(cls: Type[T], src_dict: Dict[str, Any]) -> T:
d = src_dict.copy()
def _parse_id(data: object) -> Union[None, Unset, int]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, int], data)
id = _parse_id(d.pop("id", UNSET))
pp = d.pop("pp", UNSET)
clan_map_connection = cls(
id=id,
pp=pp,
)
return clan_map_connection

View File

@ -0,0 +1,13 @@
from enum import Enum
class ClanMapsSortBy(str, Enum):
ACC = "acc"
DATE = "date"
PP = "pp"
RANK = "rank"
TOCONQUER = "toconquer"
TOHOLD = "tohold"
def __str__(self) -> str:
return str(self.value)

View File

@ -0,0 +1,96 @@
from typing import Any, Dict, Type, TypeVar, Union, cast
from attrs import define as _attrs_define
from ..types import UNSET, Unset
T = TypeVar("T", bound="ClanPoint")
@_attrs_define
class ClanPoint:
"""
Attributes:
id (Union[Unset, int]):
tag (Union[None, Unset, str]):
color (Union[None, Unset, str]):
x (Union[Unset, float]):
y (Union[Unset, float]):
"""
id: Union[Unset, int] = UNSET
tag: Union[None, Unset, str] = UNSET
color: Union[None, Unset, str] = UNSET
x: Union[Unset, float] = UNSET
y: Union[Unset, float] = UNSET
def to_dict(self) -> Dict[str, Any]:
id = self.id
tag: Union[None, Unset, str]
if isinstance(self.tag, Unset):
tag = UNSET
else:
tag = self.tag
color: Union[None, Unset, str]
if isinstance(self.color, Unset):
color = UNSET
else:
color = self.color
x = self.x
y = self.y
field_dict: Dict[str, Any] = {}
field_dict.update({})
if id is not UNSET:
field_dict["id"] = id
if tag is not UNSET:
field_dict["tag"] = tag
if color is not UNSET:
field_dict["color"] = color
if x is not UNSET:
field_dict["x"] = x
if y is not UNSET:
field_dict["y"] = y
return field_dict
@classmethod
def from_dict(cls: Type[T], src_dict: Dict[str, Any]) -> T:
d = src_dict.copy()
id = d.pop("id", UNSET)
def _parse_tag(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
tag = _parse_tag(d.pop("tag", UNSET))
def _parse_color(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
color = _parse_color(d.pop("color", UNSET))
x = d.pop("x", UNSET)
y = d.pop("y", UNSET)
clan_point = cls(
id=id,
tag=tag,
color=color,
x=x,
y=y,
)
return clan_point

View File

@ -0,0 +1,220 @@
from typing import TYPE_CHECKING, Any, Dict, List, Type, TypeVar, Union, cast
from attrs import define as _attrs_define
from ..types import UNSET, Unset
if TYPE_CHECKING:
from ..models.clan_response_full import ClanResponseFull
from ..models.leaderboard_response import LeaderboardResponse
from ..models.score_response import ScoreResponse
from ..models.score_response_with_acc import ScoreResponseWithAcc
T = TypeVar("T", bound="ClanRankingResponse")
@_attrs_define
class ClanRankingResponse:
"""
Attributes:
id (Union[Unset, int]):
clan (Union[Unset, ClanResponseFull]):
last_update_time (Union[Unset, int]):
average_rank (Union[Unset, float]):
rank (Union[Unset, int]):
pp (Union[Unset, float]):
average_accuracy (Union[Unset, float]):
total_score (Union[Unset, float]):
leaderboard_id (Union[None, Unset, str]):
leaderboard (Union[Unset, LeaderboardResponse]):
associated_scores (Union[List['ScoreResponse'], None, Unset]):
associated_scores_count (Union[Unset, int]):
my_score (Union[Unset, ScoreResponseWithAcc]):
"""
id: Union[Unset, int] = UNSET
clan: Union[Unset, "ClanResponseFull"] = UNSET
last_update_time: Union[Unset, int] = UNSET
average_rank: Union[Unset, float] = UNSET
rank: Union[Unset, int] = UNSET
pp: Union[Unset, float] = UNSET
average_accuracy: Union[Unset, float] = UNSET
total_score: Union[Unset, float] = UNSET
leaderboard_id: Union[None, Unset, str] = UNSET
leaderboard: Union[Unset, "LeaderboardResponse"] = UNSET
associated_scores: Union[List["ScoreResponse"], None, Unset] = UNSET
associated_scores_count: Union[Unset, int] = UNSET
my_score: Union[Unset, "ScoreResponseWithAcc"] = UNSET
def to_dict(self) -> Dict[str, Any]:
id = self.id
clan: Union[Unset, Dict[str, Any]] = UNSET
if not isinstance(self.clan, Unset):
clan = self.clan.to_dict()
last_update_time = self.last_update_time
average_rank = self.average_rank
rank = self.rank
pp = self.pp
average_accuracy = self.average_accuracy
total_score = self.total_score
leaderboard_id: Union[None, Unset, str]
if isinstance(self.leaderboard_id, Unset):
leaderboard_id = UNSET
else:
leaderboard_id = self.leaderboard_id
leaderboard: Union[Unset, Dict[str, Any]] = UNSET
if not isinstance(self.leaderboard, Unset):
leaderboard = self.leaderboard.to_dict()
associated_scores: Union[List[Dict[str, Any]], None, Unset]
if isinstance(self.associated_scores, Unset):
associated_scores = UNSET
elif isinstance(self.associated_scores, list):
associated_scores = []
for associated_scores_type_0_item_data in self.associated_scores:
associated_scores_type_0_item = associated_scores_type_0_item_data.to_dict()
associated_scores.append(associated_scores_type_0_item)
else:
associated_scores = self.associated_scores
associated_scores_count = self.associated_scores_count
my_score: Union[Unset, Dict[str, Any]] = UNSET
if not isinstance(self.my_score, Unset):
my_score = self.my_score.to_dict()
field_dict: Dict[str, Any] = {}
field_dict.update({})
if id is not UNSET:
field_dict["id"] = id
if clan is not UNSET:
field_dict["clan"] = clan
if last_update_time is not UNSET:
field_dict["lastUpdateTime"] = last_update_time
if average_rank is not UNSET:
field_dict["averageRank"] = average_rank
if rank is not UNSET:
field_dict["rank"] = rank
if pp is not UNSET:
field_dict["pp"] = pp
if average_accuracy is not UNSET:
field_dict["averageAccuracy"] = average_accuracy
if total_score is not UNSET:
field_dict["totalScore"] = total_score
if leaderboard_id is not UNSET:
field_dict["leaderboardId"] = leaderboard_id
if leaderboard is not UNSET:
field_dict["leaderboard"] = leaderboard
if associated_scores is not UNSET:
field_dict["associatedScores"] = associated_scores
if associated_scores_count is not UNSET:
field_dict["associatedScoresCount"] = associated_scores_count
if my_score is not UNSET:
field_dict["myScore"] = my_score
return field_dict
@classmethod
def from_dict(cls: Type[T], src_dict: Dict[str, Any]) -> T:
from ..models.clan_response_full import ClanResponseFull
from ..models.leaderboard_response import LeaderboardResponse
from ..models.score_response import ScoreResponse
from ..models.score_response_with_acc import ScoreResponseWithAcc
d = src_dict.copy()
id = d.pop("id", UNSET)
_clan = d.pop("clan", UNSET)
clan: Union[Unset, ClanResponseFull]
if isinstance(_clan, Unset):
clan = UNSET
else:
clan = ClanResponseFull.from_dict(_clan)
last_update_time = d.pop("lastUpdateTime", UNSET)
average_rank = d.pop("averageRank", UNSET)
rank = d.pop("rank", UNSET)
pp = d.pop("pp", UNSET)
average_accuracy = d.pop("averageAccuracy", UNSET)
total_score = d.pop("totalScore", UNSET)
def _parse_leaderboard_id(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
leaderboard_id = _parse_leaderboard_id(d.pop("leaderboardId", UNSET))
_leaderboard = d.pop("leaderboard", UNSET)
leaderboard: Union[Unset, LeaderboardResponse]
if isinstance(_leaderboard, Unset):
leaderboard = UNSET
else:
leaderboard = LeaderboardResponse.from_dict(_leaderboard)
def _parse_associated_scores(data: object) -> Union[List["ScoreResponse"], None, Unset]:
if data is None:
return data
if isinstance(data, Unset):
return data
try:
if not isinstance(data, list):
raise TypeError()
associated_scores_type_0 = []
_associated_scores_type_0 = data
for associated_scores_type_0_item_data in _associated_scores_type_0:
associated_scores_type_0_item = ScoreResponse.from_dict(associated_scores_type_0_item_data)
associated_scores_type_0.append(associated_scores_type_0_item)
return associated_scores_type_0
except: # noqa: E722
pass
return cast(Union[List["ScoreResponse"], None, Unset], data)
associated_scores = _parse_associated_scores(d.pop("associatedScores", UNSET))
associated_scores_count = d.pop("associatedScoresCount", UNSET)
_my_score = d.pop("myScore", UNSET)
my_score: Union[Unset, ScoreResponseWithAcc]
if isinstance(_my_score, Unset):
my_score = UNSET
else:
my_score = ScoreResponseWithAcc.from_dict(_my_score)
clan_ranking_response = cls(
id=id,
clan=clan,
last_update_time=last_update_time,
average_rank=average_rank,
rank=rank,
pp=pp,
average_accuracy=average_accuracy,
total_score=total_score,
leaderboard_id=leaderboard_id,
leaderboard=leaderboard,
associated_scores=associated_scores,
associated_scores_count=associated_scores_count,
my_score=my_score,
)
return clan_ranking_response

View File

@ -0,0 +1,110 @@
from typing import TYPE_CHECKING, Any, Dict, List, Type, TypeVar, Union, cast
from attrs import define as _attrs_define
from ..types import UNSET, Unset
if TYPE_CHECKING:
from ..models.clan_ranking_response import ClanRankingResponse
from ..models.clan_response_full import ClanResponseFull
from ..models.metadata import Metadata
T = TypeVar("T", bound="ClanRankingResponseClanResponseFullResponseWithMetadataAndContainer")
@_attrs_define
class ClanRankingResponseClanResponseFullResponseWithMetadataAndContainer:
"""
Attributes:
metadata (Union[Unset, Metadata]):
data (Union[List['ClanRankingResponse'], None, Unset]):
container (Union[Unset, ClanResponseFull]):
"""
metadata: Union[Unset, "Metadata"] = UNSET
data: Union[List["ClanRankingResponse"], None, Unset] = UNSET
container: Union[Unset, "ClanResponseFull"] = UNSET
def to_dict(self) -> Dict[str, Any]:
metadata: Union[Unset, Dict[str, Any]] = UNSET
if not isinstance(self.metadata, Unset):
metadata = self.metadata.to_dict()
data: Union[List[Dict[str, Any]], None, Unset]
if isinstance(self.data, Unset):
data = UNSET
elif isinstance(self.data, list):
data = []
for data_type_0_item_data in self.data:
data_type_0_item = data_type_0_item_data.to_dict()
data.append(data_type_0_item)
else:
data = self.data
container: Union[Unset, Dict[str, Any]] = UNSET
if not isinstance(self.container, Unset):
container = self.container.to_dict()
field_dict: Dict[str, Any] = {}
field_dict.update({})
if metadata is not UNSET:
field_dict["metadata"] = metadata
if data is not UNSET:
field_dict["data"] = data
if container is not UNSET:
field_dict["container"] = container
return field_dict
@classmethod
def from_dict(cls: Type[T], src_dict: Dict[str, Any]) -> T:
from ..models.clan_ranking_response import ClanRankingResponse
from ..models.clan_response_full import ClanResponseFull
from ..models.metadata import Metadata
d = src_dict.copy()
_metadata = d.pop("metadata", UNSET)
metadata: Union[Unset, Metadata]
if isinstance(_metadata, Unset):
metadata = UNSET
else:
metadata = Metadata.from_dict(_metadata)
def _parse_data(data: object) -> Union[List["ClanRankingResponse"], None, Unset]:
if data is None:
return data
if isinstance(data, Unset):
return data
try:
if not isinstance(data, list):
raise TypeError()
data_type_0 = []
_data_type_0 = data
for data_type_0_item_data in _data_type_0:
data_type_0_item = ClanRankingResponse.from_dict(data_type_0_item_data)
data_type_0.append(data_type_0_item)
return data_type_0
except: # noqa: E722
pass
return cast(Union[List["ClanRankingResponse"], None, Unset], data)
data = _parse_data(d.pop("data", UNSET))
_container = d.pop("container", UNSET)
container: Union[Unset, ClanResponseFull]
if isinstance(_container, Unset):
container = UNSET
else:
container = ClanResponseFull.from_dict(_container)
clan_ranking_response_clan_response_full_response_with_metadata_and_container = cls(
metadata=metadata,
data=data,
container=container,
)
return clan_ranking_response_clan_response_full_response_with_metadata_and_container

View File

@ -0,0 +1,98 @@
from typing import Any, Dict, Type, TypeVar, Union, cast
from attrs import define as _attrs_define
from ..types import UNSET, Unset
T = TypeVar("T", bound="ClanResponse")
@_attrs_define
class ClanResponse:
"""
Attributes:
id (Union[Unset, int]):
tag (Union[None, Unset, str]):
color (Union[None, Unset, str]):
name (Union[None, Unset, str]):
"""
id: Union[Unset, int] = UNSET
tag: Union[None, Unset, str] = UNSET
color: Union[None, Unset, str] = UNSET
name: Union[None, Unset, str] = UNSET
def to_dict(self) -> Dict[str, Any]:
id = self.id
tag: Union[None, Unset, str]
if isinstance(self.tag, Unset):
tag = UNSET
else:
tag = self.tag
color: Union[None, Unset, str]
if isinstance(self.color, Unset):
color = UNSET
else:
color = self.color
name: Union[None, Unset, str]
if isinstance(self.name, Unset):
name = UNSET
else:
name = self.name
field_dict: Dict[str, Any] = {}
field_dict.update({})
if id is not UNSET:
field_dict["id"] = id
if tag is not UNSET:
field_dict["tag"] = tag
if color is not UNSET:
field_dict["color"] = color
if name is not UNSET:
field_dict["name"] = name
return field_dict
@classmethod
def from_dict(cls: Type[T], src_dict: Dict[str, Any]) -> T:
d = src_dict.copy()
id = d.pop("id", UNSET)
def _parse_tag(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
tag = _parse_tag(d.pop("tag", UNSET))
def _parse_color(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
color = _parse_color(d.pop("color", UNSET))
def _parse_name(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
name = _parse_name(d.pop("name", UNSET))
clan_response = cls(
id=id,
tag=tag,
color=color,
name=name,
)
return clan_response

View File

@ -0,0 +1,357 @@
from typing import TYPE_CHECKING, Any, Dict, List, Type, TypeVar, Union, cast
from attrs import define as _attrs_define
from ..types import UNSET, Unset
if TYPE_CHECKING:
from ..models.featured_playlist_response import FeaturedPlaylistResponse
T = TypeVar("T", bound="ClanResponseFull")
@_attrs_define
class ClanResponseFull:
"""
Attributes:
id (Union[Unset, int]):
name (Union[None, Unset, str]):
color (Union[None, Unset, str]):
icon (Union[None, Unset, str]):
tag (Union[None, Unset, str]):
leader_id (Union[None, Unset, str]):
description (Union[None, Unset, str]):
bio (Union[None, Unset, str]):
rich_bio_timeset (Union[Unset, int]):
discord_invite (Union[None, Unset, str]):
players_count (Union[Unset, int]):
pp (Union[Unset, float]):
rank (Union[Unset, int]):
average_rank (Union[Unset, float]):
average_accuracy (Union[Unset, float]):
ranked_pool_percent_captured (Union[Unset, float]):
capture_leaderboards_count (Union[Unset, int]):
player_changes_callback (Union[None, Unset, str]):
clan_ranking_discord_hook (Union[None, Unset, str]):
featured_playlists (Union[List['FeaturedPlaylistResponse'], None, Unset]):
"""
id: Union[Unset, int] = UNSET
name: Union[None, Unset, str] = UNSET
color: Union[None, Unset, str] = UNSET
icon: Union[None, Unset, str] = UNSET
tag: Union[None, Unset, str] = UNSET
leader_id: Union[None, Unset, str] = UNSET
description: Union[None, Unset, str] = UNSET
bio: Union[None, Unset, str] = UNSET
rich_bio_timeset: Union[Unset, int] = UNSET
discord_invite: Union[None, Unset, str] = UNSET
players_count: Union[Unset, int] = UNSET
pp: Union[Unset, float] = UNSET
rank: Union[Unset, int] = UNSET
average_rank: Union[Unset, float] = UNSET
average_accuracy: Union[Unset, float] = UNSET
ranked_pool_percent_captured: Union[Unset, float] = UNSET
capture_leaderboards_count: Union[Unset, int] = UNSET
player_changes_callback: Union[None, Unset, str] = UNSET
clan_ranking_discord_hook: Union[None, Unset, str] = UNSET
featured_playlists: Union[List["FeaturedPlaylistResponse"], None, Unset] = UNSET
def to_dict(self) -> Dict[str, Any]:
id = self.id
name: Union[None, Unset, str]
if isinstance(self.name, Unset):
name = UNSET
else:
name = self.name
color: Union[None, Unset, str]
if isinstance(self.color, Unset):
color = UNSET
else:
color = self.color
icon: Union[None, Unset, str]
if isinstance(self.icon, Unset):
icon = UNSET
else:
icon = self.icon
tag: Union[None, Unset, str]
if isinstance(self.tag, Unset):
tag = UNSET
else:
tag = self.tag
leader_id: Union[None, Unset, str]
if isinstance(self.leader_id, Unset):
leader_id = UNSET
else:
leader_id = self.leader_id
description: Union[None, Unset, str]
if isinstance(self.description, Unset):
description = UNSET
else:
description = self.description
bio: Union[None, Unset, str]
if isinstance(self.bio, Unset):
bio = UNSET
else:
bio = self.bio
rich_bio_timeset = self.rich_bio_timeset
discord_invite: Union[None, Unset, str]
if isinstance(self.discord_invite, Unset):
discord_invite = UNSET
else:
discord_invite = self.discord_invite
players_count = self.players_count
pp = self.pp
rank = self.rank
average_rank = self.average_rank
average_accuracy = self.average_accuracy
ranked_pool_percent_captured = self.ranked_pool_percent_captured
capture_leaderboards_count = self.capture_leaderboards_count
player_changes_callback: Union[None, Unset, str]
if isinstance(self.player_changes_callback, Unset):
player_changes_callback = UNSET
else:
player_changes_callback = self.player_changes_callback
clan_ranking_discord_hook: Union[None, Unset, str]
if isinstance(self.clan_ranking_discord_hook, Unset):
clan_ranking_discord_hook = UNSET
else:
clan_ranking_discord_hook = self.clan_ranking_discord_hook
featured_playlists: Union[List[Dict[str, Any]], None, Unset]
if isinstance(self.featured_playlists, Unset):
featured_playlists = UNSET
elif isinstance(self.featured_playlists, list):
featured_playlists = []
for featured_playlists_type_0_item_data in self.featured_playlists:
featured_playlists_type_0_item = featured_playlists_type_0_item_data.to_dict()
featured_playlists.append(featured_playlists_type_0_item)
else:
featured_playlists = self.featured_playlists
field_dict: Dict[str, Any] = {}
field_dict.update({})
if id is not UNSET:
field_dict["id"] = id
if name is not UNSET:
field_dict["name"] = name
if color is not UNSET:
field_dict["color"] = color
if icon is not UNSET:
field_dict["icon"] = icon
if tag is not UNSET:
field_dict["tag"] = tag
if leader_id is not UNSET:
field_dict["leaderID"] = leader_id
if description is not UNSET:
field_dict["description"] = description
if bio is not UNSET:
field_dict["bio"] = bio
if rich_bio_timeset is not UNSET:
field_dict["richBioTimeset"] = rich_bio_timeset
if discord_invite is not UNSET:
field_dict["discordInvite"] = discord_invite
if players_count is not UNSET:
field_dict["playersCount"] = players_count
if pp is not UNSET:
field_dict["pp"] = pp
if rank is not UNSET:
field_dict["rank"] = rank
if average_rank is not UNSET:
field_dict["averageRank"] = average_rank
if average_accuracy is not UNSET:
field_dict["averageAccuracy"] = average_accuracy
if ranked_pool_percent_captured is not UNSET:
field_dict["rankedPoolPercentCaptured"] = ranked_pool_percent_captured
if capture_leaderboards_count is not UNSET:
field_dict["captureLeaderboardsCount"] = capture_leaderboards_count
if player_changes_callback is not UNSET:
field_dict["playerChangesCallback"] = player_changes_callback
if clan_ranking_discord_hook is not UNSET:
field_dict["clanRankingDiscordHook"] = clan_ranking_discord_hook
if featured_playlists is not UNSET:
field_dict["featuredPlaylists"] = featured_playlists
return field_dict
@classmethod
def from_dict(cls: Type[T], src_dict: Dict[str, Any]) -> T:
from ..models.featured_playlist_response import FeaturedPlaylistResponse
d = src_dict.copy()
id = d.pop("id", UNSET)
def _parse_name(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
name = _parse_name(d.pop("name", UNSET))
def _parse_color(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
color = _parse_color(d.pop("color", UNSET))
def _parse_icon(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
icon = _parse_icon(d.pop("icon", UNSET))
def _parse_tag(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
tag = _parse_tag(d.pop("tag", UNSET))
def _parse_leader_id(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
leader_id = _parse_leader_id(d.pop("leaderID", UNSET))
def _parse_description(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
description = _parse_description(d.pop("description", UNSET))
def _parse_bio(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
bio = _parse_bio(d.pop("bio", UNSET))
rich_bio_timeset = d.pop("richBioTimeset", UNSET)
def _parse_discord_invite(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
discord_invite = _parse_discord_invite(d.pop("discordInvite", UNSET))
players_count = d.pop("playersCount", UNSET)
pp = d.pop("pp", UNSET)
rank = d.pop("rank", UNSET)
average_rank = d.pop("averageRank", UNSET)
average_accuracy = d.pop("averageAccuracy", UNSET)
ranked_pool_percent_captured = d.pop("rankedPoolPercentCaptured", UNSET)
capture_leaderboards_count = d.pop("captureLeaderboardsCount", UNSET)
def _parse_player_changes_callback(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
player_changes_callback = _parse_player_changes_callback(d.pop("playerChangesCallback", UNSET))
def _parse_clan_ranking_discord_hook(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
clan_ranking_discord_hook = _parse_clan_ranking_discord_hook(d.pop("clanRankingDiscordHook", UNSET))
def _parse_featured_playlists(data: object) -> Union[List["FeaturedPlaylistResponse"], None, Unset]:
if data is None:
return data
if isinstance(data, Unset):
return data
try:
if not isinstance(data, list):
raise TypeError()
featured_playlists_type_0 = []
_featured_playlists_type_0 = data
for featured_playlists_type_0_item_data in _featured_playlists_type_0:
featured_playlists_type_0_item = FeaturedPlaylistResponse.from_dict(
featured_playlists_type_0_item_data
)
featured_playlists_type_0.append(featured_playlists_type_0_item)
return featured_playlists_type_0
except: # noqa: E722
pass
return cast(Union[List["FeaturedPlaylistResponse"], None, Unset], data)
featured_playlists = _parse_featured_playlists(d.pop("featuredPlaylists", UNSET))
clan_response_full = cls(
id=id,
name=name,
color=color,
icon=icon,
tag=tag,
leader_id=leader_id,
description=description,
bio=bio,
rich_bio_timeset=rich_bio_timeset,
discord_invite=discord_invite,
players_count=players_count,
pp=pp,
rank=rank,
average_rank=average_rank,
average_accuracy=average_accuracy,
ranked_pool_percent_captured=ranked_pool_percent_captured,
capture_leaderboards_count=capture_leaderboards_count,
player_changes_callback=player_changes_callback,
clan_ranking_discord_hook=clan_ranking_discord_hook,
featured_playlists=featured_playlists,
)
return clan_response_full

View File

@ -0,0 +1,92 @@
from typing import TYPE_CHECKING, Any, Dict, List, Type, TypeVar, Union, cast
from attrs import define as _attrs_define
from ..types import UNSET, Unset
if TYPE_CHECKING:
from ..models.clan_response_full import ClanResponseFull
from ..models.metadata import Metadata
T = TypeVar("T", bound="ClanResponseFullResponseWithMetadata")
@_attrs_define
class ClanResponseFullResponseWithMetadata:
"""
Attributes:
metadata (Union[Unset, Metadata]):
data (Union[List['ClanResponseFull'], None, Unset]):
"""
metadata: Union[Unset, "Metadata"] = UNSET
data: Union[List["ClanResponseFull"], None, Unset] = UNSET
def to_dict(self) -> Dict[str, Any]:
metadata: Union[Unset, Dict[str, Any]] = UNSET
if not isinstance(self.metadata, Unset):
metadata = self.metadata.to_dict()
data: Union[List[Dict[str, Any]], None, Unset]
if isinstance(self.data, Unset):
data = UNSET
elif isinstance(self.data, list):
data = []
for data_type_0_item_data in self.data:
data_type_0_item = data_type_0_item_data.to_dict()
data.append(data_type_0_item)
else:
data = self.data
field_dict: Dict[str, Any] = {}
field_dict.update({})
if metadata is not UNSET:
field_dict["metadata"] = metadata
if data is not UNSET:
field_dict["data"] = data
return field_dict
@classmethod
def from_dict(cls: Type[T], src_dict: Dict[str, Any]) -> T:
from ..models.clan_response_full import ClanResponseFull
from ..models.metadata import Metadata
d = src_dict.copy()
_metadata = d.pop("metadata", UNSET)
metadata: Union[Unset, Metadata]
if isinstance(_metadata, Unset):
metadata = UNSET
else:
metadata = Metadata.from_dict(_metadata)
def _parse_data(data: object) -> Union[List["ClanResponseFull"], None, Unset]:
if data is None:
return data
if isinstance(data, Unset):
return data
try:
if not isinstance(data, list):
raise TypeError()
data_type_0 = []
_data_type_0 = data
for data_type_0_item_data in _data_type_0:
data_type_0_item = ClanResponseFull.from_dict(data_type_0_item_data)
data_type_0.append(data_type_0_item)
return data_type_0
except: # noqa: E722
pass
return cast(Union[List["ClanResponseFull"], None, Unset], data)
data = _parse_data(d.pop("data", UNSET))
clan_response_full_response_with_metadata = cls(
metadata=metadata,
data=data,
)
return clan_response_full_response_with_metadata

View File

@ -0,0 +1,13 @@
from enum import Enum
class ClanSortBy(str, Enum):
ACC = "acc"
CAPTURES = "captures"
COUNT = "count"
NAME = "name"
PP = "pp"
RANK = "rank"
def __str__(self) -> str:
return str(self.value)

View File

@ -0,0 +1,99 @@
from typing import Any, Dict, Type, TypeVar, Union, cast
from attrs import define as _attrs_define
from ..types import UNSET, Unset
T = TypeVar("T", bound="CompactLeaderboard")
@_attrs_define
class CompactLeaderboard:
"""
Attributes:
id (Union[None, Unset, str]):
song_hash (Union[None, Unset, str]):
mode_name (Union[None, Unset, str]):
difficulty (Union[Unset, int]):
"""
id: Union[None, Unset, str] = UNSET
song_hash: Union[None, Unset, str] = UNSET
mode_name: Union[None, Unset, str] = UNSET
difficulty: Union[Unset, int] = UNSET
def to_dict(self) -> Dict[str, Any]:
id: Union[None, Unset, str]
if isinstance(self.id, Unset):
id = UNSET
else:
id = self.id
song_hash: Union[None, Unset, str]
if isinstance(self.song_hash, Unset):
song_hash = UNSET
else:
song_hash = self.song_hash
mode_name: Union[None, Unset, str]
if isinstance(self.mode_name, Unset):
mode_name = UNSET
else:
mode_name = self.mode_name
difficulty = self.difficulty
field_dict: Dict[str, Any] = {}
field_dict.update({})
if id is not UNSET:
field_dict["id"] = id
if song_hash is not UNSET:
field_dict["songHash"] = song_hash
if mode_name is not UNSET:
field_dict["modeName"] = mode_name
if difficulty is not UNSET:
field_dict["difficulty"] = difficulty
return field_dict
@classmethod
def from_dict(cls: Type[T], src_dict: Dict[str, Any]) -> T:
d = src_dict.copy()
def _parse_id(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
id = _parse_id(d.pop("id", UNSET))
def _parse_song_hash(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
song_hash = _parse_song_hash(d.pop("songHash", UNSET))
def _parse_mode_name(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
mode_name = _parse_mode_name(d.pop("modeName", UNSET))
difficulty = d.pop("difficulty", UNSET)
compact_leaderboard = cls(
id=id,
song_hash=song_hash,
mode_name=mode_name,
difficulty=difficulty,
)
return compact_leaderboard

View File

@ -0,0 +1,90 @@
from typing import TYPE_CHECKING, Any, Dict, Type, TypeVar, Union, cast
from attrs import define as _attrs_define
from ..types import UNSET, Unset
if TYPE_CHECKING:
from ..models.compact_song_response import CompactSongResponse
from ..models.difficulty_response import DifficultyResponse
T = TypeVar("T", bound="CompactLeaderboardResponse")
@_attrs_define
class CompactLeaderboardResponse:
"""
Attributes:
id (Union[None, Unset, str]):
song (Union[Unset, CompactSongResponse]):
difficulty (Union[Unset, DifficultyResponse]):
"""
id: Union[None, Unset, str] = UNSET
song: Union[Unset, "CompactSongResponse"] = UNSET
difficulty: Union[Unset, "DifficultyResponse"] = UNSET
def to_dict(self) -> Dict[str, Any]:
id: Union[None, Unset, str]
if isinstance(self.id, Unset):
id = UNSET
else:
id = self.id
song: Union[Unset, Dict[str, Any]] = UNSET
if not isinstance(self.song, Unset):
song = self.song.to_dict()
difficulty: Union[Unset, Dict[str, Any]] = UNSET
if not isinstance(self.difficulty, Unset):
difficulty = self.difficulty.to_dict()
field_dict: Dict[str, Any] = {}
field_dict.update({})
if id is not UNSET:
field_dict["id"] = id
if song is not UNSET:
field_dict["song"] = song
if difficulty is not UNSET:
field_dict["difficulty"] = difficulty
return field_dict
@classmethod
def from_dict(cls: Type[T], src_dict: Dict[str, Any]) -> T:
from ..models.compact_song_response import CompactSongResponse
from ..models.difficulty_response import DifficultyResponse
d = src_dict.copy()
def _parse_id(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
id = _parse_id(d.pop("id", UNSET))
_song = d.pop("song", UNSET)
song: Union[Unset, CompactSongResponse]
if isinstance(_song, Unset):
song = UNSET
else:
song = CompactSongResponse.from_dict(_song)
_difficulty = d.pop("difficulty", UNSET)
difficulty: Union[Unset, DifficultyResponse]
if isinstance(_difficulty, Unset):
difficulty = UNSET
else:
difficulty = DifficultyResponse.from_dict(_difficulty)
compact_leaderboard_response = cls(
id=id,
song=song,
difficulty=difficulty,
)
return compact_leaderboard_response

View File

@ -0,0 +1,196 @@
from typing import Any, Dict, Type, TypeVar, Union, cast
from attrs import define as _attrs_define
from ..models.controller_enum import ControllerEnum
from ..models.hmd import HMD
from ..types import UNSET, Unset
T = TypeVar("T", bound="CompactScore")
@_attrs_define
class CompactScore:
"""
Attributes:
id (Union[None, Unset, int]):
base_score (Union[Unset, int]):
modified_score (Union[Unset, int]):
modifiers (Union[None, Unset, str]):
full_combo (Union[Unset, bool]):
max_combo (Union[Unset, int]):
missed_notes (Union[Unset, int]):
bad_cuts (Union[Unset, int]):
hmd (Union[Unset, HMD]):
controller (Union[Unset, ControllerEnum]):
accuracy (Union[Unset, float]):
pp (Union[None, Unset, float]):
epoch_time (Union[Unset, int]):
"""
id: Union[None, Unset, int] = UNSET
base_score: Union[Unset, int] = UNSET
modified_score: Union[Unset, int] = UNSET
modifiers: Union[None, Unset, str] = UNSET
full_combo: Union[Unset, bool] = UNSET
max_combo: Union[Unset, int] = UNSET
missed_notes: Union[Unset, int] = UNSET
bad_cuts: Union[Unset, int] = UNSET
hmd: Union[Unset, HMD] = UNSET
controller: Union[Unset, ControllerEnum] = UNSET
accuracy: Union[Unset, float] = UNSET
pp: Union[None, Unset, float] = UNSET
epoch_time: Union[Unset, int] = UNSET
def to_dict(self) -> Dict[str, Any]:
id: Union[None, Unset, int]
if isinstance(self.id, Unset):
id = UNSET
else:
id = self.id
base_score = self.base_score
modified_score = self.modified_score
modifiers: Union[None, Unset, str]
if isinstance(self.modifiers, Unset):
modifiers = UNSET
else:
modifiers = self.modifiers
full_combo = self.full_combo
max_combo = self.max_combo
missed_notes = self.missed_notes
bad_cuts = self.bad_cuts
hmd: Union[Unset, str] = UNSET
if not isinstance(self.hmd, Unset):
hmd = self.hmd.value
controller: Union[Unset, str] = UNSET
if not isinstance(self.controller, Unset):
controller = self.controller.value
accuracy = self.accuracy
pp: Union[None, Unset, float]
if isinstance(self.pp, Unset):
pp = UNSET
else:
pp = self.pp
epoch_time = self.epoch_time
field_dict: Dict[str, Any] = {}
field_dict.update({})
if id is not UNSET:
field_dict["id"] = id
if base_score is not UNSET:
field_dict["baseScore"] = base_score
if modified_score is not UNSET:
field_dict["modifiedScore"] = modified_score
if modifiers is not UNSET:
field_dict["modifiers"] = modifiers
if full_combo is not UNSET:
field_dict["fullCombo"] = full_combo
if max_combo is not UNSET:
field_dict["maxCombo"] = max_combo
if missed_notes is not UNSET:
field_dict["missedNotes"] = missed_notes
if bad_cuts is not UNSET:
field_dict["badCuts"] = bad_cuts
if hmd is not UNSET:
field_dict["hmd"] = hmd
if controller is not UNSET:
field_dict["controller"] = controller
if accuracy is not UNSET:
field_dict["accuracy"] = accuracy
if pp is not UNSET:
field_dict["pp"] = pp
if epoch_time is not UNSET:
field_dict["epochTime"] = epoch_time
return field_dict
@classmethod
def from_dict(cls: Type[T], src_dict: Dict[str, Any]) -> T:
d = src_dict.copy()
def _parse_id(data: object) -> Union[None, Unset, int]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, int], data)
id = _parse_id(d.pop("id", UNSET))
base_score = d.pop("baseScore", UNSET)
modified_score = d.pop("modifiedScore", UNSET)
def _parse_modifiers(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
modifiers = _parse_modifiers(d.pop("modifiers", UNSET))
full_combo = d.pop("fullCombo", UNSET)
max_combo = d.pop("maxCombo", UNSET)
missed_notes = d.pop("missedNotes", UNSET)
bad_cuts = d.pop("badCuts", UNSET)
_hmd = d.pop("hmd", UNSET)
hmd: Union[Unset, HMD]
if isinstance(_hmd, Unset):
hmd = UNSET
else:
hmd = HMD(_hmd)
_controller = d.pop("controller", UNSET)
controller: Union[Unset, ControllerEnum]
if isinstance(_controller, Unset):
controller = UNSET
else:
controller = ControllerEnum(_controller)
accuracy = d.pop("accuracy", UNSET)
def _parse_pp(data: object) -> Union[None, Unset, float]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, float], data)
pp = _parse_pp(d.pop("pp", UNSET))
epoch_time = d.pop("epochTime", UNSET)
compact_score = cls(
id=id,
base_score=base_score,
modified_score=modified_score,
modifiers=modifiers,
full_combo=full_combo,
max_combo=max_combo,
missed_notes=missed_notes,
bad_cuts=bad_cuts,
hmd=hmd,
controller=controller,
accuracy=accuracy,
pp=pp,
epoch_time=epoch_time,
)
return compact_score

View File

@ -0,0 +1,69 @@
from typing import TYPE_CHECKING, Any, Dict, Type, TypeVar, Union
from attrs import define as _attrs_define
from ..types import UNSET, Unset
if TYPE_CHECKING:
from ..models.compact_leaderboard import CompactLeaderboard
from ..models.compact_score import CompactScore
T = TypeVar("T", bound="CompactScoreResponse")
@_attrs_define
class CompactScoreResponse:
"""
Attributes:
score (Union[Unset, CompactScore]):
leaderboard (Union[Unset, CompactLeaderboard]):
"""
score: Union[Unset, "CompactScore"] = UNSET
leaderboard: Union[Unset, "CompactLeaderboard"] = UNSET
def to_dict(self) -> Dict[str, Any]:
score: Union[Unset, Dict[str, Any]] = UNSET
if not isinstance(self.score, Unset):
score = self.score.to_dict()
leaderboard: Union[Unset, Dict[str, Any]] = UNSET
if not isinstance(self.leaderboard, Unset):
leaderboard = self.leaderboard.to_dict()
field_dict: Dict[str, Any] = {}
field_dict.update({})
if score is not UNSET:
field_dict["score"] = score
if leaderboard is not UNSET:
field_dict["leaderboard"] = leaderboard
return field_dict
@classmethod
def from_dict(cls: Type[T], src_dict: Dict[str, Any]) -> T:
from ..models.compact_leaderboard import CompactLeaderboard
from ..models.compact_score import CompactScore
d = src_dict.copy()
_score = d.pop("score", UNSET)
score: Union[Unset, CompactScore]
if isinstance(_score, Unset):
score = UNSET
else:
score = CompactScore.from_dict(_score)
_leaderboard = d.pop("leaderboard", UNSET)
leaderboard: Union[Unset, CompactLeaderboard]
if isinstance(_leaderboard, Unset):
leaderboard = UNSET
else:
leaderboard = CompactLeaderboard.from_dict(_leaderboard)
compact_score_response = cls(
score=score,
leaderboard=leaderboard,
)
return compact_score_response

View File

@ -0,0 +1,92 @@
from typing import TYPE_CHECKING, Any, Dict, List, Type, TypeVar, Union, cast
from attrs import define as _attrs_define
from ..types import UNSET, Unset
if TYPE_CHECKING:
from ..models.compact_score_response import CompactScoreResponse
from ..models.metadata import Metadata
T = TypeVar("T", bound="CompactScoreResponseResponseWithMetadata")
@_attrs_define
class CompactScoreResponseResponseWithMetadata:
"""
Attributes:
metadata (Union[Unset, Metadata]):
data (Union[List['CompactScoreResponse'], None, Unset]):
"""
metadata: Union[Unset, "Metadata"] = UNSET
data: Union[List["CompactScoreResponse"], None, Unset] = UNSET
def to_dict(self) -> Dict[str, Any]:
metadata: Union[Unset, Dict[str, Any]] = UNSET
if not isinstance(self.metadata, Unset):
metadata = self.metadata.to_dict()
data: Union[List[Dict[str, Any]], None, Unset]
if isinstance(self.data, Unset):
data = UNSET
elif isinstance(self.data, list):
data = []
for data_type_0_item_data in self.data:
data_type_0_item = data_type_0_item_data.to_dict()
data.append(data_type_0_item)
else:
data = self.data
field_dict: Dict[str, Any] = {}
field_dict.update({})
if metadata is not UNSET:
field_dict["metadata"] = metadata
if data is not UNSET:
field_dict["data"] = data
return field_dict
@classmethod
def from_dict(cls: Type[T], src_dict: Dict[str, Any]) -> T:
from ..models.compact_score_response import CompactScoreResponse
from ..models.metadata import Metadata
d = src_dict.copy()
_metadata = d.pop("metadata", UNSET)
metadata: Union[Unset, Metadata]
if isinstance(_metadata, Unset):
metadata = UNSET
else:
metadata = Metadata.from_dict(_metadata)
def _parse_data(data: object) -> Union[List["CompactScoreResponse"], None, Unset]:
if data is None:
return data
if isinstance(data, Unset):
return data
try:
if not isinstance(data, list):
raise TypeError()
data_type_0 = []
_data_type_0 = data
for data_type_0_item_data in _data_type_0:
data_type_0_item = CompactScoreResponse.from_dict(data_type_0_item_data)
data_type_0.append(data_type_0_item)
return data_type_0
except: # noqa: E722
pass
return cast(Union[List["CompactScoreResponse"], None, Unset], data)
data = _parse_data(d.pop("data", UNSET))
compact_score_response_response_with_metadata = cls(
metadata=metadata,
data=data,
)
return compact_score_response_response_with_metadata

View File

@ -0,0 +1,237 @@
from typing import Any, Dict, Type, TypeVar, Union, cast
from attrs import define as _attrs_define
from ..types import UNSET, Unset
T = TypeVar("T", bound="CompactSongResponse")
@_attrs_define
class CompactSongResponse:
"""
Attributes:
id (Union[None, Unset, str]):
hash_ (Union[None, Unset, str]):
name (Union[None, Unset, str]):
sub_name (Union[None, Unset, str]):
author (Union[None, Unset, str]):
mapper (Union[None, Unset, str]):
mapper_id (Union[Unset, int]):
collaborator_ids (Union[None, Unset, str]):
cover_image (Union[None, Unset, str]):
bpm (Union[Unset, float]):
duration (Union[Unset, float]):
full_cover_image (Union[None, Unset, str]):
"""
id: Union[None, Unset, str] = UNSET
hash_: Union[None, Unset, str] = UNSET
name: Union[None, Unset, str] = UNSET
sub_name: Union[None, Unset, str] = UNSET
author: Union[None, Unset, str] = UNSET
mapper: Union[None, Unset, str] = UNSET
mapper_id: Union[Unset, int] = UNSET
collaborator_ids: Union[None, Unset, str] = UNSET
cover_image: Union[None, Unset, str] = UNSET
bpm: Union[Unset, float] = UNSET
duration: Union[Unset, float] = UNSET
full_cover_image: Union[None, Unset, str] = UNSET
def to_dict(self) -> Dict[str, Any]:
id: Union[None, Unset, str]
if isinstance(self.id, Unset):
id = UNSET
else:
id = self.id
hash_: Union[None, Unset, str]
if isinstance(self.hash_, Unset):
hash_ = UNSET
else:
hash_ = self.hash_
name: Union[None, Unset, str]
if isinstance(self.name, Unset):
name = UNSET
else:
name = self.name
sub_name: Union[None, Unset, str]
if isinstance(self.sub_name, Unset):
sub_name = UNSET
else:
sub_name = self.sub_name
author: Union[None, Unset, str]
if isinstance(self.author, Unset):
author = UNSET
else:
author = self.author
mapper: Union[None, Unset, str]
if isinstance(self.mapper, Unset):
mapper = UNSET
else:
mapper = self.mapper
mapper_id = self.mapper_id
collaborator_ids: Union[None, Unset, str]
if isinstance(self.collaborator_ids, Unset):
collaborator_ids = UNSET
else:
collaborator_ids = self.collaborator_ids
cover_image: Union[None, Unset, str]
if isinstance(self.cover_image, Unset):
cover_image = UNSET
else:
cover_image = self.cover_image
bpm = self.bpm
duration = self.duration
full_cover_image: Union[None, Unset, str]
if isinstance(self.full_cover_image, Unset):
full_cover_image = UNSET
else:
full_cover_image = self.full_cover_image
field_dict: Dict[str, Any] = {}
field_dict.update({})
if id is not UNSET:
field_dict["id"] = id
if hash_ is not UNSET:
field_dict["hash"] = hash_
if name is not UNSET:
field_dict["name"] = name
if sub_name is not UNSET:
field_dict["subName"] = sub_name
if author is not UNSET:
field_dict["author"] = author
if mapper is not UNSET:
field_dict["mapper"] = mapper
if mapper_id is not UNSET:
field_dict["mapperId"] = mapper_id
if collaborator_ids is not UNSET:
field_dict["collaboratorIds"] = collaborator_ids
if cover_image is not UNSET:
field_dict["coverImage"] = cover_image
if bpm is not UNSET:
field_dict["bpm"] = bpm
if duration is not UNSET:
field_dict["duration"] = duration
if full_cover_image is not UNSET:
field_dict["fullCoverImage"] = full_cover_image
return field_dict
@classmethod
def from_dict(cls: Type[T], src_dict: Dict[str, Any]) -> T:
d = src_dict.copy()
def _parse_id(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
id = _parse_id(d.pop("id", UNSET))
def _parse_hash_(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
hash_ = _parse_hash_(d.pop("hash", UNSET))
def _parse_name(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
name = _parse_name(d.pop("name", UNSET))
def _parse_sub_name(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
sub_name = _parse_sub_name(d.pop("subName", UNSET))
def _parse_author(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
author = _parse_author(d.pop("author", UNSET))
def _parse_mapper(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
mapper = _parse_mapper(d.pop("mapper", UNSET))
mapper_id = d.pop("mapperId", UNSET)
def _parse_collaborator_ids(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
collaborator_ids = _parse_collaborator_ids(d.pop("collaboratorIds", UNSET))
def _parse_cover_image(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
cover_image = _parse_cover_image(d.pop("coverImage", UNSET))
bpm = d.pop("bpm", UNSET)
duration = d.pop("duration", UNSET)
def _parse_full_cover_image(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
full_cover_image = _parse_full_cover_image(d.pop("fullCoverImage", UNSET))
compact_song_response = cls(
id=id,
hash_=hash_,
name=name,
sub_name=sub_name,
author=author,
mapper=mapper,
mapper_id=mapper_id,
collaborator_ids=collaborator_ids,
cover_image=cover_image,
bpm=bpm,
duration=duration,
full_cover_image=full_cover_image,
)
return compact_song_response

View File

@ -0,0 +1,42 @@
from enum import Enum
class ControllerEnum(str, Enum):
CONTACTGLOVE = "contactglove"
CRY = "cry"
DISCO = "disco"
E4 = "e4"
ETEE = "etee"
GAMEPAD = "gamepad"
HANDS = "hands"
HPMOTION = "hpMotion"
HUAWEI = "huawei"
JOYCON = "joycon"
KNUCKLES = "knuckles"
MIRAMAR = "miramar"
NOLO = "nolo"
OCULUSTOUCH = "oculustouch"
OCULUSTOUCH2 = "oculustouch2"
ODYSSEY = "odyssey"
PICONEO2 = "picoNeo2"
PICONEO3 = "picoNeo3"
PICOPHOENIX = "picophoenix"
PIMAX = "pimax"
POLARIS = "polaris"
QUEST2 = "quest2"
QUEST3 = "quest3"
QUESTPRO = "questPro"
STEAMDECK = "steamdeck"
TUNDRA = "tundra"
UNKNOWN = "unknown"
VIVE = "vive"
VIVECOSMOS = "viveCosmos"
VIVEPRO = "vivePro"
VIVEPRO2 = "vivePro2"
VIVETRACKER = "viveTracker"
VIVETRACKER2 = "viveTracker2"
VIVETRACKER3 = "viveTracker3"
WMR = "wmr"
def __str__(self) -> str:
return str(self.value)

View File

@ -0,0 +1,156 @@
from typing import Any, Dict, Type, TypeVar, Union, cast
from attrs import define as _attrs_define
from ..types import UNSET, Unset
T = TypeVar("T", bound="CriteriaCommentary")
@_attrs_define
class CriteriaCommentary:
"""
Attributes:
id (Union[Unset, int]):
player_id (Union[None, Unset, str]):
timeset (Union[Unset, int]):
value (Union[None, Unset, str]):
edit_timeset (Union[None, Unset, int]):
edited (Union[Unset, bool]):
rank_qualification_id (Union[None, Unset, int]):
discord_message_id (Union[None, Unset, str]):
"""
id: Union[Unset, int] = UNSET
player_id: Union[None, Unset, str] = UNSET
timeset: Union[Unset, int] = UNSET
value: Union[None, Unset, str] = UNSET
edit_timeset: Union[None, Unset, int] = UNSET
edited: Union[Unset, bool] = UNSET
rank_qualification_id: Union[None, Unset, int] = UNSET
discord_message_id: Union[None, Unset, str] = UNSET
def to_dict(self) -> Dict[str, Any]:
id = self.id
player_id: Union[None, Unset, str]
if isinstance(self.player_id, Unset):
player_id = UNSET
else:
player_id = self.player_id
timeset = self.timeset
value: Union[None, Unset, str]
if isinstance(self.value, Unset):
value = UNSET
else:
value = self.value
edit_timeset: Union[None, Unset, int]
if isinstance(self.edit_timeset, Unset):
edit_timeset = UNSET
else:
edit_timeset = self.edit_timeset
edited = self.edited
rank_qualification_id: Union[None, Unset, int]
if isinstance(self.rank_qualification_id, Unset):
rank_qualification_id = UNSET
else:
rank_qualification_id = self.rank_qualification_id
discord_message_id: Union[None, Unset, str]
if isinstance(self.discord_message_id, Unset):
discord_message_id = UNSET
else:
discord_message_id = self.discord_message_id
field_dict: Dict[str, Any] = {}
field_dict.update({})
if id is not UNSET:
field_dict["id"] = id
if player_id is not UNSET:
field_dict["playerId"] = player_id
if timeset is not UNSET:
field_dict["timeset"] = timeset
if value is not UNSET:
field_dict["value"] = value
if edit_timeset is not UNSET:
field_dict["editTimeset"] = edit_timeset
if edited is not UNSET:
field_dict["edited"] = edited
if rank_qualification_id is not UNSET:
field_dict["rankQualificationId"] = rank_qualification_id
if discord_message_id is not UNSET:
field_dict["discordMessageId"] = discord_message_id
return field_dict
@classmethod
def from_dict(cls: Type[T], src_dict: Dict[str, Any]) -> T:
d = src_dict.copy()
id = d.pop("id", UNSET)
def _parse_player_id(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
player_id = _parse_player_id(d.pop("playerId", UNSET))
timeset = d.pop("timeset", UNSET)
def _parse_value(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
value = _parse_value(d.pop("value", UNSET))
def _parse_edit_timeset(data: object) -> Union[None, Unset, int]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, int], data)
edit_timeset = _parse_edit_timeset(d.pop("editTimeset", UNSET))
edited = d.pop("edited", UNSET)
def _parse_rank_qualification_id(data: object) -> Union[None, Unset, int]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, int], data)
rank_qualification_id = _parse_rank_qualification_id(d.pop("rankQualificationId", UNSET))
def _parse_discord_message_id(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
discord_message_id = _parse_discord_message_id(d.pop("discordMessageId", UNSET))
criteria_commentary = cls(
id=id,
player_id=player_id,
timeset=timeset,
value=value,
edit_timeset=edit_timeset,
edited=edited,
rank_qualification_id=rank_qualification_id,
discord_message_id=discord_message_id,
)
return criteria_commentary

View File

@ -0,0 +1,414 @@
from typing import TYPE_CHECKING, Any, Dict, Type, TypeVar, Union, cast
from attrs import define as _attrs_define
from ..models.difficulty_status import DifficultyStatus
from ..models.requirements import Requirements
from ..types import UNSET, Unset
if TYPE_CHECKING:
from ..models.modifiers_map import ModifiersMap
from ..models.modifiers_rating import ModifiersRating
T = TypeVar("T", bound="DifficultyDescription")
@_attrs_define
class DifficultyDescription:
"""
Attributes:
id (Union[Unset, int]):
value (Union[Unset, int]):
mode (Union[Unset, int]):
difficulty_name (Union[None, Unset, str]):
mode_name (Union[None, Unset, str]):
status (Union[Unset, DifficultyStatus]): Represents the difficulty status of a map.
modifier_values (Union[Unset, ModifiersMap]):
modifiers_rating (Union[Unset, ModifiersRating]):
nominated_time (Union[Unset, int]):
qualified_time (Union[Unset, int]):
ranked_time (Union[Unset, int]):
speed_tags (Union[Unset, int]):
style_tags (Union[Unset, int]):
feature_tags (Union[Unset, int]):
stars (Union[None, Unset, float]):
predicted_acc (Union[None, Unset, float]):
pass_rating (Union[None, Unset, float]):
acc_rating (Union[None, Unset, float]):
tech_rating (Union[None, Unset, float]):
type (Union[Unset, int]):
njs (Union[Unset, float]):
nps (Union[Unset, float]):
notes (Union[Unset, int]):
chains (Union[Unset, int]):
sliders (Union[Unset, int]):
bombs (Union[Unset, int]):
walls (Union[Unset, int]):
max_score (Union[Unset, int]):
duration (Union[Unset, float]):
requirements (Union[Unset, Requirements]):
"""
id: Union[Unset, int] = UNSET
value: Union[Unset, int] = UNSET
mode: Union[Unset, int] = UNSET
difficulty_name: Union[None, Unset, str] = UNSET
mode_name: Union[None, Unset, str] = UNSET
status: Union[Unset, DifficultyStatus] = UNSET
modifier_values: Union[Unset, "ModifiersMap"] = UNSET
modifiers_rating: Union[Unset, "ModifiersRating"] = UNSET
nominated_time: Union[Unset, int] = UNSET
qualified_time: Union[Unset, int] = UNSET
ranked_time: Union[Unset, int] = UNSET
speed_tags: Union[Unset, int] = UNSET
style_tags: Union[Unset, int] = UNSET
feature_tags: Union[Unset, int] = UNSET
stars: Union[None, Unset, float] = UNSET
predicted_acc: Union[None, Unset, float] = UNSET
pass_rating: Union[None, Unset, float] = UNSET
acc_rating: Union[None, Unset, float] = UNSET
tech_rating: Union[None, Unset, float] = UNSET
type: Union[Unset, int] = UNSET
njs: Union[Unset, float] = UNSET
nps: Union[Unset, float] = UNSET
notes: Union[Unset, int] = UNSET
chains: Union[Unset, int] = UNSET
sliders: Union[Unset, int] = UNSET
bombs: Union[Unset, int] = UNSET
walls: Union[Unset, int] = UNSET
max_score: Union[Unset, int] = UNSET
duration: Union[Unset, float] = UNSET
requirements: Union[Unset, Requirements] = UNSET
def to_dict(self) -> Dict[str, Any]:
id = self.id
value = self.value
mode = self.mode
difficulty_name: Union[None, Unset, str]
if isinstance(self.difficulty_name, Unset):
difficulty_name = UNSET
else:
difficulty_name = self.difficulty_name
mode_name: Union[None, Unset, str]
if isinstance(self.mode_name, Unset):
mode_name = UNSET
else:
mode_name = self.mode_name
status: Union[Unset, str] = UNSET
if not isinstance(self.status, Unset):
status = self.status.value
modifier_values: Union[Unset, Dict[str, Any]] = UNSET
if not isinstance(self.modifier_values, Unset):
modifier_values = self.modifier_values.to_dict()
modifiers_rating: Union[Unset, Dict[str, Any]] = UNSET
if not isinstance(self.modifiers_rating, Unset):
modifiers_rating = self.modifiers_rating.to_dict()
nominated_time = self.nominated_time
qualified_time = self.qualified_time
ranked_time = self.ranked_time
speed_tags = self.speed_tags
style_tags = self.style_tags
feature_tags = self.feature_tags
stars: Union[None, Unset, float]
if isinstance(self.stars, Unset):
stars = UNSET
else:
stars = self.stars
predicted_acc: Union[None, Unset, float]
if isinstance(self.predicted_acc, Unset):
predicted_acc = UNSET
else:
predicted_acc = self.predicted_acc
pass_rating: Union[None, Unset, float]
if isinstance(self.pass_rating, Unset):
pass_rating = UNSET
else:
pass_rating = self.pass_rating
acc_rating: Union[None, Unset, float]
if isinstance(self.acc_rating, Unset):
acc_rating = UNSET
else:
acc_rating = self.acc_rating
tech_rating: Union[None, Unset, float]
if isinstance(self.tech_rating, Unset):
tech_rating = UNSET
else:
tech_rating = self.tech_rating
type = self.type
njs = self.njs
nps = self.nps
notes = self.notes
chains = self.chains
sliders = self.sliders
bombs = self.bombs
walls = self.walls
max_score = self.max_score
duration = self.duration
requirements: Union[Unset, str] = UNSET
if not isinstance(self.requirements, Unset):
requirements = self.requirements.value
field_dict: Dict[str, Any] = {}
field_dict.update({})
if id is not UNSET:
field_dict["id"] = id
if value is not UNSET:
field_dict["value"] = value
if mode is not UNSET:
field_dict["mode"] = mode
if difficulty_name is not UNSET:
field_dict["difficultyName"] = difficulty_name
if mode_name is not UNSET:
field_dict["modeName"] = mode_name
if status is not UNSET:
field_dict["status"] = status
if modifier_values is not UNSET:
field_dict["modifierValues"] = modifier_values
if modifiers_rating is not UNSET:
field_dict["modifiersRating"] = modifiers_rating
if nominated_time is not UNSET:
field_dict["nominatedTime"] = nominated_time
if qualified_time is not UNSET:
field_dict["qualifiedTime"] = qualified_time
if ranked_time is not UNSET:
field_dict["rankedTime"] = ranked_time
if speed_tags is not UNSET:
field_dict["speedTags"] = speed_tags
if style_tags is not UNSET:
field_dict["styleTags"] = style_tags
if feature_tags is not UNSET:
field_dict["featureTags"] = feature_tags
if stars is not UNSET:
field_dict["stars"] = stars
if predicted_acc is not UNSET:
field_dict["predictedAcc"] = predicted_acc
if pass_rating is not UNSET:
field_dict["passRating"] = pass_rating
if acc_rating is not UNSET:
field_dict["accRating"] = acc_rating
if tech_rating is not UNSET:
field_dict["techRating"] = tech_rating
if type is not UNSET:
field_dict["type"] = type
if njs is not UNSET:
field_dict["njs"] = njs
if nps is not UNSET:
field_dict["nps"] = nps
if notes is not UNSET:
field_dict["notes"] = notes
if chains is not UNSET:
field_dict["chains"] = chains
if sliders is not UNSET:
field_dict["sliders"] = sliders
if bombs is not UNSET:
field_dict["bombs"] = bombs
if walls is not UNSET:
field_dict["walls"] = walls
if max_score is not UNSET:
field_dict["maxScore"] = max_score
if duration is not UNSET:
field_dict["duration"] = duration
if requirements is not UNSET:
field_dict["requirements"] = requirements
return field_dict
@classmethod
def from_dict(cls: Type[T], src_dict: Dict[str, Any]) -> T:
from ..models.modifiers_map import ModifiersMap
from ..models.modifiers_rating import ModifiersRating
d = src_dict.copy()
id = d.pop("id", UNSET)
value = d.pop("value", UNSET)
mode = d.pop("mode", UNSET)
def _parse_difficulty_name(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
difficulty_name = _parse_difficulty_name(d.pop("difficultyName", UNSET))
def _parse_mode_name(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
mode_name = _parse_mode_name(d.pop("modeName", UNSET))
_status = d.pop("status", UNSET)
status: Union[Unset, DifficultyStatus]
if isinstance(_status, Unset):
status = UNSET
else:
status = DifficultyStatus(_status)
_modifier_values = d.pop("modifierValues", UNSET)
modifier_values: Union[Unset, ModifiersMap]
if isinstance(_modifier_values, Unset):
modifier_values = UNSET
else:
modifier_values = ModifiersMap.from_dict(_modifier_values)
_modifiers_rating = d.pop("modifiersRating", UNSET)
modifiers_rating: Union[Unset, ModifiersRating]
if isinstance(_modifiers_rating, Unset):
modifiers_rating = UNSET
else:
modifiers_rating = ModifiersRating.from_dict(_modifiers_rating)
nominated_time = d.pop("nominatedTime", UNSET)
qualified_time = d.pop("qualifiedTime", UNSET)
ranked_time = d.pop("rankedTime", UNSET)
speed_tags = d.pop("speedTags", UNSET)
style_tags = d.pop("styleTags", UNSET)
feature_tags = d.pop("featureTags", UNSET)
def _parse_stars(data: object) -> Union[None, Unset, float]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, float], data)
stars = _parse_stars(d.pop("stars", UNSET))
def _parse_predicted_acc(data: object) -> Union[None, Unset, float]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, float], data)
predicted_acc = _parse_predicted_acc(d.pop("predictedAcc", UNSET))
def _parse_pass_rating(data: object) -> Union[None, Unset, float]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, float], data)
pass_rating = _parse_pass_rating(d.pop("passRating", UNSET))
def _parse_acc_rating(data: object) -> Union[None, Unset, float]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, float], data)
acc_rating = _parse_acc_rating(d.pop("accRating", UNSET))
def _parse_tech_rating(data: object) -> Union[None, Unset, float]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, float], data)
tech_rating = _parse_tech_rating(d.pop("techRating", UNSET))
type = d.pop("type", UNSET)
njs = d.pop("njs", UNSET)
nps = d.pop("nps", UNSET)
notes = d.pop("notes", UNSET)
chains = d.pop("chains", UNSET)
sliders = d.pop("sliders", UNSET)
bombs = d.pop("bombs", UNSET)
walls = d.pop("walls", UNSET)
max_score = d.pop("maxScore", UNSET)
duration = d.pop("duration", UNSET)
_requirements = d.pop("requirements", UNSET)
requirements: Union[Unset, Requirements]
if isinstance(_requirements, Unset):
requirements = UNSET
else:
requirements = Requirements(_requirements)
difficulty_description = cls(
id=id,
value=value,
mode=mode,
difficulty_name=difficulty_name,
mode_name=mode_name,
status=status,
modifier_values=modifier_values,
modifiers_rating=modifiers_rating,
nominated_time=nominated_time,
qualified_time=qualified_time,
ranked_time=ranked_time,
speed_tags=speed_tags,
style_tags=style_tags,
feature_tags=feature_tags,
stars=stars,
predicted_acc=predicted_acc,
pass_rating=pass_rating,
acc_rating=acc_rating,
tech_rating=tech_rating,
type=type,
njs=njs,
nps=nps,
notes=notes,
chains=chains,
sliders=sliders,
bombs=bombs,
walls=walls,
max_score=max_score,
duration=duration,
requirements=requirements,
)
return difficulty_description

View File

@ -0,0 +1,396 @@
from typing import TYPE_CHECKING, Any, Dict, Type, TypeVar, Union, cast
from attrs import define as _attrs_define
from ..models.difficulty_status import DifficultyStatus
from ..models.requirements import Requirements
from ..types import UNSET, Unset
if TYPE_CHECKING:
from ..models.modifiers_map import ModifiersMap
from ..models.modifiers_rating import ModifiersRating
T = TypeVar("T", bound="DifficultyResponse")
@_attrs_define
class DifficultyResponse:
"""
Attributes:
id (Union[Unset, int]):
value (Union[Unset, int]):
mode (Union[Unset, int]):
difficulty_name (Union[None, Unset, str]):
mode_name (Union[None, Unset, str]):
status (Union[Unset, DifficultyStatus]): Represents the difficulty status of a map.
modifier_values (Union[Unset, ModifiersMap]):
modifiers_rating (Union[Unset, ModifiersRating]):
nominated_time (Union[Unset, int]):
qualified_time (Union[Unset, int]):
ranked_time (Union[Unset, int]):
speed_tags (Union[Unset, int]):
style_tags (Union[Unset, int]):
feature_tags (Union[Unset, int]):
stars (Union[None, Unset, float]):
predicted_acc (Union[None, Unset, float]):
pass_rating (Union[None, Unset, float]):
acc_rating (Union[None, Unset, float]):
tech_rating (Union[None, Unset, float]):
type (Union[Unset, int]):
njs (Union[Unset, float]):
nps (Union[Unset, float]):
notes (Union[Unset, int]):
bombs (Union[Unset, int]):
walls (Union[Unset, int]):
max_score (Union[Unset, int]):
duration (Union[Unset, float]):
requirements (Union[Unset, Requirements]):
"""
id: Union[Unset, int] = UNSET
value: Union[Unset, int] = UNSET
mode: Union[Unset, int] = UNSET
difficulty_name: Union[None, Unset, str] = UNSET
mode_name: Union[None, Unset, str] = UNSET
status: Union[Unset, DifficultyStatus] = UNSET
modifier_values: Union[Unset, "ModifiersMap"] = UNSET
modifiers_rating: Union[Unset, "ModifiersRating"] = UNSET
nominated_time: Union[Unset, int] = UNSET
qualified_time: Union[Unset, int] = UNSET
ranked_time: Union[Unset, int] = UNSET
speed_tags: Union[Unset, int] = UNSET
style_tags: Union[Unset, int] = UNSET
feature_tags: Union[Unset, int] = UNSET
stars: Union[None, Unset, float] = UNSET
predicted_acc: Union[None, Unset, float] = UNSET
pass_rating: Union[None, Unset, float] = UNSET
acc_rating: Union[None, Unset, float] = UNSET
tech_rating: Union[None, Unset, float] = UNSET
type: Union[Unset, int] = UNSET
njs: Union[Unset, float] = UNSET
nps: Union[Unset, float] = UNSET
notes: Union[Unset, int] = UNSET
bombs: Union[Unset, int] = UNSET
walls: Union[Unset, int] = UNSET
max_score: Union[Unset, int] = UNSET
duration: Union[Unset, float] = UNSET
requirements: Union[Unset, Requirements] = UNSET
def to_dict(self) -> Dict[str, Any]:
id = self.id
value = self.value
mode = self.mode
difficulty_name: Union[None, Unset, str]
if isinstance(self.difficulty_name, Unset):
difficulty_name = UNSET
else:
difficulty_name = self.difficulty_name
mode_name: Union[None, Unset, str]
if isinstance(self.mode_name, Unset):
mode_name = UNSET
else:
mode_name = self.mode_name
status: Union[Unset, str] = UNSET
if not isinstance(self.status, Unset):
status = self.status.value
modifier_values: Union[Unset, Dict[str, Any]] = UNSET
if not isinstance(self.modifier_values, Unset):
modifier_values = self.modifier_values.to_dict()
modifiers_rating: Union[Unset, Dict[str, Any]] = UNSET
if not isinstance(self.modifiers_rating, Unset):
modifiers_rating = self.modifiers_rating.to_dict()
nominated_time = self.nominated_time
qualified_time = self.qualified_time
ranked_time = self.ranked_time
speed_tags = self.speed_tags
style_tags = self.style_tags
feature_tags = self.feature_tags
stars: Union[None, Unset, float]
if isinstance(self.stars, Unset):
stars = UNSET
else:
stars = self.stars
predicted_acc: Union[None, Unset, float]
if isinstance(self.predicted_acc, Unset):
predicted_acc = UNSET
else:
predicted_acc = self.predicted_acc
pass_rating: Union[None, Unset, float]
if isinstance(self.pass_rating, Unset):
pass_rating = UNSET
else:
pass_rating = self.pass_rating
acc_rating: Union[None, Unset, float]
if isinstance(self.acc_rating, Unset):
acc_rating = UNSET
else:
acc_rating = self.acc_rating
tech_rating: Union[None, Unset, float]
if isinstance(self.tech_rating, Unset):
tech_rating = UNSET
else:
tech_rating = self.tech_rating
type = self.type
njs = self.njs
nps = self.nps
notes = self.notes
bombs = self.bombs
walls = self.walls
max_score = self.max_score
duration = self.duration
requirements: Union[Unset, str] = UNSET
if not isinstance(self.requirements, Unset):
requirements = self.requirements.value
field_dict: Dict[str, Any] = {}
field_dict.update({})
if id is not UNSET:
field_dict["id"] = id
if value is not UNSET:
field_dict["value"] = value
if mode is not UNSET:
field_dict["mode"] = mode
if difficulty_name is not UNSET:
field_dict["difficultyName"] = difficulty_name
if mode_name is not UNSET:
field_dict["modeName"] = mode_name
if status is not UNSET:
field_dict["status"] = status
if modifier_values is not UNSET:
field_dict["modifierValues"] = modifier_values
if modifiers_rating is not UNSET:
field_dict["modifiersRating"] = modifiers_rating
if nominated_time is not UNSET:
field_dict["nominatedTime"] = nominated_time
if qualified_time is not UNSET:
field_dict["qualifiedTime"] = qualified_time
if ranked_time is not UNSET:
field_dict["rankedTime"] = ranked_time
if speed_tags is not UNSET:
field_dict["speedTags"] = speed_tags
if style_tags is not UNSET:
field_dict["styleTags"] = style_tags
if feature_tags is not UNSET:
field_dict["featureTags"] = feature_tags
if stars is not UNSET:
field_dict["stars"] = stars
if predicted_acc is not UNSET:
field_dict["predictedAcc"] = predicted_acc
if pass_rating is not UNSET:
field_dict["passRating"] = pass_rating
if acc_rating is not UNSET:
field_dict["accRating"] = acc_rating
if tech_rating is not UNSET:
field_dict["techRating"] = tech_rating
if type is not UNSET:
field_dict["type"] = type
if njs is not UNSET:
field_dict["njs"] = njs
if nps is not UNSET:
field_dict["nps"] = nps
if notes is not UNSET:
field_dict["notes"] = notes
if bombs is not UNSET:
field_dict["bombs"] = bombs
if walls is not UNSET:
field_dict["walls"] = walls
if max_score is not UNSET:
field_dict["maxScore"] = max_score
if duration is not UNSET:
field_dict["duration"] = duration
if requirements is not UNSET:
field_dict["requirements"] = requirements
return field_dict
@classmethod
def from_dict(cls: Type[T], src_dict: Dict[str, Any]) -> T:
from ..models.modifiers_map import ModifiersMap
from ..models.modifiers_rating import ModifiersRating
d = src_dict.copy()
id = d.pop("id", UNSET)
value = d.pop("value", UNSET)
mode = d.pop("mode", UNSET)
def _parse_difficulty_name(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
difficulty_name = _parse_difficulty_name(d.pop("difficultyName", UNSET))
def _parse_mode_name(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
mode_name = _parse_mode_name(d.pop("modeName", UNSET))
_status = d.pop("status", UNSET)
status: Union[Unset, DifficultyStatus]
if isinstance(_status, Unset):
status = UNSET
else:
status = DifficultyStatus(_status)
_modifier_values = d.pop("modifierValues", UNSET)
modifier_values: Union[Unset, ModifiersMap]
if isinstance(_modifier_values, Unset):
modifier_values = UNSET
else:
modifier_values = ModifiersMap.from_dict(_modifier_values)
_modifiers_rating = d.pop("modifiersRating", UNSET)
modifiers_rating: Union[Unset, ModifiersRating]
if isinstance(_modifiers_rating, Unset):
modifiers_rating = UNSET
else:
modifiers_rating = ModifiersRating.from_dict(_modifiers_rating)
nominated_time = d.pop("nominatedTime", UNSET)
qualified_time = d.pop("qualifiedTime", UNSET)
ranked_time = d.pop("rankedTime", UNSET)
speed_tags = d.pop("speedTags", UNSET)
style_tags = d.pop("styleTags", UNSET)
feature_tags = d.pop("featureTags", UNSET)
def _parse_stars(data: object) -> Union[None, Unset, float]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, float], data)
stars = _parse_stars(d.pop("stars", UNSET))
def _parse_predicted_acc(data: object) -> Union[None, Unset, float]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, float], data)
predicted_acc = _parse_predicted_acc(d.pop("predictedAcc", UNSET))
def _parse_pass_rating(data: object) -> Union[None, Unset, float]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, float], data)
pass_rating = _parse_pass_rating(d.pop("passRating", UNSET))
def _parse_acc_rating(data: object) -> Union[None, Unset, float]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, float], data)
acc_rating = _parse_acc_rating(d.pop("accRating", UNSET))
def _parse_tech_rating(data: object) -> Union[None, Unset, float]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, float], data)
tech_rating = _parse_tech_rating(d.pop("techRating", UNSET))
type = d.pop("type", UNSET)
njs = d.pop("njs", UNSET)
nps = d.pop("nps", UNSET)
notes = d.pop("notes", UNSET)
bombs = d.pop("bombs", UNSET)
walls = d.pop("walls", UNSET)
max_score = d.pop("maxScore", UNSET)
duration = d.pop("duration", UNSET)
_requirements = d.pop("requirements", UNSET)
requirements: Union[Unset, Requirements]
if isinstance(_requirements, Unset):
requirements = UNSET
else:
requirements = Requirements(_requirements)
difficulty_response = cls(
id=id,
value=value,
mode=mode,
difficulty_name=difficulty_name,
mode_name=mode_name,
status=status,
modifier_values=modifier_values,
modifiers_rating=modifiers_rating,
nominated_time=nominated_time,
qualified_time=qualified_time,
ranked_time=ranked_time,
speed_tags=speed_tags,
style_tags=style_tags,
feature_tags=feature_tags,
stars=stars,
predicted_acc=predicted_acc,
pass_rating=pass_rating,
acc_rating=acc_rating,
tech_rating=tech_rating,
type=type,
njs=njs,
nps=nps,
notes=notes,
bombs=bombs,
walls=walls,
max_score=max_score,
duration=duration,
requirements=requirements,
)
return difficulty_response

View File

@ -0,0 +1,15 @@
from enum import Enum
class DifficultyStatus(str, Enum):
INEVENT = "inevent"
NOMINATED = "nominated"
OST = "oST"
OUTDATED = "outdated"
QUALIFIED = "qualified"
RANKED = "ranked"
UNRANKABLE = "unrankable"
UNRANKED = "unranked"
def __str__(self) -> str:
return str(self.value)

View File

@ -0,0 +1,187 @@
from typing import TYPE_CHECKING, Any, Dict, Type, TypeVar, Union, cast
from attrs import define as _attrs_define
from ..types import UNSET, Unset
if TYPE_CHECKING:
from ..models.event_ranking import EventRanking
T = TypeVar("T", bound="EventPlayer")
@_attrs_define
class EventPlayer:
"""
Attributes:
id (Union[Unset, int]):
event_ranking_id (Union[None, Unset, int]):
event (Union[Unset, EventRanking]):
event_name (Union[None, Unset, str]):
player_name (Union[None, Unset, str]):
player_id (Union[None, Unset, str]):
country (Union[None, Unset, str]):
rank (Union[Unset, int]):
country_rank (Union[Unset, int]):
pp (Union[Unset, float]):
"""
id: Union[Unset, int] = UNSET
event_ranking_id: Union[None, Unset, int] = UNSET
event: Union[Unset, "EventRanking"] = UNSET
event_name: Union[None, Unset, str] = UNSET
player_name: Union[None, Unset, str] = UNSET
player_id: Union[None, Unset, str] = UNSET
country: Union[None, Unset, str] = UNSET
rank: Union[Unset, int] = UNSET
country_rank: Union[Unset, int] = UNSET
pp: Union[Unset, float] = UNSET
def to_dict(self) -> Dict[str, Any]:
id = self.id
event_ranking_id: Union[None, Unset, int]
if isinstance(self.event_ranking_id, Unset):
event_ranking_id = UNSET
else:
event_ranking_id = self.event_ranking_id
event: Union[Unset, Dict[str, Any]] = UNSET
if not isinstance(self.event, Unset):
event = self.event.to_dict()
event_name: Union[None, Unset, str]
if isinstance(self.event_name, Unset):
event_name = UNSET
else:
event_name = self.event_name
player_name: Union[None, Unset, str]
if isinstance(self.player_name, Unset):
player_name = UNSET
else:
player_name = self.player_name
player_id: Union[None, Unset, str]
if isinstance(self.player_id, Unset):
player_id = UNSET
else:
player_id = self.player_id
country: Union[None, Unset, str]
if isinstance(self.country, Unset):
country = UNSET
else:
country = self.country
rank = self.rank
country_rank = self.country_rank
pp = self.pp
field_dict: Dict[str, Any] = {}
field_dict.update({})
if id is not UNSET:
field_dict["id"] = id
if event_ranking_id is not UNSET:
field_dict["eventRankingId"] = event_ranking_id
if event is not UNSET:
field_dict["event"] = event
if event_name is not UNSET:
field_dict["eventName"] = event_name
if player_name is not UNSET:
field_dict["playerName"] = player_name
if player_id is not UNSET:
field_dict["playerId"] = player_id
if country is not UNSET:
field_dict["country"] = country
if rank is not UNSET:
field_dict["rank"] = rank
if country_rank is not UNSET:
field_dict["countryRank"] = country_rank
if pp is not UNSET:
field_dict["pp"] = pp
return field_dict
@classmethod
def from_dict(cls: Type[T], src_dict: Dict[str, Any]) -> T:
from ..models.event_ranking import EventRanking
d = src_dict.copy()
id = d.pop("id", UNSET)
def _parse_event_ranking_id(data: object) -> Union[None, Unset, int]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, int], data)
event_ranking_id = _parse_event_ranking_id(d.pop("eventRankingId", UNSET))
_event = d.pop("event", UNSET)
event: Union[Unset, EventRanking]
if isinstance(_event, Unset):
event = UNSET
else:
event = EventRanking.from_dict(_event)
def _parse_event_name(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
event_name = _parse_event_name(d.pop("eventName", UNSET))
def _parse_player_name(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
player_name = _parse_player_name(d.pop("playerName", UNSET))
def _parse_player_id(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
player_id = _parse_player_id(d.pop("playerId", UNSET))
def _parse_country(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
country = _parse_country(d.pop("country", UNSET))
rank = d.pop("rank", UNSET)
country_rank = d.pop("countryRank", UNSET)
pp = d.pop("pp", UNSET)
event_player = cls(
id=id,
event_ranking_id=event_ranking_id,
event=event,
event_name=event_name,
player_name=player_name,
player_id=player_id,
country=country,
rank=rank,
country_rank=country_rank,
pp=pp,
)
return event_player

View File

@ -0,0 +1,96 @@
from typing import Any, Dict, Type, TypeVar, Union, cast
from attrs import define as _attrs_define
from ..types import UNSET, Unset
T = TypeVar("T", bound="EventRanking")
@_attrs_define
class EventRanking:
"""
Attributes:
id (Union[Unset, int]):
name (Union[None, Unset, str]):
end_date (Union[Unset, int]):
playlist_id (Union[Unset, int]):
image (Union[None, Unset, str]):
"""
id: Union[Unset, int] = UNSET
name: Union[None, Unset, str] = UNSET
end_date: Union[Unset, int] = UNSET
playlist_id: Union[Unset, int] = UNSET
image: Union[None, Unset, str] = UNSET
def to_dict(self) -> Dict[str, Any]:
id = self.id
name: Union[None, Unset, str]
if isinstance(self.name, Unset):
name = UNSET
else:
name = self.name
end_date = self.end_date
playlist_id = self.playlist_id
image: Union[None, Unset, str]
if isinstance(self.image, Unset):
image = UNSET
else:
image = self.image
field_dict: Dict[str, Any] = {}
field_dict.update({})
if id is not UNSET:
field_dict["id"] = id
if name is not UNSET:
field_dict["name"] = name
if end_date is not UNSET:
field_dict["endDate"] = end_date
if playlist_id is not UNSET:
field_dict["playlistId"] = playlist_id
if image is not UNSET:
field_dict["image"] = image
return field_dict
@classmethod
def from_dict(cls: Type[T], src_dict: Dict[str, Any]) -> T:
d = src_dict.copy()
id = d.pop("id", UNSET)
def _parse_name(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
name = _parse_name(d.pop("name", UNSET))
end_date = d.pop("endDate", UNSET)
playlist_id = d.pop("playlistId", UNSET)
def _parse_image(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
image = _parse_image(d.pop("image", UNSET))
event_ranking = cls(
id=id,
name=name,
end_date=end_date,
playlist_id=playlist_id,
image=image,
)
return event_ranking

View File

@ -0,0 +1,164 @@
from typing import Any, Dict, Type, TypeVar, Union, cast
from attrs import define as _attrs_define
from ..models.song_status import SongStatus
from ..types import UNSET, Unset
T = TypeVar("T", bound="ExternalStatus")
@_attrs_define
class ExternalStatus:
"""
Attributes:
id (Union[Unset, int]):
status (Union[Unset, SongStatus]):
timeset (Union[Unset, int]):
link (Union[None, Unset, str]):
responsible (Union[None, Unset, str]):
details (Union[None, Unset, str]):
title (Union[None, Unset, str]):
title_color (Union[None, Unset, str]):
"""
id: Union[Unset, int] = UNSET
status: Union[Unset, SongStatus] = UNSET
timeset: Union[Unset, int] = UNSET
link: Union[None, Unset, str] = UNSET
responsible: Union[None, Unset, str] = UNSET
details: Union[None, Unset, str] = UNSET
title: Union[None, Unset, str] = UNSET
title_color: Union[None, Unset, str] = UNSET
def to_dict(self) -> Dict[str, Any]:
id = self.id
status: Union[Unset, str] = UNSET
if not isinstance(self.status, Unset):
status = self.status.value
timeset = self.timeset
link: Union[None, Unset, str]
if isinstance(self.link, Unset):
link = UNSET
else:
link = self.link
responsible: Union[None, Unset, str]
if isinstance(self.responsible, Unset):
responsible = UNSET
else:
responsible = self.responsible
details: Union[None, Unset, str]
if isinstance(self.details, Unset):
details = UNSET
else:
details = self.details
title: Union[None, Unset, str]
if isinstance(self.title, Unset):
title = UNSET
else:
title = self.title
title_color: Union[None, Unset, str]
if isinstance(self.title_color, Unset):
title_color = UNSET
else:
title_color = self.title_color
field_dict: Dict[str, Any] = {}
field_dict.update({})
if id is not UNSET:
field_dict["id"] = id
if status is not UNSET:
field_dict["status"] = status
if timeset is not UNSET:
field_dict["timeset"] = timeset
if link is not UNSET:
field_dict["link"] = link
if responsible is not UNSET:
field_dict["responsible"] = responsible
if details is not UNSET:
field_dict["details"] = details
if title is not UNSET:
field_dict["title"] = title
if title_color is not UNSET:
field_dict["titleColor"] = title_color
return field_dict
@classmethod
def from_dict(cls: Type[T], src_dict: Dict[str, Any]) -> T:
d = src_dict.copy()
id = d.pop("id", UNSET)
_status = d.pop("status", UNSET)
status: Union[Unset, SongStatus]
if isinstance(_status, Unset):
status = UNSET
else:
status = SongStatus(_status)
timeset = d.pop("timeset", UNSET)
def _parse_link(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
link = _parse_link(d.pop("link", UNSET))
def _parse_responsible(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
responsible = _parse_responsible(d.pop("responsible", UNSET))
def _parse_details(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
details = _parse_details(d.pop("details", UNSET))
def _parse_title(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
title = _parse_title(d.pop("title", UNSET))
def _parse_title_color(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
title_color = _parse_title_color(d.pop("titleColor", UNSET))
external_status = cls(
id=id,
status=status,
timeset=timeset,
link=link,
responsible=responsible,
details=details,
title=title,
title_color=title_color,
)
return external_status

View File

@ -0,0 +1,178 @@
from typing import Any, Dict, Type, TypeVar, Union, cast
from attrs import define as _attrs_define
from ..types import UNSET, Unset
T = TypeVar("T", bound="FeaturedPlaylist")
@_attrs_define
class FeaturedPlaylist:
"""
Attributes:
id (Union[Unset, int]):
playlist_link (Union[None, Unset, str]):
cover (Union[None, Unset, str]):
title (Union[None, Unset, str]):
description (Union[None, Unset, str]):
owner (Union[None, Unset, str]):
owner_cover (Union[None, Unset, str]):
owner_link (Union[None, Unset, str]):
"""
id: Union[Unset, int] = UNSET
playlist_link: Union[None, Unset, str] = UNSET
cover: Union[None, Unset, str] = UNSET
title: Union[None, Unset, str] = UNSET
description: Union[None, Unset, str] = UNSET
owner: Union[None, Unset, str] = UNSET
owner_cover: Union[None, Unset, str] = UNSET
owner_link: Union[None, Unset, str] = UNSET
def to_dict(self) -> Dict[str, Any]:
id = self.id
playlist_link: Union[None, Unset, str]
if isinstance(self.playlist_link, Unset):
playlist_link = UNSET
else:
playlist_link = self.playlist_link
cover: Union[None, Unset, str]
if isinstance(self.cover, Unset):
cover = UNSET
else:
cover = self.cover
title: Union[None, Unset, str]
if isinstance(self.title, Unset):
title = UNSET
else:
title = self.title
description: Union[None, Unset, str]
if isinstance(self.description, Unset):
description = UNSET
else:
description = self.description
owner: Union[None, Unset, str]
if isinstance(self.owner, Unset):
owner = UNSET
else:
owner = self.owner
owner_cover: Union[None, Unset, str]
if isinstance(self.owner_cover, Unset):
owner_cover = UNSET
else:
owner_cover = self.owner_cover
owner_link: Union[None, Unset, str]
if isinstance(self.owner_link, Unset):
owner_link = UNSET
else:
owner_link = self.owner_link
field_dict: Dict[str, Any] = {}
field_dict.update({})
if id is not UNSET:
field_dict["id"] = id
if playlist_link is not UNSET:
field_dict["playlistLink"] = playlist_link
if cover is not UNSET:
field_dict["cover"] = cover
if title is not UNSET:
field_dict["title"] = title
if description is not UNSET:
field_dict["description"] = description
if owner is not UNSET:
field_dict["owner"] = owner
if owner_cover is not UNSET:
field_dict["ownerCover"] = owner_cover
if owner_link is not UNSET:
field_dict["ownerLink"] = owner_link
return field_dict
@classmethod
def from_dict(cls: Type[T], src_dict: Dict[str, Any]) -> T:
d = src_dict.copy()
id = d.pop("id", UNSET)
def _parse_playlist_link(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
playlist_link = _parse_playlist_link(d.pop("playlistLink", UNSET))
def _parse_cover(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
cover = _parse_cover(d.pop("cover", UNSET))
def _parse_title(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
title = _parse_title(d.pop("title", UNSET))
def _parse_description(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
description = _parse_description(d.pop("description", UNSET))
def _parse_owner(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
owner = _parse_owner(d.pop("owner", UNSET))
def _parse_owner_cover(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
owner_cover = _parse_owner_cover(d.pop("ownerCover", UNSET))
def _parse_owner_link(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
owner_link = _parse_owner_link(d.pop("ownerLink", UNSET))
featured_playlist = cls(
id=id,
playlist_link=playlist_link,
cover=cover,
title=title,
description=description,
owner=owner,
owner_cover=owner_cover,
owner_link=owner_link,
)
return featured_playlist

View File

@ -0,0 +1,178 @@
from typing import Any, Dict, Type, TypeVar, Union, cast
from attrs import define as _attrs_define
from ..types import UNSET, Unset
T = TypeVar("T", bound="FeaturedPlaylistResponse")
@_attrs_define
class FeaturedPlaylistResponse:
"""
Attributes:
id (Union[Unset, int]):
playlist_link (Union[None, Unset, str]):
cover (Union[None, Unset, str]):
title (Union[None, Unset, str]):
description (Union[None, Unset, str]):
owner (Union[None, Unset, str]):
owner_cover (Union[None, Unset, str]):
owner_link (Union[None, Unset, str]):
"""
id: Union[Unset, int] = UNSET
playlist_link: Union[None, Unset, str] = UNSET
cover: Union[None, Unset, str] = UNSET
title: Union[None, Unset, str] = UNSET
description: Union[None, Unset, str] = UNSET
owner: Union[None, Unset, str] = UNSET
owner_cover: Union[None, Unset, str] = UNSET
owner_link: Union[None, Unset, str] = UNSET
def to_dict(self) -> Dict[str, Any]:
id = self.id
playlist_link: Union[None, Unset, str]
if isinstance(self.playlist_link, Unset):
playlist_link = UNSET
else:
playlist_link = self.playlist_link
cover: Union[None, Unset, str]
if isinstance(self.cover, Unset):
cover = UNSET
else:
cover = self.cover
title: Union[None, Unset, str]
if isinstance(self.title, Unset):
title = UNSET
else:
title = self.title
description: Union[None, Unset, str]
if isinstance(self.description, Unset):
description = UNSET
else:
description = self.description
owner: Union[None, Unset, str]
if isinstance(self.owner, Unset):
owner = UNSET
else:
owner = self.owner
owner_cover: Union[None, Unset, str]
if isinstance(self.owner_cover, Unset):
owner_cover = UNSET
else:
owner_cover = self.owner_cover
owner_link: Union[None, Unset, str]
if isinstance(self.owner_link, Unset):
owner_link = UNSET
else:
owner_link = self.owner_link
field_dict: Dict[str, Any] = {}
field_dict.update({})
if id is not UNSET:
field_dict["id"] = id
if playlist_link is not UNSET:
field_dict["playlistLink"] = playlist_link
if cover is not UNSET:
field_dict["cover"] = cover
if title is not UNSET:
field_dict["title"] = title
if description is not UNSET:
field_dict["description"] = description
if owner is not UNSET:
field_dict["owner"] = owner
if owner_cover is not UNSET:
field_dict["ownerCover"] = owner_cover
if owner_link is not UNSET:
field_dict["ownerLink"] = owner_link
return field_dict
@classmethod
def from_dict(cls: Type[T], src_dict: Dict[str, Any]) -> T:
d = src_dict.copy()
id = d.pop("id", UNSET)
def _parse_playlist_link(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
playlist_link = _parse_playlist_link(d.pop("playlistLink", UNSET))
def _parse_cover(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
cover = _parse_cover(d.pop("cover", UNSET))
def _parse_title(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
title = _parse_title(d.pop("title", UNSET))
def _parse_description(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
description = _parse_description(d.pop("description", UNSET))
def _parse_owner(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
owner = _parse_owner(d.pop("owner", UNSET))
def _parse_owner_cover(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
owner_cover = _parse_owner_cover(d.pop("ownerCover", UNSET))
def _parse_owner_link(data: object) -> Union[None, Unset, str]:
if data is None:
return data
if isinstance(data, Unset):
return data
return cast(Union[None, Unset, str], data)
owner_link = _parse_owner_link(d.pop("ownerLink", UNSET))
featured_playlist_response = cls(
id=id,
playlist_link=playlist_link,
cover=cover,
title=title,
description=description,
owner=owner,
owner_cover=owner_cover,
owner_link=owner_link,
)
return featured_playlist_response

View File

@ -0,0 +1,9 @@
from enum import Enum
class FollowerType(str, Enum):
FOLLOWERS = "followers"
FOLLOWING = "following"
def __str__(self) -> str:
return str(self.value)

View File

@ -0,0 +1,141 @@
from typing import TYPE_CHECKING, Any, Dict, Type, TypeVar, Union
from attrs import define as _attrs_define
from ..types import UNSET, Unset
if TYPE_CHECKING:
from ..models.clan import Clan
T = TypeVar("T", bound="GlobalMapHistory")
@_attrs_define
class GlobalMapHistory:
"""
Attributes:
id (Union[Unset, int]):
timestamp (Union[Unset, int]):
clan_id (Union[Unset, int]):
clan (Union[Unset, Clan]):
global_map_captured (Union[Unset, float]):
players_count (Union[Unset, int]):
pp (Union[Unset, float]):
rank (Union[Unset, int]):
average_rank (Union[Unset, float]):
average_accuracy (Union[Unset, float]):
capture_leaderboards_count (Union[Unset, int]):
"""
id: Union[Unset, int] = UNSET
timestamp: Union[Unset, int] = UNSET
clan_id: Union[Unset, int] = UNSET
clan: Union[Unset, "Clan"] = UNSET
global_map_captured: Union[Unset, float] = UNSET
players_count: Union[Unset, int] = UNSET
pp: Union[Unset, float] = UNSET
rank: Union[Unset, int] = UNSET
average_rank: Union[Unset, float] = UNSET
average_accuracy: Union[Unset, float] = UNSET
capture_leaderboards_count: Union[Unset, int] = UNSET
def to_dict(self) -> Dict[str, Any]:
id = self.id
timestamp = self.timestamp
clan_id = self.clan_id
clan: Union[Unset, Dict[str, Any]] = UNSET
if not isinstance(self.clan, Unset):
clan = self.clan.to_dict()
global_map_captured = self.global_map_captured
players_count = self.players_count
pp = self.pp
rank = self.rank
average_rank = self.average_rank
average_accuracy = self.average_accuracy
capture_leaderboards_count = self.capture_leaderboards_count
field_dict: Dict[str, Any] = {}
field_dict.update({})
if id is not UNSET:
field_dict["id"] = id
if timestamp is not UNSET:
field_dict["timestamp"] = timestamp
if clan_id is not UNSET:
field_dict["clanId"] = clan_id
if clan is not UNSET:
field_dict["clan"] = clan
if global_map_captured is not UNSET:
field_dict["globalMapCaptured"] = global_map_captured
if players_count is not UNSET:
field_dict["playersCount"] = players_count
if pp is not UNSET:
field_dict["pp"] = pp
if rank is not UNSET:
field_dict["rank"] = rank
if average_rank is not UNSET:
field_dict["averageRank"] = average_rank
if average_accuracy is not UNSET:
field_dict["averageAccuracy"] = average_accuracy
if capture_leaderboards_count is not UNSET:
field_dict["captureLeaderboardsCount"] = capture_leaderboards_count
return field_dict
@classmethod
def from_dict(cls: Type[T], src_dict: Dict[str, Any]) -> T:
from ..models.clan import Clan
d = src_dict.copy()
id = d.pop("id", UNSET)
timestamp = d.pop("timestamp", UNSET)
clan_id = d.pop("clanId", UNSET)
_clan = d.pop("clan", UNSET)
clan: Union[Unset, Clan]
if isinstance(_clan, Unset):
clan = UNSET
else:
clan = Clan.from_dict(_clan)
global_map_captured = d.pop("globalMapCaptured", UNSET)
players_count = d.pop("playersCount", UNSET)
pp = d.pop("pp", UNSET)
rank = d.pop("rank", UNSET)
average_rank = d.pop("averageRank", UNSET)
average_accuracy = d.pop("averageAccuracy", UNSET)
capture_leaderboards_count = d.pop("captureLeaderboardsCount", UNSET)
global_map_history = cls(
id=id,
timestamp=timestamp,
clan_id=clan_id,
clan=clan,
global_map_captured=global_map_captured,
players_count=players_count,
pp=pp,
rank=rank,
average_rank=average_rank,
average_accuracy=average_accuracy,
capture_leaderboards_count=capture_leaderboards_count,
)
return global_map_history

View File

@ -0,0 +1,164 @@
from typing import Any, Dict, Type, TypeVar, Union
from attrs import define as _attrs_define
from ..types import UNSET, Unset
T = TypeVar("T", bound="HistoryCompactResponse")
@_attrs_define
class HistoryCompactResponse:
"""
Attributes:
timestamp (Union[Unset, int]):
pp (Union[Unset, float]):
rank (Union[Unset, int]):
country_rank (Union[Unset, int]):
average_ranked_accuracy (Union[Unset, float]):
average_unranked_accuracy (Union[Unset, float]):
average_accuracy (Union[Unset, float]):
median_ranked_accuracy (Union[Unset, float]):
median_accuracy (Union[Unset, float]):
ranked_play_count (Union[Unset, int]):
unranked_play_count (Union[Unset, int]):
total_play_count (Union[Unset, int]):
ranked_improvements_count (Union[Unset, int]):
unranked_improvements_count (Union[Unset, int]):
total_improvements_count (Union[Unset, int]):
"""
timestamp: Union[Unset, int] = UNSET
pp: Union[Unset, float] = UNSET
rank: Union[Unset, int] = UNSET
country_rank: Union[Unset, int] = UNSET
average_ranked_accuracy: Union[Unset, float] = UNSET
average_unranked_accuracy: Union[Unset, float] = UNSET
average_accuracy: Union[Unset, float] = UNSET
median_ranked_accuracy: Union[Unset, float] = UNSET
median_accuracy: Union[Unset, float] = UNSET
ranked_play_count: Union[Unset, int] = UNSET
unranked_play_count: Union[Unset, int] = UNSET
total_play_count: Union[Unset, int] = UNSET
ranked_improvements_count: Union[Unset, int] = UNSET
unranked_improvements_count: Union[Unset, int] = UNSET
total_improvements_count: Union[Unset, int] = UNSET
def to_dict(self) -> Dict[str, Any]:
timestamp = self.timestamp
pp = self.pp
rank = self.rank
country_rank = self.country_rank
average_ranked_accuracy = self.average_ranked_accuracy
average_unranked_accuracy = self.average_unranked_accuracy
average_accuracy = self.average_accuracy
median_ranked_accuracy = self.median_ranked_accuracy
median_accuracy = self.median_accuracy
ranked_play_count = self.ranked_play_count
unranked_play_count = self.unranked_play_count
total_play_count = self.total_play_count
ranked_improvements_count = self.ranked_improvements_count
unranked_improvements_count = self.unranked_improvements_count
total_improvements_count = self.total_improvements_count
field_dict: Dict[str, Any] = {}
field_dict.update({})
if timestamp is not UNSET:
field_dict["timestamp"] = timestamp
if pp is not UNSET:
field_dict["pp"] = pp
if rank is not UNSET:
field_dict["rank"] = rank
if country_rank is not UNSET:
field_dict["countryRank"] = country_rank
if average_ranked_accuracy is not UNSET:
field_dict["averageRankedAccuracy"] = average_ranked_accuracy
if average_unranked_accuracy is not UNSET:
field_dict["averageUnrankedAccuracy"] = average_unranked_accuracy
if average_accuracy is not UNSET:
field_dict["averageAccuracy"] = average_accuracy
if median_ranked_accuracy is not UNSET:
field_dict["medianRankedAccuracy"] = median_ranked_accuracy
if median_accuracy is not UNSET:
field_dict["medianAccuracy"] = median_accuracy
if ranked_play_count is not UNSET:
field_dict["rankedPlayCount"] = ranked_play_count
if unranked_play_count is not UNSET:
field_dict["unrankedPlayCount"] = unranked_play_count
if total_play_count is not UNSET:
field_dict["totalPlayCount"] = total_play_count
if ranked_improvements_count is not UNSET:
field_dict["rankedImprovementsCount"] = ranked_improvements_count
if unranked_improvements_count is not UNSET:
field_dict["unrankedImprovementsCount"] = unranked_improvements_count
if total_improvements_count is not UNSET:
field_dict["totalImprovementsCount"] = total_improvements_count
return field_dict
@classmethod
def from_dict(cls: Type[T], src_dict: Dict[str, Any]) -> T:
d = src_dict.copy()
timestamp = d.pop("timestamp", UNSET)
pp = d.pop("pp", UNSET)
rank = d.pop("rank", UNSET)
country_rank = d.pop("countryRank", UNSET)
average_ranked_accuracy = d.pop("averageRankedAccuracy", UNSET)
average_unranked_accuracy = d.pop("averageUnrankedAccuracy", UNSET)
average_accuracy = d.pop("averageAccuracy", UNSET)
median_ranked_accuracy = d.pop("medianRankedAccuracy", UNSET)
median_accuracy = d.pop("medianAccuracy", UNSET)
ranked_play_count = d.pop("rankedPlayCount", UNSET)
unranked_play_count = d.pop("unrankedPlayCount", UNSET)
total_play_count = d.pop("totalPlayCount", UNSET)
ranked_improvements_count = d.pop("rankedImprovementsCount", UNSET)
unranked_improvements_count = d.pop("unrankedImprovementsCount", UNSET)
total_improvements_count = d.pop("totalImprovementsCount", UNSET)
history_compact_response = cls(
timestamp=timestamp,
pp=pp,
rank=rank,
country_rank=country_rank,
average_ranked_accuracy=average_ranked_accuracy,
average_unranked_accuracy=average_unranked_accuracy,
average_accuracy=average_accuracy,
median_ranked_accuracy=median_ranked_accuracy,
median_accuracy=median_accuracy,
ranked_play_count=ranked_play_count,
unranked_play_count=unranked_play_count,
total_play_count=total_play_count,
ranked_improvements_count=ranked_improvements_count,
unranked_improvements_count=unranked_improvements_count,
total_improvements_count=total_improvements_count,
)
return history_compact_response

View File

@ -0,0 +1,56 @@
from enum import Enum
class HMD(str, Enum):
ACERWMR = "acerWmr"
ARPARA = "arpara"
ASUSWMR = "asusWmr"
BIGSCREENBEYOND = "bigscreenbeyond"
CLOUDXR = "cloudxr"
CONTROLLABLE = "controllable"
DELLVISOR = "dellVisor"
DISCO = "disco"
E3 = "e3"
E4 = "e4"
GLASSES20 = "glasses20"
HEDY = "hedy"
HPREVERB = "hpReverb"
HUAWEIVR = "huaweivr"
HYPEREAL = "hypereal"
INDEX = "index"
LENOVOEXPLORER = "lenovoExplorer"
MEDION = "medion"
MEGANE1 = "megane1"
MIRAMAR = "miramar"
NOLOSONIC = "nolosonic"
PICONEO2 = "picoNeo2"
PICONEO3 = "picoNeo3"
PICONEO4 = "picoNeo4"
PIMAX5K = "pimax5k"
PIMAX8K = "pimax8k"
PIMAXARTISAN = "pimaxArtisan"
PIMAXCRYSTAL = "pimaxCrystal"
PSVR2 = "psvr2"
QIYUDREAM = "qiyuDream"
QUEST = "quest"
QUEST2 = "quest2"
QUEST3 = "quest3"
QUESTPRO = "questPro"
RIFT = "rift"
RIFTS = "riftS"
SAMSUNGWMR = "samsungWmr"
UNKNOWN = "unknown"
VAPOREON = "vaporeon"
VARJOAERO = "varjoaero"
VIVE = "vive"
VIVECOSMOS = "viveCosmos"
VIVEDVT = "viveDvt"
VIVEELITE = "viveElite"
VIVEFOCUS = "viveFocus"
VIVEPRO = "vivePro"
VIVEPRO2 = "vivePro2"
VRIDGE = "vridge"
WMR = "wmr"
def __str__(self) -> str:
return str(self.value)

View File

@ -0,0 +1,10 @@
from enum import Enum
class InfoToHighlight(str, Enum):
NONE = "none"
PLAYCOUNT = "playCount"
WATCHCOUNT = "watchCount"
def __str__(self) -> str:
return str(self.value)

Some files were not shown because too many files have changed in this diff Show More