Spaces:
Running
Running
| import os | |
| from typing import List | |
| from urllib.parse import urljoin | |
| from settings import ( | |
| DEFAULT_HUGGINGFACE_MODELS_API_BASE_URL, | |
| STATIC_PATH, | |
| ) | |
| def masked(value: str, n_shown: int, length: int = None) -> str: | |
| """Returns a string with the first and last n_shown characters | |
| and the middle of the string replaced with '*' | |
| Args: | |
| value (str): The string to mask | |
| n_shown (int): The number of characters to show at the beginning and end of the string | |
| length (int, optional): The length of the string. If not given, it will be calculated as the length of the value. Defaults to None. | |
| Returns: | |
| str: The masked string | |
| """ | |
| l = length or len(value) | |
| return value[0:n_shown] + '*'*(length-2*n_shown) + value[-n_shown:] | |
| def ofuscated(value: str) -> str: | |
| """Returns a string with the first and last 4 characters | |
| and the middle of the string replaced with '*' | |
| Args: | |
| value (str): The string to mask | |
| Returns: | |
| str: The masked string | |
| """ | |
| return masked(value, 4, len(value)//2) | |
| def preview(label:str, value: str, ofuscate=False): | |
| """Print the variable name and its value in a nice way. | |
| If ofuscate is True, it will ofuscate the value | |
| Args: | |
| variable_name (str): The name of the variable to print | |
| ofuscate (bool, optional): If True, it will ofuscate the value. Defaults to False. | |
| """ | |
| str_value = ofuscated(str(value)) if ofuscate else str(value) | |
| print(f"{label} = {str_value}") | |
| def get_url_from_env_or_default_path(env_name: str, api_path: str) -> str: | |
| """Takes an url from the env variable (given the env name) | |
| or combines with urljoin the default models base url | |
| with the default path (given the path name) | |
| Args: | |
| env_name (str): The name of the environment variable to check | |
| api_path (str): The default path to use if the environment variable is not set | |
| Returns: | |
| str: The url to use | |
| """ | |
| return os.environ.get(env_name) or urljoin( | |
| DEFAULT_HUGGINGFACE_MODELS_API_BASE_URL, api_path | |
| ) | |
| def get_file_as_string(file_name, path=STATIC_PATH) -> str: | |
| """Loads the content of a file given its name | |
| and returns all of its lines as a single string | |
| if a file path is given, it will be used | |
| instead of the default static path (from settings) | |
| Args: | |
| file_name (_type_): The name of the file to load. | |
| path (str, optional): The path to the file. Defaults to the current directory. | |
| Returns: | |
| str: The content of the file as a single string | |
| """ | |
| with open(os.path.join(path, file_name), mode='r', encoding='UTF-8') as f: | |
| return f.read() | |
| def get_sections(string: str, delimiter: str, up_to: int = None) -> List[str]: | |
| """Splits a string into sections given a delimiter | |
| Args: | |
| string (str): The string to split | |
| delimiter (str): The delimiter to use | |
| up_to (int, optional): The maximum number of sections to return. | |
| Defaults to None (which means all sections) | |
| Returns: | |
| List[str]: The list of sections (up to the given limit, if any provided) | |
| """ | |
| return [section.strip() | |
| for section in string.split(delimiter) | |
| if (section and not section.isspace())][:up_to] | |