Login to CKAN using Drupal's session cookie
Project description
ckanext-drupal-idp
When Drupal's session cookie is available use it for user authentication. Create missing users, using data from Drupal's DB and synchronize(conditionally) fields when user details changed on Drupal's side.
Requirements
- python >= 3.6
- CKAN >= 2.9
Installation
To install ckanext-drupal-idp:
-
Activate your CKAN virtual environment, for example:
. /usr/lib/ckan/default/bin/activate
-
Clone the source and install it on the virtualenv
git clone https://github.com/DataShades/ckanext-drupal-idp.git cd ckanext-drupal-idp pip install -e .
-
Add
drupal-idp
to theckan.plugins
setting in your CKAN config file (by default the config file is located at/etc/ckan/default/ckan.ini
). -
Configure Drupal's DB:
ckanext.drupal_idp.db_url = <URL>
-
Restart CKAN. For example if you've deployed CKAN with Apache on Ubuntu:
sudo service apache2 reload
Config settings
# ckanext-drupal-idp
# Defines database used by the Drupal application
# (mandatory).
ckanext.drupal_idp.db_url = mysql://drupal_user:drupal_pass@127.0.0.1:3306/db_name
# Whether to make an attempt to synchronize user's details everytime
# session is used. This may result in unauthenticated session if new name or email
# already present in CKAN database
# (optional, default: false).
ckanext.drupal_idp.synchronization.enabled = true
# Configure hostname of the drupal instance statically. Usefull for local testing with
# manually added cookie from any accessible drupal instance
# (optional)
ckanext.drupal_idp.host = my.site.com
# Whether to set sysadmin flag on the user who has Drupal's admin role
# (optional, default: false)
ckanext.drupal_idp.admin_role.inherit = true
# Name of the role that grants sysadmin status
# (optional, default: administrator)
ckanext.drupal_idp.admin_role.name = administrator
# When user created, set his ID to the same value as DrupalID
# (optional, default: false)
ckanext.drupal_idp.same_id = true
API actions
drupal_idp_user_show
Parameters:
id: (mandatory) DrupalID of the user
Details:
Accepts mandatory id
(DrupalID). The rest of parameters will be
passed to underlying user_show
.
Auth functions
drupal_idp_user_show
Details:
Checks whether user is allowed to get user details by DrupalID. At the moment only sysadmin can pass this check.
CLI
* drupal-idp - ckanext-drupal-idp CLI
* user - User management
* list - List all users with DrupalID
Developer installation
To install ckanext-drupal-idp for development, activate your CKAN virtualenv and do:
git clone https://github.com/DataShades/ckanext-drupal-idp.git
cd ckanext-drupal-idp
python setup.py develop
pip install -r dev-requirements.txt
Tests
To run the tests, do:
pytest --ckan-ini=test.ini ckanext/drupal_idp
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 ckanext-drupal-idp-0.1.5.tar.gz
.
File metadata
- Download URL: ckanext-drupal-idp-0.1.5.tar.gz
- Upload date:
- Size: 25.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.4.2 importlib_metadata/4.8.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | b860a275196cc1e2a4b464b69a2392a63edf383dea561e2680f34eeb89b4a8be |
|
MD5 | 8e68d78f156a7677d9ebc940485eaa53 |
|
BLAKE2b-256 | 65541ef410036b08cde6c58e67bc32ba98d7d46e3534c45fd7bad6fc86afc89f |
File details
Details for the file ckanext_drupal_idp-0.1.5-py3-none-any.whl
.
File metadata
- Download URL: ckanext_drupal_idp-0.1.5-py3-none-any.whl
- Upload date:
- Size: 26.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.4.2 importlib_metadata/4.8.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | ecc942934c3a19ae1b25f7a58d978afa65712fca1962da70551e1627f8be53b7 |
|
MD5 | d299ce899e1c526706eed97a94d8cb6e |
|
BLAKE2b-256 | 96bcdd3e618a64a945c1f3443f3be37bcadd61ff4b61ae6195107e60da170e4b |