Skip to main content

ParseScore - A client for collecting character data and adding it to the WoW addon

Project description

ParseScore

ParseScore is a system for collecting, processing, and displaying player performance data from Warcraft Logs.

Components

The system consists of three main components:

  1. Client: Fetches data from the server and converts it to a format usable by the addon

Features

  • Scheduled data collection that runs hourly
  • Error recovery mechanisms for API outages and rate limiting
  • Comprehensive logging system
  • Data validation for consistency and quality
  • Configuration system for customizable collection parameters

Setup

  1. Ensure you have Python 3.14 or later installed
  2. Create a virtual environment:
    uv venv
    
  3. Activate the virtual environment:
    # On Windows (PowerShell):
    .\.venv\Scripts\Activate.ps1
    # On Windows (Command Prompt):
    .venv\Scripts\activate
    # On Unix/MacOS:
    source .venv/bin/activate
    
  4. Install dependencies:
    uv sync
    
  5. Set up environment variables in a .env file:
    WCL_CLIENT_ID=your_client_id
    WCL_CLIENT_SECRET=your_client_secret
    WCL_TOKEN=your_token
    WCL_RECENT_REPORTS_URL=your_reports_url
    

Configuration

The server can be configured using a config.yaml file in the project root. If this file doesn't exist, a default one will be created when the server is first run.

The configuration file has the following sections:

  • api: API-related settings (rate limits, timeouts, etc.)
  • data_collection: Settings for the data collection process
  • database: Database settings
  • logging: Logging configuration
  • urls: URL settings
  • zones: Zone ID settings

Example configuration:

api:
  rate_limit: 9000
  rate_limit_threshold: 8500
  max_retries: 5
  timeout: 60
  batch_interval: 1
data_collection:
  schedule_interval_seconds: 3600  # 1 hour
  max_reports_to_process: 10
  concurrent_requests: 5
database:
  path: db.sqlite3
  backup_interval_days: 7
  max_backups: 5
logging:
  file: logs/server.log
  rotation: 10 MB
  retention: 1 week
  format: "{time:YYYY-MM-DD HH:mm:ss} | {level} | {message}"
  level: INFO
urls:
  recent_reports: https://www.example.com/reports
  api_endpoint: https://www.warcraftlogs.com/api/v2/client
zones:
  current_zone_id: 43

Running the Server

To run the server with the default scheduled task system:

python -m src.server.main

To run the data collection task once and exit:

python -m src.server.main --run-once

To test the configuration system:

python -m src.server.main --test-config

Alternatively, you can use the test script:

python -m tests.test_config

Client

The client is a Python application that fetches data from the server and converts it to a format usable by the addon.

Client implementation is in progress.

Addon

The addon is a World of Warcraft addon that displays player performance data in-game.

Addon implementation is in progress.

Development

Running Tests

To run the tests:

python -m pytest

Code Style

The project uses ruff for linting and formatting:

# Check for linting errors and apply automatic fixes
ruff check --fix .

# Format all files
ruff format .

Type Checking

The project uses ty for static type checking:

ty check .

Project details


Download files

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

Source Distribution

parsescore_client-0.15.tar.gz (5.5 kB view details)

Uploaded Source

Built Distribution

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

parsescore_client-0.15-py3-none-any.whl (7.4 kB view details)

Uploaded Python 3

File details

Details for the file parsescore_client-0.15.tar.gz.

File metadata

  • Download URL: parsescore_client-0.15.tar.gz
  • Upload date:
  • Size: 5.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for parsescore_client-0.15.tar.gz
Algorithm Hash digest
SHA256 c0260a19efe4a5cea46887eecc79185499a8a49b850e73290fc6301c4c439a86
MD5 ddda296aa80f440e36d701c7a419bec4
BLAKE2b-256 3787b47b6a8a71c857acdcc4d21fb587d2bd6a0746f69373cdd8b08279ceca5a

See more details on using hashes here.

Provenance

The following attestation bundles were made for parsescore_client-0.15.tar.gz:

Publisher: publish.yml on Krytos/parsescore-client

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file parsescore_client-0.15-py3-none-any.whl.

File metadata

File hashes

Hashes for parsescore_client-0.15-py3-none-any.whl
Algorithm Hash digest
SHA256 8dde3c42336e6b7ec7ee8c87cc680be6c24c9987cf94633692834161d7573466
MD5 c7bf34f10c848f616f268243cd73061f
BLAKE2b-256 f12ec528796d0aa52f7e1eaf10c554e210c43e715bb00ee0659271fb14e07aaf

See more details on using hashes here.

Provenance

The following attestation bundles were made for parsescore_client-0.15-py3-none-any.whl:

Publisher: publish.yml on Krytos/parsescore-client

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page