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

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