2021-09-08 22:01:10 +00:00
|
|
|
import logging
|
|
|
|
import datetime
|
2022-01-26 01:45:30 +00:00
|
|
|
from typing import Optional, Union
|
2021-09-08 22:01:10 +00:00
|
|
|
|
|
|
|
from app.classes.models.roles import Roles, roles_helper
|
2022-03-08 04:40:44 +00:00
|
|
|
from app.classes.shared.helpers import helper
|
2021-09-08 22:01:10 +00:00
|
|
|
|
|
|
|
try:
|
2022-03-23 02:50:12 +00:00
|
|
|
from peewee import (
|
|
|
|
SqliteDatabase,
|
|
|
|
Model,
|
|
|
|
ForeignKeyField,
|
|
|
|
CharField,
|
|
|
|
AutoField,
|
|
|
|
DateTimeField,
|
|
|
|
BooleanField,
|
|
|
|
CompositeKey,
|
|
|
|
DoesNotExist,
|
|
|
|
JOIN,
|
|
|
|
)
|
2021-09-08 22:01:10 +00:00
|
|
|
from playhouse.shortcuts import model_to_dict
|
|
|
|
|
|
|
|
except ModuleNotFoundError as e:
|
2022-03-08 04:40:44 +00:00
|
|
|
helper.auto_installer_fix(e)
|
2021-09-08 22:01:10 +00:00
|
|
|
|
2022-03-08 04:40:44 +00:00
|
|
|
logger = logging.getLogger(__name__)
|
2022-03-23 02:50:12 +00:00
|
|
|
peewee_logger = logging.getLogger("peewee")
|
2022-03-08 04:40:44 +00:00
|
|
|
peewee_logger.setLevel(logging.INFO)
|
2022-03-23 02:50:12 +00:00
|
|
|
database = SqliteDatabase(
|
|
|
|
helper.db_path, pragmas={"journal_mode": "wal", "cache_size": -1024 * 10}
|
|
|
|
)
|
2021-09-08 22:01:10 +00:00
|
|
|
|
2022-03-23 06:06:13 +00:00
|
|
|
# **********************************************************************************
|
2021-09-08 22:01:10 +00:00
|
|
|
# Users Class
|
2022-03-23 06:06:13 +00:00
|
|
|
# **********************************************************************************
|
2021-09-08 22:01:10 +00:00
|
|
|
class Users(Model):
|
|
|
|
user_id = AutoField()
|
|
|
|
created = DateTimeField(default=datetime.datetime.now)
|
|
|
|
last_login = DateTimeField(default=datetime.datetime.now)
|
|
|
|
last_update = DateTimeField(default=datetime.datetime.now)
|
|
|
|
last_ip = CharField(default="")
|
|
|
|
username = CharField(default="", unique=True, index=True)
|
|
|
|
password = CharField(default="")
|
2022-01-08 23:03:45 +00:00
|
|
|
email = CharField(default="default@example.com")
|
2021-09-08 22:01:10 +00:00
|
|
|
enabled = BooleanField(default=True)
|
|
|
|
superuser = BooleanField(default=False)
|
2021-09-29 23:32:21 +00:00
|
|
|
lang = CharField(default="en_EN")
|
2022-03-23 02:50:12 +00:00
|
|
|
support_logs = CharField(default="")
|
2022-01-15 00:23:50 +00:00
|
|
|
valid_tokens_from = DateTimeField(default=datetime.datetime.now)
|
2022-02-26 23:00:54 +00:00
|
|
|
server_order = CharField(default="")
|
2022-03-13 12:29:26 +00:00
|
|
|
preparing = BooleanField(default=False)
|
2021-09-08 22:01:10 +00:00
|
|
|
|
|
|
|
class Meta:
|
|
|
|
table_name = "users"
|
|
|
|
database = database
|
2021-10-09 09:30:21 +00:00
|
|
|
|
2022-01-15 00:23:50 +00:00
|
|
|
|
2022-03-23 06:06:13 +00:00
|
|
|
# **********************************************************************************
|
2022-01-15 00:23:50 +00:00
|
|
|
# API Keys Class
|
2022-03-23 06:06:13 +00:00
|
|
|
# **********************************************************************************
|
2022-01-15 00:23:50 +00:00
|
|
|
class ApiKeys(Model):
|
|
|
|
token_id = AutoField()
|
2022-03-23 02:50:12 +00:00
|
|
|
name = CharField(default="", unique=True, index=True)
|
2022-01-15 00:23:50 +00:00
|
|
|
created = DateTimeField(default=datetime.datetime.now)
|
2022-03-23 02:50:12 +00:00
|
|
|
user_id = ForeignKeyField(Users, backref="api_token", index=True)
|
|
|
|
server_permissions = CharField(default="00000000")
|
|
|
|
crafty_permissions = CharField(default="000")
|
2022-01-15 00:23:50 +00:00
|
|
|
superuser = BooleanField(default=False)
|
|
|
|
|
|
|
|
class Meta:
|
2022-03-23 02:50:12 +00:00
|
|
|
table_name = "api_keys"
|
2022-01-15 00:23:50 +00:00
|
|
|
database = database
|
|
|
|
|
|
|
|
|
2022-03-23 06:06:13 +00:00
|
|
|
# **********************************************************************************
|
2021-09-08 22:01:10 +00:00
|
|
|
# User Roles Class
|
2022-03-23 06:06:13 +00:00
|
|
|
# **********************************************************************************
|
2021-09-08 22:01:10 +00:00
|
|
|
class User_Roles(Model):
|
2022-03-23 02:50:12 +00:00
|
|
|
user_id = ForeignKeyField(Users, backref="user_role")
|
|
|
|
role_id = ForeignKeyField(Roles, backref="user_role")
|
2021-09-08 22:01:10 +00:00
|
|
|
|
|
|
|
class Meta:
|
2022-03-23 02:50:12 +00:00
|
|
|
table_name = "user_roles"
|
|
|
|
primary_key = CompositeKey("user_id", "role_id")
|
2021-09-08 22:01:10 +00:00
|
|
|
database = database
|
|
|
|
|
2022-03-23 02:50:12 +00:00
|
|
|
|
2022-03-23 06:06:13 +00:00
|
|
|
# **********************************************************************************
|
2021-09-08 22:01:10 +00:00
|
|
|
# Users Helpers
|
2022-03-23 06:06:13 +00:00
|
|
|
# **********************************************************************************
|
2021-09-08 22:01:10 +00:00
|
|
|
class helper_users:
|
|
|
|
@staticmethod
|
|
|
|
def get_by_id(user_id):
|
|
|
|
return Users.get_by_id(user_id)
|
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
def get_all_users():
|
2021-12-21 01:17:28 +00:00
|
|
|
query = Users.select().where(Users.username != "system")
|
2021-09-08 22:01:10 +00:00
|
|
|
return query
|
|
|
|
|
2021-09-29 23:32:21 +00:00
|
|
|
@staticmethod
|
|
|
|
def get_user_lang_by_id(user_id):
|
|
|
|
return Users.get(Users.user_id == user_id).lang
|
|
|
|
|
2021-09-08 22:01:10 +00:00
|
|
|
@staticmethod
|
|
|
|
def get_user_id_by_name(username):
|
|
|
|
try:
|
|
|
|
return (Users.get(Users.username == username)).user_id
|
|
|
|
except DoesNotExist:
|
|
|
|
return None
|
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
def user_query(user_id):
|
|
|
|
user_query = Users.select().where(Users.user_id == user_id)
|
|
|
|
return user_query
|
2021-10-09 09:30:21 +00:00
|
|
|
|
2021-09-08 22:01:10 +00:00
|
|
|
@staticmethod
|
|
|
|
def get_user(user_id):
|
|
|
|
if user_id == 0:
|
|
|
|
return {
|
2022-03-23 02:50:12 +00:00
|
|
|
"user_id": 0,
|
|
|
|
"created": "10/24/2019, 11:34:00",
|
|
|
|
"last_login": "10/24/2019, 11:34:00",
|
|
|
|
"last_update": "10/24/2019, 11:34:00",
|
|
|
|
"last_ip": "127.27.23.89",
|
|
|
|
"username": "SYSTEM",
|
|
|
|
"password": None,
|
|
|
|
"email": "default@example.com",
|
|
|
|
"enabled": True,
|
|
|
|
"superuser": True,
|
|
|
|
"roles": [],
|
|
|
|
"servers": [],
|
|
|
|
"support_logs": "",
|
2021-09-08 22:01:10 +00:00
|
|
|
}
|
|
|
|
user = model_to_dict(Users.get(Users.user_id == user_id))
|
|
|
|
|
|
|
|
if user:
|
|
|
|
# I know it should apply it without setting it but I'm just making sure
|
|
|
|
user = users_helper.add_user_roles(user)
|
|
|
|
return user
|
|
|
|
else:
|
2022-03-23 02:50:12 +00:00
|
|
|
# logger.debug("user: ({}) {}".format(user_id, {}))
|
2021-09-08 22:01:10 +00:00
|
|
|
return {}
|
|
|
|
|
2022-01-26 01:45:30 +00:00
|
|
|
@staticmethod
|
2021-12-21 01:17:28 +00:00
|
|
|
def check_system_user(user_id):
|
|
|
|
try:
|
2022-01-26 01:45:30 +00:00
|
|
|
result = Users.get(Users.user_id == user_id).user_id == user_id
|
|
|
|
if result:
|
|
|
|
return True
|
2021-12-21 01:17:28 +00:00
|
|
|
except:
|
|
|
|
return False
|
|
|
|
|
2021-09-08 22:01:10 +00:00
|
|
|
@staticmethod
|
2022-01-15 00:23:50 +00:00
|
|
|
def get_user_model(user_id: str) -> Users:
|
|
|
|
user = Users.get(Users.user_id == user_id)
|
|
|
|
user = users_helper.add_user_roles(user)
|
|
|
|
return user
|
|
|
|
|
|
|
|
@staticmethod
|
2022-03-23 02:50:12 +00:00
|
|
|
def add_user(
|
|
|
|
username: str,
|
|
|
|
password: str = None,
|
|
|
|
email: Optional[str] = None,
|
|
|
|
enabled: bool = True,
|
|
|
|
superuser: bool = False,
|
|
|
|
) -> str:
|
2021-09-08 22:01:10 +00:00
|
|
|
if password is not None:
|
|
|
|
pw_enc = helper.encode_pass(password)
|
|
|
|
else:
|
|
|
|
pw_enc = None
|
2022-03-23 02:50:12 +00:00
|
|
|
user_id = Users.insert(
|
|
|
|
{
|
|
|
|
Users.username: username.lower(),
|
|
|
|
Users.password: pw_enc,
|
|
|
|
Users.email: email,
|
|
|
|
Users.enabled: enabled,
|
|
|
|
Users.superuser: superuser,
|
|
|
|
Users.created: helper.get_time_as_string(),
|
|
|
|
}
|
|
|
|
).execute()
|
2021-09-08 22:01:10 +00:00
|
|
|
return user_id
|
2022-03-20 17:01:14 +00:00
|
|
|
|
2022-03-19 01:46:56 +00:00
|
|
|
@staticmethod
|
2022-03-23 02:50:12 +00:00
|
|
|
def add_rawpass_user(
|
|
|
|
username: str,
|
|
|
|
password: str = None,
|
|
|
|
email: Optional[str] = None,
|
|
|
|
enabled: bool = True,
|
|
|
|
superuser: bool = False,
|
|
|
|
) -> str:
|
|
|
|
user_id = Users.insert(
|
|
|
|
{
|
|
|
|
Users.username: username.lower(),
|
|
|
|
Users.password: password,
|
|
|
|
Users.email: email,
|
|
|
|
Users.enabled: enabled,
|
|
|
|
Users.superuser: superuser,
|
|
|
|
Users.created: helper.get_time_as_string(),
|
|
|
|
}
|
|
|
|
).execute()
|
2022-03-19 03:59:10 +00:00
|
|
|
return user_id
|
2021-09-08 22:01:10 +00:00
|
|
|
|
|
|
|
@staticmethod
|
2022-01-15 00:23:50 +00:00
|
|
|
def update_user(user_id, up_data=None):
|
|
|
|
if up_data is None:
|
|
|
|
up_data = {}
|
2021-09-08 22:01:10 +00:00
|
|
|
if up_data:
|
|
|
|
Users.update(up_data).where(Users.user_id == user_id).execute()
|
|
|
|
|
2022-02-26 23:00:54 +00:00
|
|
|
@staticmethod
|
|
|
|
def update_server_order(user_id, user_server_order):
|
2022-03-23 02:50:12 +00:00
|
|
|
Users.update(server_order=user_server_order).where(
|
|
|
|
Users.user_id == user_id
|
|
|
|
).execute()
|
2022-02-26 23:00:54 +00:00
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
def get_server_order(user_id):
|
|
|
|
return Users.select().where(Users.user_id == user_id)
|
|
|
|
|
2022-01-20 18:37:45 +00:00
|
|
|
@staticmethod
|
|
|
|
def get_super_user_list():
|
|
|
|
final_users = []
|
2022-04-02 16:54:30 +00:00
|
|
|
super_users = Users.select().where(
|
|
|
|
Users.superuser == True # pylint: disable=singleton-comparison
|
|
|
|
)
|
2022-01-20 18:37:45 +00:00
|
|
|
for suser in super_users:
|
|
|
|
if suser.user_id not in final_users:
|
|
|
|
final_users.append(suser.user_id)
|
|
|
|
return final_users
|
|
|
|
|
2021-09-08 22:01:10 +00:00
|
|
|
@staticmethod
|
|
|
|
def remove_user(user_id):
|
|
|
|
with database.atomic():
|
|
|
|
User_Roles.delete().where(User_Roles.user_id == user_id).execute()
|
|
|
|
user = Users.get(Users.user_id == user_id)
|
|
|
|
return user.delete_instance()
|
|
|
|
|
2022-01-14 01:42:53 +00:00
|
|
|
@staticmethod
|
|
|
|
def set_support_path(user_id, support_path):
|
2022-03-23 02:50:12 +00:00
|
|
|
Users.update(support_logs=support_path).where(
|
|
|
|
Users.user_id == user_id
|
|
|
|
).execute()
|
2022-03-13 13:26:38 +00:00
|
|
|
|
2022-03-13 12:29:26 +00:00
|
|
|
@staticmethod
|
|
|
|
def set_prepare(user_id):
|
2022-03-23 02:50:12 +00:00
|
|
|
Users.update(preparing=True).where(Users.user_id == user_id).execute()
|
2022-03-13 13:26:38 +00:00
|
|
|
|
2022-03-13 12:29:26 +00:00
|
|
|
@staticmethod
|
|
|
|
def stop_prepare(user_id):
|
2022-03-23 02:50:12 +00:00
|
|
|
Users.update(preparing=False).where(Users.user_id == user_id).execute()
|
2022-03-13 13:26:38 +00:00
|
|
|
|
2022-03-13 12:29:26 +00:00
|
|
|
@staticmethod
|
|
|
|
def clear_support_status():
|
2022-04-02 16:54:30 +00:00
|
|
|
Users.update(preparing=False).where(
|
|
|
|
Users.preparing == True # pylint: disable=singleton-comparison
|
|
|
|
).execute()
|
2022-01-14 01:42:53 +00:00
|
|
|
|
2021-09-08 22:01:10 +00:00
|
|
|
@staticmethod
|
|
|
|
def user_id_exists(user_id):
|
|
|
|
if not users_helper.get_user(user_id):
|
|
|
|
return False
|
|
|
|
return True
|
2021-10-09 09:30:21 +00:00
|
|
|
|
2022-03-23 06:06:13 +00:00
|
|
|
# **********************************************************************************
|
2022-03-23 02:50:12 +00:00
|
|
|
# User_Roles Methods
|
2022-03-23 06:06:13 +00:00
|
|
|
# **********************************************************************************
|
2021-09-08 22:01:10 +00:00
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
def get_or_create(user_id, role_id):
|
|
|
|
return User_Roles.get_or_create(user_id=user_id, role_id=role_id)
|
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
def get_user_roles_id(user_id):
|
|
|
|
roles_list = []
|
|
|
|
roles = User_Roles.select().where(User_Roles.user_id == user_id)
|
|
|
|
for r in roles:
|
2022-03-23 02:50:12 +00:00
|
|
|
roles_list.append(roles_helper.get_role(r.role_id)["role_id"])
|
2021-09-08 22:01:10 +00:00
|
|
|
return roles_list
|
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
def get_user_roles_names(user_id):
|
|
|
|
roles_list = []
|
|
|
|
roles = User_Roles.select().where(User_Roles.user_id == user_id)
|
|
|
|
for r in roles:
|
2022-03-23 02:50:12 +00:00
|
|
|
roles_list.append(roles_helper.get_role(r.role_id)["role_name"])
|
2021-09-08 22:01:10 +00:00
|
|
|
return roles_list
|
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
def add_role_to_user(user_id, role_id):
|
2022-03-23 02:50:12 +00:00
|
|
|
User_Roles.insert(
|
|
|
|
{User_Roles.user_id: user_id, User_Roles.role_id: role_id}
|
|
|
|
).execute()
|
2021-09-08 22:01:10 +00:00
|
|
|
|
|
|
|
@staticmethod
|
2022-01-15 00:23:50 +00:00
|
|
|
def add_user_roles(user: Union[dict, Users]):
|
2022-01-26 01:45:30 +00:00
|
|
|
if isinstance(user, dict):
|
2022-03-23 02:50:12 +00:00
|
|
|
user_id = user["user_id"]
|
2021-09-08 22:01:10 +00:00
|
|
|
else:
|
|
|
|
user_id = user.user_id
|
|
|
|
|
2022-03-23 06:16:22 +00:00
|
|
|
# I just copied this code from get_user,
|
|
|
|
# it had those TODOs & comments made by mac - Lukas
|
2021-10-09 09:30:21 +00:00
|
|
|
|
2022-03-23 02:50:12 +00:00
|
|
|
roles_query = (
|
|
|
|
User_Roles.select()
|
|
|
|
.join(Roles, JOIN.INNER)
|
|
|
|
.where(User_Roles.user_id == user_id)
|
|
|
|
)
|
2021-09-08 22:01:10 +00:00
|
|
|
# TODO: this query needs to be narrower
|
|
|
|
roles = set()
|
|
|
|
for r in roles_query:
|
|
|
|
roles.add(r.role_id.role_id)
|
|
|
|
|
2022-01-26 01:45:30 +00:00
|
|
|
if isinstance(user, dict):
|
2022-03-23 02:50:12 +00:00
|
|
|
user["roles"] = roles
|
2022-01-15 00:23:50 +00:00
|
|
|
else:
|
|
|
|
user.roles = roles
|
|
|
|
|
2022-03-23 02:50:12 +00:00
|
|
|
# logger.debug("user: ({}) {}".format(user_id, user))
|
2021-09-08 22:01:10 +00:00
|
|
|
return user
|
2021-10-09 09:30:21 +00:00
|
|
|
|
2021-09-08 22:01:10 +00:00
|
|
|
@staticmethod
|
|
|
|
def user_role_query(user_id):
|
|
|
|
user_query = User_Roles.select().where(User_Roles.user_id == user_id)
|
|
|
|
query = Roles.select().where(Roles.role_id == -1)
|
|
|
|
for u in user_query:
|
2021-10-09 09:30:21 +00:00
|
|
|
query = query + Roles.select().where(Roles.role_id == u.role_id)
|
2021-09-08 22:01:10 +00:00
|
|
|
return query
|
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
def delete_user_roles(user_id, removed_roles):
|
2022-03-23 02:50:12 +00:00
|
|
|
User_Roles.delete().where(User_Roles.user_id == user_id).where(
|
|
|
|
User_Roles.role_id.in_(removed_roles)
|
|
|
|
).execute()
|
2021-09-08 22:01:10 +00:00
|
|
|
|
2021-09-25 22:17:06 +00:00
|
|
|
@staticmethod
|
|
|
|
def remove_roles_from_role_id(role_id):
|
|
|
|
User_Roles.delete().where(User_Roles.role_id == role_id).execute()
|
|
|
|
|
2022-03-23 06:06:13 +00:00
|
|
|
# **********************************************************************************
|
2022-03-23 02:50:12 +00:00
|
|
|
# ApiKeys Methods
|
2022-03-23 06:06:13 +00:00
|
|
|
# **********************************************************************************
|
2022-01-15 00:23:50 +00:00
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
def get_user_api_keys(user_id: str):
|
|
|
|
return ApiKeys.select().where(ApiKeys.user_id == user_id).execute()
|
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
def get_user_api_key(key_id: str) -> ApiKeys:
|
|
|
|
return ApiKeys.get(ApiKeys.token_id == key_id)
|
|
|
|
|
|
|
|
@staticmethod
|
2022-01-26 01:45:30 +00:00
|
|
|
def add_user_api_key(
|
2022-03-23 02:50:12 +00:00
|
|
|
name: str,
|
|
|
|
user_id: str,
|
|
|
|
superuser: bool = False,
|
|
|
|
server_permissions_mask: Optional[str] = None,
|
|
|
|
crafty_permissions_mask: Optional[str] = None,
|
|
|
|
):
|
|
|
|
return ApiKeys.insert(
|
|
|
|
{
|
|
|
|
ApiKeys.name: name,
|
|
|
|
ApiKeys.user_id: user_id,
|
|
|
|
**(
|
|
|
|
{ApiKeys.server_permissions: server_permissions_mask}
|
|
|
|
if server_permissions_mask is not None
|
|
|
|
else {}
|
|
|
|
),
|
|
|
|
**(
|
|
|
|
{ApiKeys.crafty_permissions: crafty_permissions_mask}
|
|
|
|
if crafty_permissions_mask is not None
|
|
|
|
else {}
|
|
|
|
),
|
|
|
|
ApiKeys.superuser: superuser,
|
|
|
|
}
|
|
|
|
).execute()
|
2022-01-15 00:23:50 +00:00
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
def delete_user_api_keys(user_id: str):
|
|
|
|
ApiKeys.delete().where(ApiKeys.user_id == user_id).execute()
|
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
def delete_user_api_key(key_id: str):
|
|
|
|
ApiKeys.delete().where(ApiKeys.token_id == key_id).execute()
|
|
|
|
|
|
|
|
|
2022-01-26 01:45:30 +00:00
|
|
|
users_helper = helper_users()
|