Skip to main content

Another Fleet Activity Tracking tool for Alliance Auth

Project description

Alliance Auth AFAT - Another Fleet Activity Tracker

Version License Python Django pre-commit PyPI Downloads Code Style: black Discord

An Improved FAT/PAP System for Alliance Auth.

Contents

Features and highlights

  • Automatic tracking of participation on FAT links created via ESI
  • Multiple ESI fleets (with your alts)
  • Manually end ESI tracking per fleet
  • Fleet type classification (can be added in the admin backend)
  • Ship type overview per FAT link
  • Graphical statistics views
  • Custom module name
  • Re-open FAT link if the FAT link has expired and is within the defined grace time (only for clickable FAT links)
  • Manually add pilots to clickable FAT links, in case they missed to click the link (for a period of 24 hours after the FAT links original expiry time)
  • Log for the following actions (Logs are kept for a certain time, 60 days per default):
    • Create FAT link
    • Change FAT link
    • Remove FAT link
    • Re-open FAT link
    • Manually add pilot to FAT link
    • Remove pilot from FAT link

AFAT will work alongside the built-in native FAT System, bFAT and ImicusFAT. However, data does not share, but you can migrate their data to AFAT, for more information see below.

Screenshots

Dashboard

AFAT Dashboard

FAT link list

AFAT FAT Link LIst

FAT link details

AFAT FAT Link Details

Add FAT link view for FCs

AFAT Add FAT Link

Installation

Important

This app is a plugin for Alliance Auth. If you don't have Alliance Auth running already, please install it first before proceeding. (see the official AA installation guide for details)

For users migrating from one of the other FAT systems, please read the specific instructions FIRST.

Step 1 - Install the app

Make sure you are in the virtual environment (venv) of your Alliance Auth installation. Then install the latest version:

pip install allianceauth-afat

Step 2 - Update your AA settings

Configure your AA settings in your local.py as follows:

  • Add 'afat', to INSTALLED_APPS
  • Add the scheduled tasks
# AFAT - https://github.com/ppfeufer/allianceauth-afat
CELERYBEAT_SCHEDULE["afat_update_esi_fatlinks"] = {
    "task": "afat.tasks.update_esi_fatlinks",
    "schedule": crontab(minute="*/1"),
}

CELERYBEAT_SCHEDULE["afat_logrotate"] = {
    "task": "afat.tasks.logrotate",
    "schedule": crontab(minute="0", hour="1"),
}

Step 3 - Finalize the installation

Run migrations & copy static files

python manage.py collectstatic
python manage.py migrate

Restart your supervisor services for AA.

Updating

To update your existing installation of AFAT, first enable your virtual environment (venv) of your Alliance Auth installation.

pip install -U allianceauth-afat

python manage.py collectstatic
python manage.py migrate

Finally restart your supervisor services for AA

It is possible that some versions need some more changes. Always read the release notes to find out more.

Data Migration

Right after the initial installation and running migrations, you can import the data from Alliance Auth's native FAT system, from bFAT or from ImicusFAT if you have used one of these until now.

Import from native FAT

To import from the native FAT module, simply run the following command:

python myauth/manage.py afat_import_from_allianceauth_fat

Import from bFAT

To import from the bFAT module, simply run the following command:

python myauth/manage.py afat_import_from_bfat

Import from ImicusFAT

First, you need to remove all "deleted" FAT links and FATs.

This step needs to be done, because we cannot import entries marked as "deleted" due to the way Django is handling this, and some other entries might rely on them, so we need to meke sure the "deleted" data doesn't cause any trouble. You don't need to worry, you are not losing any data that is/was actively used besides what is already marked as "deleted" and ImicusFAT is no longer working with it anyways and never did.

To do so, login to your mysql database and run the following commands:

# de-activate foreign key checks
SET FOREIGN_KEY_CHECKS=0;

# remove all "deleted" FATs
delete from imicusfat_ifat where deleted_at is not null;

# remove all "deleted" fat link types
delete from imicusfat_ifatlinktype where deleted_at is not null;

