import uuid
|
|
from Log import logger
|
from app.models.resource_model import ResourceModel
|
from app.models.role_model import RoleModel
|
|
|
|
async def role_list(db, page_size: int, page_index: int, keyword: str, role_key:str, user_id):
|
query = db.query(RoleModel)
|
if role_key != "admin":
|
query.filter(RoleModel.creator==user_id)
|
if keyword:
|
query = query.filter(RoleModel.name.like('%{}%'.format(keyword)))
|
roles = query.order_by(RoleModel.id.desc()).limit(page_size).offset(
|
(page_index - 1) * page_size).all()
|
return {"total": query.count(), "rows": [role.to_json() for role in roles]}
|
|
|
async def create_role(db, role_name: str, description: str, role_key, data_scope, user_id):
|
try:
|
role_model = RoleModel(id=str(uuid.uuid4()),name=role_name, description=description,creator=user_id, data_scope=data_scope)
|
if role_key:
|
role_model.roleKey = role_key
|
db.add(role_model)
|
db.commit()
|
db.refresh(role_model)
|
except Exception as e:
|
logger.error(e)
|
db.rollback()
|
return False
|
return True
|
|
async def delete_role_data(db, role_id: str):
|
try:
|
db.query(RoleModel).filter(RoleModel.id == role_id).delete()
|
db.commit()
|
except Exception as e:
|
logger.error(e)
|
db.rollback()
|
return False
|
return True
|
|
|
async def edit_role_status(db, status: str, role_id: str):
|
try:
|
db.query(RoleModel).filter(RoleModel.id == role_id).update({"status":status})
|
db.commit()
|
except Exception as e:
|
logger.error(e)
|
db.rollback()
|
return False
|
return True
|
|
|
async def edit_role_resource(db, role_id:str, role_name:str, description:str,role_key:str, data_scope:int, resources:list, edit_type:int):
|
try:
|
role = db.query(RoleModel).filter(RoleModel.id == role_id).first()
|
if edit_type == 1:
|
role.name = role_name
|
role.description = description
|
|
if role_key:
|
role.roleKey = role_key
|
if data_scope:
|
role.data_scope = data_scope
|
else:
|
role.resources = [db.get(ResourceModel, resourcesId) for resourcesId in resources]
|
db.add(role)
|
db.commit()
|
except Exception as e:
|
logger.error(e)
|
db.rollback()
|
return False
|
return True
|