@router.post("/role", summary="添加权限角色")
async def addRole(*,
db: Session = Depends(deps.get_db),
u: Users = Depends(deps.user_perm(["perm:role:post"])),
obj: RoleSchema
):
curd_role.create(db, obj_in=obj, creator_id=u['id'])
return respSuccessJson()
这段代码是一个使用Python的FastAPI框架编写的路由处理函数。它使用了POST方法,处理的路径是"/role",作用是添加权限角色。
在函数参数中,db是一个数据库会话对象,u是一个用户对象,obj是一个角色信息的模式对象。
在函数体内部,调用了curd_role.create函数来在数据库中创建一个新的角色,该函数接受数据库会话对象db、角色信息obj,以及创建者的ID … … … u[‘id’]。这个函数的作用是在数据库中创建一个新的角色。
最后,函数返回了一个成功的JSON响应,表示角色添加成功。
def create(self, db: Session, *, obj_in: CreateSchemaType, creator_id: int = 0):
menus = db.query(Menus).filter(Menus.id.in_(obj_in.menus)).all()
obj_in_data = obj_in if isinstance(obj_in, dict) else jsonable_encoder(obj_in)
del obj_in_data['menus']
obj_in_data['creator_id'] = creator_id
obj = self.model(**obj_in_data) # type: Roles
obj.role_menu = menus
db.add(obj)
db.commit()
db.refresh(obj)
return obj
这段代码是一个方法定义,它属于某个类的一部分。这个方法叫做create,它接受一个数据库会话对象db,以及要创建的对象的数据obj_in和创建者的ID creator_id作为参数。
在方法内部,首先根据obj_in中的菜单ID查询对应的菜单对象。然后将obj_in转换成可序列化的格式,并删除其中的菜单信息。接着,将创建者的ID添加到数据中,并使用这些数据创建一个新的角色对象。将查询到的菜单对象赋值给角色对象的role_menu属性。最后,将新的角色对象添加到数据库中,提交数据库会话的更改,并刷新对象以获取最新的数据库状态,最终返回创建的角色对象。