Page Menu
Home
Software Heritage
Search
Configure Global Search
Log In
Files
F9342426
interface.py
No One
Temporary
Actions
Download File
Edit File
Delete File
View Transforms
Subscribe
Mute Notifications
Award Token
Flag For Later
Size
15 KB
Subscribers
None
interface.py
View Options
# Copyright (C) 2015-2020 The Software Heritage developers
# See the AUTHORS file at the top-level directory of this distribution
# License: GNU General Public License version 3, or any later version
# See top-level LICENSE file for more information
from
typing
import
Dict
,
Iterable
,
List
,
Optional
,
Tuple
,
TypeVar
,
Union
from
typing_extensions
import
Protocol
,
runtime_checkable
from
swh.core.api
import
remote_api_endpoint
from
swh.core.api.classes
import
PagedResult
as
CorePagedResult
from
swh.indexer.storage.model
import
(
ContentCtagsRow
,
ContentLanguageRow
,
ContentLicenseRow
,
ContentMetadataRow
,
ContentMimetypeRow
,
OriginIntrinsicMetadataRow
,
RevisionIntrinsicMetadataRow
,
)
TResult
=
TypeVar
(
"TResult"
)
PagedResult
=
CorePagedResult
[
TResult
,
str
]
Sha1
=
bytes
@runtime_checkable
class
IndexerStorageInterface
(
Protocol
):
@remote_api_endpoint
(
"check_config"
)
def
check_config
(
self
,
*
,
check_write
):
"""Check that the storage is configured and ready to go."""
...
@remote_api_endpoint
(
"content_mimetype/missing"
)
def
content_mimetype_missing
(
self
,
mimetypes
:
Iterable
[
Dict
]
)
->
List
[
Tuple
[
Sha1
,
int
]]:
"""Generate mimetypes missing from storage.
Args:
mimetypes (iterable): iterable of dict with keys:
- **id** (bytes): sha1 identifier
- **indexer_configuration_id** (int): tool used to compute the
results
Returns:
list of tuple (id, indexer_configuration_id) missing
"""
...
@remote_api_endpoint
(
"content_mimetype/range"
)
def
content_mimetype_get_partition
(
self
,
indexer_configuration_id
:
int
,
partition_id
:
int
,
nb_partitions
:
int
,
page_token
:
Optional
[
str
]
=
None
,
limit
:
int
=
1000
,
)
->
PagedResult
[
Sha1
]:
"""Retrieve mimetypes within partition partition_id bound by limit.
Args:
**indexer_configuration_id**: The tool used to index data
**partition_id**: index of the partition to fetch
**nb_partitions**: total number of partitions to split into
**page_token**: opaque token used for pagination
**limit**: Limit result (default to 1000)
Raises:
IndexerStorageArgumentException for;
- limit to None
- wrong indexer_type provided
Returns:
PagedResult of Sha1. If next_page_token is None, there is no more data
to fetch
"""
...
@remote_api_endpoint
(
"content_mimetype/add"
)
def
content_mimetype_add
(
self
,
mimetypes
:
List
[
ContentMimetypeRow
]
)
->
Dict
[
str
,
int
]:
"""Add mimetypes not present in storage.
Args:
mimetypes: mimetype rows to be added, with their `tool` attribute set to
None.
overwrite (``True``) or skip duplicates (``False``, the
default)
Returns:
Dict summary of number of rows added
"""
...
@remote_api_endpoint
(
"content_mimetype"
)
def
content_mimetype_get
(
self
,
ids
:
Iterable
[
Sha1
])
->
List
[
ContentMimetypeRow
]:
"""Retrieve full content mimetype per ids.
Args:
ids: sha1 identifiers
Returns:
mimetype row objects
"""
...
@remote_api_endpoint
(
"content_language/missing"
)
def
content_language_missing
(
self
,
languages
:
Iterable
[
Dict
]
)
->
List
[
Tuple
[
Sha1
,
int
]]:
"""List languages missing from storage.
Args:
languages (iterable): dictionaries with keys:
- **id** (bytes): sha1 identifier
- **indexer_configuration_id** (int): tool used to compute
the results
Returns:
list of tuple (id, indexer_configuration_id) missing
"""
...
@remote_api_endpoint
(
"content_language"
)
def
content_language_get
(
self
,
ids
:
Iterable
[
Sha1
])
->
List
[
ContentLanguageRow
]:
"""Retrieve full content language per ids.
Args:
ids (iterable): sha1 identifier
Returns:
language row objects
"""
...
@remote_api_endpoint
(
"content_language/add"
)
def
content_language_add
(
self
,
languages
:
List
[
ContentLanguageRow
]
)
->
Dict
[
str
,
int
]:
"""Add languages not present in storage.
Args:
languages: language row objects
Returns:
Dict summary of number of rows added
"""
...
@remote_api_endpoint
(
"content/ctags/missing"
)
def
content_ctags_missing
(
self
,
ctags
:
Iterable
[
Dict
])
->
List
[
Tuple
[
Sha1
,
int
]]:
"""List ctags missing from storage.
Args:
ctags (iterable): dicts with keys:
- **id** (bytes): sha1 identifier
- **indexer_configuration_id** (int): tool used to compute
the results
Returns:
list of missing id for the tuple (id,
indexer_configuration_id)
"""
...
@remote_api_endpoint
(
"content/ctags"
)
def
content_ctags_get
(
self
,
ids
:
Iterable
[
Sha1
])
->
List
[
ContentCtagsRow
]:
"""Retrieve ctags per id.
Args:
ids (iterable): sha1 checksums
Returns:
list of language rows
"""
...
@remote_api_endpoint
(
"content/ctags/add"
)
def
content_ctags_add
(
self
,
ctags
:
List
[
ContentCtagsRow
])
->
Dict
[
str
,
int
]:
"""Add ctags not present in storage
Args:
ctags (iterable): dictionaries with keys:
- **id** (bytes): sha1
- **ctags** ([list): List of dictionary with keys: name, kind,
line, lang
Returns:
Dict summary of number of rows added
"""
...
@remote_api_endpoint
(
"content/ctags/search"
)
def
content_ctags_search
(
self
,
expression
:
str
,
limit
:
int
=
10
,
last_sha1
:
Optional
[
Sha1
]
=
None
)
->
List
[
ContentCtagsRow
]:
"""Search through content's raw ctags symbols.
Args:
expression (str): Expression to search for
limit (int): Number of rows to return (default to 10).
last_sha1 (str): Offset from which retrieving data (default to '').
Returns:
rows of ctags including id, name, lang, kind, line, etc...
"""
...
@remote_api_endpoint
(
"content/fossology_license"
)
def
content_fossology_license_get
(
self
,
ids
:
Iterable
[
Sha1
]
)
->
List
[
ContentLicenseRow
]:
"""Retrieve licenses per id.
Args:
ids: sha1 identifiers
Yields:
license rows; possibly more than one per (sha1, tool_id) if there
are multiple licenses.
"""
...
@remote_api_endpoint
(
"content/fossology_license/add"
)
def
content_fossology_license_add
(
self
,
licenses
:
List
[
ContentLicenseRow
]
)
->
Dict
[
str
,
int
]:
"""Add licenses not present in storage.
Args:
license: license rows to be added, with their `tool` attribute set to
None.
Returns:
Dict summary of number of rows added
"""
...
@remote_api_endpoint
(
"content/fossology_license/range"
)
def
content_fossology_license_get_partition
(
self
,
indexer_configuration_id
:
int
,
partition_id
:
int
,
nb_partitions
:
int
,
page_token
:
Optional
[
str
]
=
None
,
limit
:
int
=
1000
,
)
->
PagedResult
[
Sha1
]:
"""Retrieve licenses within the partition partition_id bound by limit.
Args:
**indexer_configuration_id**: The tool used to index data
**partition_id**: index of the partition to fetch
**nb_partitions**: total number of partitions to split into
**page_token**: opaque token used for pagination
**limit**: Limit result (default to 1000)
Raises:
IndexerStorageArgumentException for;
- limit to None
- wrong indexer_type provided
Returns: PagedResult of Sha1. If next_page_token is None, there is no more data
to fetch
"""
...
@remote_api_endpoint
(
"content_metadata/missing"
)
def
content_metadata_missing
(
self
,
metadata
:
Iterable
[
Dict
]
)
->
List
[
Tuple
[
Sha1
,
int
]]:
"""List metadata missing from storage.
Args:
metadata (iterable): dictionaries with keys:
- **id** (bytes): sha1 identifier
- **indexer_configuration_id** (int): tool used to compute
the results
Yields:
missing sha1s
"""
...
@remote_api_endpoint
(
"content_metadata"
)
def
content_metadata_get
(
self
,
ids
:
Iterable
[
Sha1
])
->
List
[
ContentMetadataRow
]:
"""Retrieve metadata per id.
Args:
ids (iterable): sha1 checksums
Yields:
dictionaries with the following keys:
id (bytes)
metadata (str): associated metadata
tool (dict): tool used to compute metadata
"""
...
@remote_api_endpoint
(
"content_metadata/add"
)
def
content_metadata_add
(
self
,
metadata
:
List
[
ContentMetadataRow
]
)
->
Dict
[
str
,
int
]:
"""Add metadata not present in storage.
Args:
metadata (iterable): dictionaries with keys:
- **id**: sha1
- **metadata**: arbitrary dict
Returns:
Dict summary of number of rows added
"""
...
@remote_api_endpoint
(
"revision_intrinsic_metadata/missing"
)
def
revision_intrinsic_metadata_missing
(
self
,
metadata
:
Iterable
[
Dict
]
)
->
List
[
Tuple
[
Sha1
,
int
]]:
"""List metadata missing from storage.
Args:
metadata (iterable): dictionaries with keys:
- **id** (bytes): sha1_git revision identifier
- **indexer_configuration_id** (int): tool used to compute
the results
Returns:
missing ids
"""
...
@remote_api_endpoint
(
"revision_intrinsic_metadata"
)
def
revision_intrinsic_metadata_get
(
self
,
ids
:
Iterable
[
Sha1
]
)
->
List
[
RevisionIntrinsicMetadataRow
]:
"""Retrieve revision metadata per id.
Args:
ids (iterable): sha1 checksums
Returns:
ContentMetadataRow objects
"""
...
@remote_api_endpoint
(
"revision_intrinsic_metadata/add"
)
def
revision_intrinsic_metadata_add
(
self
,
metadata
:
List
[
RevisionIntrinsicMetadataRow
],
)
->
Dict
[
str
,
int
]:
"""Add metadata not present in storage.
Args:
metadata: ContentMetadataRow objects
Returns:
Dict summary of number of rows added
"""
...
@remote_api_endpoint
(
"origin_intrinsic_metadata"
)
def
origin_intrinsic_metadata_get
(
self
,
urls
:
Iterable
[
str
]
)
->
List
[
OriginIntrinsicMetadataRow
]:
"""Retrieve origin metadata per id.
Args:
urls (iterable): origin URLs
Returns: list of OriginIntrinsicMetadataRow
"""
...
@remote_api_endpoint
(
"origin_intrinsic_metadata/add"
)
def
origin_intrinsic_metadata_add
(
self
,
metadata
:
List
[
OriginIntrinsicMetadataRow
]
)
->
Dict
[
str
,
int
]:
"""Add origin metadata not present in storage.
Args:
metadata: list of OriginIntrinsicMetadataRow objects
Returns:
Dict summary of number of rows added
"""
...
@remote_api_endpoint
(
"origin_intrinsic_metadata/search/fulltext"
)
def
origin_intrinsic_metadata_search_fulltext
(
self
,
conjunction
:
List
[
str
],
limit
:
int
=
100
)
->
List
[
OriginIntrinsicMetadataRow
]:
"""Returns the list of origins whose metadata contain all the terms.
Args:
conjunction: List of terms to be searched for.
limit: The maximum number of results to return
Returns:
list of OriginIntrinsicMetadataRow
"""
...
@remote_api_endpoint
(
"origin_intrinsic_metadata/search/by_producer"
)
def
origin_intrinsic_metadata_search_by_producer
(
self
,
page_token
:
str
=
""
,
limit
:
int
=
100
,
ids_only
:
bool
=
False
,
mappings
:
Optional
[
List
[
str
]]
=
None
,
tool_ids
:
Optional
[
List
[
int
]]
=
None
,
)
->
PagedResult
[
Union
[
str
,
OriginIntrinsicMetadataRow
]]:
"""Returns the list of origins whose metadata contain all the terms.
Args:
page_token (str): Opaque token used for pagination.
limit (int): The maximum number of results to return
ids_only (bool): Determines whether only origin urls are
returned or the content as well
mappings (List[str]): Returns origins whose intrinsic metadata
were generated using at least one of these mappings.
Returns:
OriginIntrinsicMetadataRow objects
"""
...
@remote_api_endpoint
(
"origin_intrinsic_metadata/stats"
)
def
origin_intrinsic_metadata_stats
(
self
):
"""Returns counts of indexed metadata per origins, broken down
into metadata types.
Returns:
dict: dictionary with keys:
- total (int): total number of origins that were indexed
(possibly yielding an empty metadata dictionary)
- non_empty (int): total number of origins that we extracted
a non-empty metadata dictionary from
- per_mapping (dict): a dictionary with mapping names as
keys and number of origins whose indexing used this
mapping. Note that indexing a given origin may use
0, 1, or many mappings.
"""
...
@remote_api_endpoint
(
"indexer_configuration/add"
)
def
indexer_configuration_add
(
self
,
tools
):
"""Add new tools to the storage.
Args:
tools ([dict]): List of dictionary representing tool to
insert in the db. Dictionary with the following keys:
- **tool_name** (str): tool's name
- **tool_version** (str): tool's version
- **tool_configuration** (dict): tool's configuration
(free form dict)
Returns:
List of dict inserted in the db (holding the id key as
well). The order of the list is not guaranteed to match
the order of the initial list.
"""
...
@remote_api_endpoint
(
"indexer_configuration/data"
)
def
indexer_configuration_get
(
self
,
tool
):
"""Retrieve tool information.
Args:
tool (dict): Dictionary representing a tool with the
following keys:
- **tool_name** (str): tool's name
- **tool_version** (str): tool's version
- **tool_configuration** (dict): tool's configuration
(free form dict)
Returns:
The same dictionary with an `id` key, None otherwise.
"""
...
File Metadata
Details
Attached
Mime Type
text/x-python
Expires
Fri, Jul 4, 12:43 PM (2 w, 2 d ago)
Storage Engine
blob
Storage Format
Raw Data
Storage Handle
3292200
Attached To
rDCIDX Metadata indexer
Event Timeline
Log In to Comment