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

3 years ago
3 years ago
3 years ago
2 years ago
3 years ago
3 years ago
2 years ago
2 years ago
2 years ago
2 years ago
3 years ago
3 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
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
2 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
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
2 years ago
2 years ago
2 years ago
3 years ago
2 years ago
2 years ago
2 years ago
2 years ago
3 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
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 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
2 years ago
2 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
2 years ago
3 years ago
3 years ago
2 years ago
3 years ago
3 years ago
3 years ago
3 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
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
2 years ago
3 years ago
2 years ago
3 years ago
3 years ago
3 years ago
2 years ago
3 years ago
3 years ago
2 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
2 years ago
3 years ago
2 years ago
3 years ago
3 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
3 years ago
2 years ago
2 years ago
2 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 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
3 years ago
3 years ago
3 years ago
3 years ago
2 years ago
2 years ago
2 years ago
3 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
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
2 years ago
3 years ago
3 years ago
3 years ago
2 years ago
3 years ago
3 years ago
3 years ago
3 years ago
2 years ago
3 years ago
3 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
2 years ago
3 years ago
2 years ago
3 years ago
3 years ago
3 years ago
2 years ago
2 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
2 years ago
3 years ago
3 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
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
2 years ago
3 years ago
3 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
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 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
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
2 years ago
3 years ago
3 years ago
3 years ago
2 years ago
3 years ago
2 years ago
3 years ago
3 years ago
3 years ago
2 years ago
3 years ago
2 years ago
3 years ago
2 years ago
3 years ago
2 years ago
3 years ago
2 years ago
2 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
3 years ago
3 years ago
2 years ago
2 years ago
2 years ago
2 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 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
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 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
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
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
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
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
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
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
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
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
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
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
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
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
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
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
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
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
2 years ago
1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924
  1. package repo
  2. import (
  3. "fmt"
  4. "net/http"
  5. "net/url"
  6. "strconv"
  7. "strings"
  8. "time"
  9. "code.gitea.io/gitea/models"
  10. "code.gitea.io/gitea/modules/context"
  11. "code.gitea.io/gitea/modules/log"
  12. "code.gitea.io/gitea/modules/timeutil"
  13. "code.gitea.io/gitea/routers/repo"
  14. cloudbrainService "code.gitea.io/gitea/services/cloudbrain"
  15. "code.gitea.io/gitea/services/cloudbrain/resource"
  16. "github.com/360EntSecGroup-Skylar/excelize/v2"
  17. )
  18. type DateCloudbrainNum struct {
  19. Date string `json:"date"`
  20. CloudOneJobTypeRes map[string]int `json:"cloudOneJobTypeRes"`
  21. CloudTwoJobTypeRes map[string]int `json:"cloudTwoJobTypeRes"`
  22. IntelligentNetJobTypeRes map[string]int `json:"intelligentNetJobTypeRes"`
  23. CDCenterJobTypeRes map[string]int `json:"cDCenterJobTypeRes"`
  24. CloudBrainPeriodNum map[int]int `json:"cloudBrainPeriodNum"`
  25. CloudBrainComputeResource map[string]int `json:"cloudBrainComputeResource"`
  26. }
  27. type DateCloudbrainInfo struct {
  28. Date string `json:"date"`
  29. CloudBrainPeriodNum map[int]int `json:"cloudBrainPeriodNum"`
  30. CloudBrainComputeResource map[string]int `json:"cloudBrainComputeResource"`
  31. }
  32. type CloudbrainsStatusAnalysis struct {
  33. JobWaitingCount int64 `json:"jobWaitingCount"`
  34. JobRunningCount int64 `json:"jobRunningCount"`
  35. JobStoppedCount int64 `json:"jobStoppedCount"`
  36. JobCompletedCount int64 `json:"jobCompletedCount"`
  37. JobFailedCount int64 `json:"jobFailedCount"`
  38. JobKilledCount int64 `json:"jobKilledCount"`
  39. JobInitCount int64 `json:"jobInitCount"`
  40. }
  41. func GetAllCloudbrainsOverview(ctx *context.Context) {
  42. recordCloudbrain, err := models.GetRecordBeginTime()
  43. if err != nil {
  44. log.Error("Can not get recordCloudbrain", err)
  45. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.record_begintime_get_err"))
  46. return
  47. }
  48. recordBeginTime := recordCloudbrain[0].Cloudbrain.CreatedUnix
  49. now := time.Now()
  50. beginTime := time.Date(now.Year(), now.Month(), now.Day(), 0, 0, 0, 0, now.Location())
  51. endTime := now
  52. todayCreatorCount, err := models.GetTodayCreatorCount(beginTime, endTime)
  53. if err != nil {
  54. log.Error("Can not query todayCreatorCount.", err)
  55. return
  56. }
  57. cloudbrainTypeCount, err := models.GetCloudbrainTypeCount()
  58. if err != nil {
  59. log.Error("Can not query cloudbrainTypeCount.", err)
  60. return
  61. }
  62. todayCloudbrainCount, err := models.GetTodayCloudbrainCount(beginTime, endTime)
  63. if err != nil {
  64. log.Error("Can not query todayCloudbrainCount.", err)
  65. return
  66. }
  67. todayRunningCount, err := models.GetTodayRunningCount(beginTime, endTime)
  68. if err != nil {
  69. log.Error("Can not query todayRunningCount.", err)
  70. return
  71. }
  72. todayWaitingCount, err := models.GetTodayWaitingCount(beginTime, endTime)
  73. if err != nil {
  74. log.Error("Can not query todayWaitingCount.", err)
  75. return
  76. }
  77. todayCompletedCount := todayCloudbrainCount - todayRunningCount - todayWaitingCount
  78. creatorCount, err := models.GetCreatorCount()
  79. if err != nil {
  80. log.Error("Can not query creatorCount.", err)
  81. return
  82. }
  83. ctx.JSON(http.StatusOK, map[string]interface{}{
  84. "recordBeginTime": recordBeginTime,
  85. "updateTime": now.Unix(),
  86. "todayCreatorCount": todayCreatorCount,
  87. "creatorCount": creatorCount,
  88. "todayRunningCount": todayRunningCount,
  89. "todayCompletedCount": todayCompletedCount,
  90. "todayWaitingCount": todayWaitingCount,
  91. "todayNewJobCount": todayCloudbrainCount,
  92. "cloudbrainTypeCount": cloudbrainTypeCount,
  93. })
  94. }
  95. func GetOverviewDuration(ctx *context.Context) {
  96. durationSum := 0
  97. cardDurationSum := 0
  98. cloudBrainOneCardDuSum := 0
  99. cloudBrainTwoCardDuSum := 0
  100. c2NetCardDuSum := 0
  101. cDNetCardDuSum := 0
  102. cloudBrainOneDuration := 0
  103. cloudBrainTwoDuration := 0
  104. c2NetDuration := 0
  105. cDCenterDuration := 0
  106. cloudbrainTypeDuration, err := models.GetCloudbrainTypeCardDuration()
  107. if err != nil {
  108. log.Error("GetCloudbrainTypeCardDuration err!", err)
  109. return
  110. }
  111. for _, result := range cloudbrainTypeDuration {
  112. if result.Type == models.TypeCloudBrainOne {
  113. cloudBrainOneDuration = result.DurationSum
  114. cloudBrainOneCardDuSum = result.CardDurationSum
  115. }
  116. if result.Type == models.TypeCloudBrainTwo {
  117. cloudBrainTwoDuration = result.DurationSum
  118. cloudBrainTwoCardDuSum = result.CardDurationSum
  119. }
  120. if result.Type == models.TypeC2Net {
  121. c2NetDuration = result.DurationSum
  122. c2NetCardDuSum = result.CardDurationSum
  123. }
  124. if result.Type == models.TypeCDCenter {
  125. cDCenterDuration = result.DurationSum
  126. cDNetCardDuSum = result.CardDurationSum
  127. }
  128. }
  129. cloudbrainAllDuration, err := models.GetCloudbrainAllCardDuration()
  130. if err != nil {
  131. log.Error("GetCloudbrainAllCardDuration err!", err)
  132. return
  133. }
  134. durationSum = cloudbrainAllDuration.DurationSum
  135. cardDurationSum = cloudbrainAllDuration.CardDurationSum
  136. ctx.JSON(http.StatusOK, map[string]interface{}{
  137. "cloudBrainOneCardDuSum": cloudBrainOneCardDuSum,
  138. "cloudBrainTwoCardDuSum": cloudBrainTwoCardDuSum,
  139. "c2NetCardDuSum": c2NetCardDuSum,
  140. "cDNetCardDuSum": cDNetCardDuSum,
  141. "cardDuSum": cardDurationSum,
  142. "cloudBrainOneDuration": cloudBrainOneDuration,
  143. "cloudBrainTwoDuration": cloudBrainTwoDuration,
  144. "c2NetDuration": c2NetDuration,
  145. "cDCenterDuration": cDCenterDuration,
  146. "durationSum": durationSum,
  147. })
  148. }
  149. func GetCloudbrainCardDuration(task models.Cloudbrain) string {
  150. cardNum := int(0)
  151. spec, err := resource.GetCloudbrainSpec(task.ID)
  152. if err != nil {
  153. log.Info("error:" + err.Error())
  154. return ""
  155. }
  156. if spec != nil {
  157. cardNum = spec.AccCardsNum
  158. } else {
  159. cardNum = 1
  160. }
  161. var workServerNumber int64
  162. if task.WorkServerNumber >= 1 {
  163. workServerNumber = int64(task.WorkServerNumber)
  164. } else {
  165. workServerNumber = 1
  166. }
  167. cardDuration := models.ConvertDurationToStr(workServerNumber * int64(cardNum) * task.Duration)
  168. return cardDuration
  169. }
  170. func GetAllCloudbrainsTrend(ctx *context.Context) {
  171. queryType := ctx.QueryTrim("type")
  172. now := time.Now()
  173. beginTimeStr := ctx.QueryTrim("beginTime")
  174. endTimeStr := ctx.QueryTrim("endTime")
  175. var beginTime time.Time
  176. var endTime time.Time
  177. dateCloudbrainNum := make([]DateCloudbrainNum, 0)
  178. var err error
  179. if queryType != "" {
  180. if queryType == "all" {
  181. recordCloudbrain, err := models.GetRecordBeginTime()
  182. if err != nil {
  183. log.Error("Can not get recordCloudbrain", err)
  184. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.record_begintime_get_err"))
  185. return
  186. }
  187. brainRecordBeginTime := recordCloudbrain[0].Cloudbrain.CreatedUnix.AsTime()
  188. beginTime = brainRecordBeginTime
  189. endTime = now
  190. dateCloudbrainNum, err = getMonthCloudbrainNum(beginTime, endTime)
  191. if err != nil {
  192. log.Error("Can not query getMonthCloudbrainNum.", err)
  193. ctx.Error(http.StatusBadRequest, ctx.Tr("getMonthCloudbrainNum_get_error"))
  194. return
  195. }
  196. } else if queryType == "today" {
  197. beginTime = time.Date(now.Year(), now.Month(), now.Day(), 0, 0, 0, 0, now.Location())
  198. // endTimeTemp = now
  199. endTime = beginTime.AddDate(0, 0, 1)
  200. dateCloudbrainNum, err = getDayCloudbrainNum(beginTime, endTime)
  201. if err != nil {
  202. log.Error("Can not query getDayCloudbrainNum.", err)
  203. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainNum_get_error"))
  204. return
  205. }
  206. } else if queryType == "yesterday" {
  207. beginTime = now.AddDate(0, 0, -1)
  208. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  209. endTime = time.Date(now.Year(), now.Month(), now.Day(), 0, 0, 0, 0, now.Location())
  210. dateCloudbrainNum, err = getDayCloudbrainNum(beginTime, endTime)
  211. if err != nil {
  212. log.Error("Can not query getDayCloudbrainNum.", err)
  213. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainNum_get_error"))
  214. return
  215. }
  216. } else if queryType == "last_7day" {
  217. beginTime = now.AddDate(0, 0, -6)
  218. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  219. endTime = now
  220. dateCloudbrainNum, err = getDayCloudbrainNum(beginTime, endTime)
  221. if err != nil {
  222. log.Error("Can not query getDayCloudbrainNum.", err)
  223. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainNum_get_error"))
  224. return
  225. }
  226. } else if queryType == "last_30day" {
  227. beginTime = now.AddDate(0, 0, -29)
  228. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  229. endTime = now
  230. dateCloudbrainNum, err = getDayCloudbrainNum(beginTime, endTime)
  231. if err != nil {
  232. log.Error("Can not query getDayCloudbrainNum.", err)
  233. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainNum_get_error"))
  234. return
  235. }
  236. } else if queryType == "current_month" {
  237. endTime = now
  238. beginTime = time.Date(endTime.Year(), endTime.Month(), 1, 0, 0, 0, 0, now.Location())
  239. dateCloudbrainNum, err = getDayCloudbrainNum(beginTime, endTime)
  240. if err != nil {
  241. log.Error("Can not query getDayCloudbrainNum.", err)
  242. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainNum_get_error"))
  243. return
  244. }
  245. } else if queryType == "current_year" {
  246. endTime = now
  247. beginTime = time.Date(endTime.Year(), 1, 1, 0, 0, 0, 0, now.Location())
  248. // endTimeTemp = beginTime.AddDate(0, 1, 0)
  249. dateCloudbrainNum, err = getMonthCloudbrainNum(beginTime, endTime)
  250. if err != nil {
  251. log.Error("Can not query getMonthCloudbrainNum.", err)
  252. ctx.Error(http.StatusBadRequest, ctx.Tr("getMonthCloudbrainNum_get_error"))
  253. return
  254. }
  255. } else if queryType == "last_month" {
  256. lastMonthTime := now.AddDate(0, -1, 0)
  257. beginTime = time.Date(lastMonthTime.Year(), lastMonthTime.Month(), 1, 0, 0, 0, 0, now.Location())
  258. endTime = time.Date(now.Year(), now.Month(), 1, 0, 0, 0, 0, now.Location())
  259. dateCloudbrainNum, err = getDayCloudbrainNum(beginTime, endTime)
  260. if err != nil {
  261. log.Error("Can not query getDayCloudbrainNum.", err)
  262. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainNum_get_error"))
  263. return
  264. }
  265. }
  266. } else {
  267. if beginTimeStr == "" || endTimeStr == "" {
  268. //如果查询类型和开始时间结束时间都未设置,按queryType=all处理
  269. recordCloudbrain, err := models.GetRecordBeginTime()
  270. if err != nil {
  271. log.Error("Can not get recordCloudbrain", err)
  272. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.record_begintime_get_err"))
  273. return
  274. }
  275. brainRecordBeginTime := recordCloudbrain[0].Cloudbrain.CreatedUnix.AsTime()
  276. beginTime = brainRecordBeginTime
  277. endTime = now
  278. dateCloudbrainNum, err = getMonthCloudbrainNum(beginTime, endTime)
  279. if err != nil {
  280. log.Error("Can not query getMonthCloudbrainNum.", err)
  281. ctx.Error(http.StatusBadRequest, ctx.Tr("getMonthCloudbrainNum_get_error"))
  282. return
  283. }
  284. } else {
  285. beginTime, err = time.ParseInLocation("2006-01-02", beginTimeStr, time.Local)
  286. if err != nil {
  287. log.Error("Can not ParseInLocation.", err)
  288. ctx.Error(http.StatusBadRequest, ctx.Tr("ParseInLocation_get_error"))
  289. return
  290. }
  291. endTime, err = time.ParseInLocation("2006-01-02", endTimeStr, time.Local)
  292. if err != nil {
  293. log.Error("Can not ParseInLocation.", err)
  294. ctx.Error(http.StatusBadRequest, ctx.Tr("ParseInLocation_get_error"))
  295. return
  296. }
  297. if endTime.After(time.Now()) {
  298. endTime = time.Now()
  299. }
  300. dateCloudbrainNum, err = getDayCloudbrainNum(beginTime, endTime)
  301. if err != nil {
  302. log.Error("Can not query getDayCloudbrainNum.", err)
  303. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainNum_get_error"))
  304. return
  305. }
  306. }
  307. }
  308. ctx.JSON(http.StatusOK, map[string]interface{}{
  309. "timeCloudbrainNum": dateCloudbrainNum,
  310. })
  311. }
  312. func GetAllCloudbrainsTrendDetail(ctx *context.Context) {
  313. queryType := ctx.QueryTrim("type")
  314. now := time.Now()
  315. beginTimeStr := ctx.QueryTrim("beginTime")
  316. endTimeStr := ctx.QueryTrim("endTime")
  317. var beginTime time.Time
  318. var endTime time.Time
  319. var endTimeTemp time.Time
  320. dayCloudbrainInfo := make([]DateCloudbrainInfo, 0)
  321. var err error
  322. var count int
  323. if queryType != "" {
  324. if queryType == "all" {
  325. recordCloudbrain, err := models.GetRecordBeginTime()
  326. if err != nil {
  327. log.Error("Can not get recordCloudbrain", err)
  328. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.record_begintime_get_err"))
  329. return
  330. }
  331. brainRecordBeginTime := recordCloudbrain[0].Cloudbrain.CreatedUnix.AsTime()
  332. beginTime = brainRecordBeginTime
  333. endTime = now
  334. dayCloudbrainInfo, count, err = getMonthCloudbrainInfo(beginTime, endTime)
  335. if err != nil {
  336. log.Error("Can not query getDayCloudbrainInfo.", err)
  337. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainInfo_get_error"))
  338. return
  339. }
  340. } else if queryType == "today" {
  341. beginTime = now.AddDate(0, 0, 0)
  342. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  343. endTime = now
  344. dayCloudbrainInfo, count, err = getDayCloudbrainInfo(beginTime, endTime)
  345. if err != nil {
  346. log.Error("Can not query getDayCloudbrainInfo.", err)
  347. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainInfo_get_error"))
  348. return
  349. }
  350. } else if queryType == "yesterday" {
  351. beginTime = now.AddDate(0, 0, -1)
  352. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  353. endTime = time.Date(now.Year(), now.Month(), now.Day(), 0, 0, 0, 0, now.Location())
  354. dayCloudbrainInfo, count, err = getDayCloudbrainInfo(beginTime, endTime)
  355. if err != nil {
  356. log.Error("Can not query getDayCloudbrainInfo.", err)
  357. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainInfo_get_error"))
  358. return
  359. }
  360. } else if queryType == "last_7day" {
  361. beginTime = now.AddDate(0, 0, -6)
  362. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  363. endTime = now
  364. endTimeTemp = time.Date(endTimeTemp.Year(), endTimeTemp.Month(), endTimeTemp.Day(), 0, 0, 0, 0, now.Location())
  365. dayCloudbrainInfo, count, err = getDayCloudbrainInfo(beginTime, endTime)
  366. if err != nil {
  367. log.Error("Can not query getDayCloudbrainInfo.", err)
  368. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainInfo_get_error"))
  369. return
  370. }
  371. } else if queryType == "last_30day" {
  372. beginTime = now.AddDate(0, 0, -29)
  373. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  374. endTime = now
  375. dayCloudbrainInfo, count, err = getDayCloudbrainInfo(beginTime, endTime)
  376. if err != nil {
  377. log.Error("Can not query getDayCloudbrainInfo.", err)
  378. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainInfo_get_error"))
  379. return
  380. }
  381. } else if queryType == "current_month" {
  382. endTime = now
  383. beginTime = time.Date(endTime.Year(), endTime.Month(), 1, 0, 0, 0, 0, now.Location())
  384. dayCloudbrainInfo, count, err = getDayCloudbrainInfo(beginTime, endTime)
  385. if err != nil {
  386. log.Error("Can not query getDayCloudbrainInfo.", err)
  387. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainInfo_get_error"))
  388. return
  389. }
  390. } else if queryType == "current_year" {
  391. endTime = now
  392. beginTime = time.Date(endTime.Year(), 1, 1, 0, 0, 0, 0, now.Location())
  393. dayCloudbrainInfo, count, err = getMonthCloudbrainInfo(beginTime, endTime)
  394. if err != nil {
  395. log.Error("Can not query getDayCloudbrainInfo.", err)
  396. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainInfo_get_error"))
  397. return
  398. }
  399. } else if queryType == "last_month" {
  400. lastMonthTime := now.AddDate(0, -1, 0)
  401. beginTime = time.Date(lastMonthTime.Year(), lastMonthTime.Month(), 1, 0, 0, 0, 0, now.Location())
  402. endTime = time.Date(now.Year(), now.Month(), 1, 0, 0, 0, 0, now.Location())
  403. dayCloudbrainInfo, count, err = getDayCloudbrainInfo(beginTime, endTime)
  404. if err != nil {
  405. log.Error("Can not query getDayCloudbrainInfo.", err)
  406. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainInfo_get_error"))
  407. return
  408. }
  409. }
  410. } else {
  411. if beginTimeStr == "" || endTimeStr == "" {
  412. //如果查询类型和开始时间结束时间都未设置,按queryType=all处理
  413. recordCloudbrain, err := models.GetRecordBeginTime()
  414. if err != nil {
  415. log.Error("Can not get recordCloudbrain", err)
  416. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.record_begintime_get_err"))
  417. return
  418. }
  419. brainRecordBeginTime := recordCloudbrain[0].Cloudbrain.CreatedUnix.AsTime()
  420. beginTime = brainRecordBeginTime
  421. endTime = now
  422. dayCloudbrainInfo, count, err = getMonthCloudbrainInfo(beginTime, endTime)
  423. if err != nil {
  424. log.Error("Can not query getDayCloudbrainInfo.", err)
  425. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainInfo_get_error"))
  426. return
  427. }
  428. } else {
  429. beginTime, err = time.ParseInLocation("2006-01-02", beginTimeStr, time.Local)
  430. if err != nil {
  431. log.Error("Can not ParseInLocation.", err)
  432. ctx.Error(http.StatusBadRequest, ctx.Tr("ParseInLocation_get_error"))
  433. return
  434. }
  435. endTime, err = time.ParseInLocation("2006-01-02", endTimeStr, time.Local)
  436. if err != nil {
  437. log.Error("Can not ParseInLocation.", err)
  438. ctx.Error(http.StatusBadRequest, ctx.Tr("ParseInLocation_get_error"))
  439. return
  440. }
  441. if endTime.After(time.Now()) {
  442. endTime = time.Now()
  443. }
  444. endTimeTemp = beginTime.AddDate(0, 0, 1)
  445. dayCloudbrainInfo, count, err = getDayCloudbrainInfo(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. }
  452. }
  453. page := ctx.QueryInt("page")
  454. if page <= 0 {
  455. page = 1
  456. }
  457. pagesize := ctx.QueryInt("pagesize")
  458. if pagesize <= 0 {
  459. pagesize = 5
  460. }
  461. pageDateCloudbrainInfo := getPageDateCloudbrainInfo(dayCloudbrainInfo, page, pagesize)
  462. ctx.JSON(http.StatusOK, map[string]interface{}{
  463. "totalCount": count,
  464. "timeCloudbrainInfo": pageDateCloudbrainInfo,
  465. })
  466. }
  467. func getPageDateCloudbrainInfo(dateCloudbrainInfo []DateCloudbrainInfo, page int, pagesize int) []DateCloudbrainInfo {
  468. begin := (page - 1) * pagesize
  469. end := (page) * pagesize
  470. if begin > len(dateCloudbrainInfo)-1 {
  471. return nil
  472. }
  473. if end > len(dateCloudbrainInfo)-1 {
  474. return dateCloudbrainInfo[begin:]
  475. } else {
  476. return dateCloudbrainInfo[begin:end]
  477. }
  478. }
  479. func getPageDateCloudbrainDuration(dateUsageStatistic []models.DateUsageStatistic, page int, pagesize int) []models.DateUsageStatistic {
  480. begin := (page - 1) * pagesize
  481. end := (page) * pagesize
  482. if begin > len(dateUsageStatistic)-1 {
  483. return nil
  484. }
  485. if end > len(dateUsageStatistic)-1 {
  486. return dateUsageStatistic[begin:]
  487. } else {
  488. return dateUsageStatistic[begin:end]
  489. }
  490. }
  491. func GetAllCloudbrainsPeriodDistribution(ctx *context.Context) {
  492. queryType := ctx.QueryTrim("type")
  493. beginTimeStr := ctx.QueryTrim("beginTime")
  494. endTimeStr := ctx.QueryTrim("endTime")
  495. recordCloudbrain, err := models.GetRecordBeginTime()
  496. if err != nil {
  497. log.Error("Can not get record begin time", err)
  498. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.record_begintime_get_err"))
  499. return
  500. }
  501. recordBeginTime := time.Unix(int64(recordCloudbrain[0].Cloudbrain.CreatedUnix), 0)
  502. beginTime, endTime, err := getCloudbrainTimePeroid(ctx, recordBeginTime)
  503. if err != nil {
  504. log.Error("getCloudbrainTimePeroid error:", err)
  505. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.parameter_is_wrong"))
  506. return
  507. }
  508. cloudOneJobTypeRes := make(map[string]int)
  509. cloudTwoJobTypeRes := make(map[string]int)
  510. intelligentNetJobTypeRes := make(map[string]int)
  511. cDCenterJobTypeRes := make(map[string]int)
  512. cloudBrainPeriodNum := make(map[int]int)
  513. cloudBrainComputeResource := make(map[string]int)
  514. beginTimeTemp := beginTime.Unix()
  515. if queryType == "all" || (queryType == "" && (beginTimeStr == "" || endTimeStr == "")) {
  516. beginTimeTemp = int64(recordCloudbrain[0].Cloudbrain.CreatedUnix)
  517. }
  518. page := 1
  519. pagesize := 10000
  520. count := pagesize
  521. //Each time a maximum of 10000 pieces of data are detected to the memory, batch processing
  522. for count == pagesize && count != 0 {
  523. cloudbrains, _, err := models.CloudbrainAllStatic(&models.CloudbrainsOptions{
  524. ListOptions: models.ListOptions{
  525. Page: page,
  526. PageSize: pagesize,
  527. },
  528. Type: models.TypeCloudBrainAll,
  529. BeginTimeUnix: beginTimeTemp,
  530. EndTimeUnix: endTime.Unix(),
  531. })
  532. if err != nil {
  533. ctx.ServerError("Get cloudbrains failed:", err)
  534. return
  535. }
  536. for _, cloudbrain := range cloudbrains {
  537. if cloudbrain.Cloudbrain.Type == models.TypeCloudBrainOne {
  538. if _, ok := cloudOneJobTypeRes[cloudbrain.JobType]; !ok {
  539. cloudOneJobTypeRes[cloudbrain.JobType] = 1
  540. } else {
  541. cloudOneJobTypeRes[cloudbrain.JobType] += 1
  542. }
  543. }
  544. if cloudbrain.Cloudbrain.Type == models.TypeCloudBrainTwo {
  545. if _, ok := cloudTwoJobTypeRes[cloudbrain.JobType]; !ok {
  546. cloudTwoJobTypeRes[cloudbrain.JobType] = 1
  547. } else {
  548. cloudTwoJobTypeRes[cloudbrain.JobType] += 1
  549. }
  550. }
  551. if cloudbrain.Cloudbrain.Type == models.TypeC2Net {
  552. if _, ok := intelligentNetJobTypeRes[cloudbrain.JobType]; !ok {
  553. intelligentNetJobTypeRes[cloudbrain.JobType] = 1
  554. } else {
  555. intelligentNetJobTypeRes[cloudbrain.JobType] += 1
  556. }
  557. }
  558. if cloudbrain.Cloudbrain.Type == models.TypeCDCenter {
  559. if _, ok := cDCenterJobTypeRes[cloudbrain.JobType]; !ok {
  560. cDCenterJobTypeRes[cloudbrain.JobType] = 1
  561. } else {
  562. cDCenterJobTypeRes[cloudbrain.JobType] += 1
  563. }
  564. }
  565. if _, ok := cloudBrainPeriodNum[cloudbrain.Cloudbrain.Type]; !ok {
  566. cloudBrainPeriodNum[cloudbrain.Cloudbrain.Type] = 1
  567. } else {
  568. cloudBrainPeriodNum[cloudbrain.Cloudbrain.Type] += 1
  569. }
  570. if _, ok := cloudBrainComputeResource[cloudbrain.Cloudbrain.ComputeResource]; !ok {
  571. cloudBrainComputeResource[cloudbrain.Cloudbrain.ComputeResource] = 1
  572. } else {
  573. cloudBrainComputeResource[cloudbrain.Cloudbrain.ComputeResource] += 1
  574. }
  575. }
  576. count = len(cloudbrains)
  577. page += 1
  578. }
  579. jobTypeList := []string{string(models.JobTypeDebug), string(models.JobTypeTrain), string(models.JobTypeInference), string(models.JobTypeBenchmark),
  580. string(models.JobTypeModelSafety), string(models.JobTypeBrainScore), string(models.JobTypeSnn4imagenet)}
  581. for _, v := range jobTypeList {
  582. if _, ok := cloudOneJobTypeRes[v]; !ok {
  583. cloudOneJobTypeRes[v] = 0
  584. }
  585. if _, ok := cloudTwoJobTypeRes[v]; !ok {
  586. cloudTwoJobTypeRes[v] = 0
  587. }
  588. if _, ok := intelligentNetJobTypeRes[v]; !ok {
  589. intelligentNetJobTypeRes[v] = 0
  590. }
  591. if _, ok := cDCenterJobTypeRes[v]; !ok {
  592. cDCenterJobTypeRes[v] = 0
  593. }
  594. }
  595. cloudBrainTypeList := []int{0, 1, 2, 3}
  596. for _, v := range cloudBrainTypeList {
  597. if _, ok := cloudBrainPeriodNum[v]; !ok {
  598. cloudBrainPeriodNum[v] = 0
  599. }
  600. }
  601. ComputeResourceList := []string{"CPU/GPU", "NPU"}
  602. for _, v := range ComputeResourceList {
  603. if _, ok := cloudBrainComputeResource[v]; !ok {
  604. cloudBrainComputeResource[v] = 0
  605. }
  606. }
  607. cloudOneJobTypeRes["EVALUATION"] = cloudBrainPeriodNum[0] - cloudOneJobTypeRes[string(models.JobTypeTrain)] - cloudOneJobTypeRes[string(models.JobTypeInference)] - cloudOneJobTypeRes[string(models.JobTypeDebug)]
  608. cloudTwoJobTypeRes["EVALUATION"] = cloudBrainPeriodNum[1] - cloudTwoJobTypeRes[string(models.JobTypeTrain)] - cloudTwoJobTypeRes[string(models.JobTypeInference)] - cloudTwoJobTypeRes[string(models.JobTypeDebug)]
  609. intelligentNetJobTypeRes["EVALUATION"] = cloudBrainPeriodNum[2] - intelligentNetJobTypeRes[string(models.JobTypeTrain)] - intelligentNetJobTypeRes[string(models.JobTypeInference)] - intelligentNetJobTypeRes[string(models.JobTypeDebug)]
  610. cDCenterJobTypeRes["EVALUATION"] = cloudBrainPeriodNum[3] - cDCenterJobTypeRes[string(models.JobTypeTrain)] - cDCenterJobTypeRes[string(models.JobTypeInference)] - cDCenterJobTypeRes[string(models.JobTypeDebug)]
  611. ctx.JSON(http.StatusOK, map[string]interface{}{
  612. "cloudOneJobTypeRes": cloudOneJobTypeRes,
  613. "cloudTwoJobTypeRes": cloudTwoJobTypeRes,
  614. "intelligentNetJobTypeRes": intelligentNetJobTypeRes,
  615. "cDCenterJobTypeRes": cDCenterJobTypeRes,
  616. "cloudBrainPeriodNum": cloudBrainPeriodNum,
  617. "cloudBrainComputeResource": cloudBrainComputeResource,
  618. })
  619. }
  620. func GetCloudbrainsStatusAnalysis(ctx *context.Context) {
  621. cloudbrainStatusCount, err := models.GetCloudbrainStatusCount()
  622. log.Info("cloudbrainStatusCount:", cloudbrainStatusCount)
  623. if err != nil {
  624. log.Error("Can not query cloudbrainStatusCount.", err)
  625. return
  626. }
  627. ctx.JSON(http.StatusOK, map[string]interface{}{
  628. "cloudbrainStatusCount": cloudbrainStatusCount,
  629. })
  630. }
  631. func GetCloudbrainsDetailData(ctx *context.Context) {
  632. recordCloudbrain, err := models.GetRecordBeginTime()
  633. if err != nil {
  634. log.Error("Can not get recordCloudbrain", err)
  635. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.record_begintime_get_err"))
  636. return
  637. }
  638. recordBeginTime := recordCloudbrain[0].Cloudbrain.CreatedUnix
  639. endTime := time.Now()
  640. listType := ctx.Query("listType")
  641. jobType := ctx.Query("jobType")
  642. jobStatus := ctx.Query("jobStatus")
  643. cloudBrainType := ctx.QueryInt("Type")
  644. aiCenter := ctx.Query("aiCenter")
  645. needDeleteInfo := ctx.Query("needDeleteInfo")
  646. if cloudBrainType == models.TypeCloudBrainOne && aiCenter == models.AICenterOfCloudBrainOne {
  647. aiCenter = ""
  648. }
  649. if cloudBrainType == models.TypeCloudBrainTwo && aiCenter == models.AICenterOfCloudBrainTwo {
  650. aiCenter = ""
  651. }
  652. if cloudBrainType == models.TypeCDCenter && aiCenter == models.AICenterOfChengdu {
  653. aiCenter = ""
  654. }
  655. if cloudBrainType == models.TypeCloudBrainAll {
  656. if aiCenter == models.AICenterOfCloudBrainOne {
  657. cloudBrainType = models.TypeCloudBrainOne
  658. aiCenter = ""
  659. }
  660. if aiCenter == models.AICenterOfCloudBrainTwo {
  661. cloudBrainType = models.TypeCloudBrainTwo
  662. aiCenter = ""
  663. }
  664. if aiCenter == models.AICenterOfChengdu {
  665. cloudBrainType = models.TypeCDCenter
  666. aiCenter = ""
  667. }
  668. }
  669. page := ctx.QueryInt("page")
  670. pageSize := ctx.QueryInt("pagesize")
  671. if page <= 0 {
  672. page = 1
  673. }
  674. if pageSize <= 0 {
  675. pageSize = 10
  676. }
  677. var jobTypes []string
  678. jobTypeNot := false
  679. if jobType == string(models.JobTypeBenchmark) {
  680. jobTypes = append(jobTypes, string(models.JobTypeBenchmark), string(models.JobTypeModelSafety), string(models.JobTypeBrainScore), string(models.JobTypeSnn4imagenet))
  681. } else if jobType != "all" && jobType != "" {
  682. jobTypes = append(jobTypes, jobType)
  683. }
  684. var jobStatuses []string
  685. jobStatusNot := false
  686. if jobStatus == "other" {
  687. jobStatusNot = true
  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. } else if jobStatus != "all" && jobStatus != "" {
  692. jobStatuses = append(jobStatuses, jobStatus)
  693. }
  694. keyword := strings.Trim(ctx.Query("q"), " ")
  695. ciTasks, count, err := models.CloudbrainAll(&models.CloudbrainsOptions{
  696. ListOptions: models.ListOptions{
  697. Page: page,
  698. PageSize: pageSize,
  699. },
  700. Keyword: keyword,
  701. Type: cloudBrainType,
  702. ComputeResource: listType,
  703. JobTypeNot: jobTypeNot,
  704. JobStatusNot: jobStatusNot,
  705. JobStatus: jobStatuses,
  706. JobTypes: jobTypes,
  707. NeedRepoInfo: true,
  708. BeginTimeUnix: int64(recordBeginTime),
  709. EndTimeUnix: endTime.Unix(),
  710. AiCenter: aiCenter,
  711. NeedDeleteInfo: needDeleteInfo,
  712. })
  713. if err != nil {
  714. ctx.ServerError("Get job failed:", err)
  715. return
  716. }
  717. models.LoadSpecs4CloudbrainInfo(ciTasks)
  718. nilTime := time.Time{}
  719. tasks := []models.TaskDetail{}
  720. for i, task := range ciTasks {
  721. task = cloudbrainService.UpdateCloudbrainAiCenter(task)
  722. var taskDetail models.TaskDetail
  723. taskDetail.ID = ciTasks[i].Cloudbrain.ID
  724. taskDetail.JobID = ciTasks[i].Cloudbrain.JobID
  725. taskDetail.JobName = ciTasks[i].JobName
  726. taskDetail.DisplayJobName = ciTasks[i].DisplayJobName
  727. taskDetail.Status = ciTasks[i].Status
  728. taskDetail.JobType = ciTasks[i].JobType
  729. taskDetail.CreatedUnix = ciTasks[i].Cloudbrain.CreatedUnix
  730. taskDetail.RunTime = ciTasks[i].Cloudbrain.TrainJobDuration
  731. taskDetail.StartTime = ciTasks[i].StartTime
  732. taskDetail.EndTime = ciTasks[i].EndTime
  733. taskDetail.ComputeResource = ciTasks[i].ComputeResource
  734. taskDetail.Type = ciTasks[i].Cloudbrain.Type
  735. taskDetail.UserName = ciTasks[i].User.Name
  736. taskDetail.RepoID = ciTasks[i].RepoID
  737. taskDetail.AiCenter = repo.GetAiCenterNameByCode(task.Cloudbrain.AiCenter, ctx.Language())
  738. if ciTasks[i].Repo != nil {
  739. taskDetail.RepoName = ciTasks[i].Repo.OwnerName + "/" + ciTasks[i].Repo.Name
  740. taskDetail.RepoAlias = ciTasks[i].Repo.OwnerName + "/" + ciTasks[i].Repo.Alias
  741. }
  742. if ciTasks[i].Cloudbrain.WorkServerNumber >= 1 {
  743. taskDetail.WorkServerNum = int64(ciTasks[i].Cloudbrain.WorkServerNumber)
  744. } else {
  745. taskDetail.WorkServerNum = 1
  746. }
  747. taskDetail.CardDuration = repo.GetCloudbrainCardDuration(ciTasks[i].Cloudbrain)
  748. taskDetail.WaitTime = repo.GetCloudbrainWaitTime(ciTasks[i].Cloudbrain)
  749. if ciTasks[i].Cloudbrain.DeletedAt != nilTime || ciTasks[i].Repo == nil {
  750. taskDetail.IsDelete = true
  751. } else {
  752. taskDetail.IsDelete = false
  753. }
  754. taskDetail.Spec = ciTasks[i].Spec
  755. tasks = append(tasks, taskDetail)
  756. }
  757. pager := context.NewPagination(int(count), pageSize, page, getTotalPage(count, pageSize))
  758. pager.SetDefaultParams(ctx)
  759. pager.AddParam(ctx, "listType", "ListType")
  760. ctx.JSON(http.StatusOK, map[string]interface{}{
  761. "Title": ctx.Tr("kanban.cloudBrains"),
  762. "Tasks": tasks,
  763. "Keyword": keyword,
  764. "pager": pager,
  765. "count": count,
  766. })
  767. }
  768. func GetCloudbrainsCreateHoursData(ctx *context.Context) {
  769. recordCloudbrain, err := models.GetRecordBeginTime()
  770. if err != nil {
  771. log.Error("Can not get record begin time", err)
  772. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.record_begintime_get_err"))
  773. return
  774. }
  775. recordBeginTime := time.Unix(int64(recordCloudbrain[0].Cloudbrain.CreatedUnix), 0)
  776. // recordBeginTime, _ := time.Parse("2006-01-02 15:04:05", recordTime)
  777. now := time.Now()
  778. queryType := ctx.QueryTrim("type")
  779. beginTimeStr := ctx.QueryTrim("beginTime")
  780. endTimeStr := ctx.QueryTrim("endTime")
  781. var beginTime time.Time
  782. var endTime time.Time
  783. createHourPeriodCount := make(map[string]interface{})
  784. if queryType != "" {
  785. if queryType == "all" {
  786. beginTime = recordBeginTime
  787. endTime = now.AddDate(0, 0, 1)
  788. endTime = time.Date(endTime.Year(), endTime.Month(), endTime.Day(), 0, 0, 0, 0, now.Location())
  789. } else if queryType == "today" {
  790. beginTime = time.Date(now.Year(), now.Month(), now.Day(), 0, 0, 0, 0, now.Location())
  791. endTime = now.AddDate(0, 0, 1)
  792. } else if queryType == "yesterday" {
  793. beginTime = now.AddDate(0, 0, -1)
  794. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  795. endTime = time.Date(now.Year(), now.Month(), now.Day(), 0, 0, 0, 0, now.Location())
  796. } else if queryType == "current_week" {
  797. beginTime = now.AddDate(0, 0, -int(time.Now().Weekday())+1) //begin from monday
  798. endTime = now
  799. } else if queryType == "current_month" {
  800. beginTime = time.Date(now.Year(), now.Month(), 1, 0, 0, 0, 0, now.Location())
  801. endTime = now.AddDate(0, 0, 1)
  802. endTime = time.Date(endTime.Year(), endTime.Month(), endTime.Day(), 0, 0, 0, 0, now.Location())
  803. } else if queryType == "monthly" {
  804. endTime = now
  805. beginTime = now.AddDate(0, -1, 0)
  806. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  807. } else if queryType == "current_year" {
  808. beginTime = time.Date(now.Year(), 1, 1, 0, 0, 0, 0, now.Location())
  809. endTime = now.AddDate(0, 0, 1)
  810. endTime = time.Date(endTime.Year(), endTime.Month(), endTime.Day(), 0, 0, 0, 0, now.Location())
  811. } else if queryType == "last_month" {
  812. lastMonthTime := now.AddDate(0, -1, 0)
  813. beginTime = time.Date(lastMonthTime.Year(), lastMonthTime.Month(), 1, 0, 0, 0, 0, now.Location())
  814. endTime = time.Date(now.Year(), now.Month(), 1, 0, 0, 0, 0, now.Location())
  815. } else if queryType == "last_7day" {
  816. beginTime = now.AddDate(0, 0, -6)
  817. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  818. endTime = now.AddDate(0, 0, 1)
  819. endTime = time.Date(endTime.Year(), endTime.Month(), endTime.Day(), 0, 0, 0, 0, now.Location())
  820. } else if queryType == "last_30day" {
  821. beginTime = now.AddDate(0, 0, -29)
  822. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  823. endTime = now.AddDate(0, 0, 1)
  824. endTime = time.Date(endTime.Year(), endTime.Month(), endTime.Day(), 0, 0, 0, 0, now.Location())
  825. }
  826. } else {
  827. if beginTimeStr == "" || endTimeStr == "" {
  828. //如果查询类型和开始时间结束时间都未设置,按queryType=all处理
  829. beginTime = recordBeginTime
  830. endTime = now.AddDate(0, 0, 1)
  831. endTime = time.Date(endTime.Year(), endTime.Month(), endTime.Day(), 0, 0, 0, 0, now.Location())
  832. } else {
  833. beginTime, err = time.ParseInLocation("2006-01-02", beginTimeStr, time.Local)
  834. if err != nil {
  835. log.Error("Can not ParseInLocation.", err)
  836. ctx.Error(http.StatusBadRequest, ctx.Tr("ParseInLocation_get_error"))
  837. return
  838. }
  839. endTime, err = time.ParseInLocation("2006-01-02", endTimeStr, time.Local)
  840. if err != nil {
  841. log.Error("Can not ParseInLocation.", err)
  842. ctx.Error(http.StatusBadRequest, ctx.Tr("ParseInLocation_get_error"))
  843. return
  844. }
  845. endTime = time.Date(endTime.Year(), endTime.Month(), endTime.Day(), 0, 0, 0, 0, now.Location())
  846. }
  847. }
  848. dateBeginTime := beginTime.Format("2006-01-02")
  849. dateEndTime := endTime.Format("2006-01-02")
  850. createHourPeriodCount, err = models.GetCreateHourPeriodCount(dateBeginTime, dateEndTime)
  851. if err != nil {
  852. log.Error("Can not query hourPeriodCount.", err)
  853. ctx.Error(http.StatusBadRequest, ctx.Tr("hourPeriodCount_get_error"))
  854. return
  855. }
  856. runHourPeriodCount, err := models.GetRunHourPeriodCount(dateBeginTime, dateEndTime)
  857. if err != nil {
  858. log.Error("Can not query runHourPeriodCount.", err)
  859. ctx.Error(http.StatusBadRequest, ctx.Tr("runHourPeriodCount_get_error"))
  860. return
  861. }
  862. ctx.JSON(http.StatusOK, map[string]interface{}{
  863. "recordBeginTime": recordCloudbrain[0].Cloudbrain.CreatedUnix,
  864. "updateTime": now.Unix(),
  865. "createHourPeriodCount": createHourPeriodCount,
  866. "runHourPeriodCount": runHourPeriodCount,
  867. })
  868. }
  869. func GetWaittingTop(ctx *context.Context) {
  870. ciTasks, err := models.GetWaittingTop()
  871. if err != nil {
  872. log.Error("Can not get record begin time", err)
  873. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.record_begintime_get_err"))
  874. return
  875. }
  876. tasks := []models.TaskDetail{}
  877. for i, task := range ciTasks {
  878. ciTasks[i].Cloudbrain.ComputeResource = task.ComputeResource
  879. var taskDetail models.TaskDetail
  880. taskDetail.DisplayJobName = ciTasks[i].DisplayJobName
  881. taskDetail.UserName = ciTasks[i].User.Name
  882. taskDetail.RepoID = ciTasks[i].RepoID
  883. if ciTasks[i].Repo != nil {
  884. taskDetail.RepoName = ciTasks[i].Repo.OwnerName + "/" + ciTasks[i].Repo.Name
  885. } else {
  886. taskDetail.RepoName = ""
  887. }
  888. WaitTimeInt := time.Now().Unix() - ciTasks[i].Cloudbrain.CreatedUnix.AsTime().Unix()
  889. taskDetail.WaitTime = models.ConvertDurationToStr(WaitTimeInt)
  890. if WaitTimeInt < 0 {
  891. taskDetail.WaitTime = "00:00:00"
  892. }
  893. taskDetail.ID = ciTasks[i].Cloudbrain.ID
  894. taskDetail.ComputeResource = ciTasks[i].Cloudbrain.ComputeResource
  895. taskDetail.JobType = ciTasks[i].Cloudbrain.JobType
  896. taskDetail.JobID = ciTasks[i].Cloudbrain.JobID
  897. taskDetail.Type = ciTasks[i].Cloudbrain.Type
  898. tasks = append(tasks, taskDetail)
  899. }
  900. ctx.JSON(http.StatusOK, map[string]interface{}{
  901. "tasks": tasks,
  902. })
  903. }
  904. func GetRunningTop(ctx *context.Context) {
  905. ciTasks, err := models.GetRunningTop()
  906. if err != nil {
  907. log.Error("Can not get record begin time", err)
  908. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.record_begintime_get_err"))
  909. return
  910. }
  911. tasks := []models.TaskDetail{}
  912. for i, task := range ciTasks {
  913. ciTasks[i].Cloudbrain.ComputeResource = task.ComputeResource
  914. var taskDetail models.TaskDetail
  915. taskDetail.DisplayJobName = ciTasks[i].DisplayJobName
  916. taskDetail.RunTime = ciTasks[i].Cloudbrain.TrainJobDuration
  917. taskDetail.UserName = ciTasks[i].User.Name
  918. taskDetail.RepoID = ciTasks[i].RepoID
  919. if ciTasks[i].Repo != nil {
  920. taskDetail.RepoName = ciTasks[i].Repo.OwnerName + "/" + ciTasks[i].Repo.Name
  921. }
  922. taskDetail.ID = ciTasks[i].Cloudbrain.ID
  923. taskDetail.ComputeResource = ciTasks[i].Cloudbrain.ComputeResource
  924. taskDetail.JobType = ciTasks[i].Cloudbrain.JobType
  925. taskDetail.JobID = ciTasks[i].Cloudbrain.JobID
  926. taskDetail.Type = ciTasks[i].Cloudbrain.Type
  927. tasks = append(tasks, taskDetail)
  928. }
  929. ctx.JSON(http.StatusOK, map[string]interface{}{
  930. "tasks": tasks,
  931. })
  932. }
  933. func getCloudbrainCount(beginTime time.Time, endTime time.Time, cloudbrains []*models.CloudbrainInfo) (map[string]int, map[string]int, map[string]int, map[string]int, map[int]int, map[string]int) {
  934. cloudOneJobTypeRes := make(map[string]int)
  935. cloudTwoJobTypeRes := make(map[string]int)
  936. intelligentNetJobTypeRes := make(map[string]int)
  937. cDCenterJobTypeRes := make(map[string]int)
  938. cloudBrainPeriodNum := make(map[int]int)
  939. cloudBrainComputeResource := make(map[string]int)
  940. for _, cloudbrain := range cloudbrains {
  941. if int64(cloudbrain.Cloudbrain.CreatedUnix) >= beginTime.Unix() && int64(cloudbrain.Cloudbrain.CreatedUnix) < endTime.Unix() {
  942. if cloudbrain.Cloudbrain.Type == models.TypeCloudBrainOne {
  943. if _, ok := cloudOneJobTypeRes[cloudbrain.Cloudbrain.JobType]; !ok {
  944. cloudOneJobTypeRes[cloudbrain.Cloudbrain.JobType] = 1
  945. } else {
  946. cloudOneJobTypeRes[cloudbrain.Cloudbrain.JobType] += 1
  947. }
  948. }
  949. if cloudbrain.Cloudbrain.Type == models.TypeCloudBrainTwo {
  950. if _, ok := cloudTwoJobTypeRes[cloudbrain.JobType]; !ok {
  951. cloudTwoJobTypeRes[cloudbrain.Cloudbrain.JobType] = 1
  952. } else {
  953. cloudTwoJobTypeRes[cloudbrain.Cloudbrain.JobType] += 1
  954. }
  955. }
  956. if _, ok := cloudBrainPeriodNum[cloudbrain.Cloudbrain.Type]; !ok {
  957. cloudBrainPeriodNum[cloudbrain.Cloudbrain.Type] = 1
  958. } else {
  959. cloudBrainPeriodNum[cloudbrain.Cloudbrain.Type] += 1
  960. }
  961. if _, ok := cloudBrainComputeResource[cloudbrain.Cloudbrain.ComputeResource]; !ok {
  962. cloudBrainComputeResource[cloudbrain.Cloudbrain.ComputeResource] = 1
  963. } else {
  964. cloudBrainComputeResource[cloudbrain.Cloudbrain.ComputeResource] += 1
  965. }
  966. }
  967. }
  968. ComputeResourceList := []string{"CPU/GPU", "NPU"}
  969. for _, v := range ComputeResourceList {
  970. if _, ok := cloudBrainComputeResource[v]; !ok {
  971. cloudBrainComputeResource[v] = 0
  972. }
  973. }
  974. jobTypeList := []string{"DEBUG", "BENCHMARK", "INFERENCE", "TRAIN", "SNN4IMAGENET", "BRAINSCORE"}
  975. cloudBrainTypeList := []int{0, 1, 2, 3}
  976. for _, v := range jobTypeList {
  977. if _, ok := cloudOneJobTypeRes[v]; !ok {
  978. cloudOneJobTypeRes[v] = 0
  979. }
  980. if _, ok := cloudTwoJobTypeRes[v]; !ok {
  981. cloudTwoJobTypeRes[v] = 0
  982. }
  983. if _, ok := intelligentNetJobTypeRes[v]; !ok {
  984. intelligentNetJobTypeRes[v] = 0
  985. }
  986. if _, ok := cDCenterJobTypeRes[v]; !ok {
  987. cDCenterJobTypeRes[v] = 0
  988. }
  989. }
  990. for _, v := range cloudBrainTypeList {
  991. if _, ok := cloudBrainPeriodNum[v]; !ok {
  992. cloudBrainPeriodNum[v] = 0
  993. }
  994. }
  995. cloudBrainPeriodNum[-1] = cloudBrainPeriodNum[0] + cloudBrainPeriodNum[1] + cloudBrainPeriodNum[2] + cloudBrainPeriodNum[3]
  996. return cloudOneJobTypeRes, cloudTwoJobTypeRes, intelligentNetJobTypeRes, cDCenterJobTypeRes, cloudBrainPeriodNum, cloudBrainComputeResource
  997. }
  998. func getDayCloudbrainNum(beginTime time.Time, endTime time.Time) ([]DateCloudbrainNum, error) {
  999. var endTimeTemp time.Time
  1000. endTimeTemp = beginTime.AddDate(0, 0, 1)
  1001. cloudbrains, _, err := models.CloudbrainAllStatic(&models.CloudbrainsOptions{
  1002. Type: models.TypeCloudBrainAll,
  1003. BeginTimeUnix: beginTime.Unix(),
  1004. EndTimeUnix: endTime.Unix(),
  1005. })
  1006. if err != nil {
  1007. log.Error("Get cloudbrains failed:", err)
  1008. return nil, err
  1009. }
  1010. dayCloudbrainNum := make([]DateCloudbrainNum, 0)
  1011. for endTimeTemp.Before(endTime) || endTimeTemp.Equal(endTime) {
  1012. cloudOneJobTypeRes, cloudTwoJobTypeRes, intelligentNetJobTypeRes, cDCenterJobTypeRes, cloudBrainPeriodNum, cloudBrainComputeResource := getCloudbrainCount(beginTime, endTimeTemp, cloudbrains)
  1013. dayCloudbrainNum = append(dayCloudbrainNum, DateCloudbrainNum{
  1014. Date: beginTime.Format("2006/01/02"),
  1015. CloudOneJobTypeRes: cloudOneJobTypeRes,
  1016. CloudTwoJobTypeRes: cloudTwoJobTypeRes,
  1017. IntelligentNetJobTypeRes: intelligentNetJobTypeRes,
  1018. CDCenterJobTypeRes: cDCenterJobTypeRes,
  1019. CloudBrainPeriodNum: cloudBrainPeriodNum,
  1020. CloudBrainComputeResource: cloudBrainComputeResource,
  1021. })
  1022. if endTime.Before(endTimeTemp.AddDate(0, 0, 1)) && endTimeTemp.Before(endTime) {
  1023. beginTime = endTimeTemp
  1024. endTimeTemp = endTime
  1025. } else {
  1026. beginTime = endTimeTemp
  1027. endTimeTemp = beginTime.AddDate(0, 0, 1)
  1028. }
  1029. }
  1030. return dayCloudbrainNum, nil
  1031. }
  1032. func getMonthCloudbrainNum(beginTime time.Time, endTime time.Time) ([]DateCloudbrainNum, error) {
  1033. var endTimeTemp time.Time
  1034. now := time.Now()
  1035. endTimeTemp = beginTime.AddDate(0, 1, 0)
  1036. endTimeTemp = time.Date(endTimeTemp.Year(), endTimeTemp.Month(), 1, 0, 0, 0, 0, now.Location())
  1037. monthCloudbrainNum := make([]DateCloudbrainNum, 0)
  1038. cloudbrains, _, err := models.CloudbrainAllStatic(&models.CloudbrainsOptions{
  1039. Type: models.TypeCloudBrainAll,
  1040. BeginTimeUnix: beginTime.Unix(),
  1041. EndTimeUnix: endTime.Unix(),
  1042. })
  1043. if err != nil {
  1044. log.Error("Getcloudbrains failed:%v", err)
  1045. return nil, err
  1046. }
  1047. for endTimeTemp.Before(endTime) || endTimeTemp.Equal(endTime) {
  1048. cloudOneJobTypeRes, cloudTwoJobTypeRes, intelligentNetJobTypeRes, cDCenterJobTypeRes, cloudBrainPeriodNum, cloudBrainComputeResource := getCloudbrainCount(beginTime, endTimeTemp, cloudbrains)
  1049. monthCloudbrainNum = append(monthCloudbrainNum, DateCloudbrainNum{
  1050. Date: beginTime.Format("2006/01"),
  1051. CloudOneJobTypeRes: cloudOneJobTypeRes,
  1052. CloudTwoJobTypeRes: cloudTwoJobTypeRes,
  1053. IntelligentNetJobTypeRes: intelligentNetJobTypeRes,
  1054. CDCenterJobTypeRes: cDCenterJobTypeRes,
  1055. CloudBrainPeriodNum: cloudBrainPeriodNum,
  1056. CloudBrainComputeResource: cloudBrainComputeResource,
  1057. })
  1058. if endTime.Before(endTimeTemp.AddDate(0, 1, 0)) && endTimeTemp.Before(endTime) {
  1059. beginTime = endTimeTemp
  1060. endTimeTemp = endTime
  1061. } else {
  1062. beginTime = endTimeTemp
  1063. endTimeTemp = beginTime.AddDate(0, 1, 0)
  1064. }
  1065. }
  1066. return monthCloudbrainNum, nil
  1067. }
  1068. func getDayCloudbrainInfo(beginTime time.Time, endTime time.Time) ([]DateCloudbrainInfo, int, error) {
  1069. now := time.Now()
  1070. endTimeTemp := time.Date(endTime.Year(), endTime.Month(), endTime.Day(), 0, 0, 0, 0, now.Location())
  1071. if endTimeTemp.Equal(endTime) {
  1072. endTimeTemp = endTimeTemp.AddDate(0, 0, -1)
  1073. }
  1074. cloudbrains, _, err := models.CloudbrainAllStatic(&models.CloudbrainsOptions{
  1075. Type: models.TypeCloudBrainAll,
  1076. BeginTimeUnix: beginTime.Unix(),
  1077. EndTimeUnix: endTime.Unix(),
  1078. })
  1079. if err != nil {
  1080. log.Error("Getcloudbrains failed:%v", err)
  1081. return nil, 0, err
  1082. }
  1083. dayCloudbrainInfo := make([]DateCloudbrainInfo, 0)
  1084. count := 0
  1085. for beginTime.Before(endTimeTemp) || beginTime.Equal(endTimeTemp) {
  1086. _, _, _, _, cloudBrainPeriodNum, cloudBrainComputeResource := getCloudbrainCount(endTimeTemp, endTime, cloudbrains)
  1087. dayCloudbrainInfo = append(dayCloudbrainInfo, DateCloudbrainInfo{
  1088. Date: endTimeTemp.Format("2006/01/02"),
  1089. CloudBrainPeriodNum: cloudBrainPeriodNum,
  1090. CloudBrainComputeResource: cloudBrainComputeResource,
  1091. })
  1092. endTime = endTimeTemp
  1093. endTimeTemp = endTimeTemp.AddDate(0, 0, -1)
  1094. count += 1
  1095. }
  1096. return dayCloudbrainInfo, count, nil
  1097. }
  1098. func getMonthCloudbrainInfo(beginTime time.Time, endTime time.Time) ([]DateCloudbrainInfo, int, error) {
  1099. now := time.Now()
  1100. endTimeTemp := time.Date(endTime.Year(), endTime.Month(), 1, 0, 0, 0, 0, now.Location())
  1101. if endTimeTemp.Equal(endTime) {
  1102. endTimeTemp = endTimeTemp.AddDate(0, -1, 0)
  1103. }
  1104. cloudbrains, _, err := models.CloudbrainAllStatic(&models.CloudbrainsOptions{
  1105. Type: models.TypeCloudBrainAll,
  1106. BeginTimeUnix: beginTime.Unix(),
  1107. EndTimeUnix: endTime.Unix(),
  1108. })
  1109. if err != nil {
  1110. log.Error("Getcloudbrains failed:%v", err)
  1111. return nil, 0, err
  1112. }
  1113. dayCloudbrainInfo := make([]DateCloudbrainInfo, 0)
  1114. count := 0
  1115. for beginTime.Before(endTimeTemp) || beginTime.Equal(endTimeTemp) || (endTimeTemp.Before(beginTime) && beginTime.Before(endTime)) {
  1116. _, _, _, _, cloudBrainPeriodNum, cloudBrainComputeResource := getCloudbrainCount(endTimeTemp, endTime, cloudbrains)
  1117. dayCloudbrainInfo = append(dayCloudbrainInfo, DateCloudbrainInfo{
  1118. Date: endTimeTemp.Format("2006/01"),
  1119. CloudBrainPeriodNum: cloudBrainPeriodNum,
  1120. CloudBrainComputeResource: cloudBrainComputeResource,
  1121. })
  1122. endTime = endTimeTemp
  1123. endTimeTemp = endTimeTemp.AddDate(0, -1, 0)
  1124. count += 1
  1125. }
  1126. return dayCloudbrainInfo, count, nil
  1127. }
  1128. func DownloadCloudBrainBoard(ctx *context.Context) {
  1129. recordCloudbrain, err := models.GetRecordBeginTime()
  1130. if err != nil {
  1131. log.Error("Can not get recordCloudbrain", err)
  1132. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.record_begintime_get_err"))
  1133. return
  1134. }
  1135. page := 1
  1136. pageSize := 300
  1137. var cloudBrain = ctx.Tr("repo.cloudbrain")
  1138. fileName := getCloudbrainFileName(cloudBrain)
  1139. recordBeginTime := recordCloudbrain[0].Cloudbrain.CreatedUnix
  1140. now := time.Now()
  1141. endTime := now
  1142. _, total, err := models.CloudbrainAll(&models.CloudbrainsOptions{
  1143. ListOptions: models.ListOptions{
  1144. Page: page,
  1145. PageSize: pageSize,
  1146. },
  1147. Type: models.TypeCloudBrainAll,
  1148. BeginTimeUnix: int64(recordBeginTime),
  1149. EndTimeUnix: endTime.Unix(),
  1150. })
  1151. log.Info("totalcountisis:", total)
  1152. if err != nil {
  1153. log.Warn("Can not get cloud brain info", err)
  1154. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.cloudbrain_query_fail"))
  1155. return
  1156. }
  1157. totalPage := getTotalPage(total, pageSize)
  1158. f := excelize.NewFile()
  1159. index := f.NewSheet(cloudBrain)
  1160. f.DeleteSheet("Sheet1")
  1161. for k, v := range allCloudbrainHeader(ctx) {
  1162. f.SetCellValue(cloudBrain, k, v)
  1163. }
  1164. var row = 2
  1165. for i := 0; i < totalPage; i++ {
  1166. pageRecords, _, err := models.CloudbrainAll(&models.CloudbrainsOptions{
  1167. ListOptions: models.ListOptions{
  1168. Page: page,
  1169. PageSize: pageSize,
  1170. },
  1171. Type: models.TypeCloudBrainAll,
  1172. BeginTimeUnix: int64(recordBeginTime),
  1173. EndTimeUnix: endTime.Unix(),
  1174. NeedRepoInfo: true,
  1175. })
  1176. if err != nil {
  1177. log.Warn("Can not get cloud brain info", err)
  1178. continue
  1179. }
  1180. models.LoadSpecs4CloudbrainInfo(pageRecords)
  1181. for _, record := range pageRecords {
  1182. record = cloudbrainService.UpdateCloudbrainAiCenter(record)
  1183. record.Cloudbrain.AiCenter = repo.GetAiCenterNameByCode(record.Cloudbrain.AiCenter, ctx.Language())
  1184. for k, v := range allCloudbrainValues(row, record, ctx) {
  1185. f.SetCellValue(cloudBrain, k, v)
  1186. }
  1187. row++
  1188. }
  1189. page++
  1190. }
  1191. f.SetActiveSheet(index)
  1192. ctx.Resp.Header().Set("Content-Disposition", "attachment; filename="+url.QueryEscape(fileName))
  1193. ctx.Resp.Header().Set("Content-Type", "application/octet-stream")
  1194. f.WriteTo(ctx.Resp)
  1195. }
  1196. func getCloudbrainFileName(baseName string) string {
  1197. return baseName + "_" + time.Now().Format(EXCEL_DATE_FORMAT) + ".xlsx"
  1198. }
  1199. func allCloudbrainHeader(ctx *context.Context) map[string]string {
  1200. 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"),
  1201. "E1": ctx.Tr("repo.modelarts.createtime"), "F1": ctx.Tr("repo.modelarts.train_job.wait_time"), "G1": ctx.Tr("repo.modelarts.train_job.dura_time"),
  1202. "H1": ctx.Tr("cloudbrain.card_duration"),
  1203. "I1": ctx.Tr("repo.modelarts.train_job.start_time"), "J1": ctx.Tr("repo.modelarts.train_job.end_time"),
  1204. "K1": ctx.Tr("repo.modelarts.computing_resources"), "L1": ctx.Tr("cloudbrain.card_type"),
  1205. "M1": ctx.Tr("repo.modelarts.train_job.amount_of_compute_node"), "N1": ctx.Tr("repo.grampus.train_job.ai_center"),
  1206. "O1": ctx.Tr("cloudbrain.resource_specification"), "P1": ctx.Tr("repo.cloudbrain_creator"), "Q1": ctx.Tr("repo.repo_name"),
  1207. "R1": ctx.Tr("repo.cloudbrain_task_name"), "S1": ctx.Tr("repo.modelarts.deletetime")}
  1208. }
  1209. func allCloudbrainValues(row int, rs *models.CloudbrainInfo, ctx *context.Context) map[string]string {
  1210. 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,
  1211. getCellName("E", row): time.Unix(int64(rs.Cloudbrain.CreatedUnix), 0).Format(CREATE_TIME_FORMAT), getCellName("F", row): repo.GetCloudbrainWaitTime(rs.Cloudbrain),
  1212. getCellName("G", row): rs.TrainJobDuration, getCellName("H", row): repo.GetCloudbrainCardDuration(rs.Cloudbrain),
  1213. getCellName("I", row): getBrainStartTime(rs),
  1214. getCellName("J", row): getBrainEndTime(rs), getCellName("K", row): rs.ComputeResource, getCellName("L", row): getCloudbrainCardType(rs),
  1215. getCellName("M", row): getWorkServerNum(rs), getCellName("N", row): rs.Cloudbrain.AiCenter,
  1216. getCellName("O", row): getCloudbrainFlavorName(rs), getCellName("P", row): rs.Name,
  1217. getCellName("Q", row): getBrainRepo(rs), getCellName("R", row): rs.JobName, getCellName("S", row): getBrainDeleteTime(rs),
  1218. }
  1219. }
  1220. func getWorkServerNum(rs *models.CloudbrainInfo) string {
  1221. if rs.Cloudbrain.WorkServerNumber >= 1 {
  1222. return fmt.Sprint(rs.Cloudbrain.WorkServerNumber)
  1223. } else {
  1224. return "1"
  1225. }
  1226. }
  1227. func getBrainRepo(rs *models.CloudbrainInfo) string {
  1228. if rs.Repo != nil {
  1229. return rs.Repo.OwnerName + "/" + rs.Repo.Alias
  1230. }
  1231. return ""
  1232. }
  1233. func getBrainStartTime(rs *models.CloudbrainInfo) string {
  1234. timeString := time.Unix(int64(rs.Cloudbrain.StartTime), 0).Format(CREATE_TIME_FORMAT)
  1235. if timeString != "1970/01/01 08:00:00" {
  1236. return timeString
  1237. } else {
  1238. return "0"
  1239. }
  1240. }
  1241. func getBrainEndTime(rs *models.CloudbrainInfo) string {
  1242. timeString := time.Unix(int64(rs.Cloudbrain.EndTime), 0).Format(CREATE_TIME_FORMAT)
  1243. if timeString != "1970/01/01 08:00:00" {
  1244. return timeString
  1245. } else {
  1246. return "0"
  1247. }
  1248. }
  1249. func getCloudbrainType(rs *models.CloudbrainInfo, ctx *context.Context) string {
  1250. if rs.Cloudbrain.Type == models.TypeCloudBrainOne {
  1251. return ctx.Tr("repo.cloudbrain1")
  1252. } else if rs.Cloudbrain.Type == models.TypeCloudBrainTwo {
  1253. return ctx.Tr("repo.cloudbrain2")
  1254. } else if rs.Cloudbrain.Type == models.TypeC2Net {
  1255. return ctx.Tr("repo.intelligent_net")
  1256. } else {
  1257. return ctx.Tr("repo.cloudbrain_untype")
  1258. }
  1259. }
  1260. func getCloudbrainCardType(rs *models.CloudbrainInfo) string {
  1261. if rs.Cloudbrain.Spec != nil {
  1262. return rs.Cloudbrain.Spec.AccCardType
  1263. } else {
  1264. return ""
  1265. }
  1266. }
  1267. func getCloudbrainFlavorName(rs *models.CloudbrainInfo) string {
  1268. flavorName := repo.GetCloudbrainFlavorName(rs.Cloudbrain)
  1269. return flavorName
  1270. }
  1271. func getBrainDeleteTime(rs *models.CloudbrainInfo) string {
  1272. nilTime := time.Time{}
  1273. if rs.Cloudbrain.DeletedAt != nilTime {
  1274. return rs.Cloudbrain.DeletedAt.Format("2006-01-02 15:04:05")
  1275. } else {
  1276. return ""
  1277. }
  1278. }
  1279. func getCloudbrainTimePeroid(ctx *context.Context, recordBeginTime time.Time) (time.Time, time.Time, error) {
  1280. queryType := ctx.QueryTrim("type")
  1281. beginTimeStr := ctx.QueryTrim("beginTime")
  1282. endTimeStr := ctx.QueryTrim("endTime")
  1283. now := time.Now()
  1284. var beginTime time.Time
  1285. var endTime time.Time
  1286. var err error
  1287. if queryType != "" {
  1288. if queryType == "all" {
  1289. beginTime = recordBeginTime
  1290. endTime = now
  1291. } else if queryType == "today" {
  1292. endTime = now
  1293. beginTime = time.Date(endTime.Year(), endTime.Month(), endTime.Day(), 0, 0, 0, 0, now.Location())
  1294. } else if queryType == "yesterday" {
  1295. endTime = time.Date(now.Year(), now.Month(), now.Day(), 0, 0, 0, 0, now.Location())
  1296. beginTime = endTime.AddDate(0, 0, -1)
  1297. } else if queryType == "last_7day" {
  1298. beginTime = now.AddDate(0, 0, -6)
  1299. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  1300. endTime = now
  1301. } else if queryType == "last_30day" {
  1302. beginTime = now.AddDate(0, 0, -29)
  1303. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  1304. endTime = now
  1305. } else if queryType == "current_month" {
  1306. endTime = now
  1307. beginTime = time.Date(endTime.Year(), endTime.Month(), 1, 0, 0, 0, 0, now.Location())
  1308. } else if queryType == "monthly" {
  1309. endTime = now
  1310. beginTime = now.AddDate(0, -1, 1)
  1311. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  1312. } else if queryType == "current_year" {
  1313. endTime = now
  1314. beginTime = time.Date(endTime.Year(), 1, 1, 0, 0, 0, 0, now.Location())
  1315. } else if queryType == "last_month" {
  1316. lastMonthTime := now.AddDate(0, -1, 0)
  1317. beginTime = time.Date(lastMonthTime.Year(), lastMonthTime.Month(), 1, 0, 0, 0, 0, now.Location())
  1318. endTime = time.Date(now.Year(), now.Month(), 1, 0, 0, 0, 0, now.Location())
  1319. } else {
  1320. return now, now, fmt.Errorf("The value of type parameter is wrong.")
  1321. }
  1322. } else {
  1323. if beginTimeStr == "" || endTimeStr == "" {
  1324. //如果查询类型和开始时间结束时间都未设置,按queryType=all处理
  1325. beginTime = recordBeginTime
  1326. endTime = now
  1327. } else {
  1328. beginTime, err = time.ParseInLocation("2006-01-02", beginTimeStr, time.Local)
  1329. if err != nil {
  1330. return now, now, err
  1331. }
  1332. endTime, err = time.ParseInLocation("2006-01-02", endTimeStr, time.Local)
  1333. if err != nil {
  1334. return now, now, err
  1335. }
  1336. }
  1337. }
  1338. if beginTime.Before(recordBeginTime) {
  1339. beginTime = recordBeginTime
  1340. }
  1341. return beginTime, endTime, nil
  1342. }
  1343. func GetCloudbrainResourceOverview(ctx *context.Context) {
  1344. var recordBeginTime timeutil.TimeStamp
  1345. recordCloudbrainDuration, err := models.GetDurationRecordBeginTime()
  1346. if err != nil {
  1347. log.Error("Can not get GetDurationRecordBeginTime", err)
  1348. return
  1349. }
  1350. if len(recordCloudbrainDuration) > 0 && err == nil {
  1351. recordBeginTime = recordCloudbrainDuration[0].DateTimeUnix
  1352. } else {
  1353. recordBeginTime = timeutil.TimeStamp(time.Now().Unix())
  1354. }
  1355. recordUpdateTime := time.Now().Unix()
  1356. resourceQueues, err := models.GetCanUseCardInfo()
  1357. if err != nil {
  1358. log.Info("GetCanUseCardInfo err: %v", err)
  1359. return
  1360. }
  1361. OpenIResourceDetail := []models.ResourceDetail{}
  1362. C2NetResourceDetail := []models.ResourceDetail{}
  1363. for _, resourceQueue := range resourceQueues {
  1364. if resourceQueue.Cluster == models.OpenICluster {
  1365. aiCenterName := repo.GetAiCenterNameByCode(resourceQueue.AiCenterCode, ctx.Language())
  1366. var resourceDetail models.ResourceDetail
  1367. resourceDetail.QueueCode = resourceQueue.QueueCode
  1368. resourceDetail.Cluster = resourceQueue.Cluster
  1369. resourceDetail.AiCenterCode = resourceQueue.AiCenterCode
  1370. resourceDetail.AiCenterName = resourceQueue.AiCenterCode + "/" + aiCenterName
  1371. resourceDetail.ComputeResource = resourceQueue.ComputeResource
  1372. resourceDetail.AccCardType = resourceQueue.AccCardType + "(" + resourceQueue.ComputeResource + ")"
  1373. resourceDetail.CardsTotalNum = resourceQueue.CardsTotalNum
  1374. resourceDetail.IsAutomaticSync = resourceQueue.IsAutomaticSync
  1375. OpenIResourceDetail = append(OpenIResourceDetail, resourceDetail)
  1376. }
  1377. if resourceQueue.Cluster == models.C2NetCluster {
  1378. aiCenterName := repo.GetAiCenterNameByCode(resourceQueue.AiCenterCode, ctx.Language())
  1379. var resourceDetail models.ResourceDetail
  1380. resourceDetail.QueueCode = resourceQueue.QueueCode
  1381. resourceDetail.Cluster = resourceQueue.Cluster
  1382. resourceDetail.AiCenterCode = resourceQueue.AiCenterCode
  1383. resourceDetail.AiCenterName = resourceQueue.AiCenterCode + "/" + aiCenterName
  1384. resourceDetail.ComputeResource = resourceQueue.ComputeResource
  1385. resourceDetail.AccCardType = resourceQueue.AccCardType + "(" + resourceQueue.ComputeResource + ")"
  1386. resourceDetail.CardsTotalNum = resourceQueue.CardsTotalNum
  1387. resourceDetail.IsAutomaticSync = resourceQueue.IsAutomaticSync
  1388. C2NetResourceDetail = append(C2NetResourceDetail, resourceDetail)
  1389. }
  1390. }
  1391. openIResourceNum := make(map[string]map[string]int)
  1392. for _, openIResourceDetail := range OpenIResourceDetail {
  1393. if _, ok := openIResourceNum[openIResourceDetail.AiCenterName]; !ok {
  1394. openIResourceNum[openIResourceDetail.AiCenterName] = make(map[string]int)
  1395. }
  1396. if _, ok := openIResourceNum[openIResourceDetail.AiCenterName][openIResourceDetail.AccCardType]; !ok {
  1397. openIResourceNum[openIResourceDetail.AiCenterName][openIResourceDetail.AccCardType] = openIResourceDetail.CardsTotalNum
  1398. } else {
  1399. openIResourceNum[openIResourceDetail.AiCenterName][openIResourceDetail.AccCardType] += openIResourceDetail.CardsTotalNum
  1400. }
  1401. }
  1402. c2NetResourceNum := make(map[string]map[string]int)
  1403. for _, c2NetResourceDetail := range C2NetResourceDetail {
  1404. if _, ok := c2NetResourceNum[c2NetResourceDetail.AiCenterName]; !ok {
  1405. c2NetResourceNum[c2NetResourceDetail.AiCenterName] = make(map[string]int)
  1406. }
  1407. if _, ok := c2NetResourceNum[c2NetResourceDetail.AiCenterName][c2NetResourceDetail.AccCardType]; !ok {
  1408. c2NetResourceNum[c2NetResourceDetail.AiCenterName][c2NetResourceDetail.AccCardType] = c2NetResourceDetail.CardsTotalNum
  1409. } else {
  1410. c2NetResourceNum[c2NetResourceDetail.AiCenterName][c2NetResourceDetail.AccCardType] += c2NetResourceDetail.CardsTotalNum
  1411. }
  1412. }
  1413. ctx.JSON(http.StatusOK, map[string]interface{}{
  1414. "openI": openIResourceNum,
  1415. "c2Net": c2NetResourceNum,
  1416. "recordUpdateTime": recordUpdateTime,
  1417. "recordBeginTime": recordBeginTime,
  1418. })
  1419. }
  1420. func GetCloudbrainResourceUsageDetail(ctx *context.Context) {
  1421. aiCenterCode := ctx.QueryTrim("aiCenterCode")
  1422. if aiCenterCode == "" {
  1423. aiCenterCode = models.AICenterOfCloudBrainOne
  1424. }
  1425. beginTime, endTime := getBeginAndEndTime(ctx)
  1426. dayCloudbrainDuration, count, err := getDayCloudbrainDuration(beginTime, endTime, aiCenterCode)
  1427. if err != nil {
  1428. log.Error("Can not query dayCloudbrainDuration.", err)
  1429. return
  1430. }
  1431. hourCloudbrainDuration, err := getHourCloudbrainDuration(beginTime, endTime, aiCenterCode)
  1432. if err != nil {
  1433. log.Error("Can not query hourCloudbrainDuration.", err)
  1434. return
  1435. }
  1436. page := ctx.QueryInt("page")
  1437. if page <= 0 {
  1438. page = 1
  1439. }
  1440. pagesize := ctx.QueryInt("pagesize")
  1441. if pagesize <= 0 {
  1442. pagesize = 36500
  1443. }
  1444. pageDateCloudbrainDuration := getPageDateCloudbrainDuration(dayCloudbrainDuration, page, pagesize)
  1445. ctx.JSON(http.StatusOK, map[string]interface{}{
  1446. "totalCount": count,
  1447. "pageDateCloudbrainDuration": pageDateCloudbrainDuration,
  1448. "hourCloudbrainDuration": hourCloudbrainDuration,
  1449. })
  1450. }
  1451. func GetDurationRateStatistic(ctx *context.Context) {
  1452. beginTime, endTime := getBeginAndEndTime(ctx)
  1453. OpenIDurationRate, C2NetDurationRate, totalUsageRate := getDurationStatistic(beginTime, endTime)
  1454. ctx.JSON(http.StatusOK, map[string]interface{}{
  1455. "openIDurationRate": OpenIDurationRate,
  1456. "c2NetDurationRate": C2NetDurationRate,
  1457. "totalUsageRate": totalUsageRate,
  1458. })
  1459. }
  1460. func CloudbrainDurationStatisticForTest(ctx *context.Context) {
  1461. repo.CloudbrainDurationStatisticHour()
  1462. ctx.JSON(http.StatusOK, map[string]interface{}{
  1463. "message": 0,
  1464. })
  1465. }
  1466. func getBeginAndEndTime(ctx *context.Context) (time.Time, time.Time) {
  1467. queryType := ctx.QueryTrim("type")
  1468. now := time.Now()
  1469. beginTimeStr := ctx.QueryTrim("beginTime")
  1470. endTimeStr := ctx.QueryTrim("endTime")
  1471. var brainRecordBeginTime time.Time
  1472. var beginTime time.Time
  1473. var endTime time.Time
  1474. var err error
  1475. if queryType != "" {
  1476. if queryType == "all" {
  1477. recordCloudbrainDuration, err := models.GetDurationRecordBeginTime()
  1478. if err != nil {
  1479. log.Error("Can not get GetDurationRecordBeginTime", err)
  1480. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.record_begintime_get_err"))
  1481. return beginTime, endTime
  1482. }
  1483. if len(recordCloudbrainDuration) > 0 && err == nil {
  1484. brainRecordBeginTime = recordCloudbrainDuration[0].DateTimeUnix.AsTime()
  1485. } else {
  1486. brainRecordBeginTime = now
  1487. }
  1488. beginTime = brainRecordBeginTime
  1489. endTime = now
  1490. } else if queryType == "today" {
  1491. beginTime = now.AddDate(0, 0, 0)
  1492. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  1493. endTime = now
  1494. } else if queryType == "yesterday" {
  1495. beginTime = now.AddDate(0, 0, -1)
  1496. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  1497. endTime = time.Date(now.Year(), now.Month(), now.Day(), 0, 0, 0, 0, now.Location())
  1498. } else if queryType == "last_7day" {
  1499. beginTime = now.AddDate(0, 0, -6)
  1500. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  1501. endTime = now
  1502. } else if queryType == "last_30day" {
  1503. beginTime = now.AddDate(0, 0, -29)
  1504. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  1505. endTime = now
  1506. } else if queryType == "current_month" {
  1507. endTime = now
  1508. beginTime = time.Date(endTime.Year(), endTime.Month(), 1, 0, 0, 0, 0, now.Location())
  1509. } else if queryType == "current_year" {
  1510. endTime = now
  1511. beginTime = time.Date(endTime.Year(), 1, 1, 0, 0, 0, 0, now.Location())
  1512. } else if queryType == "last_month" {
  1513. lastMonthTime := now.AddDate(0, -1, 0)
  1514. beginTime = time.Date(lastMonthTime.Year(), lastMonthTime.Month(), 1, 0, 0, 0, 0, now.Location())
  1515. endTime = time.Date(now.Year(), now.Month(), 1, 0, 0, 0, 0, now.Location())
  1516. }
  1517. } else {
  1518. if beginTimeStr == "" || endTimeStr == "" {
  1519. //如果查询类型和开始时间结束时间都未设置,按queryType=all处理
  1520. recordCloudbrainDuration, err := models.GetDurationRecordBeginTime()
  1521. if err != nil {
  1522. log.Error("Can not get recordCloudbrain", err)
  1523. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.record_begintime_get_err"))
  1524. return beginTime, endTime
  1525. }
  1526. if len(recordCloudbrainDuration) > 0 && err == nil {
  1527. brainRecordBeginTime = recordCloudbrainDuration[0].DateTimeUnix.AsTime()
  1528. } else {
  1529. brainRecordBeginTime = now
  1530. }
  1531. beginTime = brainRecordBeginTime
  1532. endTime = now
  1533. } else {
  1534. beginTime, err = time.ParseInLocation("2006-01-02", beginTimeStr, time.Local)
  1535. if err != nil {
  1536. log.Error("Can not ParseInLocation.", err)
  1537. ctx.Error(http.StatusBadRequest, ctx.Tr("ParseInLocation_get_error"))
  1538. return beginTime, endTime
  1539. }
  1540. endTime, err = time.ParseInLocation("2006-01-02", endTimeStr, time.Local)
  1541. if err != nil {
  1542. log.Error("Can not ParseInLocation.", err)
  1543. ctx.Error(http.StatusBadRequest, ctx.Tr("ParseInLocation_get_error"))
  1544. return beginTime, endTime
  1545. }
  1546. if endTime.After(time.Now()) {
  1547. endTime = time.Now()
  1548. }
  1549. }
  1550. }
  1551. return beginTime, endTime
  1552. }
  1553. func getAiCenterUsageDuration(beginTime time.Time, endTime time.Time, cloudbrainStatistics []*models.CloudbrainDurationStatistic) (int, int, float64) {
  1554. totalDuration := int(0)
  1555. usageDuration := int(0)
  1556. usageRate := float64(0)
  1557. for _, cloudbrainStatistic := range cloudbrainStatistics {
  1558. if int64(cloudbrainStatistic.DateTimeUnix) >= beginTime.Unix() && int64(cloudbrainStatistic.DateTimeUnix) < endTime.Unix() {
  1559. totalDuration += cloudbrainStatistic.CardsTotalDuration
  1560. usageDuration += cloudbrainStatistic.CardsUseDuration
  1561. }
  1562. }
  1563. if totalDuration == 0 || usageDuration == 0 {
  1564. usageRate = 0
  1565. } else {
  1566. usageRate = float64(usageDuration) / float64(totalDuration)
  1567. }
  1568. return totalDuration, usageDuration, usageRate
  1569. }
  1570. func getDurationStatistic(beginTime time.Time, endTime time.Time) (models.DurationRateStatistic, models.DurationRateStatistic, float64) {
  1571. OpenITotalDuration := make(map[string]int)
  1572. OpenIUsageDuration := make(map[string]int)
  1573. OpenIUsageRate := make(map[string]float64)
  1574. C2NetTotalDuration := make(map[string]int)
  1575. C2NetUsageDuration := make(map[string]int)
  1576. OpenIDurationRate := models.DurationRateStatistic{}
  1577. C2NetDurationRate := models.DurationRateStatistic{}
  1578. cardDurationStatistics, err := models.GetCardDurationStatistics(&models.DurationStatisticOptions{
  1579. BeginTime: beginTime,
  1580. EndTime: endTime,
  1581. })
  1582. if err != nil {
  1583. log.Error("GetCardDurationStatistics error:", err)
  1584. return OpenIDurationRate, C2NetDurationRate, 0
  1585. }
  1586. for _, cloudbrainStatistic := range cardDurationStatistics {
  1587. aiCenterName := cloudbrainStatistic.AiCenterCode + "/" + repo.GetAiCenterNameByCode(cloudbrainStatistic.AiCenterCode, "zh-CN")
  1588. if cloudbrainStatistic.Cluster == models.OpenICluster {
  1589. if _, ok := OpenITotalDuration[aiCenterName]; !ok {
  1590. OpenITotalDuration[aiCenterName] = cloudbrainStatistic.CardsTotalDuration
  1591. } else {
  1592. OpenITotalDuration[aiCenterName] += cloudbrainStatistic.CardsTotalDuration
  1593. }
  1594. if _, ok := OpenIUsageDuration[aiCenterName]; !ok {
  1595. OpenIUsageDuration[aiCenterName] = cloudbrainStatistic.CardsUseDuration
  1596. } else {
  1597. OpenIUsageDuration[aiCenterName] += cloudbrainStatistic.CardsUseDuration
  1598. }
  1599. }
  1600. if cloudbrainStatistic.Cluster == models.C2NetCluster {
  1601. if _, ok := C2NetTotalDuration[aiCenterName]; !ok {
  1602. C2NetTotalDuration[aiCenterName] = cloudbrainStatistic.CardsTotalDuration
  1603. } else {
  1604. C2NetTotalDuration[aiCenterName] += cloudbrainStatistic.CardsTotalDuration
  1605. }
  1606. if _, ok := C2NetUsageDuration[aiCenterName]; !ok {
  1607. C2NetUsageDuration[aiCenterName] = cloudbrainStatistic.CardsUseDuration
  1608. } else {
  1609. C2NetUsageDuration[aiCenterName] += cloudbrainStatistic.CardsUseDuration
  1610. }
  1611. }
  1612. }
  1613. ResourceAiCenterRes, err := models.GetResourceAiCenters()
  1614. if err != nil {
  1615. log.Error("Can not get ResourceAiCenterRes.", err)
  1616. return OpenIDurationRate, C2NetDurationRate, 0
  1617. }
  1618. for _, v := range ResourceAiCenterRes {
  1619. aiCenterName := v.AiCenterCode + "/" + repo.GetAiCenterNameByCode(v.AiCenterCode, "zh-CN")
  1620. if cutString(v.AiCenterCode, 4) == cutString(models.AICenterOfCloudBrainOne, 4) {
  1621. if _, ok := OpenIUsageDuration[aiCenterName]; !ok {
  1622. OpenIUsageDuration[aiCenterName] = 0
  1623. }
  1624. if _, ok := OpenITotalDuration[aiCenterName]; !ok {
  1625. OpenITotalDuration[aiCenterName] = 0
  1626. }
  1627. } else {
  1628. if _, ok := C2NetUsageDuration[aiCenterName]; !ok {
  1629. C2NetUsageDuration[aiCenterName] = 0
  1630. }
  1631. }
  1632. }
  1633. totalCanUse := float64(0)
  1634. totalUse := float64(0)
  1635. totalUsageRate := float64(0)
  1636. for k, v := range OpenITotalDuration {
  1637. for i, j := range OpenIUsageDuration {
  1638. if k == i {
  1639. OpenIUsageRate[k] = float64(j) / float64(v)
  1640. }
  1641. }
  1642. }
  1643. for _, v := range OpenITotalDuration {
  1644. totalCanUse += float64(v)
  1645. }
  1646. for _, v := range OpenIUsageDuration {
  1647. totalUse += float64(v)
  1648. }
  1649. if totalCanUse == 0 || totalUse == 0 {
  1650. totalUsageRate = 0
  1651. } else {
  1652. totalUsageRate = totalUse / totalCanUse
  1653. }
  1654. delete(C2NetUsageDuration, "/")
  1655. OpenIDurationRate.AiCenterTotalDurationStat = OpenITotalDuration
  1656. OpenIDurationRate.AiCenterUsageDurationStat = OpenIUsageDuration
  1657. OpenIDurationRate.UsageRate = OpenIUsageRate
  1658. C2NetDurationRate.AiCenterTotalDurationStat = C2NetTotalDuration
  1659. C2NetDurationRate.AiCenterUsageDurationStat = C2NetUsageDuration
  1660. return OpenIDurationRate, C2NetDurationRate, totalUsageRate
  1661. }
  1662. func cutString(str string, lens int) string {
  1663. if len(str) < lens {
  1664. return str
  1665. }
  1666. return str[:lens]
  1667. }
  1668. func getDayCloudbrainDuration(beginTime time.Time, endTime time.Time, aiCenterCode string) ([]models.DateUsageStatistic, int, error) {
  1669. now := time.Now()
  1670. endTimeTemp := time.Date(endTime.Year(), endTime.Month(), endTime.Day(), 0, 0, 0, 0, now.Location())
  1671. if endTimeTemp.Equal(endTime) {
  1672. endTimeTemp = endTimeTemp.AddDate(0, 0, -1)
  1673. }
  1674. cardDurationStatistics, err := models.GetCardDurationStatistics(&models.DurationStatisticOptions{
  1675. BeginTime: beginTime,
  1676. EndTime: endTime,
  1677. AiCenterCode: aiCenterCode,
  1678. })
  1679. if err != nil {
  1680. log.Error("GetCardDurationStatistics error:", err)
  1681. return nil, 0, err
  1682. }
  1683. dayCloudbrainInfo := make([]models.DateUsageStatistic, 0)
  1684. count := 0
  1685. for beginTime.Before(endTimeTemp) || beginTime.Equal(endTimeTemp) {
  1686. TotalDuration, UsageDuration, UsageRate := getAiCenterUsageDuration(endTimeTemp, endTime, cardDurationStatistics)
  1687. dayCloudbrainInfo = append(dayCloudbrainInfo, models.DateUsageStatistic{
  1688. Date: endTimeTemp.Format("2006/01/02"),
  1689. UsageDuration: UsageDuration,
  1690. TotalDuration: TotalDuration,
  1691. UsageRate: UsageRate,
  1692. })
  1693. endTime = endTimeTemp
  1694. endTimeTemp = endTimeTemp.AddDate(0, 0, -1)
  1695. if endTimeTemp.Before(beginTime) && beginTime.Before(endTime) {
  1696. endTimeTemp = beginTime
  1697. }
  1698. count += 1
  1699. }
  1700. return dayCloudbrainInfo, count, nil
  1701. }
  1702. func getHourCloudbrainDuration(beginTime time.Time, endTime time.Time, aiCenterCode string) (models.HourTimeStatistic, error) {
  1703. hourTimeTotalDuration := make(map[string]int)
  1704. hourTimeUsageDuration := make(map[string]int)
  1705. hourTimeUsageRate := make(map[string]float64)
  1706. hourTimeStatistic := models.HourTimeStatistic{}
  1707. cardDurationStatistics, err := models.GetCardDurationStatistics(&models.DurationStatisticOptions{
  1708. BeginTime: beginTime,
  1709. EndTime: endTime,
  1710. })
  1711. if err != nil {
  1712. log.Error("GetCardDurationStatistics error:", err)
  1713. return hourTimeStatistic, err
  1714. }
  1715. for _, cloudbrainStatistic := range cardDurationStatistics {
  1716. if cloudbrainStatistic.AiCenterCode == aiCenterCode {
  1717. if _, ok := hourTimeTotalDuration[strconv.Itoa(cloudbrainStatistic.HourTime)]; !ok {
  1718. hourTimeTotalDuration[strconv.Itoa(cloudbrainStatistic.HourTime)] = cloudbrainStatistic.CardsTotalDuration
  1719. } else {
  1720. hourTimeTotalDuration[strconv.Itoa(cloudbrainStatistic.HourTime)] += cloudbrainStatistic.CardsTotalDuration
  1721. }
  1722. if _, ok := hourTimeUsageDuration[strconv.Itoa(cloudbrainStatistic.HourTime)]; !ok {
  1723. hourTimeUsageDuration[strconv.Itoa(cloudbrainStatistic.HourTime)] = cloudbrainStatistic.CardsUseDuration
  1724. } else {
  1725. hourTimeUsageDuration[strconv.Itoa(cloudbrainStatistic.HourTime)] += cloudbrainStatistic.CardsUseDuration
  1726. }
  1727. }
  1728. }
  1729. hourTimeList := []string{"0", "1", "2", "3", "4", "5", "6", "7", "8", "9", "10", "11", "12", "13", "14", "15", "16", "17", "18", "19", "20", "21", "22", "23"}
  1730. for _, v := range hourTimeList {
  1731. if _, ok := hourTimeUsageDuration[v]; !ok {
  1732. hourTimeUsageDuration[v] = 0
  1733. }
  1734. if _, ok := hourTimeTotalDuration[v]; !ok {
  1735. hourTimeTotalDuration[v] = 0
  1736. }
  1737. }
  1738. for k, v := range hourTimeTotalDuration {
  1739. for i, j := range hourTimeUsageDuration {
  1740. if k == i {
  1741. if v == 0 || j == 0 {
  1742. hourTimeUsageRate[k] = 0
  1743. } else {
  1744. hourTimeUsageRate[k] = float64(j) / float64(v)
  1745. }
  1746. }
  1747. }
  1748. }
  1749. hourTimeStatistic.HourTimeTotalDuration = hourTimeTotalDuration
  1750. hourTimeStatistic.HourTimeUsageDuration = hourTimeUsageDuration
  1751. hourTimeStatistic.HourTimeUsageRate = hourTimeUsageRate
  1752. return hourTimeStatistic, nil
  1753. }
  1754. func CloudbrainUpdateAiCenter(ctx *context.Context) {
  1755. repo.CloudbrainDurationStatisticHour()
  1756. ctx.JSON(http.StatusOK, map[string]interface{}{
  1757. "message": 0,
  1758. })
  1759. }
  1760. func GetResourceQueues(ctx *context.Context) {
  1761. resourceQueues, err := models.GetCanUseCardInfo()
  1762. if err != nil {
  1763. log.Error("GetCanUseCardInfo err: %v", err)
  1764. return
  1765. }
  1766. Resource := make([]*models.ResourceQueue, 0)
  1767. aiCenterCodeMap := make(map[string]string)
  1768. for _, resourceQueue := range resourceQueues {
  1769. if _, ok := aiCenterCodeMap[resourceQueue.AiCenterCode]; !ok {
  1770. resourceQueue.AiCenterName = repo.GetAiCenterNameByCode(resourceQueue.AiCenterCode, ctx.Language())
  1771. aiCenterCodeMap[resourceQueue.AiCenterCode] = resourceQueue.AiCenterCode
  1772. Resource = append(Resource, resourceQueue)
  1773. }
  1774. }
  1775. ctx.JSON(http.StatusOK, map[string]interface{}{
  1776. "resourceQueues": Resource,
  1777. })
  1778. }