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_dashboard.go 55 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
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
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
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
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
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
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
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
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
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
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
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
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
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
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
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
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
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
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
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
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
12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490
  1. package repo
  2. import (
  3. "fmt"
  4. "net/http"
  5. "net/url"
  6. "strings"
  7. "time"
  8. "code.gitea.io/gitea/models"
  9. "code.gitea.io/gitea/modules/context"
  10. "code.gitea.io/gitea/modules/log"
  11. "code.gitea.io/gitea/routers/repo"
  12. "github.com/360EntSecGroup-Skylar/excelize/v2"
  13. )
  14. type DateCloudbrainNum struct {
  15. Date string `json:"date"`
  16. CloudOneJobTypeRes map[string]int `json:"cloudOneJobTypeRes"`
  17. CloudTwoJobTypeRes map[string]int `json:"cloudTwoJobTypeRes"`
  18. IntelligentNetJobTypeRes map[string]int `json:"intelligentNetJobTypeRes"`
  19. CloudBrainPeriodNum map[int]int `json:"cloudBrainPeriodNum"`
  20. CloudBrainComputeResource map[string]int `json:"cloudBrainComputeResource"`
  21. }
  22. type DateCloudbrainInfo struct {
  23. Date string `json:"date"`
  24. CloudBrainPeriodNum map[int]int `json:"cloudBrainPeriodNum"`
  25. CloudBrainComputeResource map[string]int `json:"cloudBrainComputeResource"`
  26. }
  27. type CloudbrainsStatusAnalysis struct {
  28. JobWaitingCount int64 `json:"jobWaitingCount"`
  29. JobRunningCount int64 `json:"jobRunningCount"`
  30. JobStoppedCount int64 `json:"jobStoppedCount"`
  31. JobCompletedCount int64 `json:"jobCompletedCount"`
  32. JobFailedCount int64 `json:"jobFailedCount"`
  33. JobKilledCount int64 `json:"jobKilledCount"`
  34. JobInitCount int64 `json:"jobInitCount"`
  35. }
  36. func GetAllCloudbrainsOverview(ctx *context.Context) {
  37. recordCloudbrain, err := models.GetRecordBeginTime()
  38. if err != nil {
  39. log.Error("Can not get recordCloudbrain", err)
  40. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.record_begintime_get_err"))
  41. return
  42. }
  43. recordBeginTime := recordCloudbrain[0].Cloudbrain.CreatedUnix
  44. now := time.Now()
  45. beginTime := time.Date(now.Year(), now.Month(), now.Day(), 0, 0, 0, 0, now.Location())
  46. endTime := now
  47. todayCreatorCount, err := models.GetTodayCreatorCount(beginTime, endTime)
  48. if err != nil {
  49. log.Error("Can not query todayCreatorCount.", err)
  50. return
  51. }
  52. cloudbrainTypeCount, err := models.GetCloudbrainTypeCount()
  53. log.Info("cloudbrainTypeCount:", cloudbrainTypeCount)
  54. if err != nil {
  55. log.Error("Can not query cloudbrainTypeCount.", err)
  56. return
  57. }
  58. cloudbrainTpyeDurationSum, err := models.GetCloudbrainTpyeDurationSum()
  59. log.Info("cloudbrainTpyeDurationSum:", cloudbrainTpyeDurationSum)
  60. if err != nil {
  61. log.Error("Can not query cloudbrainTpyeDurationSum.", err)
  62. return
  63. }
  64. todayCloudbrainCount, err := models.GetTodayCloudbrainCount(beginTime, endTime)
  65. log.Info("todayCloudbrainCount:", todayCloudbrainCount)
  66. if err != nil {
  67. log.Error("Can not query todayCloudbrainCount.", err)
  68. return
  69. }
  70. todayRunningCount, err := models.GetTodayRunningCount(beginTime, endTime)
  71. log.Info("todayRunningCount:", todayRunningCount)
  72. if err != nil {
  73. log.Error("Can not query todayRunningCount.", err)
  74. return
  75. }
  76. todayWaitingCount, err := models.GetTodayWaitingCount(beginTime, endTime)
  77. log.Info("todayWaittingCount:", todayWaitingCount)
  78. if err != nil {
  79. log.Error("Can not query todayWaitingCount.", err)
  80. return
  81. }
  82. todayCompletedCount := todayCloudbrainCount - todayRunningCount - todayWaitingCount
  83. log.Info("todayCompletedCount:", todayCompletedCount)
  84. creatorCount, err := models.GetCreatorCount()
  85. if err != nil {
  86. log.Error("Can not query creatorCount.", err)
  87. return
  88. }
  89. // todayStatusResult := make(map[string]int)
  90. // cloudBrainNum := make(map[int]int)
  91. // cloudBrainOneDuration := int64(0)
  92. // cloudBrainTwoDuration := int64(0)
  93. // intelligentNetDuration := int64(0)
  94. // todayNewJobCount := 0
  95. // if int64(cloudbrain.Cloudbrain.CreatedUnix) >= beginTime.Unix() && int64(cloudbrain.Cloudbrain.CreatedUnix) < endTime.Unix() {
  96. // todayNewJobCount += 1
  97. // if _, ok := todayStatusResult[cloudbrain.Status]; !ok {
  98. // todayStatusResult[cloudbrain.Status] = 1
  99. // } else {
  100. // todayStatusResult[cloudbrain.Status] += 1
  101. // }
  102. // }
  103. // if _, ok := cloudBrainNum[cloudbrain.Cloudbrain.Type]; !ok {
  104. // cloudBrainNum[cloudbrain.Cloudbrain.Type] = 1
  105. // } else {
  106. // cloudBrainNum[cloudbrain.Cloudbrain.Type] += 1
  107. // }
  108. // if cloudbrain.Cloudbrain.Type == models.TypeCloudBrainOne {
  109. // cloudBrainOneDuration = cloudBrainOneDuration + cloudbrain.Cloudbrain.Duration
  110. // }
  111. // if cloudbrain.Cloudbrain.Type == models.TypeCloudBrainTwo {
  112. // cloudBrainTwoDuration = cloudBrainTwoDuration + cloudbrain.Cloudbrain.Duration
  113. // }
  114. // if cloudbrain.Cloudbrain.Type == models.TypeC2Net {
  115. // intelligentNetDuration = intelligentNetDuration + cloudbrain.Cloudbrain.Duration
  116. // }
  117. // }
  118. // count = len(cloudbrains)
  119. // page += 1
  120. // }
  121. // statusNameList := []string{string(models.ModelArtsTrainJobCompleted), string(models.JobFailed), string(models.ModelArtsTrainJobInit),
  122. // string(models.JobRunning), string(models.ModelArtsStartFailed), string(models.JobStopped), string(models.JobSucceeded),
  123. // string(models.JobWaiting), string(models.ModelArtsTrainJobKilled)}
  124. // for _, v := range statusNameList {
  125. // if _, ok := todayStatusResult[v]; !ok {
  126. // todayStatusResult[v] = 0
  127. // }
  128. // }
  129. // cloudBrainTypeList := []int{0, 1, 2}
  130. // for _, v := range cloudBrainTypeList {
  131. // if _, ok := cloudBrainNum[v]; !ok {
  132. // cloudBrainNum[v] = 0
  133. // }
  134. // }
  135. // todayRunningCount := todayStatusResult[string(models.JobRunning)]
  136. // todayCompletedCount := todayStatusResult[string(models.ModelArtsTrainJobCompleted)] + todayStatusResult[string(models.JobFailed)] +
  137. // todayStatusResult[string(models.ModelArtsStartFailed)] + todayStatusResult[string(models.JobStopped)] + todayStatusResult[string(models.JobSucceeded)] + todayStatusResult[string(models.ModelArtsTrainJobKilled)]
  138. // todayWaitingCount := todayStatusResult[string(models.ModelArtsTrainJobInit)] + todayStatusResult[string(models.JobWaiting)]
  139. ctx.JSON(http.StatusOK, map[string]interface{}{
  140. "recordBeginTime": recordBeginTime,
  141. "updateTime": now.Unix(),
  142. // "cloudBrainNum": cloudBrainNum,
  143. // "cloudBrainOneDuration": cloudBrainOneDuration,
  144. // "cloudBrainTwoDuration": cloudBrainTwoDuration,
  145. // "intelligentNetDuration": intelligentNetDuration,
  146. "todayCreatorCount": todayCreatorCount,
  147. "creatorCount": creatorCount,
  148. "todayRunningCount": todayRunningCount,
  149. "todayCompletedCount": todayCompletedCount,
  150. "todayWaitingCount": todayWaitingCount,
  151. "todayNewJobCount": todayCloudbrainCount,
  152. "cloudbrainTypeCount": cloudbrainTypeCount,
  153. })
  154. }
  155. func GetOverviewDuration(ctx *context.Context) {
  156. recordCloudbrain, err := models.GetRecordBeginTime()
  157. if err != nil {
  158. log.Error("Can not get recordCloudbrain", err)
  159. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.record_begintime_get_err"))
  160. return
  161. }
  162. recordBeginTime := recordCloudbrain[0].Cloudbrain.CreatedUnix
  163. now := time.Now()
  164. endTime := now
  165. page := 1
  166. pagesize := 1000
  167. count := pagesize
  168. worker_server_num := 1
  169. cardNum := 1
  170. durationSum := int64(0)
  171. durationSumAll := int64(0)
  172. cloudBrainOneSum := int64(0)
  173. cloudBrainTwoSum := int64(0)
  174. c2NetSum := int64(0)
  175. for count == pagesize && count != 0 {
  176. cloudbrains, _, err := models.CloudbrainAllStatic(&models.CloudbrainsOptions{
  177. ListOptions: models.ListOptions{
  178. Page: page,
  179. PageSize: pagesize,
  180. },
  181. Type: models.TypeCloudBrainAll,
  182. BeginTimeUnix: int64(recordBeginTime),
  183. EndTimeUnix: endTime.Unix(),
  184. })
  185. if err != nil {
  186. ctx.ServerError("Get cloudbrains failed:", err)
  187. return
  188. }
  189. models.LoadSpecs4CloudbrainInfo(cloudbrains)
  190. for _, cloudbrain := range cloudbrains {
  191. if cloudbrain.WorkServerNumber >= 1 {
  192. worker_server_num = cloudbrain.WorkServerNumber
  193. } else {
  194. worker_server_num = 1
  195. }
  196. if cloudbrain.Spec != nil {
  197. cardNum = cloudbrain.Spec.AccCardsNum
  198. } else {
  199. cardNum = 1
  200. }
  201. duration := cloudbrain.Duration
  202. durationSum = duration * int64(worker_server_num) * int64(cardNum)
  203. if cloudbrain.Cloudbrain.Type == models.TypeCloudBrainOne {
  204. cloudBrainOneSum += durationSum
  205. } else if cloudbrain.Cloudbrain.Type == models.TypeCloudBrainTwo {
  206. cloudBrainTwoSum += durationSum
  207. } else if cloudbrain.Cloudbrain.Type == models.TypeC2Net {
  208. c2NetSum += durationSum
  209. }
  210. durationSumAll += durationSum
  211. count = len(cloudbrains)
  212. page += 1
  213. }
  214. }
  215. ctx.JSON(http.StatusOK, map[string]interface{}{
  216. "cloudBrainOneSum": cloudBrainOneSum,
  217. "cloudBrainTwoSum": cloudBrainTwoSum,
  218. "c2NetSum": c2NetSum,
  219. "durationSumAll": durationSumAll,
  220. })
  221. }
  222. func GetAllCloudbrainsTrend(ctx *context.Context) {
  223. queryType := ctx.QueryTrim("type")
  224. now := time.Now()
  225. beginTimeStr := ctx.QueryTrim("beginTime")
  226. endTimeStr := ctx.QueryTrim("endTime")
  227. var beginTime time.Time
  228. var endTime time.Time
  229. dateCloudbrainNum := make([]DateCloudbrainNum, 0)
  230. var err error
  231. if queryType != "" {
  232. if queryType == "all" {
  233. recordCloudbrain, err := models.GetRecordBeginTime()
  234. if err != nil {
  235. log.Error("Can not get recordCloudbrain", err)
  236. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.record_begintime_get_err"))
  237. return
  238. }
  239. brainRecordBeginTime := recordCloudbrain[0].Cloudbrain.CreatedUnix.AsTime()
  240. beginTime = brainRecordBeginTime
  241. endTime = now
  242. dateCloudbrainNum, err = getMonthCloudbrainNum(beginTime, endTime)
  243. if err != nil {
  244. log.Error("Can not query getMonthCloudbrainNum.", err)
  245. ctx.Error(http.StatusBadRequest, ctx.Tr("getMonthCloudbrainNum_get_error"))
  246. return
  247. }
  248. } else if queryType == "today" {
  249. beginTime = time.Date(now.Year(), now.Month(), now.Day(), 0, 0, 0, 0, now.Location())
  250. // endTimeTemp = now
  251. endTime = beginTime.AddDate(0, 0, 1)
  252. dateCloudbrainNum, err = getDayCloudbrainNum(beginTime, endTime)
  253. if err != nil {
  254. log.Error("Can not query getDayCloudbrainNum.", err)
  255. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainNum_get_error"))
  256. return
  257. }
  258. } else if queryType == "yesterday" {
  259. beginTime = now.AddDate(0, 0, -1)
  260. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  261. endTime = time.Date(now.Year(), now.Month(), now.Day(), 0, 0, 0, 0, now.Location())
  262. dateCloudbrainNum, err = getDayCloudbrainNum(beginTime, endTime)
  263. if err != nil {
  264. log.Error("Can not query getDayCloudbrainNum.", err)
  265. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainNum_get_error"))
  266. return
  267. }
  268. } else if queryType == "last_7day" {
  269. beginTime = now.AddDate(0, 0, -6)
  270. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  271. endTime = now
  272. dateCloudbrainNum, err = getDayCloudbrainNum(beginTime, endTime)
  273. if err != nil {
  274. log.Error("Can not query getDayCloudbrainNum.", err)
  275. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainNum_get_error"))
  276. return
  277. }
  278. } else if queryType == "last_30day" {
  279. beginTime = now.AddDate(0, 0, -29)
  280. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  281. endTime = now
  282. dateCloudbrainNum, err = getDayCloudbrainNum(beginTime, endTime)
  283. if err != nil {
  284. log.Error("Can not query getDayCloudbrainNum.", err)
  285. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainNum_get_error"))
  286. return
  287. }
  288. } else if queryType == "current_month" {
  289. endTime = now
  290. beginTime = time.Date(endTime.Year(), endTime.Month(), 1, 0, 0, 0, 0, now.Location())
  291. dateCloudbrainNum, err = getDayCloudbrainNum(beginTime, endTime)
  292. if err != nil {
  293. log.Error("Can not query getDayCloudbrainNum.", err)
  294. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainNum_get_error"))
  295. return
  296. }
  297. } else if queryType == "current_year" {
  298. endTime = now
  299. beginTime = time.Date(endTime.Year(), 1, 1, 0, 0, 0, 0, now.Location())
  300. // endTimeTemp = beginTime.AddDate(0, 1, 0)
  301. dateCloudbrainNum, err = getMonthCloudbrainNum(beginTime, endTime)
  302. if err != nil {
  303. log.Error("Can not query getMonthCloudbrainNum.", err)
  304. ctx.Error(http.StatusBadRequest, ctx.Tr("getMonthCloudbrainNum_get_error"))
  305. return
  306. }
  307. } else if queryType == "last_month" {
  308. lastMonthTime := now.AddDate(0, -1, 0)
  309. beginTime = time.Date(lastMonthTime.Year(), lastMonthTime.Month(), 1, 0, 0, 0, 0, now.Location())
  310. endTime = time.Date(now.Year(), now.Month(), 1, 0, 0, 0, 0, now.Location())
  311. dateCloudbrainNum, err = getDayCloudbrainNum(beginTime, endTime)
  312. if err != nil {
  313. log.Error("Can not query getDayCloudbrainNum.", err)
  314. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainNum_get_error"))
  315. return
  316. }
  317. }
  318. } else {
  319. if beginTimeStr == "" || endTimeStr == "" {
  320. //如果查询类型和开始时间结束时间都未设置,按queryType=all处理
  321. recordCloudbrain, err := models.GetRecordBeginTime()
  322. if err != nil {
  323. log.Error("Can not get recordCloudbrain", err)
  324. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.record_begintime_get_err"))
  325. return
  326. }
  327. brainRecordBeginTime := recordCloudbrain[0].Cloudbrain.CreatedUnix.AsTime()
  328. beginTime = brainRecordBeginTime
  329. endTime = now
  330. dateCloudbrainNum, err = getMonthCloudbrainNum(beginTime, endTime)
  331. if err != nil {
  332. log.Error("Can not query getMonthCloudbrainNum.", err)
  333. ctx.Error(http.StatusBadRequest, ctx.Tr("getMonthCloudbrainNum_get_error"))
  334. return
  335. }
  336. } else {
  337. beginTime, err = time.ParseInLocation("2006-01-02", beginTimeStr, time.Local)
  338. if err != nil {
  339. log.Error("Can not ParseInLocation.", err)
  340. ctx.Error(http.StatusBadRequest, ctx.Tr("ParseInLocation_get_error"))
  341. return
  342. }
  343. endTime, err = time.ParseInLocation("2006-01-02", endTimeStr, time.Local)
  344. if err != nil {
  345. log.Error("Can not ParseInLocation.", err)
  346. ctx.Error(http.StatusBadRequest, ctx.Tr("ParseInLocation_get_error"))
  347. return
  348. }
  349. if endTime.After(time.Now()) {
  350. endTime = time.Now()
  351. }
  352. dateCloudbrainNum, err = getDayCloudbrainNum(beginTime, endTime)
  353. if err != nil {
  354. log.Error("Can not query getDayCloudbrainNum.", err)
  355. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainNum_get_error"))
  356. return
  357. }
  358. }
  359. }
  360. ctx.JSON(http.StatusOK, map[string]interface{}{
  361. "timeCloudbrainNum": dateCloudbrainNum,
  362. })
  363. }
  364. func GetAllCloudbrainsTrendDetail(ctx *context.Context) {
  365. queryType := ctx.QueryTrim("type")
  366. now := time.Now()
  367. beginTimeStr := ctx.QueryTrim("beginTime")
  368. endTimeStr := ctx.QueryTrim("endTime")
  369. var beginTime time.Time
  370. var endTime time.Time
  371. var endTimeTemp time.Time
  372. dayCloudbrainInfo := make([]DateCloudbrainInfo, 0)
  373. var err error
  374. var count int
  375. if queryType != "" {
  376. if queryType == "all" {
  377. recordCloudbrain, err := models.GetRecordBeginTime()
  378. if err != nil {
  379. log.Error("Can not get recordCloudbrain", err)
  380. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.record_begintime_get_err"))
  381. return
  382. }
  383. brainRecordBeginTime := recordCloudbrain[0].Cloudbrain.CreatedUnix.AsTime()
  384. beginTime = brainRecordBeginTime
  385. endTime = now
  386. dayCloudbrainInfo, count, err = getMonthCloudbrainInfo(beginTime, endTime)
  387. if err != nil {
  388. log.Error("Can not query getDayCloudbrainInfo.", err)
  389. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainInfo_get_error"))
  390. return
  391. }
  392. } else if queryType == "today" {
  393. beginTime = now.AddDate(0, 0, 0)
  394. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  395. endTime = now
  396. dayCloudbrainInfo, count, err = getDayCloudbrainInfo(beginTime, endTime)
  397. if err != nil {
  398. log.Error("Can not query getDayCloudbrainInfo.", err)
  399. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainInfo_get_error"))
  400. return
  401. }
  402. } else if queryType == "yesterday" {
  403. beginTime = now.AddDate(0, 0, -1)
  404. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  405. endTime = time.Date(now.Year(), now.Month(), now.Day(), 0, 0, 0, 0, now.Location())
  406. dayCloudbrainInfo, count, err = getDayCloudbrainInfo(beginTime, endTime)
  407. if err != nil {
  408. log.Error("Can not query getDayCloudbrainInfo.", err)
  409. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainInfo_get_error"))
  410. return
  411. }
  412. } else if queryType == "last_7day" {
  413. beginTime = now.AddDate(0, 0, -6)
  414. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  415. endTime = now
  416. endTimeTemp = time.Date(endTimeTemp.Year(), endTimeTemp.Month(), endTimeTemp.Day(), 0, 0, 0, 0, now.Location())
  417. dayCloudbrainInfo, count, err = getDayCloudbrainInfo(beginTime, endTime)
  418. if err != nil {
  419. log.Error("Can not query getDayCloudbrainInfo.", err)
  420. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainInfo_get_error"))
  421. return
  422. }
  423. } else if queryType == "last_30day" {
  424. beginTime = now.AddDate(0, 0, -29)
  425. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  426. endTime = now
  427. dayCloudbrainInfo, count, err = getDayCloudbrainInfo(beginTime, endTime)
  428. if err != nil {
  429. log.Error("Can not query getDayCloudbrainInfo.", err)
  430. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainInfo_get_error"))
  431. return
  432. }
  433. } else if queryType == "current_month" {
  434. endTime = now
  435. beginTime = time.Date(endTime.Year(), endTime.Month(), 1, 0, 0, 0, 0, now.Location())
  436. dayCloudbrainInfo, count, err = getDayCloudbrainInfo(beginTime, endTime)
  437. if err != nil {
  438. log.Error("Can not query getDayCloudbrainInfo.", err)
  439. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainInfo_get_error"))
  440. return
  441. }
  442. } else if queryType == "current_year" {
  443. endTime = now
  444. beginTime = time.Date(endTime.Year(), 1, 1, 0, 0, 0, 0, now.Location())
  445. dayCloudbrainInfo, count, err = getMonthCloudbrainInfo(beginTime, endTime)
  446. if err != nil {
  447. log.Error("Can not query getDayCloudbrainInfo.", err)
  448. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainInfo_get_error"))
  449. return
  450. }
  451. } else if queryType == "last_month" {
  452. lastMonthTime := now.AddDate(0, -1, 0)
  453. beginTime = time.Date(lastMonthTime.Year(), lastMonthTime.Month(), 1, 0, 0, 0, 0, now.Location())
  454. endTime = time.Date(now.Year(), now.Month(), 1, 0, 0, 0, 0, now.Location())
  455. dayCloudbrainInfo, count, err = getDayCloudbrainInfo(beginTime, endTime)
  456. if err != nil {
  457. log.Error("Can not query getDayCloudbrainInfo.", err)
  458. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainInfo_get_error"))
  459. return
  460. }
  461. }
  462. } else {
  463. if beginTimeStr == "" || endTimeStr == "" {
  464. //如果查询类型和开始时间结束时间都未设置,按queryType=all处理
  465. recordCloudbrain, err := models.GetRecordBeginTime()
  466. if err != nil {
  467. log.Error("Can not get recordCloudbrain", err)
  468. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.record_begintime_get_err"))
  469. return
  470. }
  471. brainRecordBeginTime := recordCloudbrain[0].Cloudbrain.CreatedUnix.AsTime()
  472. beginTime = brainRecordBeginTime
  473. endTime = now
  474. dayCloudbrainInfo, count, err = getMonthCloudbrainInfo(beginTime, endTime)
  475. if err != nil {
  476. log.Error("Can not query getDayCloudbrainInfo.", err)
  477. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainInfo_get_error"))
  478. return
  479. }
  480. } else {
  481. beginTime, err = time.ParseInLocation("2006-01-02", beginTimeStr, time.Local)
  482. if err != nil {
  483. log.Error("Can not ParseInLocation.", err)
  484. ctx.Error(http.StatusBadRequest, ctx.Tr("ParseInLocation_get_error"))
  485. return
  486. }
  487. endTime, err = time.ParseInLocation("2006-01-02", endTimeStr, time.Local)
  488. if err != nil {
  489. log.Error("Can not ParseInLocation.", err)
  490. ctx.Error(http.StatusBadRequest, ctx.Tr("ParseInLocation_get_error"))
  491. return
  492. }
  493. if endTime.After(time.Now()) {
  494. endTime = time.Now()
  495. }
  496. endTimeTemp = beginTime.AddDate(0, 0, 1)
  497. dayCloudbrainInfo, count, err = getDayCloudbrainInfo(beginTime, endTime)
  498. if err != nil {
  499. log.Error("Can not query getDayCloudbrainInfo.", err)
  500. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainInfo_get_error"))
  501. return
  502. }
  503. }
  504. }
  505. page := ctx.QueryInt("page")
  506. if page <= 0 {
  507. page = 1
  508. }
  509. pagesize := ctx.QueryInt("pagesize")
  510. if pagesize <= 0 {
  511. pagesize = 5
  512. }
  513. pageDateCloudbrainInfo := getPageDateCloudbrainInfo(dayCloudbrainInfo, page, pagesize)
  514. ctx.JSON(http.StatusOK, map[string]interface{}{
  515. "totalCount": count,
  516. "timeCloudbrainInfo": pageDateCloudbrainInfo,
  517. })
  518. }
  519. func getPageDateCloudbrainInfo(dateCloudbrainInfo []DateCloudbrainInfo, page int, pagesize int) []DateCloudbrainInfo {
  520. begin := (page - 1) * pagesize
  521. end := (page) * pagesize
  522. if begin > len(dateCloudbrainInfo)-1 {
  523. return nil
  524. }
  525. if end > len(dateCloudbrainInfo)-1 {
  526. return dateCloudbrainInfo[begin:]
  527. } else {
  528. return dateCloudbrainInfo[begin:end]
  529. }
  530. }
  531. func GetAllCloudbrainsPeriodDistribution(ctx *context.Context) {
  532. queryType := ctx.QueryTrim("type")
  533. beginTimeStr := ctx.QueryTrim("beginTime")
  534. endTimeStr := ctx.QueryTrim("endTime")
  535. recordCloudbrain, err := models.GetRecordBeginTime()
  536. if err != nil {
  537. log.Error("Can not get record begin time", err)
  538. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.record_begintime_get_err"))
  539. return
  540. }
  541. recordBeginTime := time.Unix(int64(recordCloudbrain[0].Cloudbrain.CreatedUnix), 0)
  542. beginTime, endTime, err := getCloudbrainTimePeroid(ctx, recordBeginTime)
  543. if err != nil {
  544. log.Error("Parameter is wrong", err)
  545. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.parameter_is_wrong"))
  546. return
  547. }
  548. cloudOneJobTypeRes := make(map[string]int)
  549. cloudTwoJobTypeRes := make(map[string]int)
  550. intelligentNetJobTypeRes := make(map[string]int)
  551. cloudBrainPeriodNum := make(map[int]int)
  552. cloudBrainComputeResource := make(map[string]int)
  553. beginTimeTemp := beginTime.Unix()
  554. if queryType == "all" || (queryType == "" && (beginTimeStr == "" || endTimeStr == "")) {
  555. beginTimeTemp = int64(recordCloudbrain[0].Cloudbrain.CreatedUnix)
  556. }
  557. page := 1
  558. pagesize := 1000
  559. count := pagesize
  560. //Each time a maximum of 1000 pieces of data are detected to the memory, batch processing
  561. for count == pagesize && count != 0 {
  562. cloudbrains, _, err := models.CloudbrainAllStatic(&models.CloudbrainsOptions{
  563. ListOptions: models.ListOptions{
  564. Page: page,
  565. PageSize: pagesize,
  566. },
  567. Type: models.TypeCloudBrainAll,
  568. BeginTimeUnix: beginTimeTemp,
  569. EndTimeUnix: endTime.Unix(),
  570. })
  571. if err != nil {
  572. ctx.ServerError("Get cloudbrains failed:", err)
  573. return
  574. }
  575. for _, cloudbrain := range cloudbrains {
  576. if cloudbrain.Cloudbrain.Type == models.TypeCloudBrainOne {
  577. if _, ok := cloudOneJobTypeRes[cloudbrain.JobType]; !ok {
  578. cloudOneJobTypeRes[cloudbrain.JobType] = 1
  579. } else {
  580. cloudOneJobTypeRes[cloudbrain.JobType] += 1
  581. }
  582. }
  583. if cloudbrain.Cloudbrain.Type == models.TypeCloudBrainTwo {
  584. if _, ok := cloudTwoJobTypeRes[cloudbrain.JobType]; !ok {
  585. cloudTwoJobTypeRes[cloudbrain.JobType] = 1
  586. } else {
  587. cloudTwoJobTypeRes[cloudbrain.JobType] += 1
  588. }
  589. }
  590. if cloudbrain.Cloudbrain.Type == models.TypeC2Net {
  591. if _, ok := intelligentNetJobTypeRes[cloudbrain.JobType]; !ok {
  592. intelligentNetJobTypeRes[cloudbrain.JobType] = 1
  593. } else {
  594. intelligentNetJobTypeRes[cloudbrain.JobType] += 1
  595. }
  596. }
  597. if _, ok := cloudBrainPeriodNum[cloudbrain.Cloudbrain.Type]; !ok {
  598. cloudBrainPeriodNum[cloudbrain.Cloudbrain.Type] = 1
  599. } else {
  600. cloudBrainPeriodNum[cloudbrain.Cloudbrain.Type] += 1
  601. }
  602. if _, ok := cloudBrainComputeResource[cloudbrain.Cloudbrain.ComputeResource]; !ok {
  603. cloudBrainComputeResource[cloudbrain.Cloudbrain.ComputeResource] = 1
  604. } else {
  605. cloudBrainComputeResource[cloudbrain.Cloudbrain.ComputeResource] += 1
  606. }
  607. }
  608. count = len(cloudbrains)
  609. page += 1
  610. }
  611. jobTypeList := []string{string(models.JobTypeDebug), string(models.JobTypeTrain), string(models.JobTypeInference), string(models.JobTypeBenchmark),
  612. string(models.JobTypeBrainScore), string(models.JobTypeSnn4imagenet)}
  613. for _, v := range jobTypeList {
  614. if _, ok := cloudOneJobTypeRes[v]; !ok {
  615. cloudOneJobTypeRes[v] = 0
  616. }
  617. if _, ok := cloudTwoJobTypeRes[v]; !ok {
  618. cloudTwoJobTypeRes[v] = 0
  619. }
  620. if _, ok := intelligentNetJobTypeRes[v]; !ok {
  621. intelligentNetJobTypeRes[v] = 0
  622. }
  623. }
  624. cloudBrainTypeList := []int{0, 1, 2}
  625. for _, v := range cloudBrainTypeList {
  626. if _, ok := cloudBrainPeriodNum[v]; !ok {
  627. cloudBrainPeriodNum[v] = 0
  628. }
  629. }
  630. ComputeResourceList := []string{"CPU/GPU", "NPU"}
  631. for _, v := range ComputeResourceList {
  632. if _, ok := cloudBrainComputeResource[v]; !ok {
  633. cloudBrainComputeResource[v] = 0
  634. }
  635. }
  636. cloudOneJobTypeRes["EVALUATION"] = cloudOneJobTypeRes[string(models.JobTypeBenchmark)] + cloudOneJobTypeRes[string(models.JobTypeSnn4imagenet)] + cloudOneJobTypeRes[string(models.JobTypeBrainScore)]
  637. cloudTwoJobTypeRes["EVALUATION"] = cloudTwoJobTypeRes[string(models.JobTypeBenchmark)] + cloudTwoJobTypeRes[string(models.JobTypeSnn4imagenet)] + cloudTwoJobTypeRes[string(models.JobTypeBrainScore)]
  638. intelligentNetJobTypeRes["EVALUATION"] = intelligentNetJobTypeRes[string(models.JobTypeBenchmark)] + intelligentNetJobTypeRes[string(models.JobTypeSnn4imagenet)] + intelligentNetJobTypeRes[string(models.JobTypeBrainScore)]
  639. ctx.JSON(http.StatusOK, map[string]interface{}{
  640. "cloudOneJobTypeRes": cloudOneJobTypeRes,
  641. "cloudTwoJobTypeRes": cloudTwoJobTypeRes,
  642. "intelligentNetJobTypeRes": intelligentNetJobTypeRes,
  643. "cloudBrainPeriodNum": cloudBrainPeriodNum,
  644. "cloudBrainComputeResource": cloudBrainComputeResource,
  645. })
  646. }
  647. func GetCloudbrainsStatusAnalysis(ctx *context.Context) {
  648. // recordCloudbrain, err := models.GetRecordBeginTime()
  649. // if err != nil {
  650. // log.Error("Can not get recordCloudbrain", err)
  651. // ctx.Error(http.StatusBadRequest, ctx.Tr("repo.record_begintime_get_err"))
  652. // return
  653. // }
  654. // recordBeginTime := recordCloudbrain[0].Cloudbrain.CreatedUnix
  655. // endTime := time.Now()
  656. // cloudBrainStatusResult := make(map[string]int)
  657. // cloudBrainStatusAnalysis := make(map[string]int)
  658. // totalCount := 0
  659. // page := 1
  660. // pagesize := 1000
  661. // count := pagesize
  662. // for count == pagesize && count != 0 {
  663. // cloudbrains, _, err := models.CloudbrainAllStatic(&models.CloudbrainsOptions{
  664. // ListOptions: models.ListOptions{
  665. // Page: page,
  666. // PageSize: pagesize,
  667. // },
  668. // Type: models.TypeCloudBrainAll,
  669. // BeginTimeUnix: int64(recordBeginTime),
  670. // EndTimeUnix: endTime.Unix(),
  671. // })
  672. // if err != nil {
  673. // ctx.ServerError("Get cloudbrains failed:", err)
  674. // return
  675. // }
  676. // for _, cloudbrain := range cloudbrains {
  677. // if _, ok := cloudBrainStatusResult[cloudbrain.Status]; !ok {
  678. // cloudBrainStatusResult[cloudbrain.Status] = 1
  679. // } else {
  680. // cloudBrainStatusResult[cloudbrain.Status] += 1
  681. // }
  682. // }
  683. // count = len(cloudbrains)
  684. // totalCount = totalCount + count
  685. // page += 1
  686. // }
  687. // var jobStatuses []string
  688. // jobStatuses = append(jobStatuses, string(models.ModelArtsTrainJobWaiting), string(models.ModelArtsTrainJobFailed), string(models.ModelArtsRunning), string(models.ModelArtsTrainJobCompleted),
  689. // string(models.ModelArtsStarting), string(models.ModelArtsRestarting), string(models.ModelArtsStartFailed),
  690. // string(models.ModelArtsStopping), string(models.ModelArtsStopped), string(models.JobSucceeded))
  691. // jobStatusesCount := 0
  692. // for _, v := range jobStatuses {
  693. // if _, ok := cloudBrainStatusResult[v]; !ok {
  694. // cloudBrainStatusAnalysis[v] = 0
  695. // } else {
  696. // cloudBrainStatusAnalysis[v] = cloudBrainStatusResult[v]
  697. // }
  698. // jobStatusesCount = jobStatusesCount + cloudBrainStatusResult[v]
  699. // }
  700. // cloudBrainStatusAnalysis["OTHER"] = totalCount - jobStatusesCount
  701. cloudbrainStatusCount, err := models.GetCloudbrainStatusCount()
  702. log.Info("cloudbrainStatusCount:", cloudbrainStatusCount)
  703. if err != nil {
  704. log.Error("Can not query cloudbrainStatusCount.", err)
  705. return
  706. }
  707. ctx.JSON(http.StatusOK, map[string]interface{}{
  708. // "cloudBrainStatusResult": cloudBrainStatusAnalysis,
  709. "cloudbrainStatusCount": cloudbrainStatusCount,
  710. })
  711. }
  712. func GetCloudbrainsDetailData(ctx *context.Context) {
  713. recordCloudbrain, err := models.GetRecordBeginTime()
  714. if err != nil {
  715. log.Error("Can not get recordCloudbrain", err)
  716. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.record_begintime_get_err"))
  717. return
  718. }
  719. recordBeginTime := recordCloudbrain[0].Cloudbrain.CreatedUnix
  720. endTime := time.Now()
  721. listType := ctx.Query("listType")
  722. jobType := ctx.Query("jobType")
  723. jobStatus := ctx.Query("jobStatus")
  724. cloudBrainType := ctx.QueryInt("Type")
  725. aiCenter := ctx.Query("aiCenter")
  726. needDeleteInfo := ctx.Query("needDeleteInfo")
  727. page := ctx.QueryInt("page")
  728. pageSize := ctx.QueryInt("pagesize")
  729. if page <= 0 {
  730. page = 1
  731. }
  732. if pageSize <= 0 {
  733. pageSize = 10
  734. }
  735. var jobTypes []string
  736. jobTypeNot := false
  737. if jobType == string(models.JobTypeBenchmark) {
  738. jobTypes = append(jobTypes, string(models.JobTypeBenchmark), string(models.JobTypeBrainScore), string(models.JobTypeSnn4imagenet))
  739. } else if jobType != "all" && jobType != "" {
  740. jobTypes = append(jobTypes, jobType)
  741. }
  742. var jobStatuses []string
  743. jobStatusNot := false
  744. if jobStatus == "other" {
  745. jobStatusNot = true
  746. jobStatuses = append(jobStatuses, string(models.ModelArtsTrainJobWaiting), string(models.ModelArtsTrainJobFailed), string(models.ModelArtsRunning), string(models.ModelArtsTrainJobCompleted),
  747. string(models.ModelArtsStarting), string(models.ModelArtsRestarting), string(models.ModelArtsStartFailed),
  748. string(models.ModelArtsStopping), string(models.ModelArtsStopped), string(models.JobSucceeded))
  749. } else if jobStatus != "all" && jobStatus != "" {
  750. jobStatuses = append(jobStatuses, jobStatus)
  751. }
  752. keyword := strings.Trim(ctx.Query("q"), " ")
  753. ciTasks, count, err := models.CloudbrainAll(&models.CloudbrainsOptions{
  754. ListOptions: models.ListOptions{
  755. Page: page,
  756. PageSize: pageSize,
  757. },
  758. Keyword: keyword,
  759. Type: cloudBrainType,
  760. ComputeResource: listType,
  761. JobTypeNot: jobTypeNot,
  762. JobStatusNot: jobStatusNot,
  763. JobStatus: jobStatuses,
  764. JobTypes: jobTypes,
  765. NeedRepoInfo: true,
  766. BeginTimeUnix: int64(recordBeginTime),
  767. EndTimeUnix: endTime.Unix(),
  768. AiCenter: aiCenter,
  769. NeedDeleteInfo: needDeleteInfo,
  770. })
  771. if err != nil {
  772. ctx.ServerError("Get job failed:", err)
  773. return
  774. }
  775. models.LoadSpecs4CloudbrainInfo(ciTasks)
  776. nilTime := time.Time{}
  777. tasks := []models.TaskDetail{}
  778. for i, task := range ciTasks {
  779. ciTasks[i].Cloudbrain.ComputeResource = task.ComputeResource
  780. var taskDetail models.TaskDetail
  781. taskDetail.ID = ciTasks[i].Cloudbrain.ID
  782. taskDetail.JobID = ciTasks[i].Cloudbrain.JobID
  783. taskDetail.JobName = ciTasks[i].JobName
  784. taskDetail.DisplayJobName = ciTasks[i].DisplayJobName
  785. taskDetail.Status = ciTasks[i].Status
  786. taskDetail.JobType = ciTasks[i].JobType
  787. taskDetail.CreatedUnix = ciTasks[i].Cloudbrain.CreatedUnix
  788. taskDetail.RunTime = ciTasks[i].Cloudbrain.TrainJobDuration
  789. taskDetail.StartTime = ciTasks[i].StartTime
  790. taskDetail.EndTime = ciTasks[i].EndTime
  791. taskDetail.ComputeResource = ciTasks[i].ComputeResource
  792. taskDetail.Type = ciTasks[i].Cloudbrain.Type
  793. taskDetail.UserName = ciTasks[i].User.Name
  794. taskDetail.RepoID = ciTasks[i].RepoID
  795. if ciTasks[i].Repo != nil {
  796. taskDetail.RepoName = ciTasks[i].Repo.OwnerName + "/" + ciTasks[i].Repo.Name
  797. taskDetail.RepoAlias = ciTasks[i].Repo.OwnerName + "/" + ciTasks[i].Repo.Alias
  798. }
  799. if ciTasks[i].Cloudbrain.WorkServerNumber >= 1 {
  800. taskDetail.WorkServerNum = int64(ciTasks[i].Cloudbrain.WorkServerNumber)
  801. } else {
  802. taskDetail.WorkServerNum = 1
  803. }
  804. // taskDetail.CardNum, taskDetail.CardType, _ = repo.GetCloudbrainCardNumAndType(ciTasks[i].Cloudbrain)
  805. // if ciTasks[i].Cloudbrain.Spec != nil {
  806. // taskDetail.CardNum = ciTasks[i].Cloudbrain.Spec.AccCardsNum
  807. // taskDetail.CardType = ciTasks[i].Cloudbrain.Spec.AccCardType
  808. // taskDetail.AiCenter = ciTasks[i].Cloudbrain.Spec.AiCenterName
  809. // }
  810. // taskDetail.AiCenter = repo.GetCloudbrainAiCenter(ciTasks[i].Cloudbrain, ctx)
  811. // taskDetail.FlavorName, _ = repo.GetCloudbrainFlavorName(ciTasks[i].Cloudbrain)
  812. taskDetail.CardDuration = repo.GetCloudbrainCardDuration(ciTasks[i].Cloudbrain)
  813. taskDetail.WaitTime = repo.GetCloudbrainWaitTime(ciTasks[i].Cloudbrain)
  814. if ciTasks[i].Cloudbrain.DeletedAt != nilTime || ciTasks[i].Repo == nil {
  815. taskDetail.IsDelete = true
  816. } else {
  817. taskDetail.IsDelete = false
  818. }
  819. taskDetail.Spec = ciTasks[i].Spec
  820. tasks = append(tasks, taskDetail)
  821. }
  822. pager := context.NewPagination(int(count), pageSize, page, getTotalPage(count, pageSize))
  823. pager.SetDefaultParams(ctx)
  824. pager.AddParam(ctx, "listType", "ListType")
  825. ctx.JSON(http.StatusOK, map[string]interface{}{
  826. "Title": ctx.Tr("kanban.cloudBrains"),
  827. "Tasks": tasks,
  828. "Keyword": keyword,
  829. "pager": pager,
  830. "count": count,
  831. })
  832. }
  833. func getCloudbrainAiCenter(task models.Cloudbrain, ctx *context.Context) string {
  834. if task.Type == models.TypeCloudBrainOne {
  835. return ctx.Tr("repo.cloudbrain1")
  836. } else if task.Type == models.TypeCloudBrainTwo {
  837. return ctx.Tr("repo.cloudbrain2")
  838. } else if task.Type == models.TypeC2Net {
  839. return task.AiCenter
  840. }
  841. return ""
  842. }
  843. func GetCloudbrainsCreateHoursData(ctx *context.Context) {
  844. recordCloudbrain, err := models.GetRecordBeginTime()
  845. if err != nil {
  846. log.Error("Can not get record begin time", err)
  847. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.record_begintime_get_err"))
  848. return
  849. }
  850. recordBeginTime := time.Unix(int64(recordCloudbrain[0].Cloudbrain.CreatedUnix), 0)
  851. // recordBeginTime, _ := time.Parse("2006-01-02 15:04:05", recordTime)
  852. now := time.Now()
  853. queryType := ctx.QueryTrim("type")
  854. beginTimeStr := ctx.QueryTrim("beginTime")
  855. endTimeStr := ctx.QueryTrim("endTime")
  856. var beginTime time.Time
  857. var endTime time.Time
  858. createHourPeriodCount := make(map[string]interface{})
  859. if queryType != "" {
  860. if queryType == "all" {
  861. beginTime = recordBeginTime
  862. endTime = now.AddDate(0, 0, 1)
  863. endTime = time.Date(endTime.Year(), endTime.Month(), endTime.Day(), 0, 0, 0, 0, now.Location())
  864. } else if queryType == "today" {
  865. beginTime = time.Date(now.Year(), now.Month(), now.Day(), 0, 0, 0, 0, now.Location())
  866. endTime = now.AddDate(0, 0, 1)
  867. } else if queryType == "yesterday" {
  868. beginTime = now.AddDate(0, 0, -1)
  869. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  870. endTime = time.Date(now.Year(), now.Month(), now.Day(), 0, 0, 0, 0, now.Location())
  871. } else if queryType == "current_week" {
  872. beginTime = now.AddDate(0, 0, -int(time.Now().Weekday())+1) //begin from monday
  873. endTime = now
  874. } else if queryType == "current_month" {
  875. beginTime = time.Date(now.Year(), now.Month(), 1, 0, 0, 0, 0, now.Location())
  876. endTime = now.AddDate(0, 0, 1)
  877. endTime = time.Date(endTime.Year(), endTime.Month(), endTime.Day(), 0, 0, 0, 0, now.Location())
  878. } else if queryType == "monthly" {
  879. endTime = now
  880. beginTime = now.AddDate(0, -1, 0)
  881. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  882. } else if queryType == "current_year" {
  883. beginTime = time.Date(now.Year(), 1, 1, 0, 0, 0, 0, now.Location())
  884. endTime = now.AddDate(0, 0, 1)
  885. endTime = time.Date(endTime.Year(), endTime.Month(), endTime.Day(), 0, 0, 0, 0, now.Location())
  886. } else if queryType == "last_month" {
  887. lastMonthTime := now.AddDate(0, -1, 0)
  888. beginTime = time.Date(lastMonthTime.Year(), lastMonthTime.Month(), 1, 0, 0, 0, 0, now.Location())
  889. endTime = time.Date(now.Year(), now.Month(), 1, 0, 0, 0, 0, now.Location())
  890. } else if queryType == "last_7day" {
  891. beginTime = now.AddDate(0, 0, -6)
  892. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  893. endTime = now.AddDate(0, 0, 1)
  894. endTime = time.Date(endTime.Year(), endTime.Month(), endTime.Day(), 0, 0, 0, 0, now.Location())
  895. } else if queryType == "last_30day" {
  896. beginTime = now.AddDate(0, 0, -29)
  897. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  898. endTime = now.AddDate(0, 0, 1)
  899. endTime = time.Date(endTime.Year(), endTime.Month(), endTime.Day(), 0, 0, 0, 0, now.Location())
  900. }
  901. } else {
  902. if beginTimeStr == "" || endTimeStr == "" {
  903. //如果查询类型和开始时间结束时间都未设置,按queryType=all处理
  904. beginTime = recordBeginTime
  905. endTime = now.AddDate(0, 0, 1)
  906. endTime = time.Date(endTime.Year(), endTime.Month(), endTime.Day(), 0, 0, 0, 0, now.Location())
  907. } else {
  908. beginTime, err = time.ParseInLocation("2006-01-02", beginTimeStr, time.Local)
  909. if err != nil {
  910. log.Error("Can not ParseInLocation.", err)
  911. ctx.Error(http.StatusBadRequest, ctx.Tr("ParseInLocation_get_error"))
  912. return
  913. }
  914. endTime, err = time.ParseInLocation("2006-01-02", endTimeStr, time.Local)
  915. if err != nil {
  916. log.Error("Can not ParseInLocation.", err)
  917. ctx.Error(http.StatusBadRequest, ctx.Tr("ParseInLocation_get_error"))
  918. return
  919. }
  920. endTime = time.Date(endTime.Year(), endTime.Month(), endTime.Day(), 0, 0, 0, 0, now.Location())
  921. }
  922. }
  923. dateBeginTime := beginTime.Format("2006-01-02")
  924. dateEndTime := endTime.Format("2006-01-02")
  925. createHourPeriodCount, err = models.GetCreateHourPeriodCount(dateBeginTime, dateEndTime)
  926. if err != nil {
  927. log.Error("Can not query hourPeriodCount.", err)
  928. ctx.Error(http.StatusBadRequest, ctx.Tr("hourPeriodCount_get_error"))
  929. return
  930. }
  931. runHourPeriodCount, err := models.GetRunHourPeriodCount(dateBeginTime, dateEndTime)
  932. if err != nil {
  933. log.Error("Can not query runHourPeriodCount.", err)
  934. ctx.Error(http.StatusBadRequest, ctx.Tr("runHourPeriodCount_get_error"))
  935. return
  936. }
  937. ctx.JSON(http.StatusOK, map[string]interface{}{
  938. "recordBeginTime": recordCloudbrain[0].Cloudbrain.CreatedUnix,
  939. "updateTime": now.Unix(),
  940. "createHourPeriodCount": createHourPeriodCount,
  941. "runHourPeriodCount": runHourPeriodCount,
  942. })
  943. }
  944. func GetWaittingTop(ctx *context.Context) {
  945. ciTasks, err := models.GetWaittingTop()
  946. if err != nil {
  947. log.Error("Can not get record begin time", err)
  948. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.record_begintime_get_err"))
  949. return
  950. }
  951. tasks := []models.TaskDetail{}
  952. for i, task := range ciTasks {
  953. ciTasks[i].Cloudbrain.ComputeResource = task.ComputeResource
  954. var taskDetail models.TaskDetail
  955. taskDetail.DisplayJobName = ciTasks[i].DisplayJobName
  956. taskDetail.UserName = ciTasks[i].User.Name
  957. taskDetail.RepoID = ciTasks[i].RepoID
  958. if ciTasks[i].Repo != nil {
  959. taskDetail.RepoName = ciTasks[i].Repo.OwnerName + "/" + ciTasks[i].Repo.Name
  960. }
  961. WaitTimeInt := time.Now().Unix() - ciTasks[i].Cloudbrain.CreatedUnix.AsTime().Unix()
  962. taskDetail.WaitTime = models.ConvertDurationToStr(WaitTimeInt)
  963. if WaitTimeInt < 0 {
  964. taskDetail.WaitTime = "00:00:00"
  965. }
  966. tasks = append(tasks, taskDetail)
  967. }
  968. ctx.JSON(http.StatusOK, map[string]interface{}{
  969. "tasks": tasks,
  970. })
  971. }
  972. func GetRunningTop(ctx *context.Context) {
  973. ciTasks, err := models.GetRunningTop()
  974. if err != nil {
  975. log.Error("Can not get record begin time", err)
  976. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.record_begintime_get_err"))
  977. return
  978. }
  979. tasks := []models.TaskDetail{}
  980. for i, task := range ciTasks {
  981. ciTasks[i].Cloudbrain.ComputeResource = task.ComputeResource
  982. var taskDetail models.TaskDetail
  983. taskDetail.DisplayJobName = ciTasks[i].DisplayJobName
  984. taskDetail.RunTime = ciTasks[i].Cloudbrain.TrainJobDuration
  985. taskDetail.UserName = ciTasks[i].User.Name
  986. taskDetail.RepoID = ciTasks[i].RepoID
  987. if ciTasks[i].Repo != nil {
  988. taskDetail.RepoName = ciTasks[i].Repo.OwnerName + "/" + ciTasks[i].Repo.Name
  989. }
  990. tasks = append(tasks, taskDetail)
  991. }
  992. ctx.JSON(http.StatusOK, map[string]interface{}{
  993. "tasks": tasks,
  994. })
  995. }
  996. func getCloudbrainCount(beginTime time.Time, endTime time.Time, cloudbrains []*models.CloudbrainInfo) (map[string]int, map[string]int, map[string]int, map[int]int, map[string]int) {
  997. cloudOneJobTypeRes := make(map[string]int)
  998. cloudTwoJobTypeRes := make(map[string]int)
  999. intelligentNetJobTypeRes := make(map[string]int)
  1000. cloudBrainPeriodNum := make(map[int]int)
  1001. cloudBrainComputeResource := make(map[string]int)
  1002. for _, cloudbrain := range cloudbrains {
  1003. if int64(cloudbrain.Cloudbrain.CreatedUnix) >= beginTime.Unix() && int64(cloudbrain.Cloudbrain.CreatedUnix) < endTime.Unix() {
  1004. if cloudbrain.Cloudbrain.Type == models.TypeCloudBrainOne {
  1005. if _, ok := cloudOneJobTypeRes[cloudbrain.Cloudbrain.JobType]; !ok {
  1006. cloudOneJobTypeRes[cloudbrain.Cloudbrain.JobType] = 1
  1007. } else {
  1008. cloudOneJobTypeRes[cloudbrain.Cloudbrain.JobType] += 1
  1009. }
  1010. }
  1011. if cloudbrain.Cloudbrain.Type == models.TypeCloudBrainTwo {
  1012. if _, ok := cloudTwoJobTypeRes[cloudbrain.JobType]; !ok {
  1013. cloudTwoJobTypeRes[cloudbrain.Cloudbrain.JobType] = 1
  1014. } else {
  1015. cloudTwoJobTypeRes[cloudbrain.Cloudbrain.JobType] += 1
  1016. }
  1017. }
  1018. if _, ok := cloudBrainPeriodNum[cloudbrain.Cloudbrain.Type]; !ok {
  1019. cloudBrainPeriodNum[cloudbrain.Cloudbrain.Type] = 1
  1020. } else {
  1021. cloudBrainPeriodNum[cloudbrain.Cloudbrain.Type] += 1
  1022. }
  1023. if _, ok := cloudBrainComputeResource[cloudbrain.Cloudbrain.ComputeResource]; !ok {
  1024. cloudBrainComputeResource[cloudbrain.Cloudbrain.ComputeResource] = 1
  1025. } else {
  1026. cloudBrainComputeResource[cloudbrain.Cloudbrain.ComputeResource] += 1
  1027. }
  1028. }
  1029. }
  1030. ComputeResourceList := []string{"CPU/GPU", "NPU"}
  1031. for _, v := range ComputeResourceList {
  1032. if _, ok := cloudBrainComputeResource[v]; !ok {
  1033. cloudBrainComputeResource[v] = 0
  1034. }
  1035. }
  1036. jobTypeList := []string{"DEBUG", "BENCHMARK", "INFERENCE", "TRAIN", "SNN4IMAGENET", "BRAINSCORE"}
  1037. cloudBrainTypeList := []int{0, 1, 2}
  1038. for _, v := range jobTypeList {
  1039. if _, ok := cloudOneJobTypeRes[v]; !ok {
  1040. cloudOneJobTypeRes[v] = 0
  1041. }
  1042. if _, ok := cloudTwoJobTypeRes[v]; !ok {
  1043. cloudTwoJobTypeRes[v] = 0
  1044. }
  1045. if _, ok := intelligentNetJobTypeRes[v]; !ok {
  1046. intelligentNetJobTypeRes[v] = 0
  1047. }
  1048. }
  1049. for _, v := range cloudBrainTypeList {
  1050. if _, ok := cloudBrainPeriodNum[v]; !ok {
  1051. cloudBrainPeriodNum[v] = 0
  1052. }
  1053. }
  1054. cloudBrainPeriodNum[-1] = cloudBrainPeriodNum[0] + cloudBrainPeriodNum[1] + cloudBrainPeriodNum[2]
  1055. return cloudOneJobTypeRes, cloudTwoJobTypeRes, intelligentNetJobTypeRes, cloudBrainPeriodNum, cloudBrainComputeResource
  1056. }
  1057. func getDayCloudbrainNum(beginTime time.Time, endTime time.Time) ([]DateCloudbrainNum, error) {
  1058. var endTimeTemp time.Time
  1059. endTimeTemp = beginTime.AddDate(0, 0, 1)
  1060. cloudbrains, _, err := models.CloudbrainAllStatic(&models.CloudbrainsOptions{
  1061. Type: models.TypeCloudBrainAll,
  1062. BeginTimeUnix: beginTime.Unix(),
  1063. EndTimeUnix: endTime.Unix(),
  1064. })
  1065. if err != nil {
  1066. log.Error("Get cloudbrains failed:", err)
  1067. return nil, err
  1068. }
  1069. dayCloudbrainNum := make([]DateCloudbrainNum, 0)
  1070. for endTimeTemp.Before(endTime) || endTimeTemp.Equal(endTime) {
  1071. cloudOneJobTypeRes, cloudTwoJobTypeRes, intelligentNetJobTypeRes, cloudBrainPeriodNum, cloudBrainComputeResource := getCloudbrainCount(beginTime, endTimeTemp, cloudbrains)
  1072. dayCloudbrainNum = append(dayCloudbrainNum, DateCloudbrainNum{
  1073. Date: beginTime.Format("2006/01/02"),
  1074. CloudOneJobTypeRes: cloudOneJobTypeRes,
  1075. CloudTwoJobTypeRes: cloudTwoJobTypeRes,
  1076. IntelligentNetJobTypeRes: intelligentNetJobTypeRes,
  1077. CloudBrainPeriodNum: cloudBrainPeriodNum,
  1078. CloudBrainComputeResource: cloudBrainComputeResource,
  1079. })
  1080. if endTime.Before(endTimeTemp.AddDate(0, 0, 1)) && endTimeTemp.Before(endTime) {
  1081. beginTime = endTimeTemp
  1082. endTimeTemp = endTime
  1083. } else {
  1084. beginTime = endTimeTemp
  1085. endTimeTemp = beginTime.AddDate(0, 0, 1)
  1086. }
  1087. }
  1088. return dayCloudbrainNum, nil
  1089. }
  1090. func getMonthCloudbrainNum(beginTime time.Time, endTime time.Time) ([]DateCloudbrainNum, error) {
  1091. var endTimeTemp time.Time
  1092. now := time.Now()
  1093. endTimeTemp = beginTime.AddDate(0, 1, 0)
  1094. endTimeTemp = time.Date(endTimeTemp.Year(), endTimeTemp.Month(), 1, 0, 0, 0, 0, now.Location())
  1095. monthCloudbrainNum := make([]DateCloudbrainNum, 0)
  1096. cloudbrains, _, err := models.CloudbrainAllStatic(&models.CloudbrainsOptions{
  1097. Type: models.TypeCloudBrainAll,
  1098. BeginTimeUnix: beginTime.Unix(),
  1099. EndTimeUnix: endTime.Unix(),
  1100. })
  1101. if err != nil {
  1102. log.Error("Getcloudbrains failed:%v", err)
  1103. return nil, err
  1104. }
  1105. for endTimeTemp.Before(endTime) || endTimeTemp.Equal(endTime) {
  1106. cloudOneJobTypeRes, cloudTwoJobTypeRes, intelligentNetJobTypeRes, cloudBrainPeriodNum, cloudBrainComputeResource := getCloudbrainCount(beginTime, endTimeTemp, cloudbrains)
  1107. monthCloudbrainNum = append(monthCloudbrainNum, DateCloudbrainNum{
  1108. Date: beginTime.Format("2006/01"),
  1109. CloudOneJobTypeRes: cloudOneJobTypeRes,
  1110. CloudTwoJobTypeRes: cloudTwoJobTypeRes,
  1111. IntelligentNetJobTypeRes: intelligentNetJobTypeRes,
  1112. CloudBrainPeriodNum: cloudBrainPeriodNum,
  1113. CloudBrainComputeResource: cloudBrainComputeResource,
  1114. })
  1115. if endTime.Before(endTimeTemp.AddDate(0, 1, 0)) && endTimeTemp.Before(endTime) {
  1116. beginTime = endTimeTemp
  1117. endTimeTemp = endTime
  1118. } else {
  1119. beginTime = endTimeTemp
  1120. endTimeTemp = beginTime.AddDate(0, 1, 0)
  1121. }
  1122. }
  1123. return monthCloudbrainNum, nil
  1124. }
  1125. func getDayCloudbrainInfo(beginTime time.Time, endTime time.Time) ([]DateCloudbrainInfo, int, error) {
  1126. now := time.Now()
  1127. endTimeTemp := time.Date(endTime.Year(), endTime.Month(), endTime.Day(), 0, 0, 0, 0, now.Location())
  1128. if endTimeTemp.Equal(endTime) {
  1129. endTimeTemp = endTimeTemp.AddDate(0, 0, -1)
  1130. }
  1131. cloudbrains, _, err := models.CloudbrainAllStatic(&models.CloudbrainsOptions{
  1132. Type: models.TypeCloudBrainAll,
  1133. BeginTimeUnix: beginTime.Unix(),
  1134. EndTimeUnix: endTime.Unix(),
  1135. })
  1136. if err != nil {
  1137. log.Error("Getcloudbrains failed:%v", err)
  1138. return nil, 0, err
  1139. }
  1140. dayCloudbrainInfo := make([]DateCloudbrainInfo, 0)
  1141. count := 0
  1142. for beginTime.Before(endTimeTemp) || beginTime.Equal(endTimeTemp) {
  1143. _, _, _, cloudBrainPeriodNum, cloudBrainComputeResource := getCloudbrainCount(endTimeTemp, endTime, cloudbrains)
  1144. dayCloudbrainInfo = append(dayCloudbrainInfo, DateCloudbrainInfo{
  1145. Date: endTimeTemp.Format("2006/01/02"),
  1146. CloudBrainPeriodNum: cloudBrainPeriodNum,
  1147. CloudBrainComputeResource: cloudBrainComputeResource,
  1148. })
  1149. endTime = endTimeTemp
  1150. endTimeTemp = endTimeTemp.AddDate(0, 0, -1)
  1151. count += 1
  1152. }
  1153. return dayCloudbrainInfo, count, nil
  1154. }
  1155. func getMonthCloudbrainInfo(beginTime time.Time, endTime time.Time) ([]DateCloudbrainInfo, int, error) {
  1156. now := time.Now()
  1157. endTimeTemp := time.Date(endTime.Year(), endTime.Month(), 1, 0, 0, 0, 0, now.Location())
  1158. if endTimeTemp.Equal(endTime) {
  1159. endTimeTemp = endTimeTemp.AddDate(0, -1, 0)
  1160. }
  1161. cloudbrains, _, err := models.CloudbrainAllStatic(&models.CloudbrainsOptions{
  1162. Type: models.TypeCloudBrainAll,
  1163. BeginTimeUnix: beginTime.Unix(),
  1164. EndTimeUnix: endTime.Unix(),
  1165. })
  1166. if err != nil {
  1167. log.Error("Getcloudbrains failed:%v", err)
  1168. return nil, 0, err
  1169. }
  1170. dayCloudbrainInfo := make([]DateCloudbrainInfo, 0)
  1171. count := 0
  1172. for beginTime.Before(endTimeTemp) || beginTime.Equal(endTimeTemp) || (endTimeTemp.Before(beginTime) && beginTime.Before(endTime)) {
  1173. _, _, _, cloudBrainPeriodNum, cloudBrainComputeResource := getCloudbrainCount(endTimeTemp, endTime, cloudbrains)
  1174. dayCloudbrainInfo = append(dayCloudbrainInfo, DateCloudbrainInfo{
  1175. Date: endTimeTemp.Format("2006/01"),
  1176. CloudBrainPeriodNum: cloudBrainPeriodNum,
  1177. CloudBrainComputeResource: cloudBrainComputeResource,
  1178. })
  1179. endTime = endTimeTemp
  1180. endTimeTemp = endTimeTemp.AddDate(0, -1, 0)
  1181. count += 1
  1182. }
  1183. return dayCloudbrainInfo, count, nil
  1184. }
  1185. func DownloadCloudBrainBoard(ctx *context.Context) {
  1186. page := 1
  1187. pageSize := 300
  1188. var cloudBrain = ctx.Tr("repo.cloudbrain")
  1189. fileName := getCloudbrainFileName(cloudBrain)
  1190. _, total, err := models.CloudbrainAll(&models.CloudbrainsOptions{
  1191. ListOptions: models.ListOptions{
  1192. Page: page,
  1193. PageSize: pageSize,
  1194. },
  1195. Type: models.TypeCloudBrainAll,
  1196. NeedRepoInfo: false,
  1197. })
  1198. if err != nil {
  1199. log.Warn("Can not get cloud brain info", err)
  1200. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.cloudbrain_query_fail"))
  1201. return
  1202. }
  1203. totalPage := getTotalPage(total, pageSize)
  1204. f := excelize.NewFile()
  1205. index := f.NewSheet(cloudBrain)
  1206. f.DeleteSheet("Sheet1")
  1207. for k, v := range allCloudbrainHeader(ctx) {
  1208. f.SetCellValue(cloudBrain, k, v)
  1209. }
  1210. var row = 2
  1211. for i := 0; i < totalPage; i++ {
  1212. pageRecords, _, err := models.CloudbrainAll(&models.CloudbrainsOptions{
  1213. ListOptions: models.ListOptions{
  1214. Page: page,
  1215. PageSize: pageSize,
  1216. },
  1217. Type: models.TypeCloudBrainAll,
  1218. NeedRepoInfo: true,
  1219. })
  1220. if err != nil {
  1221. log.Warn("Can not get cloud brain info", err)
  1222. continue
  1223. }
  1224. for _, record := range pageRecords {
  1225. for k, v := range allCloudbrainValues(row, record, ctx) {
  1226. f.SetCellValue(cloudBrain, k, v)
  1227. }
  1228. row++
  1229. }
  1230. page++
  1231. }
  1232. f.SetActiveSheet(index)
  1233. ctx.Resp.Header().Set("Content-Disposition", "attachment; filename="+url.QueryEscape(fileName))
  1234. ctx.Resp.Header().Set("Content-Type", "application/octet-stream")
  1235. f.WriteTo(ctx.Resp)
  1236. }
  1237. func getCloudbrainFileName(baseName string) string {
  1238. return baseName + "_" + time.Now().Format(EXCEL_DATE_FORMAT) + ".xlsx"
  1239. }
  1240. func allCloudbrainHeader(ctx *context.Context) map[string]string {
  1241. return map[string]string{"A1": ctx.Tr("repo.cloudbrain_task"), "B1": ctx.Tr("repo.cloudbrain_type"), "C1": ctx.Tr("repo.modelarts.status"), "D1": ctx.Tr("repo.cloudbrain_task_type"),
  1242. "E1": ctx.Tr("repo.modelarts.createtime"), "F1": ctx.Tr("repo.modelarts.train_job.wait_time"), "G1": ctx.Tr("repo.modelarts.train_job.dura_time"),
  1243. "H1": ctx.Tr("cloudbrain.card_duration"),
  1244. "I1": ctx.Tr("repo.modelarts.train_job.start_time"), "J1": ctx.Tr("repo.modelarts.train_job.end_time"),
  1245. "K1": ctx.Tr("repo.modelarts.computing_resources"), "L1": ctx.Tr("cloudbrain.card_type"),
  1246. "M1": ctx.Tr("repo.grampus.train_job.ai_center"), "N1": ctx.Tr("cloudbrain.resource_specification"),
  1247. "O1": ctx.Tr("repo.cloudbrain_creator"), "P1": ctx.Tr("repo.repo_name"), "Q1": ctx.Tr("repo.cloudbrain_task_name"),
  1248. "R1": ctx.Tr("repo.modelarts.deletetime")}
  1249. }
  1250. func allCloudbrainValues(row int, rs *models.CloudbrainInfo, ctx *context.Context) map[string]string {
  1251. return map[string]string{getCellName("A", row): rs.DisplayJobName, getCellName("B", row): getCloudbrainType(rs, ctx), getCellName("C", row): rs.Status, getCellName("D", row): rs.JobType,
  1252. getCellName("E", row): time.Unix(int64(rs.Cloudbrain.CreatedUnix), 0).Format(CREATE_TIME_FORMAT), getCellName("F", row): repo.GetCloudbrainWaitTime(rs.Cloudbrain),
  1253. getCellName("G", row): rs.TrainJobDuration, getCellName("H", row): repo.GetCloudbrainCardDuration(rs.Cloudbrain),
  1254. getCellName("I", row): getBrainStartTime(rs),
  1255. getCellName("J", row): getBrainEndTime(rs), getCellName("K", row): rs.ComputeResource, getCellName("L", row): getCloudbrainCardType(rs),
  1256. getCellName("M", row): repo.GetCloudbrainAiCenter(rs.Cloudbrain, ctx), getCellName("N", row): getCloudbrainFlavorName(rs),
  1257. getCellName("O", row): rs.Name, getCellName("P", row): getBrainRepo(rs),
  1258. getCellName("Q", row): rs.JobName, getCellName("R", row): getBrainDeleteTime(rs),
  1259. }
  1260. }
  1261. func getBrainRepo(rs *models.CloudbrainInfo) string {
  1262. if rs.Repo != nil {
  1263. return rs.Repo.OwnerName + "/" + rs.Repo.Alias
  1264. }
  1265. return ""
  1266. }
  1267. func getBrainStartTime(rs *models.CloudbrainInfo) string {
  1268. timeString := time.Unix(int64(rs.Cloudbrain.StartTime), 0).Format(CREATE_TIME_FORMAT)
  1269. if timeString != "1970/01/01 08:00:00" {
  1270. return timeString
  1271. } else {
  1272. return "0"
  1273. }
  1274. }
  1275. func getBrainEndTime(rs *models.CloudbrainInfo) string {
  1276. timeString := time.Unix(int64(rs.Cloudbrain.EndTime), 0).Format(CREATE_TIME_FORMAT)
  1277. if timeString != "1970/01/01 08:00:00" {
  1278. return timeString
  1279. } else {
  1280. return "0"
  1281. }
  1282. }
  1283. func getCloudbrainType(rs *models.CloudbrainInfo, ctx *context.Context) string {
  1284. if rs.Cloudbrain.Type == models.TypeCloudBrainOne {
  1285. return ctx.Tr("repo.cloudbrain1")
  1286. } else if rs.Cloudbrain.Type == models.TypeCloudBrainTwo {
  1287. return ctx.Tr("repo.cloudbrain2")
  1288. } else if rs.Cloudbrain.Type == models.TypeC2Net {
  1289. return ctx.Tr("repo.intelligent_net")
  1290. } else {
  1291. return ctx.Tr("repo.cloudbrain_untype")
  1292. }
  1293. }
  1294. func getCloudbrainCardType(rs *models.CloudbrainInfo) string {
  1295. _, cardType, _ := repo.GetCloudbrainCardNumAndType(rs.Cloudbrain)
  1296. return cardType
  1297. }
  1298. func getCloudbrainFlavorName(rs *models.CloudbrainInfo) string {
  1299. flavorName, _ := repo.GetCloudbrainFlavorName(rs.Cloudbrain)
  1300. return flavorName
  1301. }
  1302. func getBrainDeleteTime(rs *models.CloudbrainInfo) string {
  1303. nilTime := time.Time{}
  1304. if rs.Cloudbrain.DeletedAt != nilTime {
  1305. return rs.Cloudbrain.DeletedAt.Format("2006-01-02 15:04:05")
  1306. } else {
  1307. return ""
  1308. }
  1309. }
  1310. func getCloudbrainTimePeroid(ctx *context.Context, recordBeginTime time.Time) (time.Time, time.Time, error) {
  1311. queryType := ctx.QueryTrim("type")
  1312. beginTimeStr := ctx.QueryTrim("beginTime")
  1313. endTimeStr := ctx.QueryTrim("endTime")
  1314. now := time.Now()
  1315. var beginTime time.Time
  1316. var endTime time.Time
  1317. var err error
  1318. if queryType != "" {
  1319. if queryType == "all" {
  1320. beginTime = recordBeginTime
  1321. endTime = now
  1322. } else if queryType == "today" {
  1323. endTime = now
  1324. beginTime = time.Date(endTime.Year(), endTime.Month(), endTime.Day(), 0, 0, 0, 0, now.Location())
  1325. } else if queryType == "yesterday" {
  1326. endTime = time.Date(now.Year(), now.Month(), now.Day(), 0, 0, 0, 0, now.Location())
  1327. beginTime = endTime.AddDate(0, 0, -1)
  1328. } else if queryType == "last_7day" {
  1329. beginTime = now.AddDate(0, 0, -6)
  1330. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  1331. endTime = now
  1332. } else if queryType == "last_30day" {
  1333. beginTime = now.AddDate(0, 0, -29)
  1334. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  1335. endTime = now
  1336. } else if queryType == "current_month" {
  1337. endTime = now
  1338. beginTime = time.Date(endTime.Year(), endTime.Month(), 1, 0, 0, 0, 0, now.Location())
  1339. } else if queryType == "monthly" {
  1340. endTime = now
  1341. beginTime = now.AddDate(0, -1, 1)
  1342. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  1343. } else if queryType == "current_year" {
  1344. endTime = now
  1345. beginTime = time.Date(endTime.Year(), 1, 1, 0, 0, 0, 0, now.Location())
  1346. } else if queryType == "last_month" {
  1347. lastMonthTime := now.AddDate(0, -1, 0)
  1348. beginTime = time.Date(lastMonthTime.Year(), lastMonthTime.Month(), 1, 0, 0, 0, 0, now.Location())
  1349. endTime = time.Date(now.Year(), now.Month(), 1, 0, 0, 0, 0, now.Location())
  1350. } else {
  1351. return now, now, fmt.Errorf("The value of type parameter is wrong.")
  1352. }
  1353. } else {
  1354. if beginTimeStr == "" || endTimeStr == "" {
  1355. //如果查询类型和开始时间结束时间都未设置,按queryType=all处理
  1356. beginTime = recordBeginTime
  1357. endTime = now
  1358. } else {
  1359. beginTime, err = time.ParseInLocation("2006-01-02", beginTimeStr, time.Local)
  1360. if err != nil {
  1361. return now, now, err
  1362. }
  1363. endTime, err = time.ParseInLocation("2006-01-02", endTimeStr, time.Local)
  1364. if err != nil {
  1365. return now, now, err
  1366. }
  1367. }
  1368. }
  1369. if beginTime.Before(recordBeginTime) {
  1370. beginTime = recordBeginTime
  1371. }
  1372. return beginTime, endTime, nil
  1373. }