|
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314 |
- package sch
-
- import (
- "fmt"
- schsdk "gitlink.org.cn/cloudream/common/sdks/scheduler"
- cdssdk "gitlink.org.cn/cloudream/common/sdks/storage"
- "gitlink.org.cn/cloudream/common/utils/http2"
- "gitlink.org.cn/cloudream/common/utils/serder"
- "net/url"
- "strings"
- )
-
- type GetClusterInfoReq struct {
- IDs []schsdk.ClusterID `json:"clusterIDs"`
- }
-
- func (c *Client) GetClusterInfo(req GetClusterInfoReq, token string) ([]ClusterDetail, error) {
- targetUrl, err := url.JoinPath(c.baseURL, "schedule/queryResources")
- if err != nil {
- return nil, err
- }
-
- resp, err := http2.PostJSON(targetUrl, http2.RequestParam{
- Header: map[string]string{
- "Authorization": token,
- },
- })
- if err != nil {
- return nil, err
- }
-
- contType := resp.Header.Get("Content-Type")
- if strings.Contains(contType, http2.ContentTypeJSON) {
-
- var codeResp response[[]ClusterDetail]
- if err := serder.JSONToObjectStream(resp.Body, &codeResp); err != nil {
- return nil, fmt.Errorf("parsing response: %w", err)
- }
-
- // 该接口传入参数后查询效率很低,所以需要在这里特殊处理
- if codeResp.Code == ResponseCodeOK {
- var results []ClusterDetail
- for _, cluster := range codeResp.Data {
- for _, id := range req.IDs {
- if cluster.ClusterId == id {
- results = append(results, cluster)
- }
- }
- }
- return results, nil
- }
-
- return nil, codeResp.ToError()
- }
-
- return nil, fmt.Errorf("unknow response content type: %s", contType)
- }
-
- type CreateInferenceJobResp struct {
- TaskId string `json:"taskId"`
- }
-
- type CreateAIJobReq struct {
- Name string `json:"name"`
- Description string `json:"description"`
- JobResources schsdk.JobResources `json:"jobResources"`
- DataDistributes DataDistribute `json:"dataDistributes"`
- }
-
- type CommonJsonData struct {
- ID string `json:"id"`
- Name string `json:"name"`
- }
-
- type DataDistribute struct {
- Dataset []DatasetDistribute `json:"dataset"`
- Code []CodeDistribute `json:"code"`
- Image []ImageDistribute `json:"image"`
- Model []ModelDistribute `json:"model"`
- }
-
- type DataDetail struct {
- ClusterID schsdk.ClusterID `json:"clusterID"`
- //StorageID cdssdk.StorageID `json:"storageID"`
- StorageID cdssdk.StorageID
- JsonData string `json:"jsonData"`
- }
-
- type DatasetDistribute struct {
- DataName string `json:"dataName"`
- PackageID cdssdk.PackageID `json:"packageID"`
- Clusters []DataDetail `json:"clusters"`
- }
-
- type CodeDistribute struct {
- DataName string `json:"dataName"`
- PackageID cdssdk.PackageID `json:"packageID"`
- Output string `json:"output"`
- Clusters []DataDetail `json:"clusters"`
- }
-
- type ImageDistribute struct {
- DataName string `json:"dataName"`
- //PackageID cdssdk.PackageID `json:"packageID"`
- ImageID schsdk.ImageID `json:"packageID"`
- Clusters []DataDetail `json:"clusters"`
- }
-
- type ModelDistribute struct {
- DataName string `json:"dataName"`
- PackageID cdssdk.PackageID `json:"packageID"`
- Clusters []DataDetail `json:"clusters"`
- }
-
- type CreateJobResp struct {
- TaskID TaskID `json:"taskID"`
- TaskName string `json:"taskName"`
- ScheduleDatas []ScheduleData `json:"scheduleDatas"`
- }
-
- type ScheduleData struct {
- DataType string `json:"dataType"`
- PackageID cdssdk.PackageID `json:"packageID"`
- StorageType string `json:"storageType"`
- ClusterIDs []schsdk.ClusterID `json:"clusterIDs"`
- }
-
- func (c *Client) CreateInferenceJob(req CreateAIJobReq, token string) (*CreateInferenceJobResp, error) {
- targetUrl, err := url.JoinPath(c.baseURL, "inference/createTask")
- if err != nil {
- return nil, err
- }
-
- resp, err := http2.PostJSON(targetUrl, http2.RequestParam{
- Body: req,
- Header: map[string]string{
- "Authorization": token,
- },
- })
- if err != nil {
- return nil, err
- }
-
- contType := resp.Header.Get("Content-Type")
- if strings.Contains(contType, http2.ContentTypeJSON) {
- var codeResp respons2[CreateInferenceJobResp]
- if err := serder.JSONToObjectStream(resp.Body, &codeResp); err != nil {
- return nil, fmt.Errorf("parsing response: %w", err)
- }
-
- if codeResp.Code == ResponseCodeOK {
- return &codeResp.Data, nil
- }
-
- return nil, fmt.Errorf("error: %s", codeResp.Message)
- }
-
- return nil, fmt.Errorf("unknow response content type: %s", contType)
- }
-
- type StopInferenceJobReq struct {
- TaskId string `json:"taskId"`
- }
-
- func (c *Client) StopInferenceJob(req StopInferenceJobReq, token string) error {
- targetUrl, err := url.JoinPath(c.baseURL, "inference/createTask")
- if err != nil {
- return err
- }
-
- resp, err := http2.PostJSON(targetUrl, http2.RequestParam{
- Body: req,
- Header: map[string]string{
- "Authorization": token,
- },
- })
- if err != nil {
- return err
- }
-
- contType := resp.Header.Get("Content-Type")
- if strings.Contains(contType, http2.ContentTypeJSON) {
- var codeResp respons2[CreateInferenceJobResp]
- if err := serder.JSONToObjectStream(resp.Body, &codeResp); err != nil {
- return fmt.Errorf("parsing response: %w", err)
- }
-
- if codeResp.Code == ResponseCodeOK {
- return nil
- }
-
- return fmt.Errorf("error: %s", codeResp.Message)
- }
-
- return fmt.Errorf("unknow response content type: %s", contType)
- }
-
- func (c *Client) CreateJob(req CreateAIJobReq, token string) (*CreateJobResp, error) {
- targetUrl, err := url.JoinPath(c.baseURL, "schedule/createTask")
- if err != nil {
- return nil, err
- }
-
- resp, err := http2.PostJSON(targetUrl, http2.RequestParam{
- Body: req,
- Header: map[string]string{
- "Authorization": token,
- },
- })
- if err != nil {
- return nil, err
- }
-
- contType := resp.Header.Get("Content-Type")
- if strings.Contains(contType, http2.ContentTypeJSON) {
- var codeResp respons2[CreateJobResp]
- if err := serder.JSONToObjectStream(resp.Body, &codeResp); err != nil {
- return nil, fmt.Errorf("parsing response: %w", err)
- }
-
- if codeResp.Code == ResponseCodeOK {
- return &codeResp.Data, nil
- }
-
- return nil, fmt.Errorf("error: %s", codeResp.Message)
- }
-
- return nil, fmt.Errorf("unknow response content type: %s", contType)
-
- }
-
- type RunJobReq struct {
- TaskID TaskID `json:"taskID"`
- ScheduledDatas []DataScheduleResults `json:"scheduledDatas"`
- }
-
- type DataScheduleResult struct {
- Clusters []DataDetail `json:"clusters"`
- PackageID cdssdk.PackageID `json:"packageID"`
- PackageFullPath string `json:"packageFullPath"`
- Status bool `json:"status"`
- Msg string `json:"msg"`
- }
-
- type DataScheduleResults struct {
- DataType string `json:"dataType"`
- Results []DataScheduleResult `json:"results"`
- }
-
- func (c *Client) RunJob(req RunJobReq, token string) error {
- targetUrl, err := url.JoinPath(c.baseURL, "schedule/runTask")
- if err != nil {
- return err
- }
-
- resp, err := http2.PostJSON(targetUrl, http2.RequestParam{
- Body: req,
- Header: map[string]string{
- "Authorization": token,
- },
- })
- if err != nil {
- return err
- }
-
- contType := resp.Header.Get("Content-Type")
- if strings.Contains(contType, http2.ContentTypeJSON) {
- var codeResp respons2[string]
- if err := serder.JSONToObjectStream(resp.Body, &codeResp); err != nil {
- return fmt.Errorf("parsing response: %w", err)
- }
-
- if codeResp.Code == ResponseCodeOK {
- return nil
- }
-
- return fmt.Errorf("error: %s", codeResp.Message)
- }
-
- return fmt.Errorf("unknow response content type: %s", contType)
-
- }
-
- type CancelJobReq struct {
- TaskID TaskID `json:"taskID"`
- Msg string `json:"msg"`
- }
-
- func (c *Client) CancelJob(req CancelJobReq) error {
- targetUrl, err := url.JoinPath(c.baseURL, "schedule/queryResources")
- if err != nil {
- return err
- }
- resp, err := http2.GetJSON(targetUrl, http2.RequestParam{Body: req})
- if err != nil {
- return err
- }
- contType := resp.Header.Get("Content-Type")
- if strings.Contains(contType, http2.ContentTypeJSON) {
-
- var codeResp response[string]
- if err := serder.JSONToObjectStream(resp.Body, &codeResp); err != nil {
- return fmt.Errorf("parsing response: %w", err)
- }
-
- if codeResp.Code == ResponseCodeOK {
- return nil
- }
-
- return codeResp.ToError()
- }
-
- return fmt.Errorf("unknow response content type: %s", contType)
- }
|