* python version updated from 3.9 into 3.12 * x2text-service updated with uv and python version 3.12 * x2text-service docker file updated * Unstract packages updated with uv * Runner updated with uv * Promptservice updated with uv * Platform service updated with uv * backend service updated with uv * root pyproject.toml file updated * sdk version updated in services * unstract package modules updated based on sdk version: * docker file update * pdm lock workflow modified to support uv * Docs updated based on uv support * lock automation updated * snowflake module version updated into 3.14.0 * tox updated to support UV * tox updated to support UV * tox updated with pytest * tox updated with pytest-md-report * tox updated with module requirements * python migration from 3.9 to 3.12 * tox updated with module requirements * runner updated * Commit uv.lock changes * runner updated * Commit uv.lock changes * pytest.ini added * x2text-service docker file updated * pytest.ini removed * environment updated to test * docformatter commented on pre-commit * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * some pre-commit issues ignored * some pre-commit issues ignored * some pre-commit issues ignored * some pre-commit issues ignored * some pre-commit issues ignored * pre-commit updates * un used import removed from platfrom service controller * tox issue fixed * tox issue fixed * docker files updated * backend dockerfile updated * open installation issue fixed * Tools docker file updated with base python version 3.12 * python version updated into min 3.12 in pyproject.toml * linting issue fixed * uv version upgraded into 0.6.14 * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * migrations excluded from ruff * added PoethePoet task runner * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * feat: Added poe tasks for services (#1248) * Added poe tasks for services * reverted FE change made by mistake * updated tool-sidecar to uv and python to 3.12.9 * minor updates in pyproject descreption * feat: platform-service logging improvements (#1255) feat: Used flask util from core to improve logging in platform-service, added core as a dependency to platform-service: * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * fix: Platform-service build issue and numpy issue with Python 3.12 (#1258) * fix: Platform-service build and numpy issue with Py 3.12 * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * fix: Removed backend dockerfile install statements for numpy --------- Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com> * minor: Handled scenario when cost is not calculated due to no usage * minor: Corrected content shown for workflow input * fix: Minor fixes, used gthread for prompt-service, runner * Commit uv.lock changes * Removed unused line in tool dockerfile --------- Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com> Co-authored-by: Chandrasekharan M <chandrasekharan@zipstack.com> Co-authored-by: Chandrasekharan M <117059509+chandrasekharan-zipstack@users.noreply.github.com> Co-authored-by: ali-zipstack <muhammad.ali@zipstack.com>
57 lines
1.5 KiB
Python
57 lines
1.5 KiB
Python
import logging
|
|
from typing import Any
|
|
|
|
from django.db import IntegrityError
|
|
|
|
from account_v2.models import User
|
|
|
|
Logger = logging.getLogger(__name__)
|
|
|
|
|
|
class UserService:
|
|
def __init__(
|
|
self,
|
|
) -> None:
|
|
pass
|
|
|
|
def create_user(self, email: str, user_id: str) -> User:
|
|
try:
|
|
user: User = User(email=email, user_id=user_id, username=email)
|
|
user.save()
|
|
except IntegrityError as error:
|
|
Logger.info(f"[Duplicate Id] Failed to create User Error: {error}")
|
|
raise error
|
|
return user
|
|
|
|
def update_user(self, user: User, user_id: str) -> User:
|
|
user.user_id = user_id
|
|
user.save()
|
|
return user
|
|
|
|
def get_user_by_email(self, email: str) -> User | None:
|
|
try:
|
|
user: User = User.objects.get(email=email)
|
|
return user
|
|
except User.DoesNotExist:
|
|
return None
|
|
|
|
def get_user_by_user_id(self, user_id: str) -> Any:
|
|
try:
|
|
return User.objects.get(user_id=user_id)
|
|
except User.DoesNotExist:
|
|
return None
|
|
|
|
def get_user_by_id(self, id: str) -> Any:
|
|
"""Retrieve a user by their ID, taking into account the schema context.
|
|
|
|
Args:
|
|
id (str): The ID of the user.
|
|
|
|
Returns:
|
|
Any: The user object if found, or None if not found.
|
|
"""
|
|
try:
|
|
return User.objects.get(id=id)
|
|
except User.DoesNotExist:
|
|
return None
|