當前位置: 首頁>>代碼示例>>Python>>正文


Python Resolver.resolve方法代碼示例

本文整理匯總了Python中invenio_pidstore.resolver.Resolver.resolve方法的典型用法代碼示例。如果您正苦於以下問題:Python Resolver.resolve方法的具體用法?Python Resolver.resolve怎麽用?Python Resolver.resolve使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在invenio_pidstore.resolver.Resolver的用法示例。


在下文中一共展示了Resolver.resolve方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: test_deposit_load_task

# 需要導入模塊: from invenio_pidstore.resolver import Resolver [as 別名]
# 或者: from invenio_pidstore.resolver.Resolver import resolve [as 別名]
def test_deposit_load_task(dummy_location, deposit_dump, deposit_user,
                           deposit_record_pid):
    """Test the deposit loading task."""

    # Create a user and a record with PID corresponding with test deposit data
    assert RecordMetadata.query.count() == 1
    for dep in deposit_dump:
        load_deposit.delay(dep)
    assert RecordMetadata.query.count() == 2
    res = Resolver(pid_type='depid', object_type='rec',
                   getter=Record.get_record)
    dep_pid, dep_rec = res.resolve('1')
    assert '_deposit' in dep_rec
    assert '_files' in dep_rec
    sip = SIP.query.one()
    assert sip.user_id == deposit_user.id
    rsip = RecordSIP.query.one()
    assert rsip.pid_id == deposit_record_pid.id
    assert rsip.sip_id == sip.id

    # Test RecordsFiles API
    res = Resolver(pid_type='depid', object_type='rec',
                   getter=RecordFiles.get_record)
    dep_pid, dep_recbucket = res.resolve('1')
    files = list(dep_recbucket.files)
    assert files[0]['key'] == 'bazbar.pdf'
    assert files[0]['size'] == 12345
    assert files[0]['checksum'] == "00000000000000000000000000000000"
    assert files[0]['bucket']
    assert SIPFile.query.count() == 1
開發者ID:egabancho,項目名稱:invenio-migrator,代碼行數:32,代碼來源:test_deposit_load.py

示例2: test_deposit_load_task

# 需要導入模塊: from invenio_pidstore.resolver import Resolver [as 別名]
# 或者: from invenio_pidstore.resolver.Resolver import resolve [as 別名]
def test_deposit_load_task(dummy_location, deposit_dump, deposit_user, deposit_record_pid):
    """Test the deposit loading task."""

    # Create a user and a record with PID corresponding with test deposit data
    assert RecordMetadata.query.count() == 1
    for dep in deposit_dump:
        load_deposit(dep)
    assert RecordMetadata.query.count() == 2
    res = Resolver(pid_type="depid", object_type="rec", getter=Record.get_record)
    dep_pid, dep_rec = res.resolve("1")
    assert "_deposit" in dep_rec
    assert "_files" in dep_rec
    sip = SIP.query.one()
    assert sip.user_id == deposit_user.id
    rsip = RecordSIP.query.one()
    assert rsip.pid_id == deposit_record_pid.id
    assert rsip.sip_id == sip.id

    # Test RecordsFiles API
    res = Resolver(pid_type="depid", object_type="rec", getter=RecordFiles.get_record)
    dep_pid, dep_recbucket = res.resolve("1")
    files = list(dep_recbucket.files)
    assert files[0]["key"] == "bazbar.pdf"
    assert files[0]["size"] == 12345
    assert files[0]["checksum"] == "md5:00000000000000000000000000000000"
    assert files[0]["bucket"]
    assert SIPFile.query.count() == 1
開發者ID:tiborsimko,項目名稱:invenio-migrator,代碼行數:29,代碼來源:test_deposit_load.py

示例3: create_or_update_record

