Нема описа
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.

update_project.go 2.3KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. package project
  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. // UpdateProject 更新项目信息
  14. func UpdateProject(projectID string, req *configreq.ProjectRequest, ctx context.Context, dbFactory *database.DBFactory, reqCtx *ctx.RequestContext) *response.QueryResult[int64] {
  15. logger.Debug("UpdateProject-开始更新项目")
  16. // 参数验证
  17. if req.Description == "" || req.McpURL == "" {
  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.CheckProjectExists(ctx, db, projectID)
  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' 不存在", projectID))
  44. return util.CreateErrorResult[int64](fmt.Sprintf("项目ID '%s' 不存在", projectID), reqCtx)
  45. }
  46. // 更新项目信息
  47. rowsAffected, err := dao.UpdateProject(ctx, tx, projectID, req.Description, req.McpURL)
  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", projectID, rowsAffected))
  59. return util.CreateSuccessResultData[int64](rowsAffected, reqCtx)
  60. }