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