package apis import ( "IotAdmin/common/global" "IotAdmin/core/sdk" "IotAdmin/core/sdk/pkg/jwt-auth/user" "fmt" "net/http" "IotAdmin/app/system/models" "github.com/gin-gonic/gin/binding" "IotAdmin/core/sdk/api" _ "IotAdmin/core/sdk/pkg/response" "github.com/gin-gonic/gin" "IotAdmin/app/system/service" "IotAdmin/app/system/service/dto" ) type SysRoleApi struct { api.Api } // GetPage // @Summary 角色列表数据 // @Description Get JSON // @Tags 角色 // @Param roleName query string false "roleName" // @Param status query string false "status" // @Param roleKey query string false "roleKey" // @Param pageSize query int false "页条数" // @Param pageIndex query int false "页码" // @Success 200 {object} response.Response "{"code": 200, "data": [...]}" // @Router /api/sys-role [get] // @Security Bearer func (e SysRoleApi) GetPage(c *gin.Context) { s := service.SysRoleService{} req := dto.SysRoleGetPageReq{} err := e.MakeContext(c). MakeOrm(). Bind(&req, binding.Form). MakeService(&s.Service). Errors if err != nil { e.Logger.Error(err) e.Error(500, err, err.Error()) return } list := make([]models.SysRole, 0) var count int64 err = s.GetPage(&req, &list, &count) if err != nil { e.Error(500, err, "查询失败") return } e.PageOK(list, int(count), req.GetPageIndex(), req.GetPageSize(), "查询成功") } // Get // @Summary 获取Role数据 // @Description 获取JSON // @Tags 角色 // @Param id path string false "id" // @Success 200 {object} response.Response "{"code": 200, "data": [...]}" // @Router /api/sys-role/{id} [get] // @Security Bearer func (e SysRoleApi) Get(c *gin.Context) { s := service.SysRoleService{} req := dto.SysRoleGetReq{} err := e.MakeContext(c). MakeOrm(). Bind(&req, nil). MakeService(&s.Service). Errors if err != nil { e.Logger.Error(err) e.Error(500, err, fmt.Sprintf(" %s ", err.Error())) return } var object models.SysRole err = s.Get(&req, &object) if err != nil { e.Error(http.StatusUnprocessableEntity, err, "查询失败") return } e.OK(object, "查询成功") } // Insert // @Summary 创建角色 // @Description 获取JSON // @Tags 角色 // @Accept application/json // @Product application/json // @Param data body dto.SysRoleInsertReq true "data" // @Success 200 {object} response.Response "{"code": 200, "data": [...]}" // @Router /api/sys-role [post] // @Security Bearer func (e SysRoleApi) Insert(c *gin.Context) { s := service.SysRoleService{} req := dto.SysRoleInsertReq{} err := e.MakeContext(c). MakeOrm(). Bind(&req, binding.JSON). MakeService(&s.Service). Errors if err != nil { e.Logger.Error(err) e.Error(500, err, err.Error()) return } // 设置创建人 req.CreateBy = user.GetUserId(c) if req.Status == "" { req.Status = "2" } cb := sdk.Runtime.GetCasbinKey(c.Request.Host) err = s.Insert(&req, cb) if err != nil { e.Logger.Error(err) e.Error(500, err, "创建失败,"+err.Error()) return } _, err = global.LoadPolicy(c) if err != nil { e.Logger.Error(err) e.Error(500, err, "创建失败,"+err.Error()) return } e.OK(req.GetId(), "创建成功") } // Update 修改用户角色 // @Summary 修改用户角色 // @Description 获取JSON // @Tags 角色 // @Accept application/json // @Product application/json // @Param data body dto.SysRoleUpdateReq true "body" // @Success 200 {object} response.Response "{"code": 200, "data": [...]}" // @Router /api/sys-role/{id} [put] // @Security Bearer func (e SysRoleApi) Update(c *gin.Context) { s := service.SysRoleService{} req := dto.SysRoleUpdateReq{} err := e.MakeContext(c). MakeOrm(). Bind(&req, nil, binding.JSON). MakeService(&s.Service). Errors if err != nil { e.Logger.Error(err) e.Error(500, err, err.Error()) return } cb := sdk.Runtime.GetCasbinKey(c.Request.Host) req.SetUpdateBy(user.GetUserId(c)) err = s.Update(&req, cb, user.GetRoleKey(c)) if err != nil { e.Logger.Error(err) return } _, err = global.LoadPolicy(c) if err != nil { e.Logger.Error(err) e.Error(500, err, "更新失败,"+err.Error()) return } e.OK(req.GetId(), "更新成功") } // Delete // @Summary 删除用户角色 // @Description 删除数据 // @Tags 角色 // @Param data body dto.SysRoleDeleteReq true "body" // @Success 200 {object} response.Response "{"code": 200, "data": [...]}" // @Router /api/sys-role [delete] // @Security Bearer func (e SysRoleApi) Delete(c *gin.Context) { s := new(service.SysRoleService) req := dto.SysRoleDeleteReq{} err := e.MakeContext(c). MakeOrm(). Bind(&req, binding.JSON). MakeService(&s.Service). Errors if err != nil { e.Logger.Error(err) e.Error(500, err, fmt.Sprintf("删除角色 %v 失败,\r\n失败信息 %s", req.Ids, err.Error())) return } cb := sdk.Runtime.GetCasbinKey(c.Request.Host) err = s.Remove(&req, cb, user.GetRoleKey(c)) if err != nil { e.Logger.Error(err) e.Error(500, err, "") return } e.OK(req.GetId(), fmt.Sprintf("删除角色角色 %v 状态成功!", req.GetId())) } // Update2Status 修改用户角色状态 // @Summary 修改用户角色 // @Description 获取JSON // @Tags 角色 // @Accept application/json // @Product application/json // @Param data body dto.UpdateStatusReq true "body" // @Success 200 {object} response.Response "{"code": 200, "data": [...]}" // @Router /api/sys-role/change-status [put] // @Security Bearer func (e SysRoleApi) Update2Status(c *gin.Context) { s := service.SysRoleService{} req := dto.UpdateStatusReq{} err := e.MakeContext(c). MakeOrm(). Bind(&req, binding.JSON, nil). MakeService(&s.Service). Errors if err != nil { e.Logger.Error(err) e.Error(500, err, fmt.Sprintf("更新角色状态失败,失败原因:%s ", err.Error())) return } req.SetUpdateBy(user.GetUserId(c)) err = s.UpdateStatus(&req) if err != nil { e.Error(500, err, fmt.Sprintf("更新角色状态失败,失败原因:%s ", err.Error())) return } e.OK(req.GetId(), fmt.Sprintf("更新角色 %v 状态成功!", req.GetId())) } // Update2DataScope 更新角色数据权限 // @Summary 更新角色数据权限 // @Description 获取JSON // @Tags 角色 // @Accept application/json // @Product application/json // @Param data body dto.RoleDataScopeReq true "body" // @Success 200 {object} response.Response "{"code": 200, "data": [...]}" // @Router /api/sys-role/data-scope [put] // @Security Bearer func (e SysRoleApi) Update2DataScope(c *gin.Context) { s := service.SysRoleService{} req := dto.RoleDataScopeReq{} err := e.MakeContext(c). MakeOrm(). Bind(&req, binding.JSON, nil). MakeService(&s.Service). Errors if err != nil { e.Logger.Error(err) e.Error(500, err, err.Error()) return } data := &models.SysRole{ RoleId: req.RoleId, DataScope: req.DataScope, OrgIds: req.OrgIds, } data.UpdateBy = user.GetUserId(c) err = s.UpdateDataScope(&req).Error if err != nil { e.Error(500, err, fmt.Sprintf("更新角色数据权限失败!错误详情:%s", err.Error())) return } e.OK(nil, "操作成功") }