# 需要導入模塊: from invenio_pidstore.resolver import Resolver [as 別名]
# 或者: from invenio_pidstore.resolver.Resolver import resolve [as 別名]
def create_or_update_record(data, pid_type, id_key, minter):
    """Register a funder or grant."""
    resolver = Resolver(
        pid_type=pid_type, object_type='rec', getter=Record.get_record)

    try:
        pid, record = resolver.resolve(data[id_key])
        data_c = deepcopy(data)
        del data_c['remote_modified']
        record_c = deepcopy(data)
        del record_c['remote_modified']
        # All grants on OpenAIRE are modified periodically even if nothing
        # has changed. We need to check for actual differences in the metadata
        if data_c != record_c:
            record.update(data)
            record.commit()
            record_id = record.id
            db.session.commit()
            RecordIndexer().index_by_id(str(record_id))
    except PIDDoesNotExistError:
        record = Record.create(data)
        record_id = record.id
        minter(record.id, data)
        db.session.commit()
        RecordIndexer().index_by_id(str(record_id))
開發者ID:tiborsimko,項目名稱:invenio-openaire,代碼行數:27,代碼來源:tasks.py

示例4: recid

# 需要導入模塊: from invenio_pidstore.resolver import Resolver [as 別名]
# 或者: from invenio_pidstore.resolver.Resolver import resolve [as 別名]
def recid(pid_value=None):
    resolver = Resolver(
        pid_type='recid',
        object_type='rec',
        getter=Record.get_record)

    try:
        pid, record = resolver.resolve(pid_value)
    except:
        abort(404)

    is_public = ActionUsers.query.filter(
        ActionUsers.action == 'records-read',
        ActionUsers.user_id.is_(None)).first()

    permission_read_record = read_permission_factory(record)

    if is_public or permission_read_record.can():
        return record_view(pid_value,
                           resolver,
                           ['records/detail-'+record.get("collections", [""])[0]+'.html', 'records/detail.html'],
                           None,
                           default_view_method
                           )

    abort(403)
開發者ID:lukasheinrich,項目名稱:analysis-preservation.cern.ch,代碼行數:28,代碼來源:views.py

示例5: record_permissions

# 需要導入模塊: from invenio_pidstore.resolver import Resolver [as 別名]
# 或者: from invenio_pidstore.resolver.Resolver import resolve [as 別名]
def record_permissions(pid_value=None):
    resolver = Resolver(
        pid_type='recid',
        object_type='rec',
        getter=Record.get_record)

    pid, record = resolver.resolve(pid_value)

    permissions = get_record_permissions(record.id)

    result = dict()
    result['permissions'] = []

    collab_egroups = current_app.config.get('CAP_COLLAB_EGROUPS')

    if record.get('experiment', None):
        result['collab_egroup'] = six.next(
            six.itervalues(collab_egroups.get(record['experiment']))
            )[0]

    for p in permissions:
        if isinstance(p, ActionUsers) and p.user:
            result['permissions'].append(
                {"action": p.action, "user": {"email": p.user.email}}
            )
        elif isinstance(p, ActionRoles) and p.role:
            result['permissions'].append(
                {"action": p.action, "user": {"email": p.role.name}}
            )

    resp = jsonify(**result)
    resp.status_code = 200
    return resp
開發者ID:lukasheinrich,項目名稱:analysis-preservation.cern.ch,代碼行數:35,代碼來源:views.py

示例6: prepare_authors_data_for_pushing_to_orcid

# 需要導入模塊: from invenio_pidstore.resolver import Resolver [as 別名]
# 或者: from invenio_pidstore.resolver.Resolver import resolve [as 別名]
def prepare_authors_data_for_pushing_to_orcid(json):
    """ Extracts the authors with valid orcid credentials from the list of authors
    of a given record in json format.
    """
    resolver = Resolver(pid_type='literature',
                        object_type='rec', getter=lambda x: x)
    record_id = resolver.resolve(json.get('control_number'))[
        0].object_uuid
    authors = get_orcid_valid_authors(json)
    token = None
    author_orcid = ''
    authors_with_orcid_credentials = []
    for author in authors:
        try:
            token, author_orcid = get_authors_credentials(author['_source'])
        except AttributeError:
            continue
        try:
            authors_with_orcid_credentials.append((InspireOrcidRecords.query.filter_by(
                orcid=author_orcid, record_id=record_id).first().put_code, token, author_orcid, record_id))
        except AttributeError:
            authors_with_orcid_credentials.append(
                ([], token, author_orcid, record_id))
            continue
    return authors_with_orcid_credentials
