From 170b246901cfa0cf274c0c73cf6d0b8ae895d559 Mon Sep 17 00:00:00 2001 From: Erik Kalkoken Date: Fri, 3 Apr 2020 12:03:34 +0000 Subject: [PATCH] Extend developer docs --- .gitignore | 3 + docs/_static/images/development/aa_core.png | Bin 0 -> 197704 bytes docs/conf.py | 12 +- .../dev_setup/aa-dev-setup-wsl-vsc-v2.md | 463 ++++++++++++++++++ docs/development/dev_setup/index.md | 10 + docs/development/index.md | 2 + docs/development/tech_docu/api/esi.rst | 39 ++ docs/development/tech_docu/api/evelinks.rst | 30 ++ docs/development/tech_docu/api/eveonline.rst | 15 + docs/development/tech_docu/api/index.md | 13 + docs/development/tech_docu/api/testutils.rst | 14 + docs/development/tech_docu/celery.md | 204 ++++++++ docs/development/tech_docu/core_models.md | 5 + docs/development/tech_docu/index.md | 13 + docs/development/tech_docu/templatetags.rst | 16 + docs/installation/allianceauth.md | 5 +- 16 files changed, 840 insertions(+), 4 deletions(-) create mode 100644 docs/_static/images/development/aa_core.png create mode 100644 docs/development/dev_setup/aa-dev-setup-wsl-vsc-v2.md create mode 100644 docs/development/dev_setup/index.md create mode 100644 docs/development/tech_docu/api/esi.rst create mode 100644 docs/development/tech_docu/api/evelinks.rst create mode 100644 docs/development/tech_docu/api/eveonline.rst create mode 100644 docs/development/tech_docu/api/index.md create mode 100644 docs/development/tech_docu/api/testutils.rst create mode 100644 docs/development/tech_docu/celery.md create mode 100644 docs/development/tech_docu/core_models.md create mode 100644 docs/development/tech_docu/index.md create mode 100644 docs/development/tech_docu/templatetags.rst diff --git a/.gitignore b/.gitignore index 3e3eff98..c75ddefa 100644 --- a/.gitignore +++ b/.gitignore @@ -72,3 +72,6 @@ celerybeat-schedule #transifex .tx/ + +#other +.flake8 diff --git a/docs/_static/images/development/aa_core.png b/docs/_static/images/development/aa_core.png new file mode 100644 index 0000000000000000000000000000000000000000..fd31736521d5150759dbf9a20c08dbe87cc358ed GIT binary patch literal 197704 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 S5Rnjx3}!Eybxq%T&;J2{d@K0? literal 0 HcmV?d00001 diff --git a/docs/conf.py b/docs/conf.py index 2313fc8c..3e06966d 100644 --- a/docs/conf.py +++ b/docs/conf.py @@ -18,7 +18,10 @@ # import os import sys -sys.path.insert(0, os.path.abspath('.')) +import django +sys.path.insert(0, os.path.abspath('..')) +os.environ['DJANGO_SETTINGS_MODULE'] = 'tests.settings_all' +django.setup() # on_rtd is whether we are on readthedocs.org, this line of code grabbed from docs.readthedocs.org on_rtd = os.environ.get('READTHEDOCS', None) == 'True' @@ -38,7 +41,9 @@ from recommonmark.transform import AutoStructify # Add any Sphinx extension module names here, as strings. They can be # extensions coming with Sphinx (named 'sphinx.ext.*') or your custom # ones. -extensions = [] +extensions = [ + 'sphinx.ext.autodoc', +] # Add any paths that contain templates here, relative to this directory. templates_path = ['_templates'] @@ -148,6 +153,9 @@ man_pages = [ [author], 1) ] +# -- Options for autodoc ------------------------------------------------- + +add_module_names = False # -- Options for Texinfo output ------------------------------------------- diff --git a/docs/development/dev_setup/aa-dev-setup-wsl-vsc-v2.md b/docs/development/dev_setup/aa-dev-setup-wsl-vsc-v2.md new file mode 100644 index 00000000..0e1436ab --- /dev/null +++ b/docs/development/dev_setup/aa-dev-setup-wsl-vsc-v2.md @@ -0,0 +1,463 @@ +# Development on Windows 10 with WSL and Visual Studio Code + +This document describes step-by-step how to setup a complete development environment for Alliance Auth apps on Windows 10 with Windows Subsystem for Linux (WSL) and Visual Studio Code. + +The main benefit of this setup is that it runs all services and code in the native Linux environment (WSL) and at the same time can be full controlled from within a comfortable Windows IDE (Visual Studio Code) including code debugging. + +In addition all tools described in this guide are open source or free software. + +```eval_rst +.. hint:: + This guide is meant for development purposes only and not for installing AA in a production environment. For production installation please see chapter **Installation**. +``` + +## Overview + +The development environment consists of the following components: + +- Visual Studio Code with Remote WSL and Python extension +- WSL with Ubunutu 18.04. LTS +- Python 3.6 environment on WSL +- MySQL server on WSL +- Redis on WSL +- Alliance Auth on WSL +- Celery on WSL + +We will use the build-in Django development webserver, so we don't need to setup a WSGI server or a web server. + +## Requirement + +The only requirement is a PC with Windows 10 and Internet connection in order to download the additional software components. + +## Windows installation + +### Windows Subsystem for Linux + +- Install from here: [Microsoft docs](https://docs.microsoft.com/en-us/windows/wsl/install-win10) + +- Choose Ubuntu 18.04. LTS + +### Visual Studio Code + +- Install from here: [VSC Download](https://code.visualstudio.com/Download) + +- Open the app and install the following VSC extensions: + +- Remote WSL + +- Connect to WSL. This will automatically install the VSC server on the VSC server for WSL + +- Once connected to WSL install the Python extension on the WSL side + +## WSL Installation + +Open a WSL bash and update all software packets: + +```bash +sudo apt update && sudo apt upgrade -y +``` + +### Install Tools + +```bash +sudo apt-get install build-essential +sudo apt-get install gettext +``` + +### Install Python + +For AA we want to develop with Python 3.6, because that provides the maximum compatibility with today's AA installations. This also happens to be the default Python 3 version for Ubuntu 18.04. at the point of this writing. + +```eval_rst +.. hint:: + To check your system's Python 3 version you can enter: ``python3 --version`` +``` + +```eval_rst +.. note:: + Should your Ubuntu come with a newer version of Python we recommend to still setup your dev environment with the oldest Python 3 version supported by AA, e.g Python 3.6 + You an check out this `page `_ on how to install additional Python versions on Ubuntu. +``` + +Use the following command to install Python 3 with all required libraries with the default version: + +```bash +sudo apt-get install python3 python3-dev python3-venv python3-setuptools python3-pip python-pip +``` + +### Installing the DBMS + +Install MySQL and required libraries with the following command: + +```bash +sudo apt-get install mysql-server mysql-client libmysqlclient-dev +``` + +```eval_rst +.. note:: + We chose to use MySQL instead of MariaDB, because the standard version of MariaDB that comes with this Ubuntu distribution will not work with AA. +``` + +We need to apply a permission fix to mysql or you will get a warning with every startup: + +```bash +sudo usermod -d /var/lib/mysql/ mysql +``` + +Start the mysql server + +```bash +sudo service mysql start +``` + +Create database and user for AA + +```bash +sudo mysql -u root +``` + +```sql +CREATE USER 'aa_dev'@'localhost' IDENTIFIED BY 'PASSWORD'; +CREATE DATABASE aa_dev CHARACTER SET utf8mb4; +GRANT ALL PRIVILEGES ON aa_dev . * TO 'aa_dev'@'localhost'; +CREATE DATABASE test_aa_dev CHARACTER SET utf8mb4; +GRANT ALL PRIVILEGES ON test_aa_dev . * TO 'aa_dev'@'localhost'; +exit; +``` + +Add timezone info to mysql + +```bash +sudo mysql_tzinfo_to_sql /usr/share/zoneinfo | sudo mysql -u root mysql +``` + +### Install redis and other tools + +```bash +sudo apt-get install unzip git redis-server curl libssl-dev libbz2-dev libffi-dev +``` + +Start redis + +```bash +sudo redis-server --daemonize yes +``` + +```eval_rst +.. note:: + WSL does not have an init.d service, so it will not automatically start your services such as MySQL and Redis when you boot your Windows machine. For convenience we recommend putting the commands for starting these services in a bash script. Here is an example: :: + + #/bin/bash + # start services for AA dev + sudo service mysql start + sudo redis-server --daemonize yes + + In addition it is possible to configure Windows to automatically start WSL services, but that procedure goes beyond the scopes of this guide. +``` + +### Setup dev folder on WSL + +Setup your folders on WSL bash for your dev project. Our approach will setup one AA project with one venv and multiple apps running under the same AA project, but each in their own folder and git. + +A good location for setting up this folder structure is your home folder or a subfolder of your home: + +```text +~/aa-dev +|- venv +|- myauth +|- my_app_1 +|- my_app_2 +|- ... +``` + +Following this approach you can also setup additional AA projects, e.g. aa-dev-2, aa-dev-3 if needed. + +Create the root folder aa-dev. + +### setup virtual Python environment for aa-dev + +Create the virtual environment. Run this in your aa-dev folder: + +```bash +python3 -m venv venv +``` + +And activate your venv: + +```bash +source venv/bin/activate +``` + +### install Python packages + +```bash +pip install --upgrade pip +pip install wheel +``` + +## Alliance Auth installation + +## Install and create AA instance + +```bash +pip install allianceauth +``` + +Now we are ready to setup our AA instance. Make sure to run this command in your aa-dev folder: + +```bash +allianceauth start myauth +``` + +Next we will setup our VSC project for aa-dev by starting it directly from the WSL bash: + +```bash +code . +``` + +First you want to make sure exclude the venv folder from VSC as follows: +Open settings and go to Files:Exclude +Add pattern: `**/venv` + +### Update settings + +Open the settings file with VSC. Its under `myauth/myauth/settings/local.py` + +Make sure to have the settings of your Eve Online app ready. + +Turn on DEBUG mode to ensure your static files get served by Django: + +```python +DEBUG = True +``` + +Update name, user and password of your DATABASE configuration. + +```python +DATABASES['default'] = { + 'ENGINE': 'django.db.backends.mysql', + 'NAME': 'aa_dev', + 'USER': 'aa_dev', + 'PASSWORD': 'PASSWORD', + 'HOST': '127.0.0.1', + 'PORT': '3306', + 'OPTIONS': {'charset': 'utf8mb4'}, +} +``` + +For the Eve Online related setup you need to create a SSO app on the developer site: + +- Create your Eve Online SSO App on the [Eve Online developer site](https://developers.eveonline.com/) +- Add all ESI scopes +- Set callback URL to: `http://localhost:8000/sso/callback` + +Then update local.py with your settings: + +```python +ESI_SSO_CLIENT_ID = 'YOUR-ID' +ESI_SSO_CLIENT_SECRET = 'YOUR_SECRET' +ESI_SSO_CALLBACK_URL = 'http://localhost:8000/sso/callback' +``` + +Disable email registration: + +```python +REGISTRATION_VERIFY_EMAIL = False +``` + +### Migrations and superuser + +Before we can start AA we need to run migrations: + +```bash +cd myauth +python manage.py migrate +``` + +We also need to create a superuser for our AA installation: + +```bash +python /home/allianceserver/myauth/manage.py createsuperuser +``` + +## Running Alliance Auth + +## AA instance + +We are now ready to run out AA instance with the following command: + +```bash +python manage.py runserver +``` + +Once running you can access your auth site on the browser under `http://localhost:8000`. Or the admin site under `http://localhost:8000/admin` + +```eval_rst +.. hint:: + You can start your AA server directly from a terminal window in VSC or with a VSC debug config (see chapter about debugging for details). +``` + +```eval_rst +.. note:: + **Debug vs. Non-Debug mode** + Usually it is best to run your dev AA instance in debug mode, so you get all the detailed error messages that helps a lot for finding errors. But there might be cases where you want to test features that do not exist in debug mode (e.g. error pages) or just want to see how your app behaves in non-debug / production mode. + + When you turn off debug mode you will see a problem though: Your pages will not render correctly. The reason is that Django will stop serving your static files in production mode and expect you to serve them from a real web server. Luckily, there is an option that forces Django to continue serving your static files directly even when not in debug mode. Just start your server with the following option: ``python manage.py runserver --insecure`` +``` + +### Celery + +In addition you can start a celery worker instance for myauth. For development purposed it makes sense to only start one instance and add some additional logging. + +This can be done from the command line with the following command in the myauth folder (where manage.py is located): + +```bash +celery -E -A myauth worker -l info -P solo +``` + +Same as AA itself you can start Celery from any terminal session, from a terminal window within VSC or as a debug config in VSC (see chapter about debugging for details). For convenience we recommend starting Celery as debug config. + +## Debugging setup + +To be able to debug your code you need to add debugging configuration to VSC. At least one for AA and one for celery. + +### Breakpoints + +By default VSC will break on any uncaught exception. Since every error raised by your tests will cause an uncaught exception we recommend to deactivate this feature. + +To deactivate open click on the debug icon to switch to the debug view. Then un-check "Uncaught Exceptions" on the breakpoints window. + +### AA debug config + +In VSC click on Debug / Add Configuration and choose "Django". Should Django not appear as option make sure to first open a Django file (e.g. the local.py settings) to help VSC detect that you are using Django. + +The result should look something like this: + +```python +{ + "name": "Python: Django", + "type": "python", + "request": "launch", + "program": "${workspaceFolder}/myauth/manage.py", + "args": [ + "runserver", + "--noreload" + ], + "django": true +} +``` + +### Debug celery + +For celery we need another debug config, so that we can run it in parallel to our AA instance. + +Here is an example debug config for Celery: + +```javascript +{ + "name": "Python: Celery", + "type": "python", + "request": "launch", + "module": "celery", + "cwd": "${workspaceFolder}/myauth", + "console": "integratedTerminal", + "args": [ + "-E", + "-A", + "myauth", + "worker", + "-l", + "info", + "-P", + "solo", + ], + "django": true +}, +``` + +### Debug config for unit tests + +Finally it makes sense to have a dedicated debug config for running unit tests. Here is an example config for running all tests of the app `example`. + +```javascript +{ + "name": "Python: myauth unit tests", + "type": "python", + "request": "launch", + "program": "${workspaceFolder}/myauth/manage.py", + "args": [ + "test", + "-v 2", + "--keepdb", + "--debug-mode", + "--failfast", + "example", + ], + + "django": true +}, +``` + +You can also specify to run just a part of your test suite down to a test method. Just give the full path to the test you want to run, e.g. `example.test.test_models.TestDemoModel.test_this_method` + +### Debugging normal python scripts + +Finally you may also want to have a debug config to debug a non-Django Python script: + +```javascript +{ + "name": "Python: Current File", + "type": "python", + "request": "launch", + "program": "${file}", + "console": "integratedTerminal" +}, +``` + +## Additional tools + +The following additional tools are very helpful when developing for AA. + +### Code Spell Checker + +Typos in your user facing comments can be quite embarrassing. This spell checker helps you avoid them. + +Install from here: [Code Spell Checker](https://marketplace.visualstudio.com/items?itemName=streetsidesoftware.code-spell-checker) + +### DBeaver + +DBeaver is a free universal database tool and works with many different kinds of databases include MySQL. It can be installed on Windows 10 and will be able to help manage your MySQL databases running on WSL. + +Install from here. [DBeaver](https://dbeaver.io/) + +### django-extensions + +[django-extensions](https://django-extensions.readthedocs.io/en/latest/) is a swiss army knife for django developers with adds a lot of very useful features to your Django site. Here are a few highlights: + +- shell_plus - An enhanced version of the Django shell. It will auto-load all your models at startup so you don't have to import anything and can use them right away. +- graph_models - Creates a dependency graph of Django models. Visualizing a model dependency structure can be very useful for trying to understand how an existing Django app works, or e.g. how all the AA models work together. +- runserver_plus - The standard runserver stuff but with the Werkzeug debugger baked in. This is a must have for any serious debugging. + +## Adding apps for development + +The idea behind the particular folder structure of aa-dev is to have each and every app in its own folder and git repo. To integrate them with the AA instance they need to be installed once using the -e option that enabled editing of the package. And then added to the INSTALLED_APPS settings. + +To demonstrate let's add the example plugin to our environment. + +Open a WSL bash and navigate to the aa-dev folder. Make sure you have activate your virtual environment. (`source venv/bin/activate`) + +Run these commands: + +```bash +git clone https://gitlab.com/ErikKalkoken/allianceauth-example-plugin.git +pip install -e allianceauth-example-plugin +``` + +Add `'example'` to INSTALLED_APPS in your `local.py` settings. + +Run migrations and restart your AA server, e.g.: + +```bash +cd myauth +python manage.py migrate +``` diff --git a/docs/development/dev_setup/index.md b/docs/development/dev_setup/index.md new file mode 100644 index 00000000..0b9be3be --- /dev/null +++ b/docs/development/dev_setup/index.md @@ -0,0 +1,10 @@ +# Setup dev environment for AA + +Here you find guides on how to setup your development environment for AA. + +```eval_rst +.. toctree:: + :maxdepth: 1 + + aa-dev-setup-wsl-vsc-v2 +``` diff --git a/docs/development/index.md b/docs/development/index.md index 977ef032..05636730 100644 --- a/docs/development/index.md +++ b/docs/development/index.md @@ -8,4 +8,6 @@ custom/index aa_core/index + dev_setup/index + tech_docu/index ``` diff --git a/docs/development/tech_docu/api/esi.rst b/docs/development/tech_docu/api/esi.rst new file mode 100644 index 00000000..a5b854ec --- /dev/null +++ b/docs/development/tech_docu/api/esi.rst @@ -0,0 +1,39 @@ +====================== +django-esi +====================== + +The django-esi package provides an interface for easy access to the ESI. + +Location: ``esi`` + +This is an external package. Please also see `here `_ for it's official documentation. + +clients +=========== + +.. automodule:: esi.clients + :members: esi_client_factory + :undoc-members: + +decorators +=========== + +.. automodule:: esi.decorators + :members: + :undoc-members: + +errors +=========== + +.. automodule:: esi.errors + :members: + :undoc-members: + + +models +=========== + +.. automodule:: esi.models + :members: Scope, Token + :exclude-members: objects, provider + :undoc-members: diff --git a/docs/development/tech_docu/api/evelinks.rst b/docs/development/tech_docu/api/evelinks.rst new file mode 100644 index 00000000..a8a76779 --- /dev/null +++ b/docs/development/tech_docu/api/evelinks.rst @@ -0,0 +1,30 @@ +=============================== +evelinks +=============================== + +This package generates profile URLs for eve entities on 3rd party websites like evewho and zKillboard. + +Location: ``allianceauth.eveonline.evelinks`` + +dotlan +=============== + +.. automodule:: allianceauth.eveonline.evelinks.dotlan + :members: + :undoc-members: + +eveho +============== + +.. automodule:: allianceauth.eveonline.evelinks.evewho + :members: + :undoc-members: + + +zkillboard +=================== + +.. automodule:: allianceauth.eveonline.evelinks.zkillboard + :members: + :undoc-members: + diff --git a/docs/development/tech_docu/api/eveonline.rst b/docs/development/tech_docu/api/eveonline.rst new file mode 100644 index 00000000..054f7cb6 --- /dev/null +++ b/docs/development/tech_docu/api/eveonline.rst @@ -0,0 +1,15 @@ +====================== +eveonline +====================== + +The eveonline package provides models for commonly used Eve Online entities like characters, corporations and alliances. All models have the ability to be loaded from ESI. + +Location: ``allianceauth.eveonline`` + +models +====== + +.. automodule:: allianceauth.eveonline.models + :members: + :exclude-members: objects, provider + :undoc-members: diff --git a/docs/development/tech_docu/api/index.md b/docs/development/tech_docu/api/index.md new file mode 100644 index 00000000..a11240a9 --- /dev/null +++ b/docs/development/tech_docu/api/index.md @@ -0,0 +1,13 @@ +# API + +To reduce redundancy and help speed up development we encourage developers to utilize the following packages when developing apps for Alliance Auth. + +```eval_rst +.. toctree:: + :maxdepth: 1 + + esi + evelinks + eveonline + testutils +``` diff --git a/docs/development/tech_docu/api/testutils.rst b/docs/development/tech_docu/api/testutils.rst new file mode 100644 index 00000000..3ccea51f --- /dev/null +++ b/docs/development/tech_docu/api/testutils.rst @@ -0,0 +1,14 @@ +============================= +tests +============================= + +Here you find utility functions and classes, which can help speed up writing test cases for AA. + +Location: ``allianceauth.tests.auth_utils`` + +auth_utils +=========== + +.. automodule:: allianceauth.tests.auth_utils + :members: + :undoc-members: diff --git a/docs/development/tech_docu/celery.md b/docs/development/tech_docu/celery.md new file mode 100644 index 00000000..af58f38c --- /dev/null +++ b/docs/development/tech_docu/celery.md @@ -0,0 +1,204 @@ +# Celery FAQ + +**Alliance Auth** uses Celery for asynchronous task management. This page aims to give developers some guidance on how to use Celery when developing apps for Alliance Auth. + +For a complete documentation of Celery please refer to the [official Celery documentation](http://docs.celeryproject.org/en/latest/index.html). + +## When should I use Celery in my app? + +There are two main cases for using celery. Long duration of a process and recurrence of a process. + +### Duration + +Alliance Auth is an online web application and as such the user expects fast and immediate responses to any of his clicks or actions. Same as with any other good web site. Good response times are measures in ms and a user will perceive everything that takes longer than 1 sec as an interruption of his flow of thought (see also [Response Times: The 3 Important Limits](https://www.nngroup.com/articles/response-times-3-important-limits/)). + +As a rule of thumb we therefore recommend to use celery tasks for every process that can take longer than 1 sec to complete (also think about how long your process might take with large amounts of data). + +```eval_rst +.. note:: + Another solution for dealing with long response time in particular when loading pages is to load parts of a page asynchronously, for example with AJAX. +``` + +### Recurrence + +Another case for using celery tasks is when you need recurring execution of tasks. For example you may want to update the list of characters in a corporation from ESI every hour. + +These are called periodic tasks and Alliance Auth uses [celery beat](https://docs.celeryproject.org/en/latest/userguide/periodic-tasks.html) to implement them. + +## What is a celery task? + +For the most part a celery task is a Python functions that is configured to be executed asynchronously and controlled by Celery. Celery tasks can be automatically retried, executed periodically, executed in work flows and much more. See the [celery docs](https://docs.celeryproject.org/en/latest/userguide/tasks.html) for a more detailed description. + +## How should I use Celery in my app? + +Please use the following approach to ensure your tasks are working properly with Alliance Auth: + +- All tasks should be defined in a module of your app's package called `tasks.py` +- Every task is a Python function with has the `@shared_task` decorator. +- Task functions and the tasks module should be kept slim, just like views by mostly utilizing business logic defined in your models/managers. +- Tasks should always have logging, so their function and potential errors can be monitored properly + +Here is an example implementation of a task: + +```Python +import logging +from celery import shared_task + +logger = logging.getLogger(__name__) + + +@shared_task +def example(): + logger.info('example task started') +``` + +This task can then be started from any another Python module like so: + +```Python +from .tasks import example + +example.delay() +``` + +## How should I use celery tasks in the UI? + +There is a well established pattern for integrating asynchronous processes in the UI, for example when the user asks your app to perform a longer running action: + +1. Notify the user immediately (with a Django message) that the process for completing the action has been started and that he will receive a report once completed. + +2. Start the celery task + +3. Once the celery task is completed it should send a notification containing the result of the action to the user. It's important to send that notification also in case of errors. + +## Can I use long running tasks? + +Long running tasks are possible, but in general Celery works best with short running tasks. Therefore we strongly recommend to try and break down long running tasks into smaller tasks if possible. + +If contextually possible try to break down your long running task in shorter tasks that can run in parallel. + +However, many long running tasks consist of several smaller processes that need to run one after the other. For example you may have a loop where you perform the same action on hundreds of objects. In those cases you can define each of the smaller processes as it's own task and then link them together, so that they are run one after the other. That is called chaining in Celery and is the preferred approach for implementing long running processes. + +Example implementation for a celery chain: + +```Python +import logging +from celery import shared_task, chain + +logger = logging.getLogger(__name__) + + +@shared_task +def example(): + logger.info('example task') + +@shared_task +def long_runner(): + logger.info('started long runner') + my_tasks = list() + for _ in range(10): + task_signature = example.si() + my_task.append(task_signature) + + chain(my_tasks).delay() +``` + +In this example we fist add 10 example tasks that need to run one after the other to a list. This can be done by creating a so called signature for a task. Those signature are a kind of wrapper for tasks and can be used in various ways to compose work flow for tasks. + +The list of task signatures is then converted to a chain and started asynchronously. + +```eval_rst +.. hint:: + In our example we use ``si()``, which is a shortcut for "immutable signatures" and prevents us from having to deal with result sharing between tasks. + + For more information on signature and work flows see the official documentation on `Canvas `_. + + In this context please note that Alliance Auth currently only supports chaining, because all other variants require a so called results back, which Alliance Auth does not have. +``` + +## How can I define periodic tasks for my app? + +Periodic tasks are normal celery tasks which are added the scheduler for periodic execution. The convention for defining periodic tasks for an app is to define them in the local settings. So user will need to add those settings manually to his local settings during the installation process. + +Example setting: + +```Python +CELERYBEAT_SCHEDULE['structures_update_all_structures'] = { + 'task': 'structures.tasks.update_all_structures', + 'schedule': crontab(minute='*/30'), +} +``` + +- `structures_update_all_structures` is the name of the scheduling entry. You can chose any name, but the convention is name of your app plus name of the task. + +- `'task'`: Name of your task (full path) +- `'schedule'`: Schedule definition (see Celery documentation on [Periodic Tasks](https://docs.celeryproject.org/en/latest/userguide/periodic-tasks.html) for details) + +## How can I use priorities for tasks? + +In Alliance Auth we have defined task priorities from 0 - 9 as follows: + +```eval_rst + ====== ========= =========== + Number Priority Description + ====== ========= =========== + 0 Reserved Reserved for Auth and may not be used by apps + 1, 2 Highest Needs to run right now + 3, 4 High needs to run as soon as practical + 5 Normal default priority for most tasks + 6, 7 Low needs to run soonish, but is less urgent than most tasks + 8, 9 Lowest not urgent, can be run whenever there is time + ====== ========= =========== +``` + +```eval_rst +.. warning:: + Please make sure to use task priorities with care and especially do not use higher priorities without a good reason. All apps including Alliance Auth share the same task queues, so using higher task priorities excessively can potentially prevent more important tasks (of other apps) from completing on time. + + You also want to make sure to run use lower priorities if you have a large amount of tasks or long running tasks, which are not super urgent. (e.g. the regular update of all Eve characters from ESI runs with priority 7) +``` + +```eval_rst +.. hint:: + If no priority is specified all tasks will be started with the default priority, which is 5. +``` + +To run a task with a different priority you need to specify it when starting it. + +Example for starting a task with priority 3: + +```Python +example.apply_async(priority=3) +``` + +```eval_rst +.. hint:: + For defining a priority to tasks you can not use the convenient shortcut ``delay()``, but instead need to start a task with ``apply_async()``, which also requires you to pass parameters to your task function differently. Please check out the `official docs `_ for details. +``` + +## What special features should I be aware of? + +Every Alliance Auth installation will come with a couple of special celery related features "out-of-the-box" that you can make use of in your apps. + +### celery-once + +Celery-once is a celery extension "that allows you to prevent multiple execution and queuing of celery tasks". What that means is that you can ensure that only one instance of a celery task runs at any given time. This can be useful for example if you do not want multiple instances of you task to talk to the same external service at the same time. + +We use a custom backend for celery_once in Alliance Auth defined [here](https://gitlab.com/allianceauth/allianceauth/-/blob/master/allianceauth/services/tasks.py#L14) +You can import it for use like so: + +```Python +from allianceauth.services.tasks import QueueOnce +``` + +An example of AllianceAuth's use within the `@sharedtask` decorator, can be seen [here](https://gitlab.com/allianceauth/allianceauth/-/blob/master/allianceauth/services/modules/discord/tasks.py#L62) in the discord module +You can use it like so: + +```Python +@shared_task(bind=True, name='your_modules.update_task', base=QueueOnce) +``` + +Please see the [official documentation](hhttps://pypi.org/project/celery_once/) of celery-once for details. + +### task priorities + +Alliance Auth is using task priorities to enable priority based scheduling of task execution. Please see [How can I use priorities for tasks?](#how-can-i-use-priorities-for-tasks) for details. diff --git a/docs/development/tech_docu/core_models.md b/docs/development/tech_docu/core_models.md new file mode 100644 index 00000000..db7e2990 --- /dev/null +++ b/docs/development/tech_docu/core_models.md @@ -0,0 +1,5 @@ +# Core models + +The following diagram shows the core models of AA and Django and their relationships: + +![aa_core](/_static/images/development/aa_core.png) diff --git a/docs/development/tech_docu/index.md b/docs/development/tech_docu/index.md new file mode 100644 index 00000000..578df28d --- /dev/null +++ b/docs/development/tech_docu/index.md @@ -0,0 +1,13 @@ +# Developing apps + +In this section you find topics useful for app developers. + +```eval_rst +.. toctree:: + :maxdepth: 1 + + api/index + celery + core_models + templatetags +``` diff --git a/docs/development/tech_docu/templatetags.rst b/docs/development/tech_docu/templatetags.rst new file mode 100644 index 00000000..1437c311 --- /dev/null +++ b/docs/development/tech_docu/templatetags.rst @@ -0,0 +1,16 @@ +============= +Template Tags +============= + +The following template tags are available to be used by all apps. To use them just load the respeetive template tag in your template like so: + +.. code-block:: html + + {% load evelinks %} + +evelinks +======== + +.. automodule:: allianceauth.eveonline.templatetags.evelinks + :members: + :undoc-members: diff --git a/docs/installation/allianceauth.md b/docs/installation/allianceauth.md index a2fdcaf4..eb9152d1 100644 --- a/docs/installation/allianceauth.md +++ b/docs/installation/allianceauth.md @@ -83,7 +83,8 @@ apt-get install unzip git redis-server curl libssl-dev libbz2-dev libffi-dev CentOS: ```bash -yum install gcc gcc-c++ unzip git redis curl bzip2-devel +yum install gcc gcc-c++ unzip git redis curl +2-devel ``` ```eval_rst @@ -113,7 +114,7 @@ mysql_tzinfo_to_sql /usr/share/zoneinfo | mysql -u root -p mysql ```eval_rst .. note:: You may see errors when you add the timezone tables. To make sure that they were correctly added run the following commands and check for the ``time_zone`` tables:: - + mysql -u root -p use mysql; show tables;