A django app model user proxy
Project description
AuthProxyApp is a Django app containing a single User Proxy model, which is shared between multiple Django instances.
The purpose of this Proxy model is to access a single shared “Users” database between Django applications, with no explicit foreign relations.
It currently operates with a modified User implementation featuring a UUID as a PK, you can easily implement this by creating your own AbstractUser implementation, and storing all users and permissions in a single “Users” database.
Quick start
Add “auth_proxy” to your INSTALLED_APPS setting like this:
INSTALLED_APPS = [ ... 'auth_proxy' ]
Run python manage.py migrate to create the auth_proxy model.
To use the proxy, use auth_proxy.models.UserProxy on foreign relations (like OneToOne, ManyToMany, ManyToOne), instead of django.contrib.auth.models.User. Remember that you’re responsible of creating these proxies, unless you use the optional middlewares.
Optional:
If you wish to use the Middlewares, include them in settings like this:
MIDDLEWARE_CLASSES = ( ... 'auth_proxy.middleware.GenerateUserProxy', 'auth_proxy.middleware.AddUserProxyToRequest' )
GenerateUserProxy will create the UserProxy on user login, and AddUserProxyToRequest will add the UserProxy to the request, where it can be obtained like this: request.user_proxy.
An user router is included. It will route the following labels:
"admin", "auth", "profiles", "sessions", "oauth2_provider", "contenttypes"
To a database called users, which you should define in settings (refer to https://docs.djangoproject.com/en/4.0/topics/db/multi-db/ for more instructions). To use this router, define the following in settings:
DATABASE_ROUTERS = [ ... 'auth_proxy.routers.UsersRouter' ]
Note that upper-most routers will have more importance to Django. If you wish to ensure the router will do its intended purpose, insert it in the first position.
Requirements
This UserProxy is intended to be a shared local reference to a User object found in a separate database. This architecture allows multiple Django instances to share the same Users, and permissions, while retaining the ability to reference User models.
Hence, a shared database is needed, and it should be declared as “users” in all django instances. And a custom User model should be declared, with UUID as primary key.
TODO
REST endpoints to manage UserProxy instances
Erase UserProxy instances when Users are deleted
Building
Run python -m build
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
Hashes for django_user_proxy-1.2.4-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 4694641df5b2217c51ef1b42c1a14099d04dddf362736b3cd02b225d08b59dce |
|
MD5 | 2d69e6358a48a20f623e64452eda3a27 |
|
BLAKE2b-256 | 99f8fb06353de84c9559a1a7a09a3a7061701d81aa5d565f087280562f474154 |