Files
py-ailbl-user-profile/apps/helpers.py

105 lines
3.0 KiB
Python
Raw Normal View History

2025-12-08 07:50:09 +00:00
import datetime
2025-12-04 16:24:54 +07:00
import logging
2025-12-08 07:50:09 +00:00
import socket
import typing
import psycopg2
from flask import current_app
from psycopg2.extras import LoggingConnection
from ory_kratos_client.api import identity_api
from ory_kratos_client.configuration import Configuration
CORS_HEADERS = {
"Content-Type": "application/json",
}
SECRET_NAME = "fission-ailbl-user-profile-env"
CONFIG_NAME = "fission-eom-notification-config"
2025-12-04 16:24:54 +07:00
K8S_NAMESPACE = "default"
2025-12-08 07:50:09 +00:00
KRATOS_ADMIN_ENDPOINT_CONFIG_KEY = "KRATOS_ADMIN_ENDPOINT"
logging.basicConfig(level=logging.DEBUG)
logger = logging.getLogger(__name__)
def init_db_connection():
db_host = get_secret("PG_HOST", "locahost")
db_port = int(get_secret("PG_PORT", 55432))
if not check_port_open(ip=db_host, port=db_port):
raise Exception(
f"Establishing A Database Connection. {db_host}:{db_port}")
# options = get_secret("PG_DBSCHEMA")
# if options:
# options = f"-c search_path={options}" # if specific db schema
conn = psycopg2.connect(
database=get_secret("PG_DB", "postgres"),
user=get_secret("PG_USER", "postgres"),
password=get_secret("PG_PASS", "secret"),
host=get_secret("PG_HOST", "127.0.0.1"),
port=int(get_secret("PG_PORT", 5432)),
# options=options,
# cursor_factory=NamedTupleCursor,
connection_factory=LoggingConnection,
)
conn.initialize(logger)
return conn
# def db_row_to_dict(cursor, row):
# record = {}
# for i, column in enumerate(cursor.description):
# data = row[i]
# if isinstance(data, datetime.datetime):
# data = data.isoformat()
# record[column.name] = data
# return record
def db_row_to_dict(cursor, row):
record = {}
for i, column in enumerate(cursor.description):
data = row[i]
if isinstance(data, (datetime.datetime, datetime.date)):
data = data.isoformat()
record[column.name] = data
return record
def db_rows_to_array(cursor, rows):
return [db_row_to_dict(cursor, row) for row in rows]
2025-12-04 16:24:54 +07:00
def get_current_namespace() -> str:
try:
with open("/var/run/secrets/kubernetes.io/serviceaccount/namespace", "r") as f:
namespace = f.read()
2025-12-08 07:50:09 +00:00
except Exception as err:
current_app.logger.error(err)
2025-12-04 16:24:54 +07:00
namespace = K8S_NAMESPACE
return str(namespace)
2025-12-08 07:50:09 +00:00
def get_secret(key: str, default=None):
2025-12-04 16:24:54 +07:00
namespace = get_current_namespace()
path = f"/secrets/{namespace}/{SECRET_NAME}/{key}"
try:
with open(path, "r") as f:
return f.read()
2025-12-08 07:50:09 +00:00
except Exception as err:
current_app.logger.error(path, err)
2025-12-04 16:24:54 +07:00
return default
2025-12-08 07:50:09 +00:00
def check_port_open(ip: str, port: int, timeout: int = 30):
try:
with socket.socket(socket.AF_INET, socket.SOCK_STREAM) as s:
s.settimeout(timeout)
result = s.connect_ex((ip, port))
return result == 0
except Exception as err:
current_app.logger.err(f"Check port open error: {err}")
return False
2025-12-04 16:24:54 +07:00