Skip to main content

Login to CKAN using Drupal's session cookie

Project description

Tests

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:

  1. Activate your CKAN virtual environment, for example:

     . /usr/lib/ckan/default/bin/activate
    
  2. 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 .
    
  3. Add drupal-idp to the ckan.plugins setting in your CKAN config file (by default the config file is located at /etc/ckan/default/ckan.ini).

  4. Configure Drupal's DB:

     ckanext.drupal_idp.db_url = <URL>
    
  5. 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


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

ckanext-drupal-idp-0.1.5.tar.gz (25.6 kB view details)

Uploaded Source

Built Distribution

ckanext_drupal_idp-0.1.5-py3-none-any.whl (26.5 kB view details)

Uploaded Python 3

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

Hashes for ckanext-drupal-idp-0.1.5.tar.gz
Algorithm Hash digest
SHA256 b860a275196cc1e2a4b464b69a2392a63edf383dea561e2680f34eeb89b4a8be
MD5 8e68d78f156a7677d9ebc940485eaa53
BLAKE2b-256 65541ef410036b08cde6c58e67bc32ba98d7d46e3534c45fd7bad6fc86afc89f

See more details on using hashes here.

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

Hashes for ckanext_drupal_idp-0.1.5-py3-none-any.whl
Algorithm Hash digest
SHA256 ecc942934c3a19ae1b25f7a58d978afa65712fca1962da70551e1627f8be53b7
MD5 d299ce899e1c526706eed97a94d8cb6e
BLAKE2b-256 96bcdd3e618a64a945c1f3443f3be37bcadd61ff4b61ae6195107e60da170e4b

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page