core/auth/identity.py

34 lines
923 B
Python
Raw Normal View History

from auth.password import Password
2022-08-11 05:53:14 +00:00
from base.exceptions import InvalidPassword, ObjectNotExist
from orm import User as OrmUser
2022-08-11 05:53:14 +00:00
from base.orm import local_session
from auth.validations import User
2021-07-14 14:45:31 +00:00
from sqlalchemy import or_
class Identity:
2021-07-09 07:14:16 +00:00
@staticmethod
2021-10-24 14:13:32 +00:00
def identity(orm_user: OrmUser, password: str) -> User:
user = User(**orm_user.dict())
2021-07-14 14:45:31 +00:00
if user.password is None:
raise InvalidPassword("Wrong user password")
2021-07-09 07:14:16 +00:00
if not Password.verify(password, user.password):
raise InvalidPassword("Wrong user password")
return user
@staticmethod
2021-07-14 14:45:31 +00:00
def identity_oauth(input) -> User:
2021-08-05 16:49:08 +00:00
with local_session() as session:
user = session.query(OrmUser).filter(
2021-08-19 15:33:39 +00:00
or_(OrmUser.oauth == input["oauth"], OrmUser.email == input["email"])
2021-08-05 16:49:08 +00:00
).first()
if not user:
user = OrmUser.create(**input)
2021-08-19 15:33:39 +00:00
if not user.oauth:
user.oauth = input["oauth"]
2021-08-05 16:49:08 +00:00
session.commit()
2021-07-14 14:45:31 +00:00
2021-07-09 07:14:16 +00:00
user = User(**user.dict())
return user