core/auth/identity.py

38 lines
1.0 KiB
Python
Raw Normal View History

from auth.password import Password
from exceptions import InvalidPassword, ObjectNotExist
from orm import User as OrmUser
2021-08-05 16:49:08 +00:00
from orm.base 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
def identity(user_id: int, password: str) -> User:
2021-08-05 16:49:08 +00:00
with local_session() as session:
user = session.query(OrmUser).filter_by(id=user_id).first()
2021-07-09 07:14:16 +00:00
if not user:
raise ObjectNotExist("User does not exist")
user = User(**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