import uuid
|
|
from app.Log import logger
|
from app.models.resource_model import ResourceModel, ResourceTypeModel
|
from app.models.role_model import RoleModel
|
|
|
|
async def role_list(db, page_size: int, page_index: int, keyword: str):
|
query = db.query(RoleModel)
|
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, user_id):
|
try:
|
role_model = RoleModel(id=str(uuid.uuid4()),name=role_name, description=description,creator=user_id)
|
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, resources:list):
|
try:
|
role = db.query(RoleModel).filter(RoleModel.id == role_id).first()
|
if role_name: role.name = role_name
|
if description: role.description = description
|
if resources:
|
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
|