ckanext-dcor-schemas


Nameckanext-dcor-schemas JSON
Version 0.21.1 PyPI version JSON
download
home_pageNone
SummaryIntroduces or lifts restrictions (authorization) for managing data and metadata on DCOR
upload_time2024-11-26 20:03:47
maintainerNone
docs_urlNone
authorPaul Müller
requires_python<4,>=3.8
licenseGNU Affero General Public License v3 or later (AGPLv3+)
keywords dc dcor deformability cytometry
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            ckanext-dcor_schemas
====================

|PyPI Version| |Build Status| |Coverage Status|

This module introduces/lifts restrictions (authorization) for the management
of data and meta data on DCOR. The corresponding UI elements are modified
accordingly:

- Authorization (auth.py)

  - datasets: do not allow deleting datasets unless they are drafts
  - datasets: allow purging of deleted datasets
  - datasets: do not allow switching to a more restrictive license
  - datasets: do not allow changing the name (slug)
  - datasets: do not allow adding resources to non-draft datasets
  - datasets: do not allow to set the visibility of a public dataset to private
  - datasets: do not allow uploading datasets via the web interface
  - organization: do not allow bulk_update_delete (e.g. datasets by organization admins)
  - resources: do not allow deleting resources unless they are drafts
  - resources: only allow changing the "description"
  - resources: do not allow setting a resource id when uploading
  - user: allow all logged-in users to create datasets, circles, and collections

- Validation (validate.py)

  - datasets: force user to select authors
  - datasets: author list "authors" is CSV
  - datasets: parse DOI field (remove URL part)
  - datasets: force user to select a license
  - datasets: restrict to basic CC licenses
  - datasets: automatically generate dataset name (slug) using random characters
    if necessary (does not apply to admins)
  - datasets: a dataset without resources is considered to be a draft;
    it's state cannot be set to "active"
  - datasets: the state of a dataset that does not contain at least one
    valid .rtdc resource cannot be set to "active"
  - resources: do not allow uploading resources with the same name
    for a dataset (important for ckanext-dcor_depot)
  - resources: make sure the resource name matches the file name of the
    upload; this is actually implemented in plugin.before_create
    (IResourceController) and not in validate.py
  - resources: custom resource name is overridden during upload
  - resources: do not allow weird characters in resource names
  - resources: restrict upload data extensions to .'.rtdc', '.ini', '.csv',
    '.tsv', '.pdf', '.txt', '.jpg', '.png', '.tif', '.py', '.ipynb', '.poly',
    '.sof', '.so2'
  - resources: configuration metadata (using `dclab.dfn.config_funcs`)
  - resources: 's3_available' and 's3_url' for identifying objects that
    are available on S3 and for downloading public datasets.

- IPermissionLabels (plugin.py)

  - Allow a user A to see user B's private dataset if the private dataset
    is in a group that user A is a member of.

- UI Dataset:

  - hide "add new resource" button in ``templates/package/resources.html``
  - add field ``authors`` (csv list)
  - add field ``doi`` (validator parses URLs)
  - add field ``references`` (parses arxiv, bioRxiv, DOI, links)
  - add CC license file ``licenses.json`` (only show less restrictive licenses
    when editing the dataset)

- UI Organization:

  - remove "Delete" button in bulk view

- UI Resource:

  - Do not show these variables (because they are redundant):
    ['last modified', 'revision id', 'url type', 'state', 'on same domain']
    (``templates/package/resource_read.html``)
  - Show DC config data via "toggle-more"
  - Add supplementary resource schema via json files located in
    `dcor_schemas/resource_schema_supplements`

- Background jobs:

  - set the mimetype for each dataset
  - populate "dc:sec:key" metadata for each DC dataset
  - generates sha256 hash upon resource creation
  - populate etag resource property from S3 storage upon resource creation

- Configuration keywords:

  - the ``ckanext.dcor_schemas.allow_content_listing_for_anon`` boolean
    parameter can be set to False to prevent anonymous users to see
    circles, colletions, and other content.
  - the ``ckanext.dcor_schemas.allow_public_datasets`` boolean parameter
    can be used to disable the creation of public datasets (e.g. for DCOR-med).
  - the ``ckanext.dcor_schemas.json_resource_schema_dir`` parameter
    can be used to specify a directory containing .json files that
    define the supplementary resource schema. The default is
    ``package`` which means that the supplementary resource schema of
    this extension is used.

  - These DCOR-wide configuratio options for accessing S3 object storage

    - ``endpoint_url``
    - ``bucket_name``
    - ``access_key_id``
    - ``secret_access_key``
    - ``ssl_verify``

