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.

resty.go 9.3 kB

4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
4 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373
  1. package modelarts
  2. import (
  3. "code.gitea.io/gitea/modules/log"
  4. "crypto/tls"
  5. "encoding/json"
  6. "fmt"
  7. "net/http"
  8. "code.gitea.io/gitea/models"
  9. "code.gitea.io/gitea/modules/setting"
  10. "github.com/go-resty/resty/v2"
  11. )
  12. var (
  13. restyClient *resty.Client
  14. HOST string
  15. TOKEN string
  16. )
  17. const (
  18. methodPassword = "password"
  19. urlGetToken = "/v3/auth/tokens"
  20. urlNotebook = "/demanager/instances"
  21. urlTrainJob = "/training-jobs"
  22. urlResourceSpecs = "/job/resource-specs"
  23. errorCodeExceedLimit = "ModelArts.0118"
  24. )
  25. func getRestyClient() *resty.Client {
  26. if restyClient == nil {
  27. restyClient = resty.New()
  28. restyClient.SetTLSClientConfig(&tls.Config{InsecureSkipVerify: true})
  29. }
  30. return restyClient
  31. }
  32. func checkSetting() {
  33. if len(HOST) != 0 && len(TOKEN) != 0 && restyClient != nil {
  34. return
  35. }
  36. err := getToken()
  37. if err != nil {
  38. log.Error("getToken failed:%v", err)
  39. }
  40. }
  41. func getToken() error {
  42. HOST = setting.ModelArtsHost
  43. client := getRestyClient()
  44. params := models.GetTokenParams{
  45. Auth: models.Auth{
  46. Identity: models.Identity{
  47. Methods: []string{methodPassword},
  48. Password: models.Password{
  49. User: models.NotebookUser{
  50. Name: setting.ModelArtsUsername,
  51. Password: setting.ModelArtsPassword,
  52. Domain: models.Domain{
  53. Name: setting.ModelArtsDomain,
  54. },
  55. },
  56. },
  57. },
  58. Scope: models.Scope{
  59. Project: models.Project{
  60. Name: setting.ProjectName,
  61. },
  62. },
  63. },
  64. }
  65. res, err := client.R().
  66. SetHeader("Content-Type", "application/json").
  67. SetBody(params).
  68. Post(setting.IamHost + urlGetToken)
  69. if err != nil {
  70. return fmt.Errorf("resty getToken: %v", err)
  71. }
  72. if res.StatusCode() != http.StatusCreated {
  73. return fmt.Errorf("getToken failed:%s", res.String())
  74. }
  75. TOKEN = res.Header().Get("X-Subject-Token")
  76. log.Info(TOKEN)
  77. return nil
  78. }
  79. func createNotebook(createJobParams models.CreateNotebookParams) (*models.CreateNotebookResult, error) {
  80. checkSetting()
  81. client := getRestyClient()
  82. var result models.CreateNotebookResult
  83. retry := 0
  84. sendjob:
  85. res, err := client.R().
  86. SetHeader("Content-Type", "application/json").
  87. SetAuthToken(TOKEN).
  88. SetBody(createJobParams).
  89. SetResult(&result).
  90. Post(HOST + "/v1/" + setting.ProjectID + urlNotebook)
  91. if err != nil {
  92. return nil, fmt.Errorf("resty create notebook: %s", err)
  93. }
  94. if res.StatusCode() == http.StatusUnauthorized && retry < 1 {
  95. retry++
  96. _ = getToken()
  97. goto sendjob
  98. }
  99. var response models.NotebookResult
  100. err = json.Unmarshal(res.Body(), &response)
  101. if err != nil {
  102. log.Error("json.Unmarshal failed: %s", err.Error())
  103. return &result, fmt.Errorf("son.Unmarshal failed: %s", err.Error())
  104. }
  105. if len(response.ErrorCode) != 0 {
  106. log.Error("createNotebook failed(%s): %s", response.ErrorCode, response.ErrorMsg)
  107. if response.ErrorCode == errorCodeExceedLimit {
  108. response.ErrorMsg = "所选规格使用数量已超过最大配额限制。"
  109. }
  110. return &result, fmt.Errorf("createNotebook failed(%s): %s", response.ErrorCode, response.ErrorMsg)
  111. }
  112. return &result, nil
  113. }
  114. func GetJob(jobID string) (*models.GetNotebookResult, error) {
  115. checkSetting()
  116. client := getRestyClient()
  117. var result models.GetNotebookResult
  118. retry := 0
  119. sendjob:
  120. res, err := client.R().
  121. SetHeader("Content-Type", "application/json").
  122. SetAuthToken(TOKEN).
  123. SetResult(&result).
  124. Get(HOST + "/v1/" + setting.ProjectID + urlNotebook + "/" + jobID)
  125. if err != nil {
  126. return nil, fmt.Errorf("resty GetJob: %v", err)
  127. }
  128. if res.StatusCode() == http.StatusUnauthorized && retry < 1 {
  129. retry++
  130. _ = getToken()
  131. goto sendjob
  132. }
  133. var response models.NotebookResult
  134. err = json.Unmarshal(res.Body(), &response)
  135. if err != nil {
  136. log.Error("json.Unmarshal failed: %s", err.Error())
  137. return &result, fmt.Errorf("son.Unmarshal failed: %s", err.Error())
  138. }
  139. if len(response.ErrorCode) != 0 {
  140. log.Error("GetJob failed(%s): %s", response.ErrorCode, response.ErrorMsg)
  141. return &result, fmt.Errorf("GetJob failed(%s): %s", response.ErrorCode, response.ErrorMsg)
  142. }
  143. return &result, nil
  144. }
  145. func StopJob(jobID string, param models.NotebookAction) (*models.NotebookActionResult, error) {
  146. checkSetting()
  147. client := getRestyClient()
  148. var result models.NotebookActionResult
  149. retry := 0
  150. sendjob:
  151. res, err := client.R().
  152. SetHeader("Content-Type", "application/json").
  153. SetBody(param).
  154. SetAuthToken(TOKEN).
  155. SetResult(&result).
  156. Post(HOST + "/v1/" + setting.ProjectID + urlNotebook + "/" + jobID + "/action")
  157. if err != nil {
  158. return &result, fmt.Errorf("resty StopJob: %v", err)
  159. }
  160. if res.StatusCode() == http.StatusUnauthorized && retry < 1 {
  161. retry++
  162. _ = getToken()
  163. goto sendjob
  164. }
  165. var response models.NotebookResult
  166. err = json.Unmarshal(res.Body(), &response)
  167. if err != nil {
  168. log.Error("json.Unmarshal failed: %s", err.Error())
  169. return &result, fmt.Errorf("son.Unmarshal failed: %s", err.Error())
  170. }
  171. if len(response.ErrorCode) != 0 {
  172. log.Error("StopJob failed(%s): %s", response.ErrorCode, response.ErrorMsg)
  173. return &result, fmt.Errorf("StopJob failed(%s): %s", response.ErrorCode, response.ErrorMsg)
  174. }
  175. return &result, nil
  176. }
  177. func DelJob(jobID string) (*models.NotebookDelResult, error) {
  178. checkSetting()
  179. client := getRestyClient()
  180. var result models.NotebookDelResult
  181. retry := 0
  182. sendjob:
  183. res, err := client.R().
  184. SetHeader("Content-Type", "application/json").
  185. SetAuthToken(TOKEN).
  186. SetResult(&result).
  187. Delete(HOST + "/v1/" + setting.ProjectID + urlNotebook + "/" + jobID)
  188. if err != nil {
  189. return &result, fmt.Errorf("resty DelJob: %v", err)
  190. }
  191. if res.StatusCode() == http.StatusUnauthorized && retry < 1 {
  192. retry++
  193. _ = getToken()
  194. goto sendjob
  195. }
  196. var response models.NotebookResult
  197. err = json.Unmarshal(res.Body(), &response)
  198. if err != nil {
  199. log.Error("json.Unmarshal failed: %s", err.Error())
  200. return &result, fmt.Errorf("son.Unmarshal failed: %s", err.Error())
  201. }
  202. if len(response.ErrorCode) != 0 {
  203. log.Error("DelJob failed(%s): %s", response.ErrorCode, response.ErrorMsg)
  204. return &result, fmt.Errorf("DelJob failed(%s): %s", response.ErrorCode, response.ErrorMsg)
  205. }
  206. return &result, nil
  207. }
  208. func GetJobToken(jobID string) (*models.NotebookGetJobTokenResult, error) {
  209. checkSetting()
  210. client := getRestyClient()
  211. var result models.NotebookGetJobTokenResult
  212. retry := 0
  213. sendjob:
  214. res, err := client.R().
  215. SetHeader("Content-Type", "application/json").
  216. SetAuthToken(TOKEN).
  217. SetResult(&result).
  218. Get(HOST + "/v1/" + setting.ProjectID + urlNotebook + "/" + jobID + "/token")
  219. if err != nil {
  220. return &result, fmt.Errorf("resty GetJobToken: %v", err)
  221. }
  222. if res.StatusCode() == http.StatusUnauthorized && retry < 1 {
  223. retry++
  224. _ = getToken()
  225. goto sendjob
  226. }
  227. var response models.NotebookResult
  228. err = json.Unmarshal(res.Body(), &response)
  229. if err != nil {
  230. log.Error("json.Unmarshal failed: %s", err.Error())
  231. return &result, fmt.Errorf("son.Unmarshal failed: %s", err.Error())
  232. }
  233. if len(response.ErrorCode) != 0 {
  234. log.Error("GetJobToken failed(%s): %s", response.ErrorCode, response.ErrorMsg)
  235. return &result, fmt.Errorf("GetJobToken failed(%s): %s", response.ErrorCode, response.ErrorMsg)
  236. }
  237. return &result, nil
  238. }
  239. func createTrainJob(createJobParams models.CreateTrainJobParams) (*models.CreateTrainJobResult, error) {
  240. checkSetting()
  241. client := getRestyClient()
  242. var result models.CreateTrainJobResult
  243. log.Info("%+v",createJobParams)
  244. retry := 0
  245. sendjob:
  246. res, err := client.R().
  247. SetHeader("Content-Type", "application/json").
  248. SetAuthToken(TOKEN).
  249. SetBody(createJobParams).
  250. SetResult(&result).
  251. Post(HOST + "/v1/" + setting.ProjectID + urlTrainJob)
  252. if err != nil {
  253. return nil, fmt.Errorf("resty create train-job: %s", err)
  254. }
  255. //log.Info("%d", res.StatusCode())
  256. //req, _ := json.Marshal(createJobParams)
  257. //log.Info("%s", req)
  258. if res.StatusCode() == http.StatusUnauthorized && retry < 1 {
  259. retry++
  260. _ = getToken()
  261. goto sendjob
  262. }
  263. if res.StatusCode() != http.StatusOK {
  264. log.Error("createTrainJob failed", res.StatusCode(), res.RawResponse.Body, result.ErrorCode, result.ErrorMsg)
  265. return &result, fmt.Errorf("createTrainJob failed(%d)", res.StatusCode())
  266. }
  267. if !result.IsSuccess {
  268. log.Error("createTrainJob failed(%s): %s", result.ErrorCode, result.ErrorMsg)
  269. return &result, fmt.Errorf("createTrainJob failed(%s): %s", result.ErrorCode, result.ErrorMsg)
  270. }
  271. return &result, nil
  272. }
  273. func GetResourceSpecs() (*models.GetResourceSpecsResult, error) {
  274. checkSetting()
  275. client := getRestyClient()
  276. var result models.GetResourceSpecsResult
  277. retry := 0
  278. sendjob:
  279. res, err := client.R().
  280. SetHeader("Content-Type", "application/json").
  281. SetAuthToken(TOKEN).
  282. SetResult(&result).
  283. Get(HOST + "/v1/" + setting.ProjectID + urlResourceSpecs)
  284. if err != nil {
  285. return nil, fmt.Errorf("resty GetResourceSpecs: %v", err)
  286. }
  287. if res.StatusCode() == http.StatusUnauthorized && retry < 1 {
  288. retry++
  289. _ = getToken()
  290. goto sendjob
  291. }
  292. if res.StatusCode() != http.StatusOK {
  293. log.Error("GetResourceSpecs failed(%d)", res.StatusCode())
  294. return &result, fmt.Errorf("GetResourceSpecs failed(%d)", res.StatusCode())
  295. }
  296. if !result.IsSuccess {
  297. log.Error("GetResourceSpecs failed(%s): %s", result.ErrorCode, result.ErrorMsg)
  298. return &result, fmt.Errorf("GetResourceSpecs failed(%s): %s", result.ErrorCode, result.ErrorMsg)
  299. }
  300. return &result, nil
  301. }