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.17.tar.gz (5.9 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.17-py3-none-any.whl (7.8 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: parsescore_client-0.17.tar.gz
  • Upload date:
  • Size: 5.9 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.17.tar.gz
Algorithm Hash digest
SHA256 f952cf55b8c016480da6aeac41992064111bcb018beb75a5713f57211bea0aaa
MD5 371c9e711a5608fcfa3ecddbefa5dac2
BLAKE2b-256 20456b4c9476ffc5b4afcbd81e6700f1f070896a6ee0fe261d84dbb3ad1220de

See more details on using hashes here.

Provenance

The following attestation bundles were made for parsescore_client-0.17.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.17-py3-none-any.whl.

File metadata

File hashes

Hashes for parsescore_client-0.17-py3-none-any.whl
Algorithm Hash digest
SHA256 4281157ebc1001725c6fe48d2f57b9f5f2785fc659c8d00ab8cf85b90fb0a22e
MD5 43e828891a9e9ef77f2f1a83b8d639f5
BLAKE2b-256 d8bf9080050392ae596b5e66df5d7d77e358101407860af6a05f9075d5991c23

See more details on using hashes here.

Provenance

The following attestation bundles were made for parsescore_client-0.17-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