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.

createalgorithmlogic.go 1.9 kB

4 months ago
4 months ago
4 months ago
4 months ago
12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  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. "errors"
  16. "github.com/go-resty/resty/v2"
  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. algorithm "gitlink.org.cn/JointCloud/pcm-coordinator/internal/types/ai"
  21. )
  22. type CreateAlgorithmLogic struct {
  23. logx.Logger
  24. ctx context.Context
  25. svcCtx *svc.ServiceContext
  26. }
  27. func NewCreateAlgorithmLogic(ctx context.Context, svcCtx *svc.ServiceContext) *CreateAlgorithmLogic {
  28. return &CreateAlgorithmLogic{
  29. Logger: logx.WithContext(ctx),
  30. ctx: ctx,
  31. svcCtx: svcCtx,
  32. }
  33. }
  34. func (l *CreateAlgorithmLogic) CreateAlgorithm(req *algorithm.CreateAlgorithmReq) (resp *algorithm.CreateAlgorithmResp, 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. createAlgorithmResp := &algorithm.CreateAlgorithmResp{}
  43. _, err = httpClient.SetHeader("Content-Type", "application/json").
  44. SetQueryParams(map[string]string{"pfId": cluster.ClusterInfo.Id}).
  45. SetBody(req).
  46. SetResult(&createAlgorithmResp).
  47. Post(cluster.ClusterInfo.Server + "/ai/algorithm/create")
  48. return createAlgorithmResp, 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.