Source code for inspirehep.modules.forms.fields.doi

# -*- 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.

"""DOI field."""

from __future__ import absolute_import, division, print_function

from wtforms import StringField

from ..field_base import INSPIREField
from ..filter_utils import strip_prefixes, strip_string
from ..validation_utils import DOISyntaxValidator

__all__ = ['DOIField']


def missing_doi_warning(dummy_form, field, submit=False, fields=None):
    """
    Field processor.

    Checks for existence of a DOI, and otherwise asks people to provide it.
    """
    if not field.errors and not field.data:
        field.add_message("Please provide a DOI if possible.", state="warning")
        raise StopIteration()


[docs]class DOIField(INSPIREField, StringField): """DOIField.""" def __init__(self, **kwargs): """Init.""" defaults = dict( icon='barcode', validators=[ DOISyntaxValidator(), ], filters=[ strip_string, strip_prefixes("doi:", "http://dx.doi.org/"), ], placeholder="e.g. 10.1234/foo.bar...", widget_classes="form-control" ) defaults.update(kwargs) super(DOIField, self).__init__(**defaults)