# Copyright (C) 2022 CVAT.ai Corporation # # SPDX-License-Identifier: MIT import os.path as osp import requests from cvat_sdk.api_client import ApiClient, Configuration ROOT_DIR = __file__[:__file__.rfind(osp.join("utils", ""))] ASSETS_DIR = osp.abspath(osp.join(ROOT_DIR, 'assets')) # Suppress the warning from Bandit about hardcoded passwords USER_PASS = '!Q@W#E$R' # nosec BASE_URL = 'http://localhost:8080' API_URL = BASE_URL + '/api/' # MiniIO settings MINIO_KEY = 'minio_access_key' MINIO_SECRET_KEY = 'minio_secret_key' # nosec MINIO_ENDPOINT_URL = 'http://localhost:9000' def _to_query_params(**kwargs): return '&'.join([f'{k}={v}' for k,v in kwargs.items()]) def get_server_url(endpoint, **kwargs): return BASE_URL + '/' + endpoint + '?' + _to_query_params(**kwargs) def get_api_url(endpoint, **kwargs): return API_URL + endpoint + '?' + _to_query_params(**kwargs) def get_method(username, endpoint, **kwargs): return requests.get(get_api_url(endpoint, **kwargs), auth=(username, USER_PASS)) def options_method(username, endpoint, **kwargs): return requests.options(get_api_url(endpoint, **kwargs), auth=(username, USER_PASS)) def delete_method(username, endpoint, **kwargs): return requests.delete(get_api_url(endpoint, **kwargs), auth=(username, USER_PASS)) def patch_method(username, endpoint, data, **kwargs): return requests.patch(get_api_url(endpoint, **kwargs), json=data, auth=(username, USER_PASS)) def post_method(username, endpoint, data, **kwargs): return requests.post(get_api_url(endpoint, **kwargs), json=data, auth=(username, USER_PASS)) def post_files_method(username, endpoint, data, files, **kwargs): return requests.post(get_api_url(endpoint, **kwargs), data=data, files=files, auth=(username, USER_PASS)) def server_get(username, endpoint, **kwargs): return requests.get(get_server_url(endpoint, **kwargs), auth=(username, USER_PASS)) def make_api_client(user: str, *, password: str = None) -> ApiClient: return ApiClient(configuration=Configuration(host=BASE_URL, username=user, password=password or USER_PASS))