Без опису
Ви не можете вибрати більше 25 тем Теми мають розпочинатися з літери або цифри, можуть містити дефіси (-) і не повинні перевищувати 35 символів.

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. package role
  2. import (
  3. "context"
  4. "fmt"
  5. "git.x2erp.com/qdy/go-base/ctx"
  6. "git.x2erp.com/qdy/go-base/logger"
  7. "git.x2erp.com/qdy/go-base/model/request/configreq"
  8. "git.x2erp.com/qdy/go-base/model/response"
  9. "git.x2erp.com/qdy/go-base/util"
  10. "git.x2erp.com/qdy/go-db/factory/database"
  11. "git.x2erp.com/qdy/go-svc-configure/internal/service/dao"
  12. )
  13. // UpdateRole 更新角色信息
  14. func UpdateRole(roleID string, req *configreq.RoleRequest, ctx context.Context, dbFactory *database.DBFactory, reqCtx *ctx.RequestContext) *response.QueryResult[int64] {
  15. logger.Debug("UpdateRole-开始更新角色")
  16. // 参数验证
  17. if req.Name == "" || req.Description == "" {
  18. logger.ErrorC(reqCtx, "角色名称和描述不能为空")
  19. return util.CreateErrorResult[int64]("角色名称和描述不能为空", reqCtx)
  20. }
  21. // 获取数据库连接并开始事务
  22. db := dbFactory.GetDB()
  23. tx, err := db.BeginTxx(ctx, nil)
  24. if err != nil {
  25. logger.ErrorC(reqCtx, fmt.Sprintf("开始事务失败: %v", err))
  26. return util.CreateErrorResult[int64](fmt.Sprintf("开始事务失败: %v", err), reqCtx)
  27. }
  28. defer func() {
  29. if p := recover(); p != nil {
  30. tx.Rollback()
  31. panic(p)
  32. }
  33. }()
  34. // 检查角色是否存在
  35. exists, err := dao.CheckRoleExists(ctx, db, roleID)
  36. if err != nil {
  37. tx.Rollback()
  38. logger.ErrorC(reqCtx, fmt.Sprintf("检查角色存在性失败: %v", err))
  39. return util.CreateErrorResult[int64](fmt.Sprintf("检查角色存在性失败: %v", err), reqCtx)
  40. }
  41. if !exists {
  42. tx.Rollback()
  43. logger.ErrorC(reqCtx, fmt.Sprintf("角色ID '%s' 不存在", roleID))
  44. return util.CreateErrorResult[int64](fmt.Sprintf("角色ID '%s' 不存在", roleID), reqCtx)
  45. }
  46. // 更新角色信息
  47. rowsAffected, err := dao.UpdateRole(ctx, tx, roleID, req.Name, req.Description)
  48. if err != nil {
  49. tx.Rollback()
  50. logger.ErrorC(reqCtx, fmt.Sprintf("更新角色失败: %v", err))
  51. return util.CreateErrorResult[int64](fmt.Sprintf("更新角色失败: %v", err), reqCtx)
  52. }
  53. // 提交事务
  54. if err := tx.Commit(); err != nil {
  55. logger.ErrorC(reqCtx, fmt.Sprintf("提交事务失败: %v", err))
  56. return util.CreateErrorResult[int64](fmt.Sprintf("提交事务失败: %v", err), reqCtx)
  57. }
  58. logger.Debug(fmt.Sprintf("成功更新角色: %s, 影响行数: %d", roleID, rowsAffected))
  59. return util.CreateSuccessResultData[int64](rowsAffected, reqCtx)
  60. }