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.

cloudbrains.go 7.4 kB

3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251
  1. package admin
  2. import (
  3. "net/http"
  4. "net/url"
  5. "strconv"
  6. "strings"
  7. "time"
  8. "github.com/360EntSecGroup-Skylar/excelize/v2"
  9. "code.gitea.io/gitea/modules/modelarts"
  10. "code.gitea.io/gitea/routers/repo"
  11. "code.gitea.io/gitea/models"
  12. "code.gitea.io/gitea/modules/base"
  13. "code.gitea.io/gitea/modules/context"
  14. "code.gitea.io/gitea/modules/log"
  15. "code.gitea.io/gitea/modules/setting"
  16. )
  17. const (
  18. tplCloudBrains base.TplName = "admin/cloudbrain/list"
  19. tplImages base.TplName = "admin/cloudbrain/images"
  20. tplCommitImages base.TplName = "admin/cloudbrain/imagecommit"
  21. EXCEL_DATE_FORMAT = "20060102150405"
  22. CREATE_TIME_FORMAT = "2006/01/02 15:04:05"
  23. )
  24. func CloudBrains(ctx *context.Context) {
  25. ctx.Data["Title"] = ctx.Tr("admin.cloudBrains")
  26. ctx.Data["PageIsAdmin"] = true
  27. ctx.Data["PageIsAdminCloudBrains"] = true
  28. listType := ctx.Query("listType")
  29. jobType := ctx.Query("jobType")
  30. jobStatus := ctx.Query("jobStatus")
  31. ctx.Data["ListType"] = listType
  32. ctx.Data["JobType"] = jobType
  33. ctx.Data["JobStatus"] = jobStatus
  34. page := ctx.QueryInt("page")
  35. if page <= 0 {
  36. page = 1
  37. }
  38. var jobTypes []string
  39. jobTypeNot := false
  40. if jobType == string(models.JobTypeBenchmark) {
  41. jobTypes = append(jobTypes, string(models.JobTypeBenchmark), string(models.JobTypeBrainScore), string(models.JobTypeSnn4imagenet))
  42. } else if jobType != "all" && jobType != "" {
  43. jobTypes = append(jobTypes, jobType)
  44. }
  45. var jobStatuses []string
  46. jobStatusNot := false
  47. if jobStatus == "other" {
  48. jobStatusNot = true
  49. jobStatuses = append(jobStatuses, string(models.ModelArtsTrainJobWaiting), string(models.ModelArtsTrainJobFailed), string(models.ModelArtsRunning), string(models.ModelArtsTrainJobCompleted),
  50. string(models.ModelArtsStarting), string(models.ModelArtsRestarting), string(models.ModelArtsStartFailed),
  51. string(models.ModelArtsStopping), string(models.ModelArtsStopped), string(models.JobSucceeded))
  52. } else if jobStatus != "all" && jobStatus != "" {
  53. jobStatuses = append(jobStatuses, jobStatus)
  54. }
  55. keyword := strings.Trim(ctx.Query("q"), " ")
  56. ciTasks, count, err := models.Cloudbrains(&models.CloudbrainsOptions{
  57. ListOptions: models.ListOptions{
  58. Page: page,
  59. PageSize: setting.UI.IssuePagingNum,
  60. },
  61. Keyword: keyword,
  62. JobTypeNot: jobTypeNot,
  63. JobStatusNot: jobStatusNot,
  64. JobStatus: jobStatuses,
  65. JobTypes: jobTypes,
  66. NeedRepoInfo: true,
  67. IsLatestVersion: modelarts.IsLatestVersion,
  68. ComputeResource: listType,
  69. Type: models.TypeCloudBrainAll,
  70. })
  71. if err != nil {
  72. ctx.ServerError("Get job failed:", err)
  73. return
  74. }
  75. for i, task := range ciTasks {
  76. ciTasks[i].CanDebug = true
  77. ciTasks[i].CanDel = true
  78. ciTasks[i].Cloudbrain.ComputeResource = task.ComputeResource
  79. ciTasks[i].Cloudbrain.AiCenter = repo.GetCloudbrainAiCenter(task.Cloudbrain, ctx)
  80. _, cardType, _ := repo.GetCloudbrainCardNumAndType(task.Cloudbrain)
  81. ciTasks[i].Cloudbrain.CardType = cardType
  82. ciTasks[i].Cloudbrain.Cluster = repo.GetCloudbrainCluster(task.Cloudbrain, ctx)
  83. }
  84. pager := context.NewPagination(int(count), setting.UI.IssuePagingNum, page, getTotalPage(count, setting.UI.IssuePagingNum))
  85. pager.SetDefaultParams(ctx)
  86. pager.AddParam(ctx, "listType", "ListType")
  87. ctx.Data["Page"] = pager
  88. ctx.Data["PageIsCloudBrain"] = true
  89. ctx.Data["Tasks"] = ciTasks
  90. ctx.Data["CanCreate"] = true
  91. ctx.Data["Keyword"] = keyword
  92. ctx.HTML(200, tplCloudBrains)
  93. }
  94. func Images(ctx *context.Context) {
  95. ctx.Data["PageIsAdminImages"] = true
  96. ctx.HTML(200, tplImages)
  97. }
  98. func CloudBrainCommitImageShow(ctx *context.Context) {
  99. ctx.Data["PageIsAdminImages"] = true
  100. ctx.HTML(200, tplCommitImages)
  101. }
  102. func DownloadCloudBrains(ctx *context.Context) {
  103. page := 1
  104. pageSize := 300
  105. var cloudBrain = ctx.Tr("repo.cloudbrain")
  106. fileName := getFileName(cloudBrain)
  107. _, total, err := models.Cloudbrains(&models.CloudbrainsOptions{
  108. ListOptions: models.ListOptions{
  109. Page: page,
  110. PageSize: 1,
  111. },
  112. Type: models.TypeCloudBrainAll,
  113. NeedRepoInfo: false,
  114. IsLatestVersion: modelarts.IsLatestVersion,
  115. })
  116. if err != nil {
  117. log.Warn("Can not get cloud brain info", err)
  118. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.cloudbrain_query_fail"))
  119. return
  120. }
  121. totalPage := getTotalPage(total, pageSize)
  122. f := excelize.NewFile()
  123. index := f.NewSheet(cloudBrain)
  124. f.DeleteSheet("Sheet1")
  125. for k, v := range allHeader(ctx) {
  126. f.SetCellValue(cloudBrain, k, v)
  127. }
  128. var row = 2
  129. for i := 0; i < totalPage; i++ {
  130. pageRecords, _, err := models.Cloudbrains(&models.CloudbrainsOptions{
  131. ListOptions: models.ListOptions{
  132. Page: page,
  133. PageSize: pageSize,
  134. },
  135. Type: models.TypeCloudBrainAll,
  136. NeedRepoInfo: true,
  137. IsLatestVersion: modelarts.IsLatestVersion,
  138. })
  139. if err != nil {
  140. log.Warn("Can not get cloud brain info", err)
  141. continue
  142. }
  143. for _, record := range pageRecords {
  144. for k, v := range allValues(row, record, ctx) {
  145. f.SetCellValue(cloudBrain, k, v)
  146. }
  147. row++
  148. }
  149. page++
  150. }
  151. f.SetActiveSheet(index)
  152. ctx.Resp.Header().Set("Content-Disposition", "attachment; filename="+url.QueryEscape(fileName))
  153. ctx.Resp.Header().Set("Content-Type", "application/octet-stream")
  154. f.WriteTo(ctx.Resp)
  155. }
  156. func allValues(row int, rs *models.CloudbrainInfo, ctx *context.Context) map[string]string {
  157. return map[string]string{getCellName("A", row): rs.DisplayJobName, getCellName("B", row): repo.GetCloudbrainCluster(rs.Cloudbrain, ctx),
  158. getCellName("C", row): rs.JobType, getCellName("D", row): rs.Status, getCellName("E", row): time.Unix(int64(rs.Cloudbrain.CreatedUnix), 0).Format(CREATE_TIME_FORMAT),
  159. getCellName("F", row): getDurationTime(rs), getCellName("G", row): rs.ComputeResource,
  160. getCellName("H", row): repo.GetCloudbrainAiCenter(rs.Cloudbrain, ctx), getCellName("I", row): getCloudbrainCardType(rs),
  161. getCellName("J", row): rs.Name, getCellName("K", row): getRepoPathName(rs), getCellName("L", row): rs.JobName,
  162. }
  163. }
  164. func getCloudbrainCardType(rs *models.CloudbrainInfo) string {
  165. _, cardType, _ := repo.GetCloudbrainCardNumAndType(rs.Cloudbrain)
  166. return cardType
  167. }
  168. func getRepoPathName(rs *models.CloudbrainInfo) string {
  169. if rs.Repo != nil {
  170. return rs.Repo.OwnerName + "/" + rs.Repo.Alias
  171. }
  172. return ""
  173. }
  174. func getDurationTime(rs *models.CloudbrainInfo) string {
  175. if rs.JobType == "TRAIN" || rs.JobType == "INFERENCE" {
  176. return rs.TrainJobDuration
  177. } else {
  178. return "-"
  179. }
  180. }
  181. func getFileName(baseName string) string {
  182. return baseName + "_" + time.Now().Format(EXCEL_DATE_FORMAT) + ".xlsx"
  183. }
  184. func getTotalPage(total int64, pageSize int) int {
  185. another := 0
  186. if int(total)%pageSize != 0 {
  187. another = 1
  188. }
  189. return int(total)/pageSize + another
  190. }
  191. func allHeader(ctx *context.Context) map[string]string {
  192. return map[string]string{"A1": ctx.Tr("repo.cloudbrain_task"), "B1": ctx.Tr("repo.modelarts.cluster"),
  193. "C1": ctx.Tr("repo.cloudbrain_task_type"), "D1": ctx.Tr("repo.modelarts.status"), "E1": ctx.Tr("repo.modelarts.createtime"),
  194. "F1": ctx.Tr("repo.modelarts.train_job.dura_time"), "G1": ctx.Tr("repo.modelarts.computing_resources"),
  195. "H1": ctx.Tr("repo.modelarts.ai_center"), "I1": ctx.Tr("repo.modelarts.card_type"), "J1": ctx.Tr("repo.cloudbrain_creator"),
  196. "K1": ctx.Tr("repo.repo_name"), "L1": ctx.Tr("repo.cloudbrain_task_name")}
  197. }
  198. func getCellName(col string, row int) string {
  199. return col + strconv.Itoa(row)
  200. }