https://github.com/ppfeufer/aa-example-plugin
Alliance Auth Example Plugin (GitHub Version)
https://github.com/ppfeufer/aa-example-plugin
Last synced: 3 months ago
JSON representation
Alliance Auth Example Plugin (GitHub Version)
- Host: GitHub
- URL: https://github.com/ppfeufer/aa-example-plugin
- Owner: ppfeufer
- License: gpl-3.0
- Created: 2022-03-12T18:38:53.000Z (almost 4 years ago)
- Default Branch: master
- Last Pushed: 2025-07-08T08:16:48.000Z (6 months ago)
- Last Synced: 2025-07-08T09:28:20.497Z (6 months ago)
- Language: Python
- Size: 202 KB
- Stars: 1
- Watchers: 3
- Forks: 18
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
# Example Plugin App for Alliance Auth (GitHub Version)
This is an example plugin app for [Alliance Auth](https://gitlab.com/allianceauth/allianceauth)
(AA) that can be used as a starting point to develop custom plugins.




_(These badges are examples, you can and should replace them with your own)_
For the GitLab version of this example app, please have a look over here, Erik
Kalkoken was so friendly to provide it » [Alliance Auth Example App (GitLab Version)](https://gitlab.com/ErikKalkoken/allianceauth-example-plugin)
______________________________________________________________________
- [Example Plugin App for Alliance Auth (GitHub Version)](#example-plugin-app-for-alliance-auth-github-version)
- [Features](#features)
- [How to Use It](#how-to-use-it)
- [Cloning From Repo](#cloning-from-repo)
- [Renaming the App](#renaming-the-app)
- [Clearing Migrations](#clearing-migrations)
- [Writing Unit Tests](#writing-unit-tests)
- [Installing Into Your Dev AA](#installing-into-your-dev-aa)
- [Installing Into Production AA](#installing-into-production-aa)
- [Contribute](#contribute)
______________________________________________________________________
- The plugin can be installed, upgraded (and removed) into an existing AA
installation using PyInstaller.
- It has its own menu item in the sidebar.
- It has one view that shows a panel and some text
To use this example as a basis for your own development, just fork this repo and then
clone it on your dev machine.
You then should rename the app, and then you can install it into your AA dev
installation.
For this app, we're assuming that you have all your AA projects, your virtual
environment, and your AA installation under one top folder (e.g. aa-dev).
This should look something like this:
```text
aa-dev
|- venv/
|- myauth/
|- aa-example-plugin
|- (other AA projects ...)
```
Then just cd into the top folder (e.g. aa-dev) and clone the repo from your fork.
You can give the repo a new name right away (e.g. `aa-your-app-name`). You also want
to create a new git repo for it.
Finally, enable [pre-commit](https://pre-commit.com) to enable automatic code style
checking.
```bash
git clone https://github.com/YourName/aa-example-plugin.git aa-your-app-name
cd aa-your-app-name
rm -rf .git
git init
pre-commit install
```
Before installing this app into your dev AA you need to rename it to something
suitable for your development project. Otherwise, you risk not being able to install
additional apps that might also be called example.
Here is an overview of the places that you need to edit to adopt the name.
Easiest is to just find & replace `example` with your new app name in all files
listed below.
One small warning about picking names: Python is a bit particular about what special
characters are allowed for names of modules and packages. To avoid any pitfalls, I
would therefore recommend using only normal characters (a-z) in your app's name
unless you know exactly what you're doing.
| Location | Description |
| ---------------------------------------- | -------------------------------------------------------------------------------------- |
| `./example/` | Folder name |
| `./example/static/example/` | Folder name |
| `./example/templates/example/` | Folder name |
| `./pyproject.cfg` | Update module name for version import, update package name, update title, author, etc. |
| `./example/apps.py` | App name |
| `./example/__init__.py` | App name |
| `./example/auth_hooks.py` | Menu hook config incl. icon and label of your app's menu item appearing in the sidebar |
| `./example/models.py` | App name |
| `./example/urls.py` | App name |
| `./example/views.py` | Permission name and template path |
| `./example/templates/example/base.html` | Title of your app to be shown in all views and as title in the browser tab |
| `./example/templates/example/index.html` | Template path |
| `./testauth/local.py` | App name in `PACKAGE` constant |
| `./.coveragerc` | App name |
| `./MANIFEST.in` | App name |
| `./README.md` | Clear content |
| `./LICENSE` | Replace with your own license |
| `./tox.ini` | App name |
| `./.isort.cfg` | App name for `import_heading_firstparty` |
| `./Makefile` | App name and package name |
Instead of renaming your app in the migrations, it's easier to just recreate them
later in the process. For this to work, you need to delete the old migration files in
your `migrations` folder.
```bash
rm your-app-name/migrations/0001_initial.py
rm -rf your-app-name/migrations/_pycache
```
Write your unit tests in `your-app-name/tests/` and make sure that you use a "test\_"
prefix for files with your unit tests.
## Installing Into Your Dev AA
Once you've cloned or copied all files into place and finished renaming the app,
you're ready to install it to your dev AA instance.
Make sure you're in your venv. Then install it with pip in editable mode:
```bash
pip install -e aa-your-app-name
```
First add your app to the Django project by adding the name of your app to
INSTALLED_APPS in `settings/local.py`.
Next, we will create new migrations for your app:
```bash
python manage.py makemigrations
```
Then run a check to see if everything is set up correctly.
```bash
python manage.py check
```
In case they're errors make sure to fix them before proceeding.
Next, perform migrations to add your model to the database:
```bash
python manage.py migrate
```
Finally, restart your AA server and that's it.
## Installing Into Production AA
To install your plugin into a production AA, run this command within the virtual
Python environment of your AA installation:
```bash
pip install git+https://github.com/YourName/aa-your-app-name
```
Alternatively, you can create a package file and manually upload it to your
production AA:
```bash
pip install build
python -m build
```
You'll find the package under `./dist/aa-your-app-name.tar.gz` after this.
Install your package directly from the package file:
```bash
pip install aa-your-app-name.tar.gz
```
Then add your app to `INSTALLED_APPS` in `settings/local.py`, run migrations and
restart your allianceserver.
If you've made a new app for AA, please consider sharing it with the rest of the
community. For any questions on how to share your app, please contact the AA devs on
their Discord. You find the current community creations
[here](https://gitlab.com/allianceauth/community-creations).