開發者ID:kaplun,項目名稱:inspire-next,代碼行數:27,代碼來源:tasks.py

示例7: prepare_authors_data_for_pushing_to_orcid

# 需要導入模塊: from invenio_pidstore.resolver import Resolver [as 別名]
# 或者: from invenio_pidstore.resolver.Resolver import resolve [as 別名]
def prepare_authors_data_for_pushing_to_orcid(data):
    """Extract the authors with valid ORCID credentials.

    It uses the list of authors from a given record in JSON format.
    """
    pid_type = current_app.config['ORCID_RECORDS_PID_TYPE']
    resolver = Resolver(pid_type=pid_type,
                        object_type='rec', getter=lambda x: x)
    fetcher_name = current_app.config['ORCID_RECORDS_PID_FETCHER']
    pid = current_pidstore.fetchers[fetcher_name](None, data)
    record_identifier = pid.pid_value
    record_id = resolver.resolve(record_identifier)[0].object_uuid
    authors = get_orcid_valid_authors(data)
    token = None
    author_orcid = ''
    authors_with_orcid_credentials = []
    for author in authors:
        try:
            token, author_orcid = get_authors_credentials(author)
        except AttributeError:
            continue
        try:
            authors_with_orcid_credentials.append((
                ORCIDRecords.query.filter_by(
                    orcid=author_orcid, record_id=record_id
                ).first().put_code,
                token, author_orcid, record_id
            ))
        except AttributeError:
            authors_with_orcid_credentials.append(
                ([], token, author_orcid, record_id))
            continue
    return authors_with_orcid_credentials
開發者ID:tiborsimko,項目名稱:invenio-orcid,代碼行數:35,代碼來源:tasks.py

示例8: run

# 需要導入模塊: from invenio_pidstore.resolver import Resolver [as 別名]
# 或者: from invenio_pidstore.resolver.Resolver import resolve [as 別名]
    def run(self, event):
        """Process the circulation event.

        This method builds the frame, fetching the item and calling *_run*
        in a nested transaction.
        """
        resolver = Resolver(pid_type='crcitm', object_type='rec',
                            getter=Item.get_record)
        _, item = resolver.resolve(event.payload['item_id'])

        self.circulation_event_schema.context['item'] = item

        data, errors = self.circulation_event_schema.load(event.payload)
        if errors:
            event.response_code = 400
            event.response = {'message': errors}
            return

        if data.get('dry_run'):
            event.response_code = 204
            return

        with db.session.begin_nested():
            data, _ = self.circulation_event_schema.dump(data)
            self._run(item, data)
            item.commit()
            RecordIndexer().index(item)
開發者ID:tiborsimko,項目名稱:invenio-circulation,代碼行數:29,代碼來源:receivers.py

示例9: curate

# 需要導入模塊: from invenio_pidstore.resolver import Resolver [as 別名]
# 或者: from invenio_pidstore.resolver.Resolver import resolve [as 別名]
def curate(community):
    """Index page with uploader and list of existing depositions.

    :param community_id: ID of the community to curate.
    """
    if request.method == 'POST':
        action = request.json.get('action')
        recid = request.json.get('recid')

        # 'recid' is mandatory
        if not recid:
            return jsonify({'status': 'danger', 'msg': _('Unknown record')})
        if action not in ['accept', 'reject', 'remove']:
            return jsonify({'status': 'danger', 'msg': _('Unknown action')})

        # Resolve recid to a Record
        resolver = Resolver(
            pid_type='recid', object_type='rec', getter=Record.get_record)
        pid, record = resolver.resolve(recid)

        action_name = ""
        status = "success"
        # Perform actions
        try:
            if action == "accept":
                community.accept_record(record)
                action_name = "added to"
            elif action == "reject":
                community.reject_record(record)
                action_name = "rejected from"
                status = "info"
            elif action == "remove":
                community.remove_record(record)
                action_name = "removed from"
                status = "info"
        except CommunitiesError:
            return jsonify({
                'status': 'danger',
                'msg': _('record not in the curation list,'
                         ' please refresh the page.')})

        record.commit()
        db.session.commit()
        RecordIndexer().index_by_id(record.id)
        title = ""
        if "title_statement" in record \
            and "title" in record["title_statement"]:
            title = record["title_statement"]["title"]
        message = _('The record '
            '"{}" has been {} the community.').format(title, action_name)
        return jsonify({'status': status, 'msg': message})

    ctx = {'community': community}
    return render_template(
        current_app.config['COMMUNITIES_CURATE_TEMPLATE'],
        **ctx
    )
