Skip to main content

Industry Plugin for Alliance Auth (GitHub Version)

Project description

Alliance Auth Industry Plugin

A powerful plugin for Alliance Auth to help corporation and alliance members track their EVE Online industry operations. This app utilizes the EVE Swagger Interface (ESI) to synchronize industry jobs directly into your Alliance Auth environment.

Features

  • Personal Dashboard: Users can easily track their active, completed, and delivered industry jobs.
  • Corporate Dashboard: Directors and Managers can monitor all corporate industry jobs from a centralized overview.
  • Member Portal (Self-Service): Members can request hulls, structures, or components, paste EFT fits directly to automatically parse requirements, and receive real-time quotes.
  • Industrialist Dashboard (Job Market): Corp builders can claim automated production tasks, track their history, and compete on the Gamification Leaderboards.
  • Director Control Panel: Complete ERP solution for directors to manage orders, prioritize tasks, analyze missing stock, and set rules for Material Efficiency and Prices.
  • Core Engine & Automation: Automated Celery tasks to synchronize Corporate ESI Hangars, calculate complex Bills of Materials (SDE vs Fuzzwork API), and trigger jobs based on Target Thresholds.
  • Planetary Interaction (PI): Monitor PI planets, extractor pins, production facilities, and countdown timers for active extraction.
  • Discord Integration: Receive automatic Direct Messages via Discord when a personal industry job finishes.
  • DataTables: Clean, sortable, and searchable tables for quick insights.
  • Countdown Timers: Real-time countdown timers indicating exactly when active jobs will finish.
  • SDE Integration: Resolves blueprint and product Type IDs into readable names and official EVE Online icons.

Prerequisites

Before installing this plugin, ensure your Alliance Auth instance meets the following requirements:

  • Alliance Auth v5.x
  • django-esi v4.0.0+ (Included by default in Alliance Auth v5.x)
  • django-eveuniverse: Used for resolving Type IDs to Item Names and Icons.
  • Alliance Auth Discord Service: Required if you want users to receive Direct Messages upon job completion.
  • A working Celery setup (standard in Alliance Auth) for background synchronization tasks.

Installation

  1. Activate your virtual environment:

    source /path/to/venv/bin/activate
    
  2. Install the App: From your application directory (or via PyPI if published):

    pip install -e /path/to/aa-industry
    
  3. Configure Settings: Add the app and its dependencies to your INSTALLED_APPS inside myauth/settings/local.py:

    INSTALLED_APPS += [
        "eveuniverse",
        "industry_reforged",
    ]
    
  4. Run Migrations: Update your database to include the new models.

    python manage.py makemigrations
    python manage.py migrate
    
  5. Restart Services: Restart your Gunicorn/Supervisor and Celery worker so the changes take effect.

    sudo systemctl restart myauth
    sudo systemctl restart myauth-celery
    

Configuration & Usage

1. Load EveUniverse Data

Since this plugin relies on django-eveuniverse to resolve Item Types, make sure the basic EVE universe data is loaded. You may need to run the standard EveUniverse load commands to pull the latest SDE types if you haven't already.

2. Permissions

Assign the following permissions in the Django Admin panel:

  • industry.basic_access: Grants access to the Personal Dashboard (intended for all members).
  • industry.corp_access: Grants access to the Corporate Dashboard (intended for Directors or Industry Managers).

3. Required ESI Scopes (SSO Grants)

This plugin requires specific ESI scopes depending on the features you want to use. Make sure these are configured in your Alliance Auth Eve Online SSO settings:

  • esi-industry.read_character_jobs.v1: Required for Personal Dashboard. Users grant this via the "Add Personal Token" button.
  • esi-industry.read_corporation_jobs.v1: Required for Corporate Dashboard. Directors grant this via the "Add Corporate Token" button.
  • esi-planets.manage_planets.v1: Required for Planetary Interaction tracking. Users grant this via the AA Tokens page.
  • esi-assets.read_corporation_assets.v1: Required for the Core Engine to synchronize Corporate Inventory Hangars. Directors grant this via the "Add Corporate Token" button.
  • esi-universe.read_structures.v1: Required to resolve public Upwell structure names in EVE. Directors grant this via the "Add Corporate Token" button.
  • esi-corporations.read_structures.v1: Required for the Director Control Panel to discover and resolve names for structures owned by the corporation. Directors grant this via the "Add Corporate Token" button.

