Hector Salvador [Fisharp]
Structured dataclasses for requests and settings.
2bc3f5c
raw
history blame
3.05 kB
import os
from typing import List
from urllib.parse import urljoin
from settings import DEFAULT_HUGGINGFACE_MODELS_API_BASE_URL
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='.') -> 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 current directory
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) -> List[str]:
"""Splits a string into sections given a delimiter
Args:
string (str): The string to split
delimiter (str): The delimiter to use
Returns:
List[str]: The list of sections
"""
return [section.strip()
for section in string.split(delimiter)
if (section and not section.isspace())]