Source code for starmap_client.providers.base
from abc import ABC, abstractmethod
from typing import Any, Dict, Generic, List, Optional, TypeVar
TQRC = TypeVar("TQRC") # QueryResponseContainer
TQRE = TypeVar("TQRE") # QueryResponseEntity
[docs]
class StarmapProvider(ABC, Generic[TQRC, TQRE]):
"""Define the interface for a local mappings provider."""
api = "default"
"""The provider's API level implementation."""
[docs]
@abstractmethod
def query(self, params: Dict[str, Any]) -> Optional[TQRC]:
"""Retrieve the mapping without using the server.
It relies in the local provider to retrieve the correct mapping
according to the parameters.
Args:
params (dict):
The request params to retrieve the mapping.
Returns:
The requested mapping when found.
"""
[docs]
@abstractmethod
def list_content(self) -> List[TQRE]:
"""Return a list with all stored responses."""
[docs]
@abstractmethod
def store(self, response: TQRE) -> None:
"""Store a single response into the local provider.
Args:
response (response):
The object to store.
"""