開發者ID:tind,項目名稱:invenio-communities,代碼行數:59,代碼來源:ui.py

示例10: get_record_by_pid

# 需要導入模塊: from invenio_pidstore.resolver import Resolver [as 別名]
# 或者: from invenio_pidstore.resolver.Resolver import resolve [as 別名]
 def get_record_by_pid(cls, pid, with_deleted=False):
     """Get ils record by pid value."""
     resolver = Resolver(
         pid_type=CIRCULATION_LOAN_PID_TYPE,
         object_type="rec",
         getter=cls.get_record,
     )
     persistent_identifier, record = resolver.resolve(str(pid))
     return record
開發者ID:inveniosoftware,項目名稱:invenio-circulation,代碼行數:11,代碼來源:api.py

示例11: fetch_published

# 需要導入模塊: from invenio_pidstore.resolver import Resolver [as 別名]
# 或者: from invenio_pidstore.resolver.Resolver import resolve [as 別名]
    def fetch_published(self):
        """Return a tuple with PID and published record."""
        pid_type = self['_deposit']['pid']['type']
        pid_value = self['_deposit']['pid']['value']

        resolver = Resolver(
            pid_type=pid_type, object_type='rec',
            getter=partial(Record.get_record, with_deleted=True)
        )
        return resolver.resolve(pid_value)
開發者ID:nharraud,項目名稱:invenio-deposit,代碼行數:12,代碼來源:api.py

示例12: get_record_by_id

# 需要導入模塊: from invenio_pidstore.resolver import Resolver [as 別名]
# 或者: from invenio_pidstore.resolver.Resolver import resolve [as 別名]
def get_record_by_id(recid):
    try:
        resolver = Resolver(pid_type='recid', object_type='rec', getter=Record.get_record)
        pid, record = resolver.resolve(recid)
        return record
    except NoResultFound:
        current_app.logger.exception('No record found for recid {}'.format(recid))
        return None
    except PIDDoesNotExistError:
        current_app.logger.exception('The PID {0} does not exist'.format(recid))
        return None
開發者ID:HEPData,項目名稱:hepdata3,代碼行數:13,代碼來源:common.py

示例13: fundertree2json

