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.

cloudbrain.go 21 kB

5 years ago
5 years ago
4 years ago
5 years ago
4 years ago
5 years ago
5 years ago
4 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
4 years ago
4 years ago
4 years ago
4 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 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
5 years ago
5 years ago
4 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
4 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663
  1. package models
  2. import (
  3. "encoding/json"
  4. "errors"
  5. "fmt"
  6. "time"
  7. "xorm.io/xorm"
  8. "code.gitea.io/gitea/modules/setting"
  9. "code.gitea.io/gitea/modules/timeutil"
  10. "xorm.io/builder"
  11. )
  12. type CloudbrainStatus string
  13. type JobType string
  14. type ModelArtsJobStatus string
  15. const (
  16. JobWaiting CloudbrainStatus = "WAITING"
  17. JobStopped CloudbrainStatus = "STOPPED"
  18. JobSucceeded CloudbrainStatus = "SUCCEEDED"
  19. JobFailed CloudbrainStatus = "FAILED"
  20. JobRunning CloudbrainStatus = "RUNNING"
  21. JobTypeDebug JobType = "DEBUG"
  22. JobTypeBenchmark JobType = "BENCHMARK"
  23. JobTypeSnn4imagenet JobType = "SNN4IMAGENET"
  24. ModelArtsCreateQueue ModelArtsJobStatus = "CREATE_QUEUING" //免费资源创建排队中
  25. ModelArtsCreating ModelArtsJobStatus = "CREATING" //创建中
  26. ModelArtsCreateFailed ModelArtsJobStatus = "CREATE_FAILED" //创建失败
  27. ModelArtsStartQueuing ModelArtsJobStatus = "START_QUEUING" //免费资源启动排队中
  28. ModelArtsReadyToStart ModelArtsJobStatus = "READY_TO_START" //免费资源等待启动
  29. ModelArtsStarting ModelArtsJobStatus = "STARTING" //启动中
  30. ModelArtsRestarting ModelArtsJobStatus = "RESTARTING" //重启中
  31. ModelArtsStartFailed ModelArtsJobStatus = "START_FAILED" //启动失败
  32. ModelArtsRunning ModelArtsJobStatus = "RUNNING" //运行中
  33. ModelArtsStopping ModelArtsJobStatus = "STOPPING" //停止中
  34. ModelArtsStopped ModelArtsJobStatus = "STOPPED" //停止
  35. ModelArtsUnavailable ModelArtsJobStatus = "UNAVAILABLE" //故障
  36. ModelArtsDeleted ModelArtsJobStatus = "DELETED" //已删除
  37. ModelArtsResizing ModelArtsJobStatus = "RESIZING" //规格变更中
  38. ModelArtsResizFailed ModelArtsJobStatus = "RESIZE_FAILED" //规格变更失败
  39. )
  40. type Cloudbrain struct {
  41. ID int64 `xorm:"pk autoincr"`
  42. JobID string `xorm:"INDEX NOT NULL"`
  43. JobType string `xorm:"INDEX NOT NULL DEFAULT 'DEBUG'"`
  44. JobName string `xorm:"INDEX"`
  45. Status string `xorm:"INDEX"`
  46. UserID int64 `xorm:"INDEX"`
  47. RepoID int64 `xorm:"INDEX"`
  48. SubTaskName string `xorm:"INDEX"`
  49. ContainerID string
  50. ContainerIp string
  51. CreatedUnix timeutil.TimeStamp `xorm:"INDEX created"`
  52. UpdatedUnix timeutil.TimeStamp `xorm:"INDEX updated"`
  53. DeletedAt time.Time `xorm:"deleted"`
  54. CanDebug bool `xorm:"-"`
  55. Type int `xorm:"INDEX DEFAULT 0"`
  56. User *User `xorm:"-"`
  57. Repo *Repository `xorm:"-"`
  58. }
  59. type CloudBrainLoginResult struct {
  60. Code string
  61. Msg string
  62. Payload map[string]interface{}
  63. }
  64. type TaskRole struct {
  65. Name string `json:"name"`
  66. TaskNumber int8 `json:"taskNumber"`
  67. MinSucceededTaskCount int8 `json:"minSucceededTaskCount"`
  68. MinFailedTaskCount int8 `json:"minFailedTaskCount"`
  69. CPUNumber int8 `json:"cpuNumber"`
  70. GPUNumber int8 `json:"gpuNumber"`
  71. MemoryMB int `json:"memoryMB"`
  72. ShmMB int `json:"shmMB"`
  73. Command string `json:"command"`
  74. NeedIBDevice bool `json:"needIBDevice"`
  75. IsMainRole bool `json:"isMainRole"`
  76. UseNNI bool `json:"useNNI"`
  77. }
  78. type StHostPath struct {
  79. Path string `json:"path"`
  80. MountPath string `json:"mountPath"`
  81. ReadOnly bool `json:"readOnly"`
  82. }
  83. type Volume struct {
  84. HostPath StHostPath `json:"hostPath"`
  85. }
  86. type CreateJobParams struct {
  87. JobName string `json:"jobName"`
  88. RetryCount int8 `json:"retryCount"`
  89. GpuType string `json:"gpuType"`
  90. Image string `json:"image"`
  91. TaskRoles []TaskRole `json:"taskRoles"`
  92. Volumes []Volume `json:"volumes"`
  93. }
  94. type CreateJobResult struct {
  95. Code string `json:"code"`
  96. Msg string `json:"msg"`
  97. Payload map[string]interface{} `json:"payload"`
  98. }
  99. type GetJobResult struct {
  100. Code string `json:"code"`
  101. Msg string `json:"msg"`
  102. Payload map[string]interface{} `json:"payload"`
  103. }
  104. type GetImagesResult struct {
  105. Code string `json:"code"`
  106. Msg string `json:"msg"`
  107. Payload GetImagesPayload `json:"payload"`
  108. }
  109. type GetImagesPayload struct {
  110. Count int `json:"count"`
  111. ImageInfo []*ImageInfo `json:"rows"`
  112. }
  113. type CloudbrainsOptions struct {
  114. ListOptions
  115. RepoID int64 // include all repos if empty
  116. UserID int64
  117. JobID int64
  118. SortType string
  119. CloudbrainIDs []int64
  120. // JobStatus CloudbrainStatus
  121. Type int
  122. }
  123. type TaskPod struct {
  124. TaskRoleStatus struct {
  125. Name string `json:"name"`
  126. } `json:"taskRoleStatus"`
  127. TaskStatuses []struct {
  128. TaskIndex int `json:"taskIndex"`
  129. PodUID string `json:"podUid"`
  130. PodIP string `json:"podIp"`
  131. PodName string `json:"podName"`
  132. ContainerID string `json:"containerId"`
  133. ContainerIP string `json:"containerIp"`
  134. ContainerGpus string `json:"containerGpus"`
  135. State string `json:"state"`
  136. StartAt time.Time `json:"startAt"`
  137. FinishedAt time.Time `json:"finishedAt"`
  138. ExitCode int `json:"exitCode"`
  139. ExitDiagnostics string `json:"exitDiagnostics"`
  140. RetriedCount int `json:"retriedCount"`
  141. StartTime string
  142. FinishedTime string
  143. } `json:"taskStatuses"`
  144. }
  145. type TaskInfo struct {
  146. Username string `json:"username"`
  147. TaskName string `json:"task_name"`
  148. CodeName string `json:"code_name"`
  149. BenchmarkCategory []string `json:"selected_category"`
  150. CodeLink string `json:"code_link"`
  151. }
  152. func ConvertToTaskPod(input map[string]interface{}) (TaskPod, error) {
  153. data, _ := json.Marshal(input)
  154. var taskPod TaskPod
  155. err := json.Unmarshal(data, &taskPod)
  156. taskPod.TaskStatuses[0].StartTime = time.Unix(taskPod.TaskStatuses[0].StartAt.Unix()+8*3600, 0).UTC().Format("2006-01-02 15:04:05")
  157. taskPod.TaskStatuses[0].FinishedTime = time.Unix(taskPod.TaskStatuses[0].FinishedAt.Unix()+8*3600, 0).UTC().Format("2006-01-02 15:04:05")
  158. return taskPod, err
  159. }
  160. type JobResultPayload struct {
  161. ID string `json:"id"`
  162. Name string `json:"name"`
  163. Platform string `json:"platform"`
  164. JobStatus struct {
  165. Username string `json:"username"`
  166. State string `json:"state"`
  167. SubState string `json:"subState"`
  168. ExecutionType string `json:"executionType"`
  169. Retries int `json:"retries"`
  170. CreatedTime int64 `json:"createdTime"`
  171. CompletedTime int64 `json:"completedTime"`
  172. AppID string `json:"appId"`
  173. AppProgress string `json:"appProgress"`
  174. AppTrackingURL string `json:"appTrackingUrl"`
  175. AppLaunchedTime int64 `json:"appLaunchedTime"`
  176. AppCompletedTime interface{} `json:"appCompletedTime"`
  177. AppExitCode int `json:"appExitCode"`
  178. AppExitDiagnostics string `json:"appExitDiagnostics"`
  179. AppExitType interface{} `json:"appExitType"`
  180. VirtualCluster string `json:"virtualCluster"`
  181. StartTime string
  182. EndTime string
  183. } `json:"jobStatus"`
  184. TaskRoles map[string]interface{} `json:"taskRoles"`
  185. Resource struct {
  186. CPU int `json:"cpu"`
  187. Memory string `json:"memory"`
  188. NvidiaComGpu int `json:"nvidia.com/gpu"`
  189. } `json:"resource"`
  190. Config struct {
  191. Image string `json:"image"`
  192. JobID string `json:"jobId"`
  193. GpuType string `json:"gpuType"`
  194. JobName string `json:"jobName"`
  195. JobType string `json:"jobType"`
  196. TaskRoles []struct {
  197. Name string `json:"name"`
  198. ShmMB int `json:"shmMB"`
  199. Command string `json:"command"`
  200. MemoryMB int `json:"memoryMB"`
  201. CPUNumber int `json:"cpuNumber"`
  202. GpuNumber int `json:"gpuNumber"`
  203. IsMainRole bool `json:"isMainRole"`
  204. TaskNumber int `json:"taskNumber"`
  205. NeedIBDevice bool `json:"needIBDevice"`
  206. MinFailedTaskCount int `json:"minFailedTaskCount"`
  207. MinSucceededTaskCount int `json:"minSucceededTaskCount"`
  208. } `json:"taskRoles"`
  209. RetryCount int `json:"retryCount"`
  210. } `json:"config"`
  211. Userinfo struct {
  212. User string `json:"user"`
  213. OrgID string `json:"org_id"`
  214. } `json:"userinfo"`
  215. }
  216. func ConvertToJobResultPayload(input map[string]interface{}) (JobResultPayload, error) {
  217. data, _ := json.Marshal(input)
  218. var jobResultPayload JobResultPayload
  219. err := json.Unmarshal(data, &jobResultPayload)
  220. jobResultPayload.JobStatus.StartTime = time.Unix(jobResultPayload.JobStatus.CreatedTime/1000, 0).Format("2006-01-02 15:04:05")
  221. jobResultPayload.JobStatus.EndTime = time.Unix(jobResultPayload.JobStatus.CompletedTime/1000, 0).Format("2006-01-02 15:04:05")
  222. return jobResultPayload, err
  223. }
  224. type ImagesResultPayload struct {
  225. Images []struct {
  226. ID int `json:"id"`
  227. Name string `json:"name"`
  228. Place string `json:"place"`
  229. Description string `json:"description"`
  230. Provider string `json:"provider"`
  231. Createtime string `json:"createtime"`
  232. Remark string `json:"remark"`
  233. } `json:"taskStatuses"`
  234. }
  235. type ImageInfo struct {
  236. ID int `json:"id"`
  237. Name string `json:"name"`
  238. Place string `json:"place"`
  239. Description string `json:"description"`
  240. Provider string `json:"provider"`
  241. Createtime string `json:"createtime"`
  242. Remark string `json:"remark"`
  243. IsPublic int `json:"isPublic"`
  244. PlaceView string
  245. }
  246. type Categories struct {
  247. Category []*Category `json:"category"`
  248. }
  249. type Category struct {
  250. Id int `json:"id"`
  251. Value string `json:"value"`
  252. }
  253. type CommitImageParams struct {
  254. Ip string `json:"ip"`
  255. TaskContainerId string `json:"taskContainerId"`
  256. ImageTag string `json:"imageTag"`
  257. ImageDescription string `json:"imageDescription"`
  258. }
  259. type CommitImageResult struct {
  260. Code string `json:"code"`
  261. Msg string `json:"msg"`
  262. Payload map[string]interface{} `json:"payload"`
  263. }
  264. type StopJobResult struct {
  265. Code string `json:"code"`
  266. Msg string `json:"msg"`
  267. }
  268. type CreateNotebookParams struct {
  269. JobName string `json:"name"`
  270. Description string `json:"description"`
  271. ProfileID string `json:"profile_id"`
  272. Flavor string `json:"flavor"`
  273. Spec Spec `json:"spec"`
  274. Workspace Workspace `json:"workspace"`
  275. }
  276. type Workspace struct {
  277. ID string `json:"id"`
  278. }
  279. type Spec struct {
  280. Storage Storage `json:"storage"`
  281. AutoStop AutoStop `json:"auto_stop"`
  282. }
  283. type AutoStop struct {
  284. Enable bool `json:"enable"`
  285. Duration int `json:"duration"`
  286. }
  287. type Storage struct {
  288. Type string `json:"type"`
  289. Location Location `json:"location"`
  290. }
  291. type Location struct {
  292. Path string `json:"path"`
  293. }
  294. type NotebookResult struct {
  295. ErrorCode string `json:"error_code"`
  296. ErrorMsg string `json:"error_msg"`
  297. }
  298. type CreateNotebookResult struct {
  299. ErrorCode string `json:"error_code"`
  300. ErrorMsg string `json:"error_msg"`
  301. ID string `json:"id"`
  302. Name string `json:"name"`
  303. Description string `json:"description"`
  304. Status string `json:"status"`
  305. CreationTimestamp string `json:"creation_timestamp"`
  306. LatestUpdateTimestamp string `json:"latest_update_timestamp"`
  307. Profile struct {
  308. ID string `json:"id"`
  309. Name string `json:"name"`
  310. Description string `json:"description"`
  311. DeType string `json:"de_type"`
  312. FlavorType string `json:"flavor_type"`
  313. } `json:"profile"`
  314. Flavor string `json:"flavor"`
  315. FlavorDetails struct{
  316. Name string `json:"name"`
  317. Status string `json:"status"`
  318. QueuingNum int `json:"queuing_num"`
  319. QueueLeftTime int `json:"queue_left_time"` //s
  320. Duration int `json:"duration"` //auto_stop_time s
  321. } `json:"flavor_details"`
  322. }
  323. type GetNotebookResult struct {
  324. ErrorCode string `json:"error_code"`
  325. ErrorMsg string `json:"error_msg"`
  326. ID string `json:"id"`
  327. Name string `json:"name"`
  328. Description string `json:"description"`
  329. Status string `json:"status"`
  330. CreationTimestamp string `json:"creation_timestamp"`
  331. CreateTime string
  332. LatestUpdateTimestamp string `json:"latest_update_timestamp"`
  333. LatestUpdateTime string
  334. Profile struct {
  335. ID string `json:"id"`
  336. Name string `json:"name"`
  337. Description string `json:"description"`
  338. DeType string `json:"de_type"`
  339. FlavorType string `json:"flavor_type"`
  340. } `json:"profile"`
  341. Flavor string `json:"flavor"`
  342. FlavorDetails struct{
  343. Name string `json:"name"`
  344. Status string `json:"status"`
  345. QueuingNum int `json:"queuing_num"`
  346. QueueLeftTime int `json:"queue_left_time"` //s
  347. Duration int `json:"duration"` //auto_stop_time s
  348. } `json:"flavor_details"`
  349. QueuingInfo struct{
  350. ID string `json:"id"`
  351. Name string `json:"name"`
  352. Flavor string `json:"flavor"`
  353. DeType string `json:"de_type"`
  354. Status string `json:"status"`
  355. BeginTimestamp int `json:"begin_timestamp"`//time of instance begin in queue
  356. BeginTime string
  357. RemainTime int `json:"remain_time"` //remain time of instance
  358. EndTimestamp int `json:"end_timestamp"` //
  359. EndTime string
  360. Rank int `json:"rank"` //rank of instance in queue
  361. } `json:"queuing_info"`
  362. Spec struct{
  363. Annotations struct{
  364. TargetDomain string `json:"target_domain"`
  365. Url string `json:"url"`
  366. } `json:"annotations"`
  367. } `json:"spec"`
  368. }
  369. type GetTokenParams struct {
  370. Auth Auth `json:"auth"`
  371. }
  372. type Auth struct {
  373. Identity Identity `json:"identity"`
  374. Scope Scope `json:"scope"`
  375. }
  376. type Scope struct {
  377. Project Project `json:"project"`
  378. }
  379. type Project struct {
  380. Name string `json:"name"`
  381. }
  382. type Identity struct {
  383. Methods []string `json:"methods"`
  384. Password Password `json:"password"`
  385. }
  386. type Password struct {
  387. User NotebookUser `json:"user"`
  388. }
  389. type NotebookUser struct {
  390. Name string `json:"name"`
  391. Password string `json:"password"`
  392. Domain Domain `json:"domain"`
  393. }
  394. type Domain struct {
  395. Name string `json:"name"`
  396. }
  397. const (
  398. ActionStart = "start"
  399. ActionStop = "stop"
  400. ActionRestart = "restart"
  401. ActionQueue = "queue"
  402. ActionDequeue = "dequeue"
  403. )
  404. type NotebookAction struct {
  405. Action string `json:"action"`
  406. }
  407. type NotebookActionResult struct {
  408. ErrorCode string `json:"error_code"`
  409. ErrorMsg string `json:"error_msg"`
  410. CurrentStatus string `json:"current_status"`
  411. PreviousState string `json:"previous_state"`
  412. }
  413. type NotebookGetJobTokenResult struct {
  414. ErrorCode string `json:"error_code"`
  415. ErrorMsg string `json:"error_msg"`
  416. Token string `json:"token"`
  417. }
  418. type NotebookDelResult struct {
  419. InstanceID string `json:"instance_id"`
  420. }
  421. type CreateTrainJobParams struct {
  422. JobName string `json:"job_name"`
  423. Description string `json:"job_desc"`
  424. Config Config `json:"config"`
  425. WorkspaceID string `json:"workspace_id"`
  426. }
  427. type Config struct {
  428. WorkServerNum int `json:"worker_server_num"`
  429. AppUrl string `json:"app_url"` //训练作业的代码目录
  430. BootFileUrl string `json:"boot_file_url"` //训练作业的代码启动文件,需要在代码目录下
  431. Parameter []Parameter `json:"parameter"`
  432. DataUrl string `json:"data_url"` //训练作业需要的数据集OBS路径URL
  433. DatasetID string `json:"dataset_id"`
  434. DataVersionID string `json:"dataset_version_id"`
  435. DataSource []DataSource `json:"data_source"`
  436. SpecID int64 `json:"spec_id"`
  437. EngineID int64 `json:"engine_id"`
  438. ModelID int64 `json:"model_id"`
  439. TrainUrl string `json:"train_url"` //训练作业的输出文件OBS路径URL
  440. LogUrl string `json:"log_url"`
  441. UserImageUrl string `json:"user_image_url"`
  442. UserCommand string `json:"user_command"`
  443. CreateVersion bool `json:"create_version"`
  444. Volumes []Volumes `json:"volumes"`
  445. }
  446. type Parameter struct {
  447. Label string `json:"label"`
  448. Value string `json:"value"`
  449. }
  450. type DataSource struct {
  451. DatasetID string `json:"dataset_id"`
  452. DatasetVersion string `json:"dataset_version"`
  453. Type string `json:"type"`
  454. DataUrl string `json:"data_url"`
  455. }
  456. type Volumes struct {
  457. Nfs Nfs `json:"nfs"`
  458. HostPath HostPath `json:"host_path"`
  459. }
  460. type Nfs struct {
  461. ID string `json:"id"`
  462. SourcePath string `json:"src_path"`
  463. DestPath string `json:"dest_path"`
  464. ReadOnly bool `json:"read_only"`
  465. }
  466. type HostPath struct {
  467. SourcePath string `json:"src_path"`
  468. DestPath string `json:"dest_path"`
  469. ReadOnly bool `json:"read_only"`
  470. }
  471. type CreateTrainJobResult struct {
  472. ErrorCode string `json:"error_code"`
  473. ErrorMsg string `json:"error_msg"`
  474. IsSuccess bool `json:"is_success"`
  475. JobName string `json:"job_name"`
  476. JobID int64 `json:"job_id"`
  477. Status int `json:"status"`
  478. CreationTime int64 `json:"create_time"`
  479. VersionID int64 `json:"version_id"`
  480. ResourceID string `json:"resource_id"`
  481. VersionName string `json:"version_name"`
  482. }
  483. func Cloudbrains(opts *CloudbrainsOptions) ([]*Cloudbrain, int64, error) {
  484. sess := x.NewSession()
  485. defer sess.Close()
  486. var cond = builder.NewCond()
  487. if opts.RepoID > 0 {
  488. cond = cond.And(
  489. builder.Eq{"cloudbrain.repo_id": opts.RepoID},
  490. )
  491. }
  492. if opts.UserID > 0 {
  493. cond = cond.And(
  494. builder.Eq{"cloudbrain.user_id": opts.UserID},
  495. )
  496. }
  497. if (opts.JobID) > 0 {
  498. cond = cond.And(
  499. builder.Eq{"cloudbrain.job_id": opts.JobID},
  500. )
  501. }
  502. if (opts.Type) >= 0 {
  503. cond = cond.And(
  504. builder.Eq{"cloudbrain.type": opts.Type},
  505. )
  506. }
  507. // switch opts.JobStatus {
  508. // case JobWaiting:
  509. // cond.And(builder.Eq{"cloudbrain.status": int(JobWaiting)})
  510. // case JobFailed:
  511. // cond.And(builder.Eq{"cloudbrain.status": int(JobFailed)})
  512. // case JobStopped:
  513. // cond.And(builder.Eq{"cloudbrain.status": int(JobStopped)})
  514. // case JobSucceeded:
  515. // cond.And(builder.Eq{"cloudbrain.status": int(JobSucceeded)})
  516. // }
  517. if len(opts.CloudbrainIDs) > 0 {
  518. cond = cond.And(builder.In("cloudbrain.id", opts.CloudbrainIDs))
  519. }
  520. count, err := sess.Where(cond).Count(new(Cloudbrain))
  521. if err != nil {
  522. return nil, 0, fmt.Errorf("Count: %v", err)
  523. }
  524. if opts.Page >= 0 && opts.PageSize > 0 {
  525. var start int
  526. if opts.Page == 0 {
  527. start = 0
  528. } else {
  529. start = (opts.Page - 1) * opts.PageSize
  530. }
  531. sess.Limit(opts.PageSize, start)
  532. }
  533. sess.OrderBy("cloudbrain.created_unix DESC")
  534. cloudbrains := make([]*Cloudbrain, 0, setting.UI.IssuePagingNum)
  535. if err := sess.Where(cond).Find(&cloudbrains); err != nil {
  536. return nil, 0, fmt.Errorf("Find: %v", err)
  537. }
  538. sess.Close()
  539. return cloudbrains, count, nil
  540. }
  541. func CreateCloudbrain(cloudbrain *Cloudbrain) (err error) {
  542. if _, err = x.Insert(cloudbrain); err != nil {
  543. return err
  544. }
  545. return nil
  546. }
  547. func getRepoCloudBrain(cb *Cloudbrain) (*Cloudbrain, error) {
  548. has, err := x.Get(cb)
  549. if err != nil {
  550. return nil, err
  551. } else if !has {
  552. return nil, errors.New("cloudbrain task is not found")
  553. }
  554. return cb, nil
  555. }
  556. func GetRepoCloudBrainByJobID(repoID int64, jobID string) (*Cloudbrain, error) {
  557. cb := &Cloudbrain{JobID: jobID, RepoID: repoID}
  558. return getRepoCloudBrain(cb)
  559. }
  560. func GetCloudbrainByJobID(jobID string) (*Cloudbrain, error) {
  561. cb := &Cloudbrain{JobID: jobID}
  562. return getRepoCloudBrain(cb)
  563. }
  564. func SetCloudbrainStatusByJobID(jobID string, status CloudbrainStatus) (err error) {
  565. cb := &Cloudbrain{JobID: jobID, Status: string(status)}
  566. _, err = x.Cols("status").Where("cloudbrain.job_id=?", jobID).Update(cb)
  567. return
  568. }
  569. func UpdateJob(job *Cloudbrain) error {
  570. return updateJob(x, job)
  571. }
  572. func updateJob(e Engine, job *Cloudbrain) error {
  573. var sess *xorm.Session
  574. sess = e.Where("job_id = ?", job.JobID)
  575. _, err := sess.Cols("status", "container_id", "container_ip").Update(job)
  576. return err
  577. }
  578. func DeleteJob(job *Cloudbrain) error {
  579. return deleteJob(x, job)
  580. }
  581. func deleteJob(e Engine, job *Cloudbrain) error {
  582. _, err := e.ID(job.ID).Delete(job)
  583. return err
  584. }