Нет описания
Вы не можете выбрать более 25 тем Темы должны начинаться с буквы или цифры, могут содержать дефисы(-) и должны содержать не более 35 символов.

create_tenant.go 2.4KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. package tenant
  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. // CreateTenant 创建租户
  14. func CreateTenant(req *configreq.TenantRequest, ctx context.Context, dbFactory *database.DBFactory, reqCtx *ctx.RequestContext) *response.QueryResult[int64] {
  15. logger.Debug("CreateTenant-开始创建租户")
  16. // 参数验证
  17. if req.TenantID == "" || req.Name == "" {
  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.CheckTenantExists(ctx, db, req.TenantID)
  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.TenantID))
  44. return util.CreateErrorResult[int64](fmt.Sprintf("租户ID '%s' 已存在", req.TenantID), reqCtx)
  45. }
  46. // 创建租户
  47. creator := reqCtx.UserID
  48. if creator == "" {
  49. creator = "system"
  50. }
  51. rowsAffected, err := dao.CreateTenant(ctx, tx, req.TenantID, req.Name, 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.TenantID, rowsAffected))
  63. return util.CreateSuccessResultData[int64](rowsAffected, reqCtx)
  64. }