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

aiStorage.go 1.8 kB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. package database
  2. import (
  3. "github.com/zeromicro/go-zero/core/logx"
  4. "gitlink.org.cn/JointCloud/pcm-coordinator/api/internal/types"
  5. "gitlink.org.cn/JointCloud/pcm-coordinator/pkg/constants"
  6. "gitlink.org.cn/JointCloud/pcm-coordinator/pkg/models"
  7. "gorm.io/gorm"
  8. "time"
  9. )
  10. type AiStorage struct {
  11. DbEngin *gorm.DB
  12. }
  13. func (s *AiStorage) GetParticipants() (*types.ClusterListResp, error) {
  14. var resp types.ClusterListResp
  15. tx := s.DbEngin.Raw("select * from t_cluster where `deleted_at` IS NULL ORDER BY create_time Desc").Scan(&resp.List)
  16. if tx.Error != nil {
  17. logx.Errorf(tx.Error.Error())
  18. return nil, tx.Error
  19. }
  20. return &resp, nil
  21. }
  22. func (s *AiStorage) GetClustersByAdapterId(id string) (*types.ClusterListResp, error) {
  23. var resp types.ClusterListResp
  24. tx := s.DbEngin.Raw("select * from t_cluster where `deleted_at` IS NULL and `adapter_id` = ? ORDER BY create_time Desc", id).Scan(&resp.List)
  25. if tx.Error != nil {
  26. logx.Errorf(tx.Error.Error())
  27. return nil, tx.Error
  28. }
  29. return &resp, nil
  30. }
  31. func (s *AiStorage) GetAdapterIdsByType(adapterType string) ([]string, error) {
  32. var list []types.AdapterInfo
  33. var ids []string
  34. db := s.DbEngin.Model(&types.AdapterInfo{}).Table("t_adapter")
  35. db = db.Where("type = ?", adapterType)
  36. err := db.Order("create_time desc").Find(&list).Error
  37. if err != nil {
  38. return nil, err
  39. }
  40. for _, info := range list {
  41. ids = append(ids, info.Id)
  42. }
  43. return ids, nil
  44. }
  45. func (s *AiStorage) SaveTask(name string) error {
  46. // 构建主任务结构体
  47. taskModel := models.Task{
  48. Status: constants.Saved,
  49. Description: "ai task",
  50. Name: name,
  51. CommitTime: time.Now(),
  52. }
  53. // 保存任务数据到数据库
  54. tx := s.DbEngin.Create(&taskModel)
  55. if tx.Error != nil {
  56. return tx.Error
  57. }
  58. return nil
  59. }
  60. func (s *AiStorage) UpdateTask() error {
  61. return nil
  62. }

PCM is positioned as Software stack over Cloud, aiming to build the standards and ecology of heterogeneous cloud collaboration for JCC in a non intrusive and autonomous peer-to-peer manner.