PerFact API - FastAPI main package (middleware, auth, entrypoints)
Project description
PerFact API Base
The main FastAPI package for the PerFact API. Provides authentication, authorisation, database session handling, and plugin discovery. All domain-specific API modules are in separate packages and loaded automatically at startup via entry points.
Applications
perfact.api.main.app — user-facing API
Hosts all plugins registered under the perfact.api entry point group. All routes are served under the /api path prefix. Users authenticate via a login cookie or an Authorization: Apikey … header. Access to individual endpoints can be restricted by role:
from perfact.api.main.auth import require_roles
@router.get("/my-endpoint")
@require_roles("MyRole")
def my_endpoint(session: DBSession) -> ...:
...
perfact.api.main.assignworker — task runner API
Hosts all plugins registered under the perfact.assignapi entry point group. All routes are served under the /assignworker path prefix. Intended for internal use by assignd. Authentication is HTTP Basic Auth with a pre-shared password hash configured in the YAML config file.
Plugin discovery
At startup, both apps iterate over their respective entry point group and call mount(app) on each discovered plugin:
INFO - start plugin discovery
INFO - try to include plugin: perfact.api.pd.routes:mount
INFO - finished discovery and include: 1 plugins
A plugin registers itself by declaring an entry point in its pyproject.toml:
[project.entry-points.'perfact.api']
myplugin = 'perfact.api.myplugin.routes:mount'
getting started as developer
After you checked out this repository, do the following steps to be able to debug your application:
- create and activate venv
python -m venv .venv source .venv/bin/activate # linux .venv/Scripts/Activate.ps1 # PowerShell
- Install the API plugins you want to include without doing changes by installing them from pypi:
pip install perfact-api-base-model
- Install the API plugins you want to include and change in your instance by checking them out somewhere and installing/linking them into your application via
pip install -e:pip install -e ../perfact-api-base-model/ # required pip install -e ../perfact-api-app-model/ # required pip install -e ../perfact-api-pd-model/ # example
Hint: Every code change is available in the application after the next restart/reload. Changes to the entrypoints are available after the next install command execution (as this is recreating the ENTRYPOINTS-file belonging to the package in the site-packages folder).
You can install as much as plugins you like, even custom ones.
pip will automaticly check if more dependencies needed by the plugin while installing, e.g.
Requirement already satisfied: fastapi
Now you can run the application:
uvicorn perfact.api.main.app:app # run API for frontend
uvicorn perfact.api.main.assignworker:app # run API for assignd worker APIs
uvicorn perfact.api.main.app:app --reload --reload-include ../ # run API for frontend with auto-reload for all editable dependencies
There is a launch.json-file provided to debug the application in VS Code. To use that, you have to create a configuration file (see below).
Configuration
The application can be configured by providing a configuration yaml-File containing informations about the database connection and basic auth credentials (for assignworker).
The configuration file is given to the application by providing the location (absolute or relative to working dir) in the environment variable PERFACT_API_CONFIG_PATH.
Example:
connstr: postgresql+psycopg://zope@/perfactema # default, can be left out
basicauth: "$argon2id$v=19$m=65536,t=3,p=4$6itEouPTNwWEXDKScKmMrw$NwhN1vAUN8EZjC62HrtXjx7n+K1Mujjd/QqioaHvyOg" # password=test
Dependencies
perfact-api-app-modelfastapisqlalchemypsycopg[c]argon2-cffipydantic-settings
Maintainers
- Viktor Dick viktor.dick@perfact.de
- Alexander Rolfes alexander.rolfes@perfact.de
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file perfact_api_main-0.7.tar.gz.
File metadata
- Download URL: perfact_api_main-0.7.tar.gz
- Upload date:
- Size: 15.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.14.4
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
abb461ddac49eee23337d5d83edafc252aae25509eb749ea9c929e7ff470579c
|
|
| MD5 |
461bbea972b3384c8c1eadecd2184a0a
|
|
| BLAKE2b-256 |
0783e512f2f5df09d44ad3c1fafec5fd3b1ceb4da7867f6e97de6adee2995752
|
File details
Details for the file perfact_api_main-0.7-py2.py3-none-any.whl.
File metadata
- Download URL: perfact_api_main-0.7-py2.py3-none-any.whl
- Upload date:
- Size: 12.6 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.14.4
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
24d4d6ddaece1a3184758cbcf88ebb13bac9725b44c1f84b2fd80ea622b83a0a
|
|
| MD5 |
665c1720b32bda8be54d6ee284735024
|
|
| BLAKE2b-256 |
4a2060c233c083899b541a534e5670ceaacf78eed798d8aea92b0960ad9acccc
|