"Invenio module containing some customizations and configuration for TU Wien."
Project description
Invenio package for tweaking InvenioRDM to the needs of TU Wien.
The following list is a quick overview of the most relevant customizations happening in this package:
Configuration values
Permission policies
OIDC authentication handling
E-Mail notification on errors
User profile extension
Integration with other TU Wien services
Details
Configuration values
The primary purpose of this Invenio package is to provide some baseline configuration for InvenioRDM to suit deployment at TU Wien. These updated configurations include (but are not limited to) setting default values for record metadata and enabling access requests for restricted records per default.
Permission policies
InvenioRDM is not just some sort of cheap storage platform where users can upload their data and update it at any time. Instead, it is a platform intended to host digital objects that get [DOIs](https://www.doi.org/) assigned. Since the idea behind DOIs (and persistent identifiers in general) is to point at the same content over time, it does not allow users to change the files after publication.
This is one of the unique features that the system offers that may not be immediately obvious to users. To make sure that users understand the implications of using the system, we require a brief communication between the users and operators.
In contrast to vanilla InvenioRDM, having an account is not enough to create uploads in our system. Instead, the creation of records requires the trusted-user role, which typically has to be given out by administrators.
Also, communities can be quite confusing in the beginning. Thus, we restrict the creation of new communities for non-administrators.
OIDC authentication handling
We do not want to handle certain aspects like password management of user management in our system. Instead, we offload authentication to a separate service, with which InvenioRDM communicates via OIDC. Sometimes we have slightly non-standard requirements, which are satisfied by the authentication handler logic in this package.
E-Mail notification on errors
This module defines a custom log handler for error-level logs which sends out notifications as e-mail to a set of configured recipient addresses.
User profile extension
We forgot to secure the rights to curate metadata for uploads in our system in the first version of the terms of use. So instead, we extended the user profiles to collect consent for curation individually per user.
Integration with other TU Wien services
One of the benefits of hosting InvenioRDM as an institutional repository is that it enables some conveniences by integrating with the local environment more. For example, we integrate with [TISS](https://tiss.tuwien.ac.at/) by periodically querying it for TU Wien employees and adding their names to the controlled vocabulary of known names.
Changes
Version 2024.2 (released 2024-06-24, updated 2024-09-17)
v12 compat: Chase Invenio-OAuthClient refactoring
v12 compat: Chase permission policy changes
v12 compat: Chase record ownership changes
v12 compat: Remove breadcrumbs
Use configuration items instead of hacks for the community permission policy
Flatten the user preference curation.consent to curation_consent
Override search mappings
Remove support for creating community-submission requests for drafts
Allow {user,guest} access requests for new drafts by default
Add install extras for search
Add Flask-Minify as opt-in for minifying HTML responses (without the golang minifiers)
Show all accessible drafts in the user’s dashboard
Give out permissions to access the draft’s files with the preview permission
Deduplicate some generators in the permission policy
Remove references to the unused trusted-publisher role
Use the finalize_app entrypoint for the SMTP handler rather than a hacky blueprint
Update README
Remove overridden search mappings for community members
Version 2024.1 (released 2024-05-22, updated 2024-05-22)
Store given_name and family_name in user profiles
Use these values to more accurately synthesize default values for creators in metadata
Store the TISS ID in the user profile for people with TU Wien affiliation
Version 2023.2 (released 2023-04-24, updated 2023-12-22)
v11 compat: Update permission policies and disable archive download
Set affiliation (hard-coded) to TU Wien in user.profile
Set a default template for the description metadata field
Add a null check for the current_user in the logging formatter
Prevent the logging formatter from blowing up outside of a request context
Add utilities and a celery task for updating the names vocabulary with information from TISS
Enable sending of registration mails
Allow edits to owners of published records even if they only have trusted-user role
Fix a typo in the config generated by the TUWSSOSettingsHelper
Fix function to fetch user by username
Add record curation preferences to user settings
Version 2023.1 (released 2023-01-13)
Update definition of the default creator for new uploads
Version 2022.3 (released 2022-10-28, updated 2022-11-30)
v10 compat: Discard imports of removed Admin/SuperUser generators
Rework the initialization procedure used for some custom overrides
Migrate from setup.py to setup.cfg
Move Flask config override from Invenio-Theme-TUW to Invenio-Config-TUW
Update “Terms of Use” link in registration form
Version 2022.2 (released 2022-07-19, updated 2022-10-22)
v9 compat: Chase changes in Invenio-{Accounts,OAuthClient} 2.x
v9 compat: Update permission policies
v9 compat: Hack in permission policy for communities
Refactor permissions and config
Remove leftover views.py
Set deposit form file size limits
Fix permissions
Reverse contents of CHANGES.rst (recent changes are shown on top)
Attach SMTP error handler to the application in production mode
Add custom logging formatter
Auto-confirm newly registered users’ e-mail addresses if SECURITY_CONFIRMABLE is False
Set default user preferences (visibility=public, email_visibility=restricted)
Set default value for version metadata to 1.0.0
Add config item to put the system into “read-only mode”
Version 2022.1 (released 2022-03-23, updated 2022-04-06)
Update permissions for creating and editing drafts
Use the OAI metadata implementation from Invenio-RDM-Records
Change the default file size and bucket quota limits to 75GB
Version 2021.2 (released 2021-12-07, updated 2021-12-20)
Make ready for InvenioRDM v7
Add requests permission policy
Enforce a rate limit for HTTP requests
Change method of overriding the record permission policy
Add datacite and oai_datacite metadataPrefixes to the OAI endpoint
Version 2021.1 (released 2021-07-15)
Initial public release.
Update the list of citation styles
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
Hashes for invenio_config_tuw-2024.2.10.tar.gz
Algorithm | Hash digest | |
---|---|---|
SHA256 | e9115f7a54d984bde602b4ff812cff2409897570bab92ea7e78e6707752cb566 |
|
MD5 | 87b5c9337cd04391e8d0f03433b5fbfc |
|
BLAKE2b-256 | d2456cf99c82f800b7f2f131dce9e27ac21c22e8c02e97c764b4fd4b9cc62765 |
Hashes for invenio_config_tuw-2024.2.10-py2.py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | e82d81a4ddcb096eab34b0654a5461d6e9aa690ce2aac850d2e58c5ad75926fd |
|
MD5 | 4ecdbf2bdf850eb8ef811b09673b8299 |
|
BLAKE2b-256 | f38438d1e439a9eee5ed2cc42cb89af3aa74c7c69e27f4b1415c8d23cfd24e16 |