Açıklama Yok
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

create_project_skill.go 2.5KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. package skill
  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. // CreateProjectSkill 创建项目Skill
  14. func CreateProjectSkill(req *configreq.ProjectSkillRequest, ctx context.Context, dbFactory *database.DBFactory, reqCtx *ctx.RequestContext) *response.QueryResult[int64] {
  15. logger.Debug("CreateProjectSkill-开始创建项目Skill")
  16. // 参数验证
  17. if req.SkillID == "" || req.ProjectID == "" || req.Description == "" || req.Content == "" {
  18. logger.ErrorC(reqCtx, "项目Skill参数不能为空")
  19. return util.CreateErrorResult[int64]("项目Skill参数不能为空", 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. // 检查SkillID是否已存在
  35. exists, err := dao.CheckProjectSkillExists(ctx, db, req.SkillID)
  36. if err != nil {
  37. tx.Rollback()
  38. logger.ErrorC(reqCtx, fmt.Sprintf("检查项目Skill存在性失败: %v", err))
  39. return util.CreateErrorResult[int64](fmt.Sprintf("检查项目Skill存在性失败: %v", err), reqCtx)
  40. }
  41. if exists {
  42. tx.Rollback()
  43. logger.ErrorC(reqCtx, fmt.Sprintf("SkillID '%s' 已存在", req.SkillID))
  44. return util.CreateErrorResult[int64](fmt.Sprintf("SkillID '%s' 已存在", req.SkillID), reqCtx)
  45. }
  46. // 创建项目Skill
  47. creator := reqCtx.UserID
  48. if creator == "" {
  49. creator = "system"
  50. }
  51. rowsAffected, err := dao.CreateProjectSkill(ctx, tx, req.SkillID, req.ProjectID, req.Description, req.Content, creator)
  52. if err != nil {
  53. tx.Rollback()
  54. logger.ErrorC(reqCtx, fmt.Sprintf("创建项目Skill失败: %v", err))
  55. return util.CreateErrorResult[int64](fmt.Sprintf("创建项目Skill失败: %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("成功创建项目Skill: %s, 影响行数: %d", req.SkillID, rowsAffected))
  63. return util.CreateSuccessResultData[int64](rowsAffected, reqCtx)
  64. }