# 需要導入模塊: from invenio_pidstore.resolver import Resolver [as 別名]
# 或者: from invenio_pidstore.resolver.Resolver import resolve [as 別名]
    def fundertree2json(self, tree, oai_id):
        """Convert OpenAIRE's funder XML to JSON."""
        try:
            tree = self.get_subtree(tree, 'fundingtree')[0]
        except IndexError:  # pragma: nocover
            pass

        funder_node = self.get_subtree(tree, 'funder')
        subfunder_node = self.get_subtree(tree, '//funding_level_0')

        funder_id = self.get_text_node(funder_node[0], './id') \
            if funder_node else None
        subfunder_id = self.get_text_node(subfunder_node[0], './id') \
            if subfunder_node else None
        funder_name = self.get_text_node(funder_node[0], './shortname') \
            if funder_node else ""
        subfunder_name = self.get_text_node(subfunder_node[0], './name') \
            if subfunder_node else ""

        # Try to resolve the subfunder first, on failure try to resolve the
        # main funder, on failure raise an error.
        funder_doi_url = None
        if subfunder_id:
            funder_doi_url = self.funder_resolver.resolve_by_id(subfunder_id)
        if not funder_doi_url:
            if funder_id:
                funder_doi_url = self.funder_resolver.resolve_by_id(funder_id)
        if not funder_doi_url:
            funder_doi_url = self.funder_resolver.resolve_by_oai_id(oai_id)
        if not funder_doi_url:
            raise FunderNotFoundError(oai_id, funder_id, subfunder_id)

        funder_doi = FundRefDOIResolver.strip_doi_host(funder_doi_url)
        if not funder_name:
            # Grab name from FundRef record.
            resolver = Resolver(
                pid_type='frdoi', object_type='rec', getter=Record.get_record)
            try:
                dummy_pid, funder_rec = resolver.resolve(funder_doi)
                funder_name = funder_rec['acronyms'][0]
            except PersistentIdentifierError:
                raise OAIRELoadingError(
                    "Please ensure that funders have been loaded prior to"
                    "loading grants. Could not resolve funder {0}".format(
                        funder_doi))

        return dict(
            doi=funder_doi,
            url=funder_doi_url,
            name=funder_name,
            program=subfunder_name,
        )
開發者ID:krzysztof,項目名稱:invenio-openaire,代碼行數:54,代碼來源:loaders.py

示例14: test_permission

# 需要導入模塊: from invenio_pidstore.resolver import Resolver [as 別名]
# 或者: from invenio_pidstore.resolver.Resolver import resolve [as 別名]
def test_permission(app):
    """Test permission control to records."""
    app.config.update(
        WTF_CSRF_ENABLED=False,
        SECRET_KEY='CHANGEME',
        SECURITY_PASSWORD_SALT='CHANGEME',
        # conftest switches off permission checking, so re-enable it for this
        # app.
        RECORDS_UI_DEFAULT_PERMISSION_FACTORY='helpers:'
                                              'only_authenticated_users',
    )
    Menu(app)
    InvenioRecordsUI(app)
    accounts = InvenioAccounts(app)
    app.register_blueprint(accounts_blueprint)
    InvenioAccess(app)
    setup_record_fixture(app)

    # Create admin
    with app.app_context():
        accounts.datastore.create_user(
            email='[email protected]',
            password=encrypt_password('123456'),
            active=True,
        )

        # Get record 1
        r = Resolver(pid_type='recid', object_type='rec',
                     getter=Record.get_record)
        dummy_pid, record = r.resolve('1')

        db.session.commit()

    with app.test_request_context():
        login_url = url_for('security.login')
        record_url = url_for('invenio_records_ui.recid', pid_value='1')

    # Access record 1 as admin
    with app.test_client() as client:
        res = client.get(record_url)
        assert res.status_code == 302
        res = client.post(login_url, data={
            'email': '[email protected]', 'password': '123456'})
        assert res.status_code == 302
        res = client.get(record_url)
        res.status_code == 200

    # Access record 1 as anonymous
    with app.test_client() as client:
        res = client.get(record_url)
        res.status_code == 403
開發者ID:hachreak,項目名稱:invenio-records-ui,代碼行數:53,代碼來源:test_invenio_records_ui.py

示例15: create_or_update_record

# 需要導入模塊: from invenio_pidstore.resolver import Resolver [as 別名]
# 或者: from invenio_pidstore.resolver.Resolver import resolve [as 別名]
def create_or_update_record(data, pid_type, id_key, minter):
    """Register a funder or grant."""
    resolver = Resolver(
        pid_type=pid_type, object_type='rec', getter=Record.get_record)

    try:
        pid, record = resolver.resolve(data[id_key])
        if data['remote_modified'] != record['remote_modified']:
            record.update(data)
            record.commit()
            db.session.commit()
    except PIDDoesNotExistError:
        record = Record.create(data)
        minter(record.id, data)
        db.session.commit()
開發者ID:SamiHiltunen,項目名稱:invenio-openaire,代碼行數:17,代碼來源:tasks.py


注:本文中的invenio_pidstore.resolver.Resolver.resolve方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。