Nav apraksta
Nevar pievienot vairāk kā 25 tēmas Tēmai ir jāsākas ar burtu vai ciparu, tā var saturēt domu zīmes ('-') un var būt līdz 35 simboliem gara.

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  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. // CreateRole 创建角色
  14. func CreateRole(req *configreq.RoleRequest, ctx context.Context, dbFactory *database.DBFactory, reqCtx *ctx.RequestContext) *response.QueryResult[int64] {
  15. logger.Debug("CreateRole-开始创建角色")
  16. // 参数验证
  17. if req.RoleID == "" || 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. // 检查角色ID是否已存在
  35. exists, err := dao.CheckRoleExists(ctx, db, req.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' 已存在", req.RoleID))
  44. return util.CreateErrorResult[int64](fmt.Sprintf("角色ID '%s' 已存在", req.RoleID), reqCtx)
  45. }
  46. // 创建角色
  47. creator := reqCtx.UserID
  48. if creator == "" {
  49. creator = "system"
  50. }
  51. rowsAffected, err := dao.CreateRole(ctx, tx, req.RoleID, req.Name, req.Description, creator)
  52. if err != nil {
  53. tx.Rollback()
  54. logger.ErrorC(reqCtx, fmt.Sprintf("创建角色失败: %v", err))
  55. return util.CreateErrorResult[int64](fmt.Sprintf("创建角色失败: %v", err), reqCtx)
  56. }
  57. // 提交事务
  58. if err := tx.Commit(); err != nil {
  59. logger.ErrorC(reqCtx, fmt.Sprintf("提交事务失败: %v", err))
  60. return util.CreateErrorResult[int64](fmt.Sprintf("提交事务失败: %v", err), reqCtx)
  61. }
  62. logger.Debug(fmt.Sprintf("成功创建角色: %s, 影响行数: %d", req.RoleID, rowsAffected))
  63. return util.CreateSuccessResultData[int64](rowsAffected, reqCtx)
  64. }