Source code for inspirehep.modules.editor.permissions

# -*- coding: utf-8 -*-
#
# This file is part of INSPIRE.
# Copyright (C) 2014-2017 CERN.
#
# INSPIRE is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# INSPIRE is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with INSPIRE. If not, see <http://www.gnu.org/licenses/>.
#
# In applying this license, CERN does not waive the privileges and immunities
# granted to it by virtue of its status as an Intergovernmental Organization
# or submit itself to any jurisdiction.

from __future__ import absolute_import, division, print_function

from functools import wraps

from flask import abort, session
from flask_login import current_user

from invenio_access.permissions import (
    ParameterizedActionNeed,
    Permission,
)

from inspirehep.modules.pidstore.utils import get_pid_type_from_endpoint
from inspirehep.modules.records.permissions import has_update_permission
from inspirehep.utils.record_getter import get_db_record


action_editor_use_api = ParameterizedActionNeed(
    'editor-use-api', argument=None
)

editor_use_api_permission = Permission(
    action_editor_use_api
)


[docs]def editor_permission(fn): @wraps(fn) def decorator(endpoint, pid_value, **kwargs): cache_key = 'editor-permission-{0}-{1}'.format( endpoint, pid_value ) is_allowed = session.get(cache_key) if is_allowed is not None: if is_allowed: return fn(endpoint, pid_value, **kwargs) else: abort(403) pid_type = get_pid_type_from_endpoint(endpoint) record = get_db_record(pid_type, pid_value) is_allowed = has_update_permission(current_user, record) session[cache_key] = is_allowed if is_allowed: return fn(endpoint, pid_value, **kwargs) else: abort(403) return decorator