Base API class

Module for the base class handling the access to the Database API.

class owimetadatabase_preprocessor.io.API(api_root: str = 'https://owimetadatabase.azurewebsites.net/api/v1', token: str | None = None, uname: str | None = None, password: str | None = None, **kwargs)

Bases: object

Base API class handling user access information to the Database API.

__init__(api_root: str = 'https://owimetadatabase.azurewebsites.net/api/v1', token: str | None = None, uname: str | None = None, password: str | None = None, **kwargs) None

Create an instance of the API class with the required parameters.

Parameters:
  • api_root – Optional: root URL of the API endpoint, the default working database url is provided.

  • token – Optional: token to access the API.

  • uname – Optional: username to access the API.

  • password – Optional: password to access the API.

  • kwargs – Additional parameters to pass to the API.

Returns:

None

send_request(url_data_type: str, url_params: Dict[str, str]) Response

Handle sending appropriate request according to the type of authentication.

Parameters:
  • url_data_type – Type of the data we want to request (according to database model).

  • url_params – Parameters to send with the request to the database.

Returns:

An instance of the Response object.

static check_request_health(resp: Response) None

Check status code of the response to request and provide detials if unexpected.

Parameters:

resp – Instance of the Response object.

Returns:

None

static output_to_df(response: Response) DataFrame

Transform output to Pandas dataframe.

Parameters:

response – Raw output of the sent request.

Returns:

Pandas dataframe of the data from the output.

static postprocess_data(df: DataFrame, output_type: str) Dict[str, bool | int64 | None]

Process dataframe information to extarct the necessary additional data.

Parameters:
  • df – Dataframe of the output data.

  • output_type – Expected type (amount) of the data extracted.

Returns:

Dictionary of the additional data extracted.

static validate_data(df, data_type)
process_data(url_data_type: str, url_params: Dict[str, str], output_type: str) Tuple[DataFrame, Dict[str, bool | int64 | None]]

Process output data according to specified request parameters.

Parameters:
  • url_data_type – Type of the data we want to request (according to database model).

  • url_params – Parameters to send with the request to the database.

  • output_type – Expected type (amount) of the data extracted.

Returns:

A tuple of dataframe with the requested data and additional data from postprocessing.