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.

createdatasetlogic.go 1.9 kB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. /*
  2. Copyright (c) [2023] [pcm]
  3. [pcm-coordinator] is licensed under Mulan PSL v2.
  4. You can use this software according to the terms and conditions of the Mulan PSL v2.
  5. You may obtain a copy of Mulan PSL v2 at:
  6. http://license.coscl.org.cn/MulanPSL2
  7. THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND,
  8. EITHER EXPaRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT,
  9. MERCHANTABILITY OR FIT FOR A PARTICULAR PURPOSE.
  10. See the Mulan PSL v2 for more details.
  11. */
  12. package ai
  13. import (
  14. "context"
  15. "github.com/go-resty/resty/v2"
  16. "github.com/pkg/errors"
  17. "github.com/zeromicro/go-zero/core/logx"
  18. "gitlink.org.cn/JointCloud/pcm-coordinator/internal/svc"
  19. "gitlink.org.cn/JointCloud/pcm-coordinator/internal/types"
  20. dataset "gitlink.org.cn/JointCloud/pcm-coordinator/internal/types/ai"
  21. )
  22. type CreateDataSetLogic struct {
  23. logx.Logger
  24. ctx context.Context
  25. svcCtx *svc.ServiceContext
  26. }
  27. func NewCreateDataSetLogic(ctx context.Context, svcCtx *svc.ServiceContext) *CreateDataSetLogic {
  28. return &CreateDataSetLogic{
  29. Logger: logx.WithContext(ctx),
  30. ctx: ctx,
  31. svcCtx: svcCtx,
  32. }
  33. }
  34. func (l *CreateDataSetLogic) CreateDataSet(req *dataset.CreateDatasetReq) (resp *dataset.CreateDatasetResp, err error) {
  35. cluster := &types.GetClusterByIdResp{}
  36. tx := l.svcCtx.DbEngin.Raw("select * from t_cluster where id = ?", req.ClusterId).Scan(&cluster.ClusterInfo)
  37. if tx.Error != nil {
  38. logx.Errorf(tx.Error.Error())
  39. return nil, errors.New("cluster create failed")
  40. }
  41. httpClient := resty.New().R()
  42. createDatasetResp := &dataset.CreateDatasetResp{}
  43. _, err = httpClient.SetHeader("Content-Type", "application/json").
  44. SetQueryParams(map[string]string{"pfId": cluster.ClusterInfo.Id}).
  45. SetBody(req).
  46. SetResult(&createDatasetResp).
  47. Post(cluster.ClusterInfo.Server + "/ai/dataset/create")
  48. return createDatasetResp, err
  49. }

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.