Skip to main content

An app that helps keep track of installed packages and outstanding updates for Alliance Auth

Project description

Package Monitor

An app for keeping track of installed packages and outstanding updates with Alliance Auth.

release python django pipeline codecov license pre-commit Code style: black chat

Contents

Overview

Package Monitor is an app for Alliance Auth that helps you keep your installation up-to-date. It shows you all installed distributions packages and will automatically notify you, when there are updates available.

Features:

  • Shows list of installed distributions packages with related Django apps (if any)
  • Identifies new valid releases for installed packages on PyPI
  • Notifies user which installed packages are outdated and should be updated
  • Shows the number of outdated packages as badge in the sidebar
  • Takes into account the requirements of all installed packages and the current Python version when recommending updates
  • Option to add distribution pages to the monitor which are not related to Django apps
  • Option to show all known distribution packages (as opposed to only the ones that belong to installed Django apps)
  • Copy the respective command for a package update to your clipboard directly from the package list
  • Can automatically notify admins when there is an update available for a currently installed package

Hint: Update notifications are sent as AA notifications to all admins. We recommend using Discord Notify to automatically forward those notifications to Discord as DMs.

Screenshots

screenshot

Installation

Step 1 - Check Preconditions

Please make sure you meet all preconditions before proceeding:

  • Package Monitor 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)

Step 2 - Install app

Make sure you are in the virtual environment (venv) of your Alliance Auth installation. Then install the newest release from PYPI:

pip install aa-package-monitor

Step 3 - Configure settings

Add 'package_monitor' to INSTALLED_APPS.

Add the following lines to your local.py to enable regular checking for updates:

CELERYBEAT_SCHEDULE['package_monitor_update_distributions'] = {
    'task': 'package_monitor.tasks.update_distributions',
    'schedule': crontab(minute='*/60'),
}

Step 4 - Finalize installation

Run migrations & copy static files

python manage.py migrate
python manage.py collectstatic

Restart your supervisor services for Auth

Step 5 - Initial data load

Last, but not least perform an initial data load of all distribution packages by running the following command:

python manage.py package_monitor_refresh

Updating

pip install -U aa-package-monitor

python manage.py collectstatic

python manage.py migrate

Finally restart your AA supervisor services.

User Guide

This section explains how to use the app.

Terminology

To avoid any confusion here are our definitions of some important terms:

  • App: A Django application. An app is always part of a distribution package
  • Distribution package A Python package that can be installed via pip or setuptools. Distribution packages can contain several apps.
  • Requirement: A requirement is a condition that distribution packages can define to specify dependencies to environments or other distribution packages with specific versions. For example the distribution package django-eveuniverse can have the requirement "django-esi>=2.0", which means is requires the package django-esi in at leasts version 2.0

Operation modes

You can run Package Monitor in one of two modes:

  • Keep everything updated
  • Keep apps and selected distribution packages updated

Keep everything updated

In this mode Package Monitor will monitor all installed distribution packages. In this mode you will be informed you about updates to any of your distribution packages.

This is the default operation mode.

Keep apps and selected distribution packages updated

With this mode Package Monitor will monitor only those distribution packages that contain actually installed Django apps. In this mode you will be informed if there is an update to any of your apps. Note that in mode A other installed distributions packages will not be shown.

To activate this mode set PACKAGE_MONITOR_SHOW_ALL_PACKAGES to False in your local settings.

You can also add some additional distributions to be monitored. For example you might want to add celery.

See also Settings for an overview of all settings.

Latest version

Package Monitor will automatically determine a latest version for a distribution package from PyPI. Note that this can differ from the latest version shown on PyPI, because of additional considerations:

First, Package Monitor will take into account all requirements of all installed distribution packages. For example if the Alliance Auth has the requirement "Django<3", then it will only show Django 2.x as latest, since Django 3.x would not fullfil the requirement set by Alliance Auth.

Second, Package Monitor will in general ignore pre-releases and consider stable releases for updates only. The only exception is if the current package also is a pre release. For example you may have Black installed as beta release, therefore the app will also suggest newer beta releases.

Settings

Here is a list of available settings for this app. They can be configured by adding them to your AA settings file (local.py).

Note that all settings are optional and the app will use the documented default settings if they are not used.

Name Description Default
PACKAGE_MONITOR_EXCLUDE_PACKAGES Names of distribution packages to excluded from monitoring. []
PACKAGE_MONITOR_INCLUDE_PACKAGES Names of additional distribution packages to be monitored, e.g. ["celery", "redis]. This setting only makes sense when you are not monitoring all packages already. []
PACKAGE_MONITOR_NOTIFICATIONS_ENABLED Whether to notify when an update is available for a currently installed distribution package. Notifications will be sent as AA notification to all admins. False
PACKAGE_MONITOR_SHOW_ALL_PACKAGES Whether to monitor all distribution packages, as opposed to only monitoring packages that contain Django apps. True
PACKAGE_MONITOR_SHOW_EDITABLE_PACKAGES Whether to show distribution packages installed as editable. Since version information about editable packages is often outdated, this type of packages are not shown by default. False

Permissions

This is an overview of all permissions used by this app. Note that all permissions are in the "general" section.

Name Purpose Code
Can access this app and view User can access the app and also request updates to the list of distribution packages general.basic_access

Management Commands

The following management commands are included in this app:

Command Description
package_monitor_refresh Refreshes all data about distribution packages. This command does functionally the same as the hourly update and is helpful to use after you have completed updating outdated packages to quickly see the result of your actions on the website.

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-package-monitor-1.8.1.tar.gz (74.3 kB view details)

Uploaded Source

Built Distribution

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

aa_package_monitor-1.8.1-py3-none-any.whl (81.8 kB view details)

Uploaded Python 3

File details

Details for the file aa-package-monitor-1.8.1.tar.gz.

File metadata

  • Download URL: aa-package-monitor-1.8.1.tar.gz
  • Upload date:
  • Size: 74.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.8.16

File hashes

Hashes for aa-package-monitor-1.8.1.tar.gz
Algorithm Hash digest
SHA256 ea93894c131e42b196da4c3d576524d83352a89958485e1f135018e222225770
MD5 9560d8dc7774619c3066f7eb6e5d82d0
BLAKE2b-256 8d797d71fcd70f7615f8d26ce295cfa08b0415467db85ae878e102e3debb3a1c

See more details on using hashes here.

File details

Details for the file aa_package_monitor-1.8.1-py3-none-any.whl.

File metadata

File hashes

Hashes for aa_package_monitor-1.8.1-py3-none-any.whl
Algorithm Hash digest
SHA256 1f73e177c1a5bf522afc42a368620b171f055a5b8ab3ce28757be5d60d90f008
MD5 be558544e7ecfeb0be0c4a66c4c98f4e
BLAKE2b-256 e19f16b2784bbb93d6d93a4e55439c4a0b2ef5efb9b700f5dec22f9a6a254257

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