4. Corporate Inventory Setup

To track your corporate inventory, you must explicitly configure which hangars to track (to avoid syncing thousands of irrelevant items and hitting ESI rate limits):

  1. Navigate to the Director Dashboard and click Configurations.
  2. Click the Discover Hangars button to scan your corporation's assets via ESI.
  3. Add the specific hangars (e.g. "Corp Hangar 1") that you want to track.
  4. Go to the Director Inventory page and click the Sync Inventory button to manually force an initial sync. After that, the background Celery task will keep it updated.

Note: For Corporate Syncs, an Admin must link the Director character in the Django Admin interface under Corporation Sync Configuration.

5. Background Syncing

The app relies on Celery tasks to periodically fetch data from EVE Online. To run these tasks automatically, add the following to your myauth/settings/local.py:

from celery.schedules import crontab

if "CELERYBEAT_SCHEDULE" not in locals():
    CELERYBEAT_SCHEDULE = {}

CELERYBEAT_SCHEDULE["industry_update_character_jobs"] = {
    "task": "industry_reforged.tasks.update_character_jobs",
    "schedule": crontab(minute="*/30"),
}

CELERYBEAT_SCHEDULE["industry_update_corporation_jobs"] = {
    "task": "industry_reforged.tasks.update_corporation_jobs",
    "schedule": crontab(minute="*/30"),
}

CELERYBEAT_SCHEDULE["industry_update_character_pi"] = {
    "task": "industry_reforged.tasks.update_character_pi",
    "schedule": crontab(minute="0"),
}

CELERYBEAT_SCHEDULE["industry_sync_corp_inventory"] = {
    "task": "industry_reforged.tasks.task_sync_corp_inventory",
    "schedule": crontab(minute="*/15"),
}

CELERYBEAT_SCHEDULE["industry_pull_market_data"] = {
    "task": "industry_reforged.tasks.task_pull_market_data",
    "schedule": crontab(hour="11", minute="30"),  # Around EVE Downtime
}

After updating local.py, be sure to restart your Celery worker and Celery Beat services.

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

aa_industry_reforged-0.1.0b1.tar.gz (62.4 kB view details)

Uploaded Source

Built Distribution

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

aa_industry_reforged-0.1.0b1-py3-none-any.whl (81.7 kB view details)

Uploaded Python 3

File details

Details for the file aa_industry_reforged-0.1.0b1.tar.gz.

File metadata

  • Download URL: aa_industry_reforged-0.1.0b1.tar.gz
  • Upload date:
  • Size: 62.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.8

File hashes

Hashes for aa_industry_reforged-0.1.0b1.tar.gz
Algorithm Hash digest
SHA256 c197e0d8d67c7f9e34e3dc9af1a43d676ed313e5efd66a6e6d580d0faa68fd22
MD5 3c28b3940cd87e77f5e1f658379664ed
BLAKE2b-256 d7b62d6dbe15cffdbf212942e91b36b6514eafe725ed32481e62aa01f78a29c0

See more details on using hashes here.

File details

Details for the file aa_industry_reforged-0.1.0b1-py3-none-any.whl.

File metadata

File hashes

Hashes for aa_industry_reforged-0.1.0b1-py3-none-any.whl
Algorithm Hash digest
SHA256 684bfa5e00618f4fe689991c1ef80cd3dbf37b27aff405f1e8778166280316ce
MD5 e27b3c4383b05a5506ce1cedc920bcca
BLAKE2b-256 0eb1ec54a4f7fd05320cb72932433f0d51f2cfb8521217ae4cc5dfb57feb15b0

See more details on using hashes here.

Supported by

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