- API extensions:

  - ``resource_upload_s3_urls`` returns a dictionary containing the upload
    URLs (single file or multipart) required for uploading a new resource
    directly to S3
  - ``resource_schema_supplements`` returns a dictionary of the
    current supplementary resource schema
  - ``supported_resource_suffixes`` returns a list of supported
    resource suffixes

- CLI:

  - CKAN command `list-circles` returns the list of DCOR circles
  - CKAN command `list-collections` returns the list of DCOR collections
  - CKAN command `list-group-resources <NAME>` returns the list of resources in
    a DCOR circle or collection
  - CKAN command `list-zombie-users` for users with no datasets and
    no activity for a certain amount of time
  - CKAN command `run-jobs-dcor-schemas` that runs all background
    jobs for all resources (if not already done)
  - CKAN command `dcor-move-dataset-to-circle` for moving a dataset to
    a different circle


Installation
------------
Simply run

::

    pip install ckanext-dcor_schemas

In the configuration file ckan.ini:

::
    
    ckan.plugins = [...] dcor_schemas
    ckan.extra_resource_fields = etag sha256


Testing
-------
If CKAN/DCOR is installed and setup for testing, this extension can
be tested with pytest:

::

    pytest ckanext

Testing can also be done via vagrant in a virtualmachine using the
`dcor-test <https://app.vagrantup.com/paulmueller/boxes/dcor-test/>` image.
Make sure that `vagrant` and `virtualbox` are installed and run the
following commands in the root of this repository:

::

    # Setup virtual machine using `Vagrantfile`
    vagrant up
    # Run the tests
    vagrant ssh -- sudo bash /testing/vagrant-run-tests.sh


.. |PyPI Version| image:: https://img.shields.io/pypi/v/ckanext.dcor_schemas.svg
   :target: https://pypi.python.org/pypi/ckanext.dcor_schemas
.. |Build Status| image:: https://img.shields.io/github/actions/workflow/status/DCOR-dev/ckanext-dcor_schemas/check.yml
   :target: https://github.com/DCOR-dev/ckanext-dcor_schemas/actions?query=workflow%3AChecks
.. |Coverage Status| image:: https://img.shields.io/codecov/c/github/DCOR-dev/ckanext-dcor_schemas
   :target: https://codecov.io/gh/DCOR-dev/ckanext-dcor_schemas

            

