mirror of
https://github.com/Cian-H/invenio-config-iform.git
synced 2025-12-23 05:21:57 +00:00
Compare commits
8 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
f0fbabbaa8 | ||
|
|
5e2a58c764 | ||
|
|
9af1beff88 | ||
|
|
80575cbced | ||
|
|
60b85e6ad5 | ||
|
|
10f68379b5 | ||
|
|
49766790d7 | ||
|
|
977d5588f4 |
47
.github/workflows/tests.yml
vendored
47
.github/workflows/tests.yml
vendored
@@ -20,9 +20,42 @@ jobs:
|
|||||||
runs-on: ubuntu-20.04
|
runs-on: ubuntu-20.04
|
||||||
strategy:
|
strategy:
|
||||||
matrix:
|
matrix:
|
||||||
python-version: [3.6, 3.7, 3.8]
|
python-version: [3.6, 3.7, 3.8, 3.9]
|
||||||
requirements-level: [min, pypi]
|
requirements-level: [min, pypi]
|
||||||
|
db-service: [postgresql12]
|
||||||
|
search-service: [elasticsearch7]
|
||||||
|
exclude:
|
||||||
|
- python-version: 3.6
|
||||||
|
requirements-level: pypi
|
||||||
|
|
||||||
|
- python-version: 3.7
|
||||||
|
requirements-level: min
|
||||||
|
|
||||||
|
- python-version: 3.8
|
||||||
|
requirements-level: min
|
||||||
|
|
||||||
|
- python-version: 3.9
|
||||||
|
requirements-level: min
|
||||||
|
|
||||||
|
- db-service: postgresql12
|
||||||
|
requirements-level: min
|
||||||
|
|
||||||
|
- search-service: elasticsearch7
|
||||||
|
requirements-level: min
|
||||||
|
|
||||||
|
include:
|
||||||
|
|
||||||
|
- db-service: postgresql12
|
||||||
|
DB_EXTRAS: "postgresql"
|
||||||
|
|
||||||
|
|
||||||
|
- search-service: elasticsearch7
|
||||||
|
SEARCH_EXTRAS: "elasticsearch7"
|
||||||
|
|
||||||
|
env:
|
||||||
|
DB: ${{ matrix.db-service }}
|
||||||
|
SEARCH: ${{ matrix.search-service }}
|
||||||
|
EXTRAS: all,${{ matrix.DB_EXTRAS }},${{ matrix.SEARCH_EXTRAS }}
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout
|
- name: Checkout
|
||||||
uses: actions/checkout@v2
|
uses: actions/checkout@v2
|
||||||
@@ -35,8 +68,7 @@ jobs:
|
|||||||
- name: Generate dependencies
|
- name: Generate dependencies
|
||||||
run: |
|
run: |
|
||||||
python -m pip install --upgrade pip setuptools py wheel requirements-builder
|
python -m pip install --upgrade pip setuptools py wheel requirements-builder
|
||||||
requirements-builder -e all --level=${{ matrix.requirements-level }} setup.py > .${{ matrix.requirements-level }}-${{ matrix.python-version }}-requirements.txt
|
requirements-builder -e "$EXTRAS" --level=${{ matrix.requirements-level }} setup.py > .${{ matrix.requirements-level }}-${{ matrix.python-version }}-requirements.txt
|
||||||
|
|
||||||
- name: Cache pip
|
- name: Cache pip
|
||||||
uses: actions/cache@v2
|
uses: actions/cache@v2
|
||||||
with:
|
with:
|
||||||
@@ -45,10 +77,11 @@ jobs:
|
|||||||
|
|
||||||
- name: Install dependencies
|
- name: Install dependencies
|
||||||
run: |
|
run: |
|
||||||
pip install -r .${{matrix.requirements-level}}-${{ matrix.python-version }}-requirements.txt
|
pip install -r .${{ matrix.requirements-level }}-${{ matrix.python-version }}-requirements.txt
|
||||||
pip install .[all]
|
pip install ".[$EXTRAS]"
|
||||||
pip freeze
|
pip freeze
|
||||||
|
docker --version
|
||||||
|
docker-compose --version
|
||||||
- name: Run tests
|
- name: Run tests
|
||||||
run: |
|
run: |
|
||||||
./run-tests.sh
|
./run-tests.sh
|
||||||
|
|||||||
@@ -34,15 +34,18 @@ recursive-include docs *.py
|
|||||||
recursive-include docs *.rst
|
recursive-include docs *.rst
|
||||||
recursive-include docs *.txt
|
recursive-include docs *.txt
|
||||||
recursive-include docs Makefile
|
recursive-include docs Makefile
|
||||||
recursive-include invenio_config_tugraz *.html
|
|
||||||
recursive-include tests *.py
|
recursive-include tests *.py
|
||||||
|
|
||||||
|
|
||||||
# added by check_manifest.py
|
# added by check_manifest.py
|
||||||
recursive-include invenio_config_tugraz *.crt
|
recursive-include invenio_config_tugraz *.crt
|
||||||
recursive-include invenio_config_tugraz *.json
|
recursive-include invenio_config_tugraz *.json
|
||||||
recursive-include invenio_config_tugraz *.key
|
recursive-include invenio_config_tugraz *.key
|
||||||
recursive-include invenio_config_tugraz *.xml
|
recursive-include invenio_config_tugraz *.xml
|
||||||
recursive-include invenio_config_tugraz *.gitkeep
|
recursive-include invenio_config_tugraz *.gitkeep
|
||||||
|
recursive-include invenio_config_tugraz *.txt
|
||||||
|
recursive-include invenio_config_tugraz *.html
|
||||||
|
|
||||||
|
|
||||||
# added by check-manifest
|
# added by check-manifest
|
||||||
recursive-include invenio_config_tugraz *.csv
|
recursive-include invenio_config_tugraz *.csv
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
..
|
..
|
||||||
Copyright (C) 2020 Mojib Wali.
|
Copyright (C) 2020-2021 Graz University of Technology.
|
||||||
|
|
||||||
invenio-config-tugraz is free software; you can redistribute it and/or
|
invenio-config-tugraz is free software; you can redistribute it and/or
|
||||||
modify it under the terms of the MIT License; see LICENSE file for more
|
modify it under the terms of the MIT License; see LICENSE file for more
|
||||||
@@ -15,10 +15,10 @@
|
|||||||
.. image:: https://img.shields.io/pypi/dm/invenio-config-tugraz.svg
|
.. image:: https://img.shields.io/pypi/dm/invenio-config-tugraz.svg
|
||||||
:target: https://pypi.python.org/pypi/invenio-config-tugraz
|
:target: https://pypi.python.org/pypi/invenio-config-tugraz
|
||||||
|
|
||||||
.. image:: https://img.shields.io/github/tag/mb-wali/invenio-config-tugraz.svg
|
.. image:: https://img.shields.io/github/tag/tu-graz-library/invenio-config-tugraz.svg
|
||||||
:target: https://github.com/mb-wali/invenio-config-tugraz/releases
|
:target: https://github.com/mb-wali/invenio-config-tugraz/releases
|
||||||
|
|
||||||
.. image:: https://img.shields.io/github/license/mb-wali/invenio-config-tugraz.svg
|
.. image:: https://img.shields.io/github/license/tu-graz-library/invenio-config-tugraz.svg
|
||||||
:target: https://github.com/mb-wali/invenio-config-tugraz/blob/master/LICENSE
|
:target: https://github.com/mb-wali/invenio-config-tugraz/blob/master/LICENSE
|
||||||
|
|
||||||
.. image:: https://readthedocs.org/projects/invenio-config-tugraz/badge/?version=latest
|
.. image:: https://readthedocs.org/projects/invenio-config-tugraz/badge/?version=latest
|
||||||
|
|||||||
@@ -13,7 +13,7 @@ encoding = utf-8
|
|||||||
|
|
||||||
# Extraction from Jinja2 templates
|
# Extraction from Jinja2 templates
|
||||||
|
|
||||||
[jinja2: **/templates/**.html]
|
[jinja2: **/templates/**.*]
|
||||||
encoding = utf-8
|
encoding = utf-8
|
||||||
extensions = jinja2.ext.autoescape, jinja2.ext.with_
|
extensions = jinja2.ext.autoescape, jinja2.ext.with_
|
||||||
|
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
# -*- coding: utf-8 -*-
|
# -*- coding: utf-8 -*-
|
||||||
#
|
#
|
||||||
# Copyright (C) 2020 Graz University of Technology.
|
# Copyright (C) 2020-2021 Graz University of Technology.
|
||||||
#
|
#
|
||||||
# invenio-config-tugraz is free software; you can redistribute it and/or
|
# invenio-config-tugraz is free software; you can redistribute it and/or
|
||||||
# modify it under the terms of the MIT License; see LICENSE file for more
|
# modify it under the terms of the MIT License; see LICENSE file for more
|
||||||
@@ -49,40 +49,40 @@ Using Custom Generator for a policy:
|
|||||||
Permissions for Invenio records.
|
Permissions for Invenio records.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
from invenio_records_permissions.generators import (
|
# from invenio_records_permissions.generators import (
|
||||||
Admin,
|
# Admin,
|
||||||
AnyUser,
|
# AnyUser,
|
||||||
AnyUserIfPublic,
|
# AnyUserIfPublic,
|
||||||
RecordOwners,
|
# RecordOwners,
|
||||||
)
|
# )
|
||||||
from invenio_records_permissions.policies.base import BasePermissionPolicy
|
# from invenio_records_permissions.policies.base import BasePermissionPolicy
|
||||||
|
|
||||||
from .generators import RecordIp
|
# from .generators import RecordIp
|
||||||
|
|
||||||
|
|
||||||
class TUGRAZPermissionPolicy(BasePermissionPolicy):
|
# class TUGRAZPermissionPolicy(BasePermissionPolicy):
|
||||||
"""Access control configuration for records.
|
# """Access control configuration for records.
|
||||||
|
|
||||||
This overrides the /api/records endpoint.
|
# This overrides the /api/records endpoint.
|
||||||
|
|
||||||
"""
|
# """
|
||||||
|
|
||||||
# Read access to API given to everyone.
|
# # Read access to API given to everyone.
|
||||||
can_search = [AnyUser(), RecordIp()]
|
# can_search = [AnyUser(), RecordIp()]
|
||||||
|
|
||||||
# Read access given to everyone if public record/files and owners always.
|
# # Read access given to everyone if public record/files and owners always.
|
||||||
can_read = [AnyUserIfPublic(), RecordOwners(), RecordIp()]
|
# can_read = [AnyUserIfPublic(), RecordOwners(), RecordIp()]
|
||||||
|
|
||||||
# Create action given to no one (Not even superusers) bc Deposits should
|
# # Create action given to no one (Not even superusers) bc Deposits should
|
||||||
# be used.
|
# # be used.
|
||||||
can_create = [AnyUser()]
|
# can_create = [AnyUser()]
|
||||||
|
|
||||||
# Update access given to record owners.
|
# # Update access given to record owners.
|
||||||
can_update = [RecordOwners()]
|
# can_update = [RecordOwners()]
|
||||||
|
|
||||||
# Delete access given to admins only.
|
# # Delete access given to admins only.
|
||||||
can_delete = [Admin()]
|
# can_delete = [Admin()]
|
||||||
|
|
||||||
# Associated files permissions (which are really bucket permissions)
|
# # Associated files permissions (which are really bucket permissions)
|
||||||
can_read_files = [AnyUserIfPublic(), RecordOwners()]
|
# can_read_files = [AnyUserIfPublic(), RecordOwners()]
|
||||||
can_update_files = [RecordOwners()]
|
# can_update_files = [RecordOwners()]
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
# -*- coding: utf-8 -*-
|
# -*- coding: utf-8 -*-
|
||||||
#
|
#
|
||||||
# Copyright (C) 2020 Graz University of Technology.
|
# Copyright (C) 2020-2021 Graz University of Technology.
|
||||||
#
|
#
|
||||||
# invenio-config-tugraz is free software; you can redistribute it and/or
|
# invenio-config-tugraz is free software; you can redistribute it and/or
|
||||||
# modify it under the terms of the MIT License; see LICENSE file for more
|
# modify it under the terms of the MIT License; see LICENSE file for more
|
||||||
@@ -84,7 +84,7 @@ SECURITY_EMAIL_SENDER = "info@invenio-test.tugraz.at"
|
|||||||
"""Email address used as sender of account registration emails."""
|
"""Email address used as sender of account registration emails."""
|
||||||
"""Domain name should match the domain used in web server."""
|
"""Domain name should match the domain used in web server."""
|
||||||
|
|
||||||
SECURITY_EMAIL_SUBJECT_REGISTER = _("Welcome to RDM!")
|
SECURITY_EMAIL_SUBJECT_REGISTER = _("Welcome to TU Graz Repository!")
|
||||||
"""Email subject for account registration emails."""
|
"""Email subject for account registration emails."""
|
||||||
|
|
||||||
MAIL_SUPPRESS_SEND = True
|
MAIL_SUPPRESS_SEND = True
|
||||||
@@ -172,6 +172,15 @@ SECURITY_CONFIRMABLE = False
|
|||||||
Instead user will get a welcome email.
|
Instead user will get a welcome email.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
# Flask-Security
|
||||||
|
# =============
|
||||||
|
# See https://pythonhosted.org/Flask-Security/configuration.html
|
||||||
|
SECURITY_EMAIL_PLAINTEXT = True
|
||||||
|
"""Render email content as plaintext."""
|
||||||
|
|
||||||
|
SECURITY_EMAIL_HTML = False
|
||||||
|
"""Render email content as HTML."""
|
||||||
|
|
||||||
|
|
||||||
ACCOUNTS = True
|
ACCOUNTS = True
|
||||||
"""Tells if the templates should use the accounts module.
|
"""Tells if the templates should use the accounts module.
|
||||||
@@ -198,16 +207,9 @@ RECAPTCHA_PRIVATE_KEY = None
|
|||||||
# =======
|
# =======
|
||||||
# See:
|
# See:
|
||||||
# https://invenio-records-permissions.readthedocs.io/en/latest/configuration.html
|
# https://invenio-records-permissions.readthedocs.io/en/latest/configuration.html
|
||||||
#
|
|
||||||
# Uncomment these to enable overriding Base permissions - (NOT RECOMMANDED)
|
|
||||||
# RECORDS_PERMISSIONS_RECORD_POLICY = (
|
|
||||||
# 'invenio_config_tugraz.base_permissions.TUGRAZPermissionPolicy'
|
|
||||||
# )
|
|
||||||
#
|
|
||||||
# Uncomment these to enable overriding RDM permissions
|
# Uncomment these to enable overriding RDM permissions
|
||||||
# RDM_RECORDS_BIBLIOGRAPHIC_SERVICE_CONFIG = (
|
# from .rdm_permissions import TUGRAZRDMRecordServiceConfig
|
||||||
# 'invenio_config_tugraz.rdm_permissions.TUGRAZBibliographicRecordServiceConfig'
|
# RDM_RECORDS_BIBLIOGRAPHIC_SERVICE_CONFIG = TUGRAZRDMRecordServiceConfig
|
||||||
# )
|
|
||||||
"""Access control configuration for records."""
|
"""Access control configuration for records."""
|
||||||
|
|
||||||
# invenio-rdm-records
|
# invenio-rdm-records
|
||||||
@@ -215,9 +217,7 @@ RECAPTCHA_PRIVATE_KEY = None
|
|||||||
# See:
|
# See:
|
||||||
# https://invenio-rdm-records.readthedocs.io/en/latest/configuration.html
|
# https://invenio-rdm-records.readthedocs.io/en/latest/configuration.html
|
||||||
#
|
#
|
||||||
RDM_RECORDS_USER_FIXTURE_PASSWORDS = {
|
RDM_RECORDS_USER_FIXTURE_PASSWORDS = {"info@tugraz.at": None}
|
||||||
"info@tugraz.at": None
|
|
||||||
}
|
|
||||||
"""Overrides for the user fixtures' passwords.
|
"""Overrides for the user fixtures' passwords.
|
||||||
The password set for a user fixture in this dictionary overrides the
|
The password set for a user fixture in this dictionary overrides the
|
||||||
password set in the ``users.yaml`` file. This can be used to set custom
|
password set in the ``users.yaml`` file. This can be used to set custom
|
||||||
|
|||||||
@@ -7,6 +7,7 @@
|
|||||||
# details.
|
# details.
|
||||||
|
|
||||||
"""invenio module that adds tugraz configs."""
|
"""invenio module that adds tugraz configs."""
|
||||||
|
from flask import Blueprint
|
||||||
|
|
||||||
from . import config
|
from . import config
|
||||||
|
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
# -*- coding: utf-8 -*-
|
# -*- coding: utf-8 -*-
|
||||||
#
|
#
|
||||||
# Copyright (C) 2020 Mojib Wali.
|
# Copyright (C) 2020-2021 Graz University of Technology.
|
||||||
#
|
#
|
||||||
# invenio-config-tugraz is free software; you can redistribute it and/or
|
# invenio-config-tugraz is free software; you can redistribute it and/or
|
||||||
# modify it under the terms of the MIT License; see LICENSE file for more
|
# modify it under the terms of the MIT License; see LICENSE file for more
|
||||||
@@ -153,7 +153,7 @@ The succinct encoding of the permissions for your instance gives you
|
|||||||
|
|
||||||
from elasticsearch_dsl.query import Q
|
from elasticsearch_dsl.query import Q
|
||||||
from flask import current_app, request
|
from flask import current_app, request
|
||||||
from invenio_access.permissions import any_user, authenticated_user, superuser_access
|
from invenio_access.permissions import any_user, superuser_access
|
||||||
from invenio_records_permissions.generators import Generator
|
from invenio_records_permissions.generators import Generator
|
||||||
|
|
||||||
|
|
||||||
@@ -221,20 +221,3 @@ class RecordIp(Generator):
|
|||||||
if user_ip in current_app.config["INVENIO_CONFIG_TUGRAZ_SINGLE_IP"]:
|
if user_ip in current_app.config["INVENIO_CONFIG_TUGRAZ_SINGLE_IP"]:
|
||||||
return True
|
return True
|
||||||
return False
|
return False
|
||||||
|
|
||||||
|
|
||||||
class AuthenticatedUser(Generator):
|
|
||||||
"""Allows authenticated users."""
|
|
||||||
|
|
||||||
def __init__(self):
|
|
||||||
"""Constructor."""
|
|
||||||
super(AuthenticatedUser, self).__init__()
|
|
||||||
|
|
||||||
def needs(self, **kwargs):
|
|
||||||
"""Enabling Needs."""
|
|
||||||
return [authenticated_user]
|
|
||||||
|
|
||||||
def query_filter(self, **kwargs):
|
|
||||||
"""Filters for current identity as super user."""
|
|
||||||
# TODO: Implement with new permissions metadata
|
|
||||||
return []
|
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
# -*- coding: utf-8 -*-
|
# -*- coding: utf-8 -*-
|
||||||
#
|
#
|
||||||
# Copyright (C) 2020 Graz University of Technology.
|
# Copyright (C) 2020-2021 Graz University of Technology.
|
||||||
#
|
#
|
||||||
# invenio-config-tugraz is free software; you can redistribute it and/or
|
# invenio-config-tugraz is free software; you can redistribute it and/or
|
||||||
# modify it under the terms of the MIT License; see LICENSE file for more
|
# modify it under the terms of the MIT License; see LICENSE file for more
|
||||||
@@ -53,59 +53,34 @@ Using Custom Generator for a policy:
|
|||||||
Permissions for Invenio (RDM) Records.
|
Permissions for Invenio (RDM) Records.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
from invenio_rdm_records.services import (
|
from invenio_rdm_records.services import RDMRecordPermissionPolicy
|
||||||
BibliographicRecordServiceConfig,
|
from invenio_rdm_records.services.config import RDMRecordServiceConfig
|
||||||
RDMRecordPermissionPolicy,
|
from invenio_rdm_records.services.generators import IfDraft, IfRestricted, RecordOwners
|
||||||
)
|
|
||||||
from invenio_records_permissions.generators import (
|
from invenio_records_permissions.generators import (
|
||||||
Admin,
|
Admin,
|
||||||
AnyUser,
|
AnyUser,
|
||||||
RecordOwners,
|
AuthenticatedUser,
|
||||||
|
Disable,
|
||||||
SuperUser,
|
SuperUser,
|
||||||
|
SystemProcess,
|
||||||
)
|
)
|
||||||
|
|
||||||
from .generators import AuthenticatedUser, RecordIp
|
|
||||||
|
|
||||||
|
|
||||||
class TUGRAZPermissionPolicy(RDMRecordPermissionPolicy):
|
class TUGRAZPermissionPolicy(RDMRecordPermissionPolicy):
|
||||||
"""Access control configuration for rdm records.
|
"""Access control configuration for rdm records.
|
||||||
|
|
||||||
This overrides the origin:
|
This overrides the origin:
|
||||||
https://github.com/inveniosoftware/invenio-rdm-records/blob/master/invenio_rdm_records/services/permissions.py.
|
https://github.com/inveniosoftware/invenio-rdm-records/blob/master/invenio_rdm_records/services/permissions.py.
|
||||||
|
Access control configuration for records.
|
||||||
|
Note that even if the array is empty, the invenio_access Permission class
|
||||||
|
always adds the ``superuser-access``, so admins will always be allowed.
|
||||||
|
- Create action given to everyone for now.
|
||||||
|
- Read access given to everyone if public record and given to owners
|
||||||
|
always. (inherited)
|
||||||
|
- Update access given to record owners. (inherited)
|
||||||
|
- Delete access given to admins only. (inherited)
|
||||||
"""
|
"""
|
||||||
|
|
||||||
# Read access given to:
|
|
||||||
# TODO:
|
|
||||||
# AnyUserIfPublic : grant access if record is public
|
|
||||||
# RecordIp: grant access for single_ip
|
|
||||||
# RecordOwners: owner of records, enable once the deposit is allowed only for loged-in users.
|
|
||||||
# CURRENT:
|
|
||||||
# RecordIp: grant access for single_ip
|
|
||||||
can_read = [RecordIp()] # RecordOwners()
|
|
||||||
|
|
||||||
# Search access given to:
|
class TUGRAZRDMRecordServiceConfig(RDMRecordServiceConfig):
|
||||||
# AnyUser : grant access anyUser
|
|
||||||
# RecordIp: grant access for single_ip
|
|
||||||
can_search = [AnyUser(), RecordIp()]
|
|
||||||
|
|
||||||
# Update access given to record owners.
|
|
||||||
can_update = [RecordOwners()]
|
|
||||||
|
|
||||||
# Delete access given to admins only.
|
|
||||||
can_delete = [Admin()]
|
|
||||||
|
|
||||||
# Create action given to AuthenticatedUser
|
|
||||||
# UI - if user is loged in
|
|
||||||
# API - if user has Access token (Bearer API-TOKEN)
|
|
||||||
can_create = [AuthenticatedUser()]
|
|
||||||
|
|
||||||
# Associated files permissions (which are really bucket permissions)
|
|
||||||
# can_read_files = [AnyUserIfPublic(), RecordOwners()]
|
|
||||||
# can_update_files = [RecordOwners()]
|
|
||||||
|
|
||||||
|
|
||||||
class TUGRAZBibliographicRecordServiceConfig(BibliographicRecordServiceConfig):
|
|
||||||
"""Overriding BibliographicRecordServiceConfig."""
|
"""Overriding BibliographicRecordServiceConfig."""
|
||||||
|
|
||||||
permission_policy_cls = TUGRAZPermissionPolicy
|
|
||||||
|
|||||||
20
invenio_config_tugraz/templates/security/email/welcome.html
Normal file
20
invenio_config_tugraz/templates/security/email/welcome.html
Normal file
@@ -0,0 +1,20 @@
|
|||||||
|
<p>{{ _('Dear %(email)s!', email=user.email) }}</p>
|
||||||
|
|
||||||
|
<p>{{ _('To help you get started, here are some useful links:') }}</p>
|
||||||
|
|
||||||
|
<p>
|
||||||
|
<a href="https://{{ config.SITE_HOSTNAME }}{{ url_for('invenio_theme_tugraz.index') }}">{{ _('TU Graz Repository') }}</a> <br>
|
||||||
|
<a href="https://{{ config.SITE_HOSTNAME }}{{ url_for('invenio_theme_tugraz.guide')">{{ _('Reference Guide') }}</a><br>
|
||||||
|
<a href="https://{{ config.SITE_HOSTNAME }}{{ url_for('invenio_theme_tugraz.terms')">{{ _('Terms and Conditions') }}</a> <br>
|
||||||
|
</p>
|
||||||
|
|
||||||
|
{% if security.confirmable %}
|
||||||
|
<p>{{ _('You can confirm your email through the link below:') }}</p>
|
||||||
|
|
||||||
|
<p><a href="{{ confirmation_link }}">{{ _('Confirm my account') }}</a></p>
|
||||||
|
{% endif %}
|
||||||
|
|
||||||
|
<p>
|
||||||
|
{{ _('Best regards') }} <br>
|
||||||
|
{{ _('TU Graz Repository Team') }}
|
||||||
|
</p>
|
||||||
21
invenio_config_tugraz/templates/security/email/welcome.txt
Normal file
21
invenio_config_tugraz/templates/security/email/welcome.txt
Normal file
@@ -0,0 +1,21 @@
|
|||||||
|
{{ _('Dear %(email)s!', email=user.email) }}
|
||||||
|
|
||||||
|
{{ _('To help you get started, here are some useful links:') }}
|
||||||
|
|
||||||
|
{{ _('Repository')}}
|
||||||
|
https://{{ config.SITE_HOSTNAME }}{{ url_for('invenio_theme_tugraz.index') }}
|
||||||
|
|
||||||
|
{{ _('Repository Guide')}}
|
||||||
|
https://{{ config.SITE_HOSTNAME }}{{ url_for('invenio_theme_tugraz.guide') }}
|
||||||
|
|
||||||
|
{{ _('Terms And Conditions') }}
|
||||||
|
https://{{ config.SITE_HOSTNAME }}{{ url_for('invenio_theme_tugraz.terms') }}
|
||||||
|
|
||||||
|
|
||||||
|
{% if security.confirmable %}
|
||||||
|
{{ _('You can confirm your email through the link below:') }}
|
||||||
|
{{ confirmation_link }}">
|
||||||
|
{% endif %}
|
||||||
|
|
||||||
|
{{ _('Best regards') }}
|
||||||
|
{{ _('TU Graz Repository Team') }}
|
||||||
@@ -1,15 +1,15 @@
|
|||||||
# German translations for invenio-config-tugraz.
|
# German translations for invenio-config-tugraz.
|
||||||
# Copyright (C) 2020 Mojib Wali
|
# Copyright (C) 2021 Mojib Wali
|
||||||
# This file is distributed under the same license as the
|
# This file is distributed under the same license as the
|
||||||
# invenio-config-tugraz project.
|
# invenio-config-tugraz project.
|
||||||
# FIRST AUTHOR <EMAIL@ADDRESS>, 2020.
|
# FIRST AUTHOR <EMAIL@ADDRESS>, 2021.
|
||||||
#
|
#
|
||||||
msgid ""
|
msgid ""
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: invenio-config-tugraz 0.1.5\n"
|
"Project-Id-Version: invenio-config-tugraz 0.5.4\n"
|
||||||
"Report-Msgid-Bugs-To: mojib.wali@tugraz.at\n"
|
"Report-Msgid-Bugs-To: mojib.wali@tugraz.at\n"
|
||||||
"POT-Creation-Date: 2020-10-06 09:28+0200\n"
|
"POT-Creation-Date: 2021-04-22 09:24+0200\n"
|
||||||
"PO-Revision-Date: 2020-10-06 09:28+0200\n"
|
"PO-Revision-Date: 2021-04-22 09:12+0200\n"
|
||||||
"Last-Translator: FULL NAME <EMAIL@ADDRESS>\n"
|
"Last-Translator: FULL NAME <EMAIL@ADDRESS>\n"
|
||||||
"Language: de\n"
|
"Language: de\n"
|
||||||
"Language-Team: de <LL@li.org>\n"
|
"Language-Team: de <LL@li.org>\n"
|
||||||
@@ -17,9 +17,42 @@ msgstr ""
|
|||||||
"MIME-Version: 1.0\n"
|
"MIME-Version: 1.0\n"
|
||||||
"Content-Type: text/plain; charset=utf-8\n"
|
"Content-Type: text/plain; charset=utf-8\n"
|
||||||
"Content-Transfer-Encoding: 8bit\n"
|
"Content-Transfer-Encoding: 8bit\n"
|
||||||
"Generated-By: Babel 2.8.0\n"
|
"Generated-By: Babel 2.9.0\n"
|
||||||
|
|
||||||
#: invenio_config_tugraz/config.py:80
|
#: invenio_config_tugraz/config.py:87
|
||||||
msgid "Welcome to RDM!"
|
msgid "Welcome to TU Graz Repository!"
|
||||||
|
msgstr "Willkommen im TU Graz Repository!"
|
||||||
|
|
||||||
|
#: invenio_config_tugraz/templates/security/email/welcome.txt:1
|
||||||
|
#, python-format
|
||||||
|
msgid "Dear %(email)s!"
|
||||||
|
msgstr "Lieber %(email)s!"
|
||||||
|
|
||||||
|
#: invenio_config_tugraz/templates/security/email/welcome.txt:3
|
||||||
|
msgid "To help you get started, here are some useful links:"
|
||||||
|
msgstr "Um Ihnen den Einstieg zu erleichtern, finden Sie hier einige nützliche Links:"
|
||||||
|
|
||||||
|
#: invenio_config_tugraz/templates/security/email/welcome.txt:5
|
||||||
|
msgid "Repository"
|
||||||
|
msgstr ""
|
||||||
|
|
||||||
|
#: invenio_config_tugraz/templates/security/email/welcome.txt:8
|
||||||
|
msgid "Repository Guide"
|
||||||
|
msgstr "Handbuch"
|
||||||
|
|
||||||
|
#: invenio_config_tugraz/templates/security/email/welcome.txt:11
|
||||||
|
msgid "Terms And Conditions"
|
||||||
|
msgstr "Nutzungsbedingungen"
|
||||||
|
|
||||||
|
#: invenio_config_tugraz/templates/security/email/welcome.txt:16
|
||||||
|
msgid "You can confirm your email through the link below:"
|
||||||
|
msgstr "Sie können Ihre E-Mail über den folgenden Link bestätigen:"
|
||||||
|
|
||||||
|
#: invenio_config_tugraz/templates/security/email/welcome.txt:20
|
||||||
|
msgid "Best regards"
|
||||||
|
msgstr "Liebe grüße"
|
||||||
|
|
||||||
|
#: invenio_config_tugraz/templates/security/email/welcome.txt:21
|
||||||
|
msgid "TU Graz Repository Team"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
|
|||||||
@@ -1,24 +1,57 @@
|
|||||||
# Translations template for invenio-config-tugraz.
|
# Translations template for invenio-config-tugraz.
|
||||||
# Copyright (C) 2020 Mojib Wali
|
# Copyright (C) 2021 Mojib Wali
|
||||||
# This file is distributed under the same license as the
|
# This file is distributed under the same license as the
|
||||||
# invenio-config-tugraz project.
|
# invenio-config-tugraz project.
|
||||||
# FIRST AUTHOR <EMAIL@ADDRESS>, 2020.
|
# FIRST AUTHOR <EMAIL@ADDRESS>, 2021.
|
||||||
#
|
#
|
||||||
#, fuzzy
|
#, fuzzy
|
||||||
msgid ""
|
msgid ""
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: invenio-config-tugraz 0.1.5\n"
|
"Project-Id-Version: invenio-config-tugraz 0.5.4\n"
|
||||||
"Report-Msgid-Bugs-To: mojib.wali@tugraz.at\n"
|
"Report-Msgid-Bugs-To: mojib.wali@tugraz.at\n"
|
||||||
"POT-Creation-Date: 2020-10-06 09:28+0200\n"
|
"POT-Creation-Date: 2021-04-22 09:24+0200\n"
|
||||||
"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
|
"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
|
||||||
"Last-Translator: FULL NAME <EMAIL@ADDRESS>\n"
|
"Last-Translator: FULL NAME <EMAIL@ADDRESS>\n"
|
||||||
"Language-Team: LANGUAGE <LL@li.org>\n"
|
"Language-Team: LANGUAGE <LL@li.org>\n"
|
||||||
"MIME-Version: 1.0\n"
|
"MIME-Version: 1.0\n"
|
||||||
"Content-Type: text/plain; charset=utf-8\n"
|
"Content-Type: text/plain; charset=utf-8\n"
|
||||||
"Content-Transfer-Encoding: 8bit\n"
|
"Content-Transfer-Encoding: 8bit\n"
|
||||||
"Generated-By: Babel 2.8.0\n"
|
"Generated-By: Babel 2.9.0\n"
|
||||||
|
|
||||||
#: invenio_config_tugraz/config.py:80
|
#: invenio_config_tugraz/config.py:87
|
||||||
msgid "Welcome to RDM!"
|
msgid "Welcome to TU Graz Repository!"
|
||||||
|
msgstr ""
|
||||||
|
|
||||||
|
#: invenio_config_tugraz/templates/security/email/welcome.txt:1
|
||||||
|
#, python-format
|
||||||
|
msgid "Dear %(email)s!"
|
||||||
|
msgstr ""
|
||||||
|
|
||||||
|
#: invenio_config_tugraz/templates/security/email/welcome.txt:3
|
||||||
|
msgid "To help you get started, here are some useful links:"
|
||||||
|
msgstr ""
|
||||||
|
|
||||||
|
#: invenio_config_tugraz/templates/security/email/welcome.txt:5
|
||||||
|
msgid "Repository"
|
||||||
|
msgstr ""
|
||||||
|
|
||||||
|
#: invenio_config_tugraz/templates/security/email/welcome.txt:8
|
||||||
|
msgid "Repository Guide"
|
||||||
|
msgstr ""
|
||||||
|
|
||||||
|
#: invenio_config_tugraz/templates/security/email/welcome.txt:11
|
||||||
|
msgid "Terms And Conditions"
|
||||||
|
msgstr ""
|
||||||
|
|
||||||
|
#: invenio_config_tugraz/templates/security/email/welcome.txt:16
|
||||||
|
msgid "You can confirm your email through the link below:"
|
||||||
|
msgstr ""
|
||||||
|
|
||||||
|
#: invenio_config_tugraz/templates/security/email/welcome.txt:20
|
||||||
|
msgid "Best regards"
|
||||||
|
msgstr ""
|
||||||
|
|
||||||
|
#: invenio_config_tugraz/templates/security/email/welcome.txt:21
|
||||||
|
msgid "TU Graz Repository Team"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
|
|||||||
@@ -12,4 +12,4 @@ This file is imported by ``invenio_config_tugraz.__init__``,
|
|||||||
and parsed by ``setup.py``.
|
and parsed by ``setup.py``.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
__version__ = "0.5.2"
|
__version__ = "0.5.5"
|
||||||
|
|||||||
44
invenio_config_tugraz/views.py
Normal file
44
invenio_config_tugraz/views.py
Normal file
@@ -0,0 +1,44 @@
|
|||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
#
|
||||||
|
# Copyright (C) 2020-2021 Graz University of Technology.
|
||||||
|
#
|
||||||
|
# invenio-config-tugraz is free software; you can redistribute it and/or
|
||||||
|
# modify it under the terms of the MIT License; see LICENSE file for more
|
||||||
|
# details.
|
||||||
|
|
||||||
|
"""invenio module for TUGRAZ config."""
|
||||||
|
|
||||||
|
from os import environ
|
||||||
|
from typing import Dict
|
||||||
|
|
||||||
|
from elasticsearch_dsl.utils import AttrDict
|
||||||
|
from flask import Blueprint, current_app
|
||||||
|
|
||||||
|
|
||||||
|
def ui_blueprint(app):
|
||||||
|
"""Blueprint for the routes and resources provided by invenio-config-tugraz."""
|
||||||
|
blueprint = Blueprint(
|
||||||
|
"invenio_config_tugraz",
|
||||||
|
__name__,
|
||||||
|
template_folder="templates",
|
||||||
|
)
|
||||||
|
|
||||||
|
@blueprint.before_app_first_request
|
||||||
|
def rank_higher():
|
||||||
|
"""Rank this modules blueprint higher than blueprint of security module."""
|
||||||
|
blueprints = current_app._blueprint_order
|
||||||
|
our_index = None
|
||||||
|
security_index = None
|
||||||
|
|
||||||
|
for index, bp in enumerate(blueprints):
|
||||||
|
if bp.name == "security":
|
||||||
|
security_index = index
|
||||||
|
if bp.name == "invenio_config_tugraz":
|
||||||
|
our_index = index
|
||||||
|
|
||||||
|
if (security_index is not None) and (our_index > security_index):
|
||||||
|
temp = blueprints[security_index]
|
||||||
|
blueprints[security_index] = blueprints[our_index]
|
||||||
|
blueprints[our_index] = temp
|
||||||
|
|
||||||
|
return blueprint
|
||||||
31
setup.py
31
setup.py
@@ -1,6 +1,6 @@
|
|||||||
# -*- coding: utf-8 -*-
|
# -*- coding: utf-8 -*-
|
||||||
#
|
#
|
||||||
# Copyright (C) 2020 Mojib Wali.
|
# Copyright (C) 2020-2021 Graz University of Technology.
|
||||||
#
|
#
|
||||||
# invenio-config-tugraz is free software; you can redistribute it and/or
|
# invenio-config-tugraz is free software; you can redistribute it and/or
|
||||||
# modify it under the terms of the MIT License; see LICENSE file for more
|
# modify it under the terms of the MIT License; see LICENSE file for more
|
||||||
@@ -17,13 +17,18 @@ history = open("CHANGES.rst").read()
|
|||||||
|
|
||||||
tests_require = [
|
tests_require = [
|
||||||
"pytest-invenio>=1.4.0",
|
"pytest-invenio>=1.4.0",
|
||||||
"SQLAlchemy-Utils>=0.33.1,<0.36",
|
"invenio-app>=1.3.0,<2.0.0",
|
||||||
"invenio-rdm-records~=0.20.8",
|
|
||||||
"invenio-search[elasticsearch7]>=1.4.0",
|
|
||||||
"psycopg2-binary>=2.8.6",
|
|
||||||
]
|
]
|
||||||
|
|
||||||
|
# Should follow invenio-app-rdm
|
||||||
|
invenio_search_version = ">=1.4.0,<1.5.0"
|
||||||
|
invenio_db_version = ">=1.0.9,<1.1.0"
|
||||||
|
|
||||||
extras_require = {
|
extras_require = {
|
||||||
|
"elasticsearch7": [f"invenio-search[elasticsearch7]{invenio_search_version}"],
|
||||||
|
"mysql": [f"invenio-db[mysql,versioning]{invenio_db_version}"],
|
||||||
|
"postgresql": [f"invenio-db[postgresql,versioning]{invenio_db_version}"],
|
||||||
|
"sqlite": [f"invenio-db[versioning]{invenio_db_version}"],
|
||||||
"docs": [
|
"docs": [
|
||||||
"Sphinx>=3",
|
"Sphinx>=3",
|
||||||
],
|
],
|
||||||
@@ -31,7 +36,14 @@ extras_require = {
|
|||||||
}
|
}
|
||||||
|
|
||||||
extras_require["all"] = []
|
extras_require["all"] = []
|
||||||
for reqs in extras_require.values():
|
for name, reqs in extras_require.items():
|
||||||
|
if name[0] == ":" or name in (
|
||||||
|
"elasticsearch7",
|
||||||
|
"mysql",
|
||||||
|
"postgresql",
|
||||||
|
"sqlite",
|
||||||
|
):
|
||||||
|
continue
|
||||||
extras_require["all"].extend(reqs)
|
extras_require["all"].extend(reqs)
|
||||||
|
|
||||||
setup_requires = [
|
setup_requires = [
|
||||||
@@ -41,8 +53,8 @@ setup_requires = [
|
|||||||
|
|
||||||
install_requires = [
|
install_requires = [
|
||||||
"Flask-BabelEx>=0.9.4",
|
"Flask-BabelEx>=0.9.4",
|
||||||
"elasticsearch_dsl>=7.2.1",
|
# keep this in sync with invenioRDM release
|
||||||
"sqlalchemy-continuum>=1.3.11",
|
"invenio_rdm_records>=0.28.0,<0.29.0",
|
||||||
]
|
]
|
||||||
|
|
||||||
packages = find_packages()
|
packages = find_packages()
|
||||||
@@ -72,6 +84,9 @@ setup(
|
|||||||
"invenio_base.apps": [
|
"invenio_base.apps": [
|
||||||
"invenio_config_tugraz = invenio_config_tugraz:InvenioConfigTugraz",
|
"invenio_config_tugraz = invenio_config_tugraz:InvenioConfigTugraz",
|
||||||
],
|
],
|
||||||
|
"invenio_base.blueprints": [
|
||||||
|
"invenio_config_tugraz = invenio_config_tugraz.views:ui_blueprint",
|
||||||
|
],
|
||||||
"invenio_i18n.translations": [
|
"invenio_i18n.translations": [
|
||||||
"messages = invenio_config_tugraz",
|
"messages = invenio_config_tugraz",
|
||||||
],
|
],
|
||||||
|
|||||||
@@ -8,9 +8,9 @@
|
|||||||
|
|
||||||
"""Test Generators."""
|
"""Test Generators."""
|
||||||
|
|
||||||
from invenio_access.permissions import any_user, authenticated_user
|
from invenio_access.permissions import any_user
|
||||||
|
|
||||||
from invenio_config_tugraz.generators import AuthenticatedUser, RecordIp
|
from invenio_config_tugraz.generators import RecordIp
|
||||||
|
|
||||||
|
|
||||||
def test_recordip(create_app, open_record, singleip_record):
|
def test_recordip(create_app, open_record, singleip_record):
|
||||||
@@ -27,12 +27,3 @@ def test_recordip(create_app, open_record, singleip_record):
|
|||||||
assert generator.excludes(record=open_record) == []
|
assert generator.excludes(record=open_record) == []
|
||||||
|
|
||||||
assert generator.query_filter().to_dict() == {'bool': {'must_not': [{'match': {'access.access_right': 'singleip'}}]}}
|
assert generator.query_filter().to_dict() == {'bool': {'must_not': [{'match': {'access.access_right': 'singleip'}}]}}
|
||||||
|
|
||||||
|
|
||||||
def test_authenticateduser():
|
|
||||||
"""Test Generator AuthenticatedUser."""
|
|
||||||
generator = AuthenticatedUser()
|
|
||||||
|
|
||||||
assert generator.needs() == [authenticated_user]
|
|
||||||
assert generator.excludes() == []
|
|
||||||
assert generator.query_filter() == []
|
|
||||||
|
|||||||
Reference in New Issue
Block a user