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.7 kB

2 years ago
3 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
3 years ago
2 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
2 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266
  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.JobTypeModelSafety), 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. models.LoadSpecs4CloudbrainInfo(ciTasks)
  82. for i, task := range ciTasks {
  83. ciTasks[i].CanDebug = true
  84. ciTasks[i].CanDel = true
  85. ciTasks[i].Cloudbrain.ComputeResource = task.ComputeResource
  86. if ciTasks[i].Cloudbrain.Spec != nil {
  87. if ciTasks[i].Cloudbrain.Type == models.TypeC2Net {
  88. ciTasks[i].Cloudbrain.Spec.Cluster = models.C2NetCluster
  89. } else {
  90. ciTasks[i].Cloudbrain.Spec.Cluster = models.OpenICluster
  91. }
  92. }
  93. }
  94. pager := context.NewPagination(int(count), setting.UI.IssuePagingNum, page, getTotalPage(count, setting.UI.IssuePagingNum))
  95. pager.SetDefaultParams(ctx)
  96. pager.AddParam(ctx, "listType", "ListType")
  97. ctx.Data["Page"] = pager
  98. ctx.Data["PageIsCloudBrain"] = true
  99. ctx.Data["Tasks"] = ciTasks
  100. ctx.Data["CanCreate"] = true
  101. ctx.Data["Keyword"] = keyword
  102. ctx.HTML(200, tplCloudBrains)
  103. }
  104. func Images(ctx *context.Context) {
  105. ctx.Data["PageIsAdminImages"] = true
  106. ctx.HTML(200, tplImages)
  107. }
  108. func CloudBrainCommitImageShow(ctx *context.Context) {
  109. ctx.Data["PageIsAdminImages"] = true
  110. ctx.HTML(200, tplCommitImages)
  111. }
  112. func DownloadCloudBrains(ctx *context.Context) {
  113. page := 1
  114. pageSize := 300
  115. var cloudBrain = ctx.Tr("repo.cloudbrain")
  116. fileName := getFileName(cloudBrain)
  117. _, total, err := models.Cloudbrains(&models.CloudbrainsOptions{
  118. ListOptions: models.ListOptions{
  119. Page: page,
  120. PageSize: 1,
  121. },
  122. Type: models.TypeCloudBrainAll,
  123. NeedRepoInfo: false,
  124. IsLatestVersion: modelarts.IsLatestVersion,
  125. })
  126. if err != nil {
  127. log.Warn("Can not get cloud brain info", err)
  128. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.cloudbrain_query_fail"))
  129. return
  130. }
  131. totalPage := getTotalPage(total, pageSize)
  132. f := excelize.NewFile()
  133. index := f.NewSheet(cloudBrain)
  134. f.DeleteSheet("Sheet1")
  135. for k, v := range allHeader(ctx) {
  136. f.SetCellValue(cloudBrain, k, v)
  137. }
  138. var row = 2
  139. for i := 0; i < totalPage; i++ {
  140. pageRecords, _, err := models.Cloudbrains(&models.CloudbrainsOptions{
  141. ListOptions: models.ListOptions{
  142. Page: page,
  143. PageSize: pageSize,
  144. },
  145. Type: models.TypeCloudBrainAll,
  146. NeedRepoInfo: true,
  147. IsLatestVersion: modelarts.IsLatestVersion,
  148. })
  149. if err != nil {
  150. log.Warn("Can not get cloud brain info", err)
  151. continue
  152. }
  153. models.LoadSpecs4CloudbrainInfo(pageRecords)
  154. for _, record := range pageRecords {
  155. for k, v := range allValues(row, record, ctx) {
  156. f.SetCellValue(cloudBrain, k, v)
  157. }
  158. row++
  159. }
  160. page++
  161. }
  162. f.SetActiveSheet(index)
  163. ctx.Resp.Header().Set("Content-Disposition", "attachment; filename="+url.QueryEscape(fileName))
  164. ctx.Resp.Header().Set("Content-Type", "application/octet-stream")
  165. f.WriteTo(ctx.Resp)
  166. }
  167. func allValues(row int, rs *models.CloudbrainInfo, ctx *context.Context) map[string]string {
  168. return map[string]string{getCellName("A", row): rs.DisplayJobName, getCellName("B", row): repo.GetCloudbrainCluster(rs.Cloudbrain, ctx),
  169. getCellName("C", row): rs.JobType, getCellName("D", row): rs.Status, getCellName("E", row): time.Unix(int64(rs.Cloudbrain.CreatedUnix), 0).Format(CREATE_TIME_FORMAT),
  170. getCellName("F", row): getDurationTime(rs), getCellName("G", row): rs.ComputeResource,
  171. getCellName("H", row): repo.GetCloudbrainAiCenter(rs.Cloudbrain, ctx), getCellName("I", row): getCloudbrainCardType(rs),
  172. getCellName("J", row): rs.Name, getCellName("K", row): getRepoPathName(rs), getCellName("L", row): rs.JobName,
  173. }
  174. }
  175. func getCloudbrainCardType(rs *models.CloudbrainInfo) string {
  176. if rs.Cloudbrain.Spec != nil {
  177. return rs.Cloudbrain.Spec.AccCardType
  178. } else {
  179. return ""
  180. }
  181. }
  182. func getRepoPathName(rs *models.CloudbrainInfo) string {
  183. if rs.Repo != nil {
  184. return rs.Repo.OwnerName + "/" + rs.Repo.Alias
  185. }
  186. return ""
  187. }
  188. func getDurationTime(rs *models.CloudbrainInfo) string {
  189. if rs.JobType == "TRAIN" || rs.JobType == "INFERENCE" {
  190. return rs.TrainJobDuration
  191. } else {
  192. return "-"
  193. }
  194. }
  195. func getFileName(baseName string) string {
  196. return baseName + "_" + time.Now().Format(EXCEL_DATE_FORMAT) + ".xlsx"
  197. }
  198. func getTotalPage(total int64, pageSize int) int {
  199. another := 0
  200. if int(total)%pageSize != 0 {
  201. another = 1
  202. }
  203. return int(total)/pageSize + another
  204. }
  205. func allHeader(ctx *context.Context) map[string]string {
  206. return map[string]string{"A1": ctx.Tr("repo.cloudbrain_task"), "B1": ctx.Tr("repo.modelarts.cluster"),
  207. "C1": ctx.Tr("repo.cloudbrain_task_type"), "D1": ctx.Tr("repo.modelarts.status"), "E1": ctx.Tr("repo.modelarts.createtime"),
  208. "F1": ctx.Tr("repo.modelarts.train_job.dura_time"), "G1": ctx.Tr("repo.modelarts.computing_resources"),
  209. "H1": ctx.Tr("repo.modelarts.ai_center"), "I1": ctx.Tr("repo.modelarts.card_type"), "J1": ctx.Tr("repo.cloudbrain_creator"),
  210. "K1": ctx.Tr("repo.repo_name"), "L1": ctx.Tr("repo.cloudbrain_task_name")}
  211. }
  212. func getCellName(col string, row int) string {
  213. return col + strconv.Itoa(row)
  214. }