A Django app that handles the communication between the IDP and the products for the authorization of users.
Project description
Django IDP User
Installation
-
Install the package:
pip install django-idp-user
If you want to use the async version of the package, you can install it with the
async
extra:pip install django-idp-user[async]
-
Add
idp_user
to yourINSTALLED_APPS
:INSTALLED_APPS = [ # ... 'idp_user', ]
-
Add the settings of the app in
settings.py
like this:AUTH_USER_MODEL = 'idp_user.User' IDP_USER_APP = { "IDP_ENVIRONMENT": "staging/production/etc.", "APP_IDENTIFIER": "str", "ROLES": "path.to.roles_choices", "FAUST_APP_PATH": "backend.kafka_consumer.app", "USE_REDIS_CACHE": True, "IDP_URL": "idp_url", # Optional "APP_ENTITIES": { "<entity_type>": { "model": "<path.to.entity_type.model>", "identifier_attr": "<field_name>", "label_attr": "<field_name>", } }, } REST_FRAMEWORK = { 'DEFAULT_SCHEMA_CLASS': 'drf_spectacular.openapi.AutoSchema' or 'idp_user.schema_extensions.AutoSchemaWithRole', 'DEFAULT_AUTHENTICATION_CLASSES': ( 'idp_user.auth.AuthenticationBackend', ), } SPECTACULAR_SETTINGS = { 'DEFAULT_AUTHENTICATION_CLASSES': ( 'idp_user.schema_extensions.BearerTokenScheme', ), 'SERVE_AUTHENTICATION': () } # Kafka Related KAFKA_ARN = "<aws_kafka_arn>" # Encoded in base64 KAFKA_AWS_ACCESS_KEY_ID = "<access_key_id>" KAFKA_AWS_SECRET_ACCESS_KEY = "<secret_access_key_id>" # Encoded in base64 AWS_S3_REGION_NAME = "<region_name>"
-
Create the database tables for the app by running the following command:
python manage.py migrate
Async Support
Django version 4.1.1 is required for async support.
To use the async version of the package, you need to add the async
extra when installing the package:
pip install django-idp-user[async]
If you are using Channels for websockets, you can use the IDPChannelsAuthenticationMiddleware
like so:
from channels.routing import ProtocolTypeRouter, URLRouter
from idp_user.auth import IDPChannelsAuthenticationMiddleware
application = ProtocolTypeRouter({
"websocket": IDPChannelsAuthenticationMiddleware(
AuthMiddlewareStack(
URLRouter(
# ...
)
)
),
})
Settings Reference
-
IDP_ENVIRONMENT
- The environment of the IDP with which the app will communicate.
- Used mainly for the Kafka Consumer & Producer.
-
APP_IDENTIFIER
- The app identifier, as defined in the IDP.
-
ROLES
- The path to the roles choices.
-
FAUST_APP_PATH
- The path to the Faust app.
-
IDP_URL
- The URL of the IDP, used for local development, or when using the IDP as an Authentication Backend.
-
USE_REDIS_CACHE
- If True, the cache will be used
- When developing locally, you can leave this as
False
.
-
APP_ENTITIES
- This dict links the AppEntityTypes declared on the IDP for this app to their actual models, so that they can be used for authorization purposes. In the value dicts, the attributes that will be used as the identifier and label are declared as well.
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
Built Distribution
File details
Details for the file django_idp_user-3.0.0.tar.gz
.
File metadata
- Download URL: django_idp_user-3.0.0.tar.gz
- Upload date:
- Size: 19.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.9.20
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | df42b858f34386b500bb9230fbd0c33015116e0a0a6711b372bc10b91550099e |
|
MD5 | 8a49b43340720bdc53848b80b2246fc4 |
|
BLAKE2b-256 | de0c26d69a80d5030fdf40355cb92c0c123f7e2e9bef18145f5e19dda98d70b0 |
File details
Details for the file django_idp_user-3.0.0-py3-none-any.whl
.
File metadata
- Download URL: django_idp_user-3.0.0-py3-none-any.whl
- Upload date:
- Size: 32.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.9.20
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 11a80b0bc72375ebd0d87a623d3649afa3f80b8c620416514468de59df4215f6 |
|
MD5 | ebbf071f54982c56144bc2c68e68c03c |
|
BLAKE2b-256 | f3754befc7d5927f373a58e36b3c11aba23f1662cbffa70905d4180f6be1edfc |