|
- package participant
-
- import (
- "errors"
- "fmt"
- "github.com/go-resty/resty/v2"
- "gitlink.org.cn/JointCloud/pcm-coordinator/internal/scheduler/database"
- "net/http"
- "sync"
- )
-
- const (
- // 算法路由
- AlgorithmById = "/ai/algorithm/get" //根据Id查询算法列表
- AlgorithmsList = "/ai/algorithm/list" //所有算法列表
- AlgorithmCreateById = "/ai/algorithm/create" //根据Id创建算法
-
- // 数据集路由
- DatasetCreateById = "/ai/dataset/create" //根据Id创建数据集
-
- // 模型相关路由
- ModelCreateById = "/ai/model/create" //根据Id创建模型
-
- // 资源相关路由
- ResourceSpecList = "/ai/resource/specs" //所有资源列表,根据参数 train or infer 查询资源
- ResourceTrainingById = "/ai/resource/train/get" //根据Id查询资源列表
- ResourceTrainingList = "/ai/resource/train/list" //所有训练资源列表
-
- // 任务相关路由
- TaskCreateTrain = "/ai/task/train"
- TaskResultSync = "/ai/task/sync"
- TaskLog = "/ai/task/log"
- TaskTrainingDetail = "/ai/task/train/detail"
- TaskInferenceDetail = "/ai/task/infer/detail"
- )
-
- type Ai struct {
- store *database.AiStorage
- idAddr sync.Map
- }
-
- func New(store *database.AiStorage, adapterId string) (*Ai, error) {
- if store == nil {
- return nil, errors.New("store cannot be nil")
- }
-
- a := &Ai{
- store: store,
- }
-
- css, err := store.GetClustersByAdapterId(adapterId)
- if err != nil {
- return nil, fmt.Errorf("failed to get clusters: %w", err)
- }
-
- for _, info := range css.List {
- a.idAddr.Store(info.Id, info.Server)
- }
-
- InitClient()
- return a, nil
- }
-
- func (a *Ai) UpdateAddr(id string, addr string) {
- a.idAddr.Store(id, addr)
- }
-
- func (a *Ai) GetServerAddrById(id string) (string, bool) {
- val, ok := a.idAddr.Load(id)
- if !ok {
- return "", false
- }
- addr, ok := val.(string)
- if !ok {
- return "", false
- }
- return addr, true
- }
-
- func (a *Ai) AlgorithmById(platformId string) (resp *Resp, err error) {
- addr, ok := a.GetServerAddrById(platformId)
- if !ok {
- return nil, fmt.Errorf("clusterId not found: %s", platformId)
- }
- respErr := &RespErr{}
- _, err = Request(addr+AlgorithmById, http.MethodGet, func(req *resty.Request) {
- req.SetQueryParams(map[string]string{
- "pfId": platformId,
- }).SetError(&respErr).SetResult(&resp)
- })
- if err != nil {
- return nil, err
- }
- return
- }
-
- func (a *Ai) AlgorithmCreateById(platformId string, param *CreateParam) (resp *Resp, err error) {
- addr, ok := a.GetServerAddrById(platformId)
- if !ok {
- return nil, fmt.Errorf("clusterId not found: %s", platformId)
- }
- respErr := &RespErr{}
- _, err = Request(addr+AlgorithmCreateById, http.MethodPost, func(req *resty.Request) {
- req.SetQueryParams(map[string]string{
- "pfId": platformId,
- }).SetBody(param).SetError(&respErr).SetResult(&resp)
- })
- if err != nil {
- return nil, err
- }
- return
- }
-
- func (a *Ai) DatasetCreateById(platformId string, param *CreateParam) (resp *Resp, err error) {
- addr, ok := a.GetServerAddrById(platformId)
- if !ok {
- return nil, fmt.Errorf("clusterId not found: %s", platformId)
- }
- respErr := &RespErr{}
- _, err = Request(addr+DatasetCreateById, http.MethodPost, func(req *resty.Request) {
- req.SetQueryParams(map[string]string{
- "pfId": platformId,
- }).SetBody(param).SetError(&respErr).SetResult(&resp)
- })
- if err != nil {
- return nil, err
- }
- return
- }
-
- func (a *Ai) ModelCreateById(platformId string, param *CreateParam) (resp *Resp, err error) {
- addr, ok := a.GetServerAddrById(platformId)
- if !ok {
- return nil, fmt.Errorf("clusterId not found: %s", platformId)
- }
- respErr := &RespErr{}
- _, err = Request(addr+ModelCreateById, http.MethodPost, func(req *resty.Request) {
- req.SetQueryParams(map[string]string{
- "pfId": platformId,
- }).SetBody(param).SetError(&respErr).SetResult(&resp)
- })
- if err != nil {
- return nil, err
- }
- return
- }
-
- func (a *Ai) TaskCreateTrain(platformId string, param *TaskCreateParam) (resp *Resp, err error) {
- addr, ok := a.GetServerAddrById(platformId)
- if !ok {
- return nil, fmt.Errorf("clusterId not found: %s", platformId)
- }
- respErr := &RespErr{}
- _, err = Request(addr+TaskCreateTrain, http.MethodPost, func(req *resty.Request) {
- req.SetQueryParams(map[string]string{
- "pfId": platformId,
- }).SetBody(param).SetError(&respErr).SetResult(&resp)
- })
- if err != nil {
- return nil, err
- }
- return
- }
-
- func (a *Ai) TaskResultSync(platformId string, param *TaskResultSyncParam) (resp *Resp, err error) {
- addr, ok := a.GetServerAddrById(platformId)
- if !ok {
- return nil, fmt.Errorf("clusterId not found: %s", platformId)
- }
- respErr := &RespErr{}
- _, err = Request(addr+TaskResultSync, http.MethodPost, func(req *resty.Request) {
- req.SetQueryParams(map[string]string{
- "pfId": platformId,
- }).SetBody(param).SetError(&respErr).SetResult(&resp)
- })
- if err != nil {
- return nil, err
- }
- return
- }
-
- func (a *Ai) TaskLog(platformId string, taskId string) (resp *Resp, err error) {
- addr, ok := a.GetServerAddrById(platformId)
- if !ok {
- return nil, fmt.Errorf("clusterId not found: %s", platformId)
- }
- respErr := &RespErr{}
- _, err = Request(addr+TaskLog, http.MethodGet, func(req *resty.Request) {
- req.SetQueryParams(map[string]string{
- "pfId": platformId,
- "taskId": taskId,
- }).SetError(&respErr).SetResult(&resp)
- })
- if err != nil {
- return nil, err
- }
- return
- }
-
- func (a *Ai) TaskTrainingDetail(platformId string, taskId string) (resp *Resp, err error) {
- addr, ok := a.GetServerAddrById(platformId)
- if !ok {
- return nil, fmt.Errorf("clusterId not found: %s", platformId)
- }
- respErr := &RespErr{}
- _, err = Request(addr+TaskTrainingDetail, http.MethodGet, func(req *resty.Request) {
- req.SetQueryParams(map[string]string{
- "pfId": platformId,
- "taskId": taskId,
- }).SetError(&respErr).SetResult(&resp)
- })
- if err != nil {
- return nil, err
- }
- return
- }
-
- func (a *Ai) TaskInferenceDetail(platformId string, taskId string) (resp *Resp, err error) {
- addr, ok := a.GetServerAddrById(platformId)
- if !ok {
- return nil, fmt.Errorf("clusterId not found: %s", platformId)
- }
- respErr := &RespErr{}
- _, err = Request(addr+TaskInferenceDetail, http.MethodGet, func(req *resty.Request) {
- req.SetQueryParams(map[string]string{
- "pfId": platformId,
- "taskId": taskId,
- }).SetError(&respErr).SetResult(&resp)
- })
- if err != nil {
- return nil, err
- }
- return
- }
|