Raw data

            {
    "_id": null,
    "home_page": null,
    "name": "ckanext-dcor-schemas",
    "maintainer": null,
    "docs_url": null,
    "requires_python": "<4,>=3.8",
    "maintainer_email": "Paul M\u00fcller <dev@craban.de>",
    "keywords": "DC, DCOR, deformability, cytometry",
    "author": "Paul M\u00fcller",
    "author_email": null,
    "download_url": "https://files.pythonhosted.org/packages/e8/9d/30da1729653fa2178a49599371111d9e3f02b0c4c91907ef15742dcfd77d/ckanext_dcor_schemas-0.21.1.tar.gz",
    "platform": null,
    "description": "ckanext-dcor_schemas\n====================\n\n|PyPI Version| |Build Status| |Coverage Status|\n\nThis module introduces/lifts restrictions (authorization) for the management\nof data and meta data on DCOR. The corresponding UI elements are modified\naccordingly:\n\n- Authorization (auth.py)\n\n  - datasets: do not allow deleting datasets unless they are drafts\n  - datasets: allow purging of deleted datasets\n  - datasets: do not allow switching to a more restrictive license\n  - datasets: do not allow changing the name (slug)\n  - datasets: do not allow adding resources to non-draft datasets\n  - datasets: do not allow to set the visibility of a public dataset to private\n  - datasets: do not allow uploading datasets via the web interface\n  - organization: do not allow bulk_update_delete (e.g. datasets by organization admins)\n  - resources: do not allow deleting resources unless they are drafts\n  - resources: only allow changing the \"description\"\n  - resources: do not allow setting a resource id when uploading\n  - user: allow all logged-in users to create datasets, circles, and collections\n\n- Validation (validate.py)\n\n  - datasets: force user to select authors\n  - datasets: author list \"authors\" is CSV\n  - datasets: parse DOI field (remove URL part)\n  - datasets: force user to select a license\n  - datasets: restrict to basic CC licenses\n  - datasets: automatically generate dataset name (slug) using random characters\n    if necessary (does not apply to admins)\n  - datasets: a dataset without resources is considered to be a draft;\n    it's state cannot be set to \"active\"\n  - datasets: the state of a dataset that does not contain at least one\n    valid .rtdc resource cannot be set to \"active\"\n  - resources: do not allow uploading resources with the same name\n    for a dataset (important for ckanext-dcor_depot)\n  - resources: make sure the resource name matches the file name of the\n    upload; this is actually implemented in plugin.before_create\n    (IResourceController) and not in validate.py\n  - resources: custom resource name is overridden during upload\n  - resources: do not allow weird characters in resource names\n  - resources: restrict upload data extensions to .'.rtdc', '.ini', '.csv',\n    '.tsv', '.pdf', '.txt', '.jpg', '.png', '.tif', '.py', '.ipynb', '.poly',\n    '.sof', '.so2'\n  - resources: configuration metadata (using `dclab.dfn.config_funcs`)\n  - resources: 's3_available' and 's3_url' for identifying objects that\n    are available on S3 and for downloading public datasets.\n\n- IPermissionLabels (plugin.py)\n\n  - Allow a user A to see user B's private dataset if the private dataset\n    is in a group that user A is a member of.\n\n- UI Dataset:\n\n  - hide \"add new resource\" button in ``templates/package/resources.html``\n  - add field ``authors`` (csv list)\n  - add field ``doi`` (validator parses URLs)\n  - add field ``references`` (parses arxiv, bioRxiv, DOI, links)\n  - add CC license file ``licenses.json`` (only show less restrictive licenses\n    when editing the dataset)\n\n- UI Organization:\n\n  - remove \"Delete\" button in bulk view\n\n- UI Resource:\n\n  - Do not show these variables (because they are redundant):\n    ['last modified', 'revision id', 'url type', 'state', 'on same domain']\n    (``templates/package/resource_read.html``)\n  - Show DC config data via \"toggle-more\"\n  - Add supplementary resource schema via json files located in\n    `dcor_schemas/resource_schema_supplements`\n\n- Background jobs:\n\n  - set the mimetype for each dataset\n  - populate \"dc:sec:key\" metadata for each DC dataset\n  - generates sha256 hash upon resource creation\n  - populate etag resource property from S3 storage upon resource creation\n\n- Configuration keywords:\n\n  - the ``ckanext.dcor_schemas.allow_content_listing_for_anon`` boolean\n    parameter can be set to False to prevent anonymous users to see\n    circles, colletions, and other content.\n  - the ``ckanext.dcor_schemas.allow_public_datasets`` boolean parameter\n    can be used to disable the creation of public datasets (e.g. for DCOR-med).\n  - the ``ckanext.dcor_schemas.json_resource_schema_dir`` parameter\n    can be used to specify a directory containing .json files that\n    define the supplementary resource schema. The default is\n    ``package`` which means that the supplementary resource schema of\n    this extension is used.\n\n  - These DCOR-wide configuratio options for accessing S3 object storage\n\n    - ``endpoint_url``\n    - ``bucket_name``\n    - ``access_key_id``\n    - ``secret_access_key``\n    - ``ssl_verify``\n\n- API extensions:\n\n  - ``resource_upload_s3_urls`` returns a dictionary containing the upload\n    URLs (single file or multipart) required for uploading a new resource\n    directly to S3\n  - ``resource_schema_supplements`` returns a dictionary of the\n    current supplementary resource schema\n  - ``supported_resource_suffixes`` returns a list of supported\n    resource suffixes\n\n- CLI:\n\n  - CKAN command `list-circles` returns the list of DCOR circles\n  - CKAN command `list-collections` returns the list of DCOR collections\n  - CKAN command `list-group-resources <NAME>` returns the list of resources in\n    a DCOR circle or collection\n  - CKAN command `list-zombie-users` for users with no datasets and\n    no activity for a certain amount of time\n  - CKAN command `run-jobs-dcor-schemas` that runs all background\n    jobs for all resources (if not already done)\n  - CKAN command `dcor-move-dataset-to-circle` for moving a dataset to\n    a different circle\n\n\nInstallation\n------------\nSimply run\n\n::\n\n    pip install ckanext-dcor_schemas\n\nIn the configuration file ckan.ini:\n\n::\n    \n    ckan.plugins = [...] dcor_schemas\n    ckan.extra_resource_fields = etag sha256\n\n\nTesting\n-------\nIf CKAN/DCOR is installed and setup for testing, this extension can\nbe tested with pytest:\n\n::\n\n    pytest ckanext\n\nTesting can also be done via vagrant in a virtualmachine using the\n`dcor-test <https://app.vagrantup.com/paulmueller/boxes/dcor-test/>` image.\nMake sure that `vagrant` and `virtualbox` are installed and run the\nfollowing commands in the root of this repository:\n\n::\n\n    # Setup virtual machine using `Vagrantfile`\n    vagrant up\n    # Run the tests\n    vagrant ssh -- sudo bash /testing/vagrant-run-tests.sh\n\n\n.. |PyPI Version| image:: https://img.shields.io/pypi/v/ckanext.dcor_schemas.svg\n   :target: https://pypi.python.org/pypi/ckanext.dcor_schemas\n.. |Build Status| image:: https://img.shields.io/github/actions/workflow/status/DCOR-dev/ckanext-dcor_schemas/check.yml\n   :target: https://github.com/DCOR-dev/ckanext-dcor_schemas/actions?query=workflow%3AChecks\n.. |Coverage Status| image:: https://img.shields.io/codecov/c/github/DCOR-dev/ckanext-dcor_schemas\n   :target: https://codecov.io/gh/DCOR-dev/ckanext-dcor_schemas\n",
    "bugtrack_url": null,
    "license": "GNU Affero General Public License v3 or later (AGPLv3+)",
    "summary": "Introduces or lifts restrictions (authorization) for managing data and metadata on DCOR",
    "version": "0.21.1",
    "project_urls": {
        "changelog": "https://github.com/DCOR-dev/ckanext-dcor_schemas/blob/main/CHANGELOG",
        "source": "https://github.com/DCOR-dev/ckanext-dcor_schemas",
        "tracker": "https://github.com/DCOR-dev/ckanext-dcor_schemas/issues"
    },
    "split_keywords": [
        "dc",
        " dcor",
        " deformability",
        " cytometry"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "e7b267a21c6f695d3be9bc8cffd27bf10f7a0707b16da5838948ad86e31abac3",
                "md5": "9d418391d099d89b0f781e8355c14a27",
                "sha256": "0552df2c50ddc49f73a61eae15567e27400837a141713e0dcde04b63a5c43216"
            },
            "downloads": -1,
            "filename": "ckanext_dcor_schemas-0.21.1-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "9d418391d099d89b0f781e8355c14a27",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": "<4,>=3.8",
            "size": 704650,
            "upload_time": "2024-11-26T20:03:46",
            "upload_time_iso_8601": "2024-11-26T20:03:46.011683Z",
            "url": "https://files.pythonhosted.org/packages/e7/b2/67a21c6f695d3be9bc8cffd27bf10f7a0707b16da5838948ad86e31abac3/ckanext_dcor_schemas-0.21.1-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "e89d30da1729653fa2178a49599371111d9e3f02b0c4c91907ef15742dcfd77d",
                "md5": "f9b43165490f2193ab9bbe10fecd6963",
                "sha256": "570a3d99d00578c871bb62fecaac3e33c3826c9d657ae3a5aa5874b83fa9e5f8"
            },
            "downloads": -1,
            "filename": "ckanext_dcor_schemas-0.21.1.tar.gz",
            "has_sig": false,
            "md5_digest": "f9b43165490f2193ab9bbe10fecd6963",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": "<4,>=3.8",
            "size": 695996,
            "upload_time": "2024-11-26T20:03:47",
            "upload_time_iso_8601": "2024-11-26T20:03:47.624749Z",
            "url": "https://files.pythonhosted.org/packages/e8/9d/30da1729653fa2178a49599371111d9e3f02b0c4c91907ef15742dcfd77d/ckanext_dcor_schemas-0.21.1.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-11-26 20:03:47",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "DCOR-dev",
    "github_project": "ckanext-dcor_schemas",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "lcname": "ckanext-dcor-schemas"
}
        
Elapsed time: 0.38842s