Skip to main content

A CKAN extension that allows organisation members to create datasets, and edit or delete the datasets they have created.

Project description

ckanext-userdatasets

Travis Coveralls CKAN Python

A CKAN extension that allows organisation members to create datasets, and edit or delete the datasets they have created.

Overview

This extension changes the permissions of users with the 'Member' role in an organisation, allowing them to create datasets, and to edit or delete the datasets they have created. Unlike users with the 'Editor' role, they cannot edit or delete datasets created by other users.

Notes:

  • This applies to the existing 'Member' role rather than creating a new one as it is currently not possible to add new roles from an extension;
  • The plugin works with custom dataset types, however it will not work with other plugins which override package/resource update/create/delete authorization functions, and package_create/update actions.

Warning: This plugin modifies CKAN's permission system. The current implementation cannot be considered fully safe and should only be used AT YOUR OWN RISK in a trusted environment. Ensure you run the tests with your plugins enabled.

Installation

Path variables used below:

  • $INSTALL_FOLDER (i.e. where CKAN is installed), e.g. /usr/lib/ckan/default
  • $CONFIG_FILE, e.g. /etc/ckan/default/development.ini
  1. Clone the repository into the src folder:
cd $INSTALL_FOLDER/src
git clone https://github.com/NaturalHistoryMuseum/ckanext-userdatasets.git
  1. Activate the virtual env:
. $INSTALL_FOLDER/bin/activate
  1. Install the requirements from requirements.txt:
cd $INSTALL_FOLDER/src/ckanext-userdatasets
pip install -r requirements.txt
  1. Run setup.py:
cd $INSTALL_FOLDER/src/ckanext-userdatasets
python setup.py develop
  1. Add 'userdatasets' to the list of plugins in your $CONFIG_FILE:
ckan.plugins = ... userdatasets

Configuration

There are no configuration options for this extension.

Usage

Actions

No new actions are defined in this extension; three are overridden to modify validators and permissions.

package_create

package_update

organization_list_for_user

Testing

Test coverage is currently extremely limited.

To run the tests in this extension, there is a Docker compose configuration available in this repository to make it easy.

To run the tests against ckan 2.9.x on Python3:

  1. Build the required images
docker-compose build
  1. Then run the tests. The root of the repository is mounted into the ckan container as a volume by the Docker compose configuration, so you should only need to rebuild the ckan image if you change the extension's dependencies.
docker-compose run ckan

The ckan image uses the Dockerfile in the docker/ folder which is based on openknowledge/ckan-dev:2.9.

Note that currently the tests mock the Datacite API and therefore don't require an internet connection nor your Datacite credentials to run.

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-userdatasets-2.0.0.tar.gz (29.3 kB view details)

Uploaded Source

Built Distributions

ckanext_userdatasets-2.0.0-py3.10.egg (10.1 kB view details)

Uploaded Source

ckanext_userdatasets-2.0.0-py3-none-any.whl (23.6 kB view details)

Uploaded Python 3

File details

Details for the file ckanext-userdatasets-2.0.0.tar.gz.

File metadata

  • Download URL: ckanext-userdatasets-2.0.0.tar.gz
  • Upload date:
  • Size: 29.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.10.8

File hashes

Hashes for ckanext-userdatasets-2.0.0.tar.gz
Algorithm Hash digest
SHA256 75cd692ce7cbba400dedcf58ee7ade1d48fdb69a5eb03eb6ec9505ba6bdb928d
MD5 3a109f845e22765058719e6c9bdade2f
BLAKE2b-256 c5359a02e57f945fe6652d3edfbbce560808dcba1fe1fe497d7aa112f7eb362d

See more details on using hashes here.

File details

Details for the file ckanext_userdatasets-2.0.0-py3.10.egg.

File metadata

File hashes

Hashes for ckanext_userdatasets-2.0.0-py3.10.egg
Algorithm Hash digest
SHA256 84454bdc6106512d740bf3935a66625e82be55ce22224a316d63c98eb1836bda
MD5 eae0f2ccf18418098f044f5f42b3a495
BLAKE2b-256 88d57cd7c2259df42ec3b998a415b4b832424f464aed30a5a596f509a391e31c

See more details on using hashes here.

File details

Details for the file ckanext_userdatasets-2.0.0-py3-none-any.whl.

File metadata

File hashes

Hashes for ckanext_userdatasets-2.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 485f904ca680072494fb29e926f42cdfd56ab634cef406d293536e23bbbdea44
MD5 9b993190098eb0eb59d179b47fc8e4e6
BLAKE2b-256 55a1b96296200cdece7b6e6a5d84f4a8f1021494a64b9d30d2e304989d133a68

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