# get all fatlink IDs of "deleted" fatlinks as comma separated list and make sure
# to have that in your notepad saved, you need this list for the next comamnds
select group_concat(id) from imicusfat_ifatlink where deleted_at is not null;

# now remove everything that is related to those IDs
# make sure to replace "id_list" with the comma separated
# list of IDs from the earlier command
delete from imicusfat_clickifatduration where fleet_id in (id_list);
delete from imicusfat_ifat where ifatlink_id in (id_list);
delete from imicusfat_ifatlink where id in(id_list);

# re-activate foreign key checks
SET FOREIGN_KEY_CHECKS=1;

Once done, start the actual import script like this:

python myauth/manage.py afat_import_from_imicusfat

Settings

To customize the module, the following settings are available.

Name Description Default Value
AFAT_APP_NAME Custom application name, in case you'd like a different name Fleet Activity Tracking
AFAT_DEFAULT_FATLINK_EXPIRY_TIME Default expiry time for clickable FAT links in Minutes 60
AFAT_DEFAULT_FATLINK_REOPEN_GRACE_TIME Time in minutes a FAT link can be re-opened after it has expired 60
AFAT_DEFAULT_FATLINK_REOPEN_DURATION Time in minutes a FAT link is re-opened 60
AFAT_DEFAULT_LOG_DURATION Time in days before log entries are being removed from the DB 60

Permissions

Name Description Notes
basic_access Can access the AFAT module Your line member probably want this permission, so they can see the module and click the FAT links they are given. They also can see their own statistics with this permission.
manage_afat Can manage the AFAT module Your Military lead probably should get this permission
add_fatlink Can create FAT Links Your regular FC or who ever should be able to add FAT links should have this permission
stats_corporation_own Can see own corporation statistics
stats_corporation_other Can see statistics of other corporations
logs_view Can view the modules logs

Changelog

To keep track of all changes, please read the Changelog.

Contributing

You want to contribute to this project? That's cool!

Please make sure to read the contribution guidelines (I promise, it's not much, just some basics)

Credits

AFAT is maintained by @ppfeufer is based on ImicusFAT maintained by @exiom with @Aproia and @ppfeufer (no longer) which is based on allianceauth-bfat by @colcrunch

Project details


Release history Release notifications | RSS feed

Download files

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

Source Distribution

allianceauth-afat-2.2.6.tar.gz (622.4 kB view details)

Uploaded Source

Built Distribution

allianceauth_afat-2.2.6-py3-none-any.whl (665.2 kB view details)

Uploaded Python 3

File details

Details for the file allianceauth-afat-2.2.6.tar.gz.

File metadata

  • Download URL: allianceauth-afat-2.2.6.tar.gz
  • Upload date:
  • Size: 622.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.6.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.61.2 CPython/3.8.11

File hashes

Hashes for allianceauth-afat-2.2.6.tar.gz
Algorithm Hash digest
SHA256 a564bcb1b137716d2511374894f44cbce60d7721034a4a03d16e203c4db48d9f
MD5 f6d3aa14856d98b1a7e64df331438ba7
BLAKE2b-256 546bdd84e621b1e75280e5b0de1b27484c993b5754e5ac6c305992188feebb60

See more details on using hashes here.

File details

Details for the file allianceauth_afat-2.2.6-py3-none-any.whl.

File metadata

  • Download URL: allianceauth_afat-2.2.6-py3-none-any.whl
  • Upload date:
  • Size: 665.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.6.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.61.2 CPython/3.8.11

File hashes

Hashes for allianceauth_afat-2.2.6-py3-none-any.whl
Algorithm Hash digest
SHA256 38c4a24b95647c7ec26fc7b98cbd2f70d2294c364418d502a80e68b8d33cf9f4
MD5 28bba34a344807fe307c7226d3474f4c
BLAKE2b-256 c2ccfb727332946dd9dc5351f8a941c3665330f3dc5837b9cbb50d09ce8466ab

See more details on using hashes here.

Supported by

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