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