Files
Wu Clan e1edcade21 Add RBAC authorisation and some tools or optimisations (#41)
* WIP: add rbac authorization

* Perform pre-commit fixes

* add rbac route whitelist

* add init test data user role associations

* Restore database table id naming to fix generic crud base

* Add database section value uniqueness settings

* Update the test directory to tests

* Update route_name file name to health_check

* Split user auth and user action interfaces

* Fix conflict between merge and current branch

* Add pymysql dependencies

* Fix RBAC authentication method

* Add the select serialisation tool

* Fix missing return messages due to global exception handler slicing

* Update the user interface with associated relationships

* Add items to be completed

* Perform pre-commit fixes

* Add pre-made routers

* Paging data return structure optimisation

* Split user auth and user interface tests

* Fix user register test data structure error

* Fix duplicate named test classes
2023-05-17 22:13:37 +08:00

178 lines
5.9 KiB
Python

#!/usr/bin/env python3
# -*- coding: utf-8 -*-
import asyncio
from email_validator import EmailNotValidError, validate_email
from faker import Faker
from backend.app.common.jwt import get_hash_password
from backend.app.common.log import log
from backend.app.database.db_mysql import async_db_session
from backend.app.models import User, Role, Menu, Dept
class InitTestData:
"""初始化测试数据"""
def __init__(self):
self.fake = Faker('zh_CN')
@staticmethod
async def create_dept():
"""自动创建部门"""
async with async_db_session.begin() as db:
department_obj = Dept(name='test', create_user=1)
db.add(department_obj)
log.info('部门 test 创建成功')
@staticmethod
async def create_role():
"""自动创建角色"""
async with async_db_session.begin() as db:
role_obj = Role(name='test', create_user=1)
role_obj.menus.append(Menu(name='test', create_user=1))
db.add(role_obj)
log.info('角色 test 创建成功')
@staticmethod
async def create_test_user():
"""创建测试用户"""
username = 'test'
password = 'test'
email = 'test@gmail.com'
user_obj = User(
username=username,
nickname=username,
password=get_hash_password(password),
email=email,
is_superuser=True,
dept_id=1,
)
async with async_db_session.begin() as db:
user_obj.roles.append(await db.get(Role, 1))
db.add(user_obj)
log.info(f'测试用户创建成功,账号:{username},密码:{password}')
@staticmethod
async def create_superuser_by_yourself():
"""手动创建管理员账户"""
log.info('开始创建自定义管理员用户')
print('请输入用户名:')
username = input()
print('请输入密码:')
password = input()
print('请输入邮箱:')
while True:
email = input()
try:
validate_email(email, check_deliverability=False).email
except EmailNotValidError:
print('邮箱不符合规范,请重新输入:')
continue
break
user_obj = User(
username=username,
nickname=username,
password=get_hash_password(password),
email=email,
is_superuser=True,
dept_id=1,
)
async with async_db_session.begin() as db:
user_obj.roles.append(await db.get(Role, 1))
db.add(user_obj)
log.info(f'自定义管理员用户创建成功,账号:{username},密码:{password}')
async def fake_user(self):
"""自动创建普通用户"""
username = self.fake.user_name()
password = self.fake.password()
email = self.fake.email()
user_obj = User(
username=username,
nickname=username,
password=get_hash_password(password),
email=email,
is_superuser=False,
dept_id=1,
)
async with async_db_session.begin() as db:
user_obj.roles.append(await db.get(Role, 1))
db.add(user_obj)
log.info(f'普通用户创建成功,账号:{username},密码:{password}')
async def fake_no_active_user(self):
"""自动创建锁定普通用户"""
username = self.fake.user_name()
password = self.fake.password()
email = self.fake.email()
user_obj = User(
username=username,
nickname=username,
password=get_hash_password(password),
email=email,
is_active=False,
is_superuser=False,
dept_id=1,
)
async with async_db_session.begin() as db:
user_obj.roles.append(await db.get(Role, 1))
db.add(user_obj)
log.info(f'普通锁定用户创建成功,账号:{username},密码:{password}')
async def fake_superuser(self):
"""自动创建管理员用户"""
username = self.fake.user_name()
password = self.fake.password()
email = self.fake.email()
user_obj = User(
username=username,
nickname=username,
password=get_hash_password(password),
email=email,
is_superuser=True,
dept_id=1,
)
async with async_db_session.begin() as db:
user_obj.roles.append(await db.get(Role, 1))
db.add(user_obj)
log.info(f'管理员用户创建成功,账号:{username},密码:{password}')
async def fake_no_active_superuser(self):
"""自动创建锁定管理员用户"""
username = self.fake.user_name()
password = self.fake.password()
email = self.fake.email()
user_obj = User(
username=username,
nickname=username,
password=get_hash_password(password),
email=email,
is_active=False,
is_superuser=True,
dept_id=1,
)
async with async_db_session.begin() as db:
user_obj.roles.append(await db.get(Role, 1))
db.add(user_obj)
log.info(f'管理员锁定用户创建成功,账号:{username},密码:{password}')
async def init_data(self):
"""自动创建数据"""
log.info('⏳ 开始初始化数据')
await self.create_dept()
await self.create_role()
await self.create_test_user()
await self.create_superuser_by_yourself()
await self.fake_user()
await self.fake_no_active_user()
await self.fake_superuser()
await self.fake_no_active_superuser()
log.info('✅ 数据初始化完成')
if __name__ == '__main__':
init = InitTestData()
loop = asyncio.get_event_loop()
loop.run_until_complete(init.init_data())