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 73 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
2 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
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
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
2 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
2 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
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
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
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
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
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
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
2 years ago
3 years ago
2 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
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968
  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), string(models.JobTypeSnn4Ecoset)}
  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", "GCU"}
  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. listType := ctx.Query("listType")
  640. jobType := ctx.Query("jobType")
  641. jobStatus := ctx.Query("jobStatus")
  642. cloudBrainType := ctx.QueryInt("Type")
  643. aiCenter := ctx.Query("aiCenter")
  644. needDeleteInfo := ctx.Query("needDeleteInfo")
  645. accCardType := ctx.Query("accCardType")
  646. accCardsNum := ctx.QueryInt("accCardsNum")
  647. workServerNumber := ctx.QueryInt("workServerNumber")
  648. beginTimeStr := ctx.QueryTrim("beginTime")
  649. endTimeStr := ctx.QueryTrim("endTime")
  650. var beginTimeUnix int64
  651. var endTimeUnix int64
  652. if beginTimeStr == "" || endTimeStr == "" {
  653. beginTimeUnix = int64(recordBeginTime)
  654. endTimeUnix = time.Now().Unix()
  655. } else {
  656. beginTime, err := time.ParseInLocation("2006-01-02T15:04:05", beginTimeStr, time.Local)
  657. if err != nil {
  658. log.Error("Can not ParseInLocation.", err)
  659. ctx.Error(http.StatusBadRequest, ctx.Tr("ParseInLocation_get_error"))
  660. return
  661. }
  662. beginTimeUnix = beginTime.Unix()
  663. endTime, err := time.ParseInLocation("2006-01-02T15:04:05", endTimeStr, time.Local)
  664. if err != nil {
  665. log.Error("Can not ParseInLocation.", err)
  666. ctx.Error(http.StatusBadRequest, ctx.Tr("ParseInLocation_get_error"))
  667. return
  668. }
  669. endTimeUnix = endTime.Unix()
  670. }
  671. if cloudBrainType == models.TypeCloudBrainOne && aiCenter == models.AICenterOfCloudBrainOne {
  672. aiCenter = ""
  673. }
  674. if cloudBrainType == models.TypeCloudBrainTwo && aiCenter == models.AICenterOfCloudBrainTwo {
  675. aiCenter = ""
  676. }
  677. if cloudBrainType == models.TypeCDCenter && aiCenter == models.AICenterOfChengdu {
  678. aiCenter = ""
  679. }
  680. if cloudBrainType == models.TypeCloudBrainAll {
  681. if aiCenter == models.AICenterOfCloudBrainOne {
  682. cloudBrainType = models.TypeCloudBrainOne
  683. aiCenter = ""
  684. }
  685. if aiCenter == models.AICenterOfCloudBrainTwo {
  686. cloudBrainType = models.TypeCloudBrainTwo
  687. aiCenter = ""
  688. }
  689. if aiCenter == models.AICenterOfChengdu {
  690. cloudBrainType = models.TypeCDCenter
  691. aiCenter = ""
  692. }
  693. }
  694. page := ctx.QueryInt("page")
  695. pageSize := ctx.QueryInt("pagesize")
  696. if page <= 0 {
  697. page = 1
  698. }
  699. if pageSize <= 0 {
  700. pageSize = 10
  701. }
  702. var jobTypes []string
  703. jobTypeNot := false
  704. if jobType == string(models.JobTypeBenchmark) {
  705. jobTypes = append(jobTypes, string(models.JobTypeBenchmark), string(models.JobTypeModelSafety), string(models.JobTypeBrainScore), string(models.JobTypeSnn4imagenet), string(models.JobTypeSnn4Ecoset))
  706. } else if jobType != "all" && jobType != "" {
  707. jobTypes = append(jobTypes, jobType)
  708. }
  709. var jobStatuses []string
  710. jobStatusNot := false
  711. if jobStatus == "other" {
  712. jobStatusNot = true
  713. jobStatuses = append(jobStatuses, string(models.ModelArtsTrainJobWaiting), string(models.ModelArtsTrainJobFailed), string(models.ModelArtsRunning), string(models.ModelArtsTrainJobCompleted),
  714. string(models.ModelArtsStarting), string(models.ModelArtsRestarting), string(models.ModelArtsStartFailed),
  715. string(models.ModelArtsStopping), string(models.ModelArtsStopped), string(models.JobSucceeded))
  716. } else if jobStatus != "all" && jobStatus != "" {
  717. jobStatuses = append(jobStatuses, jobStatus)
  718. }
  719. keyword := strings.Trim(ctx.Query("q"), " ")
  720. ciTasks, count, err := models.CloudbrainAll(&models.CloudbrainsOptions{
  721. ListOptions: models.ListOptions{
  722. Page: page,
  723. PageSize: pageSize,
  724. },
  725. Keyword: keyword,
  726. Type: cloudBrainType,
  727. ComputeResource: listType,
  728. JobTypeNot: jobTypeNot,
  729. JobStatusNot: jobStatusNot,
  730. JobStatus: jobStatuses,
  731. JobTypes: jobTypes,
  732. NeedRepoInfo: true,
  733. BeginTimeUnix: beginTimeUnix,
  734. EndTimeUnix: endTimeUnix,
  735. AiCenter: aiCenter,
  736. NeedDeleteInfo: needDeleteInfo,
  737. AccCardType: accCardType,
  738. AccCardsNum: accCardsNum,
  739. WorkServerNumber: workServerNumber,
  740. })
  741. if err != nil {
  742. ctx.ServerError("Get job failed:", err)
  743. return
  744. }
  745. models.LoadSpecs4CloudbrainInfo(ciTasks)
  746. nilTime := time.Time{}
  747. tasks := []models.TaskDetail{}
  748. for i, task := range ciTasks {
  749. task = cloudbrainService.UpdateCloudbrainAiCenter(task)
  750. var taskDetail models.TaskDetail
  751. taskDetail.ID = ciTasks[i].Cloudbrain.ID
  752. taskDetail.JobID = ciTasks[i].Cloudbrain.JobID
  753. taskDetail.JobName = ciTasks[i].JobName
  754. taskDetail.DisplayJobName = ciTasks[i].DisplayJobName
  755. taskDetail.Status = ciTasks[i].Status
  756. taskDetail.JobType = ciTasks[i].JobType
  757. taskDetail.CreatedUnix = ciTasks[i].Cloudbrain.CreatedUnix
  758. taskDetail.RunTime = ciTasks[i].Cloudbrain.TrainJobDuration
  759. taskDetail.StartTime = ciTasks[i].StartTime
  760. taskDetail.EndTime = ciTasks[i].EndTime
  761. taskDetail.ComputeResource = ciTasks[i].ComputeResource
  762. taskDetail.Type = ciTasks[i].Cloudbrain.Type
  763. taskDetail.UserName = ciTasks[i].User.Name
  764. taskDetail.RepoID = ciTasks[i].RepoID
  765. taskDetail.AiCenter = repo.GetAiCenterNameByCode(task.Cloudbrain.AiCenter, ctx.Language())
  766. if ciTasks[i].Repo != nil {
  767. taskDetail.RepoName = ciTasks[i].Repo.OwnerName + "/" + ciTasks[i].Repo.Name
  768. taskDetail.RepoAlias = ciTasks[i].Repo.OwnerName + "/" + ciTasks[i].Repo.Alias
  769. }
  770. if ciTasks[i].Cloudbrain.WorkServerNumber >= 1 {
  771. taskDetail.WorkServerNum = int64(ciTasks[i].Cloudbrain.WorkServerNumber)
  772. } else {
  773. taskDetail.WorkServerNum = 1
  774. }
  775. taskDetail.CardDuration = repo.GetCloudbrainCardDuration(ciTasks[i].Cloudbrain)
  776. taskDetail.WaitTime = repo.GetCloudbrainWaitTime(ciTasks[i].Cloudbrain)
  777. if ciTasks[i].Cloudbrain.DeletedAt != nilTime || ciTasks[i].Repo == nil {
  778. taskDetail.IsDelete = true
  779. } else {
  780. taskDetail.IsDelete = false
  781. }
  782. taskDetail.Spec = ciTasks[i].Spec
  783. tasks = append(tasks, taskDetail)
  784. }
  785. pager := context.NewPagination(int(count), pageSize, page, getTotalPage(count, pageSize))
  786. pager.SetDefaultParams(ctx)
  787. pager.AddParam(ctx, "listType", "ListType")
  788. ctx.JSON(http.StatusOK, map[string]interface{}{
  789. "Title": ctx.Tr("kanban.cloudBrains"),
  790. "Tasks": tasks,
  791. "Keyword": keyword,
  792. "pager": pager,
  793. "count": count,
  794. })
  795. }
  796. func GetCloudbrainsCreateHoursData(ctx *context.Context) {
  797. recordCloudbrain, err := models.GetRecordBeginTime()
  798. if err != nil {
  799. log.Error("Can not get record begin time", err)
  800. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.record_begintime_get_err"))
  801. return
  802. }
  803. recordBeginTime := time.Unix(int64(recordCloudbrain[0].Cloudbrain.CreatedUnix), 0)
  804. // recordBeginTime, _ := time.Parse("2006-01-02 15:04:05", recordTime)
  805. now := time.Now()
  806. queryType := ctx.QueryTrim("type")
  807. beginTimeStr := ctx.QueryTrim("beginTime")
  808. endTimeStr := ctx.QueryTrim("endTime")
  809. var beginTime time.Time
  810. var endTime time.Time
  811. createHourPeriodCount := make(map[string]interface{})
  812. if queryType != "" {
  813. if queryType == "all" {
  814. beginTime = recordBeginTime
  815. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  816. endTime = now.AddDate(0, 0, 1)
  817. endTime = time.Date(endTime.Year(), endTime.Month(), endTime.Day(), 0, 0, 0, 0, now.Location())
  818. } else if queryType == "today" {
  819. beginTime = time.Date(now.Year(), now.Month(), now.Day(), 0, 0, 0, 0, now.Location())
  820. endTime = now.AddDate(0, 0, 1)
  821. endTime = time.Date(endTime.Year(), endTime.Month(), endTime.Day(), 0, 0, 0, 0, now.Location())
  822. } else if queryType == "yesterday" {
  823. beginTime = now.AddDate(0, 0, -1)
  824. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  825. endTime = time.Date(now.Year(), now.Month(), now.Day(), 0, 0, 0, 0, now.Location())
  826. } else if queryType == "current_week" {
  827. beginTime = now.AddDate(0, 0, -int(time.Now().Weekday())+1) //begin from monday
  828. endTime = now
  829. } else if queryType == "current_month" {
  830. beginTime = time.Date(now.Year(), now.Month(), 1, 0, 0, 0, 0, now.Location())
  831. endTime = now.AddDate(0, 0, 1)
  832. endTime = time.Date(endTime.Year(), endTime.Month(), endTime.Day(), 0, 0, 0, 0, now.Location())
  833. } else if queryType == "monthly" {
  834. endTime = now
  835. beginTime = now.AddDate(0, -1, 0)
  836. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  837. } else if queryType == "current_year" {
  838. beginTime = time.Date(now.Year(), 1, 1, 0, 0, 0, 0, now.Location())
  839. endTime = now.AddDate(0, 0, 1)
  840. endTime = time.Date(endTime.Year(), endTime.Month(), endTime.Day(), 0, 0, 0, 0, now.Location())
  841. } else if queryType == "last_month" {
  842. lastMonthTime := now.AddDate(0, -1, 0)
  843. beginTime = time.Date(lastMonthTime.Year(), lastMonthTime.Month(), 1, 0, 0, 0, 0, now.Location())
  844. endTime = time.Date(now.Year(), now.Month(), 1, 0, 0, 0, 0, now.Location())
  845. } else if queryType == "last_7day" {
  846. beginTime = now.AddDate(0, 0, -6)
  847. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  848. endTime = now.AddDate(0, 0, 1)
  849. endTime = time.Date(endTime.Year(), endTime.Month(), endTime.Day(), 0, 0, 0, 0, now.Location())
  850. } else if queryType == "last_30day" {
  851. beginTime = now.AddDate(0, 0, -29)
  852. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  853. endTime = now.AddDate(0, 0, 1)
  854. endTime = time.Date(endTime.Year(), endTime.Month(), endTime.Day(), 0, 0, 0, 0, now.Location())
  855. }
  856. } else {
  857. if beginTimeStr == "" || endTimeStr == "" {
  858. //如果查询类型和开始时间结束时间都未设置,按queryType=all处理
  859. beginTime = recordBeginTime
  860. endTime = now.AddDate(0, 0, 1)
  861. endTime = time.Date(endTime.Year(), endTime.Month(), endTime.Day(), 0, 0, 0, 0, now.Location())
  862. } else {
  863. beginTime, err = time.ParseInLocation("2006-01-02", beginTimeStr, time.Local)
  864. if err != nil {
  865. log.Error("Can not ParseInLocation.", err)
  866. ctx.Error(http.StatusBadRequest, ctx.Tr("ParseInLocation_get_error"))
  867. return
  868. }
  869. endTime, err = time.ParseInLocation("2006-01-02", endTimeStr, time.Local)
  870. if err != nil {
  871. log.Error("Can not ParseInLocation.", err)
  872. ctx.Error(http.StatusBadRequest, ctx.Tr("ParseInLocation_get_error"))
  873. return
  874. }
  875. endTime = time.Date(endTime.Year(), endTime.Month(), endTime.Day(), 0, 0, 0, 0, now.Location())
  876. }
  877. }
  878. dateBeginTime := beginTime.Format("2006-01-02")
  879. dateEndTime := endTime.Format("2006-01-02")
  880. createHourPeriodCount, err = models.GetCreateHourPeriodCount(dateBeginTime, dateEndTime)
  881. if err != nil {
  882. log.Error("Can not query hourPeriodCount.", err)
  883. ctx.Error(http.StatusBadRequest, ctx.Tr("hourPeriodCount_get_error"))
  884. return
  885. }
  886. dataPeriodCount := make(map[string]int64)
  887. days := (endTime.Unix() - beginTime.Unix()) / 3600 / 24
  888. for i := 0; i < int(days); i++ {
  889. runHourPeriodCount, err := models.GetRunHourPeriodCount(dateBeginTime, dateEndTime)
  890. if err != nil {
  891. log.Error("Can not query runHourPeriodCount.", err)
  892. ctx.Error(http.StatusBadRequest, ctx.Tr("runHourPeriodCount_get_error"))
  893. return
  894. }
  895. var slice = []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"}
  896. for _, v := range slice {
  897. dataPeriodCount[v] = dataPeriodCount[v] + runHourPeriodCount[v]
  898. }
  899. beginTime = endTime
  900. endTime = endTime.AddDate(0, 0, 1)
  901. dateBeginTime = beginTime.Format("2006-01-02")
  902. dateEndTime = endTime.Format("2006-01-02")
  903. }
  904. ctx.JSON(http.StatusOK, map[string]interface{}{
  905. "recordBeginTime": recordCloudbrain[0].Cloudbrain.CreatedUnix,
  906. "updateTime": now.Unix(),
  907. "createHourPeriodCount": createHourPeriodCount,
  908. "runHourPeriodCount": dataPeriodCount,
  909. })
  910. }
  911. func GetWaittingTop(ctx *context.Context) {
  912. ciTasks, err := models.GetWaittingTop()
  913. if err != nil {
  914. log.Error("Can not get record begin time", err)
  915. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.record_begintime_get_err"))
  916. return
  917. }
  918. tasks := []models.TaskDetail{}
  919. for i, task := range ciTasks {
  920. ciTasks[i].Cloudbrain.ComputeResource = task.ComputeResource
  921. var taskDetail models.TaskDetail
  922. taskDetail.DisplayJobName = ciTasks[i].DisplayJobName
  923. taskDetail.UserName = ciTasks[i].User.Name
  924. taskDetail.RepoID = ciTasks[i].RepoID
  925. if ciTasks[i].Repo != nil {
  926. taskDetail.RepoName = ciTasks[i].Repo.OwnerName + "/" + ciTasks[i].Repo.Name
  927. } else {
  928. taskDetail.RepoName = ""
  929. }
  930. WaitTimeInt := time.Now().Unix() - ciTasks[i].Cloudbrain.CreatedUnix.AsTime().Unix()
  931. taskDetail.WaitTime = models.ConvertDurationToStr(WaitTimeInt)
  932. if WaitTimeInt < 0 {
  933. taskDetail.WaitTime = "00:00:00"
  934. }
  935. taskDetail.ID = ciTasks[i].Cloudbrain.ID
  936. taskDetail.ComputeResource = ciTasks[i].Cloudbrain.ComputeResource
  937. taskDetail.JobType = ciTasks[i].Cloudbrain.JobType
  938. taskDetail.JobID = ciTasks[i].Cloudbrain.JobID
  939. taskDetail.Type = ciTasks[i].Cloudbrain.Type
  940. tasks = append(tasks, taskDetail)
  941. }
  942. ctx.JSON(http.StatusOK, map[string]interface{}{
  943. "tasks": tasks,
  944. })
  945. }
  946. func GetRunningTop(ctx *context.Context) {
  947. ciTasks, err := models.GetRunningTop()
  948. if err != nil {
  949. log.Error("Can not get record begin time", err)
  950. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.record_begintime_get_err"))
  951. return
  952. }
  953. tasks := []models.TaskDetail{}
  954. for i, task := range ciTasks {
  955. ciTasks[i].Cloudbrain.ComputeResource = task.ComputeResource
  956. var taskDetail models.TaskDetail
  957. taskDetail.DisplayJobName = ciTasks[i].DisplayJobName
  958. taskDetail.RunTime = ciTasks[i].Cloudbrain.TrainJobDuration
  959. taskDetail.UserName = ciTasks[i].User.Name
  960. taskDetail.RepoID = ciTasks[i].RepoID
  961. if ciTasks[i].Repo != nil {
  962. taskDetail.RepoName = ciTasks[i].Repo.OwnerName + "/" + ciTasks[i].Repo.Name
  963. }
  964. taskDetail.ID = ciTasks[i].Cloudbrain.ID
  965. taskDetail.ComputeResource = ciTasks[i].Cloudbrain.ComputeResource
  966. taskDetail.JobType = ciTasks[i].Cloudbrain.JobType
  967. taskDetail.JobID = ciTasks[i].Cloudbrain.JobID
  968. taskDetail.Type = ciTasks[i].Cloudbrain.Type
  969. tasks = append(tasks, taskDetail)
  970. }
  971. ctx.JSON(http.StatusOK, map[string]interface{}{
  972. "tasks": tasks,
  973. })
  974. }
  975. 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) {
  976. cloudOneJobTypeRes := make(map[string]int)
  977. cloudTwoJobTypeRes := make(map[string]int)
  978. intelligentNetJobTypeRes := make(map[string]int)
  979. cDCenterJobTypeRes := make(map[string]int)
  980. cloudBrainPeriodNum := make(map[int]int)
  981. cloudBrainComputeResource := make(map[string]int)
  982. for _, cloudbrain := range cloudbrains {
  983. if int64(cloudbrain.Cloudbrain.CreatedUnix) >= beginTime.Unix() && int64(cloudbrain.Cloudbrain.CreatedUnix) < endTime.Unix() {
  984. if cloudbrain.Cloudbrain.Type == models.TypeCloudBrainOne {
  985. if _, ok := cloudOneJobTypeRes[cloudbrain.Cloudbrain.JobType]; !ok {
  986. cloudOneJobTypeRes[cloudbrain.Cloudbrain.JobType] = 1
  987. } else {
  988. cloudOneJobTypeRes[cloudbrain.Cloudbrain.JobType] += 1
  989. }
  990. }
  991. if cloudbrain.Cloudbrain.Type == models.TypeCloudBrainTwo {
  992. if _, ok := cloudTwoJobTypeRes[cloudbrain.JobType]; !ok {
  993. cloudTwoJobTypeRes[cloudbrain.Cloudbrain.JobType] = 1
  994. } else {
  995. cloudTwoJobTypeRes[cloudbrain.Cloudbrain.JobType] += 1
  996. }
  997. }
  998. if _, ok := cloudBrainPeriodNum[cloudbrain.Cloudbrain.Type]; !ok {
  999. cloudBrainPeriodNum[cloudbrain.Cloudbrain.Type] = 1
  1000. } else {
  1001. cloudBrainPeriodNum[cloudbrain.Cloudbrain.Type] += 1
  1002. }
  1003. if _, ok := cloudBrainComputeResource[cloudbrain.Cloudbrain.ComputeResource]; !ok {
  1004. cloudBrainComputeResource[cloudbrain.Cloudbrain.ComputeResource] = 1
  1005. } else {
  1006. cloudBrainComputeResource[cloudbrain.Cloudbrain.ComputeResource] += 1
  1007. }
  1008. }
  1009. }
  1010. ComputeResourceList := []string{"CPU/GPU", "NPU", "GCU"}
  1011. for _, v := range ComputeResourceList {
  1012. if _, ok := cloudBrainComputeResource[v]; !ok {
  1013. cloudBrainComputeResource[v] = 0
  1014. }
  1015. }
  1016. jobTypeList := []string{"DEBUG", "BENCHMARK", "INFERENCE", "TRAIN", "SNN4IMAGENET", "BRAINSCORE"}
  1017. cloudBrainTypeList := []int{0, 1, 2, 3}
  1018. for _, v := range jobTypeList {
  1019. if _, ok := cloudOneJobTypeRes[v]; !ok {
  1020. cloudOneJobTypeRes[v] = 0
  1021. }
  1022. if _, ok := cloudTwoJobTypeRes[v]; !ok {
  1023. cloudTwoJobTypeRes[v] = 0
  1024. }
  1025. if _, ok := intelligentNetJobTypeRes[v]; !ok {
  1026. intelligentNetJobTypeRes[v] = 0
  1027. }
  1028. if _, ok := cDCenterJobTypeRes[v]; !ok {
  1029. cDCenterJobTypeRes[v] = 0
  1030. }
  1031. }
  1032. for _, v := range cloudBrainTypeList {
  1033. if _, ok := cloudBrainPeriodNum[v]; !ok {
  1034. cloudBrainPeriodNum[v] = 0
  1035. }
  1036. }
  1037. cloudBrainPeriodNum[-1] = cloudBrainPeriodNum[0] + cloudBrainPeriodNum[1] + cloudBrainPeriodNum[2] + cloudBrainPeriodNum[3]
  1038. return cloudOneJobTypeRes, cloudTwoJobTypeRes, intelligentNetJobTypeRes, cDCenterJobTypeRes, cloudBrainPeriodNum, cloudBrainComputeResource
  1039. }
  1040. func getDayCloudbrainNum(beginTime time.Time, endTime time.Time) ([]DateCloudbrainNum, error) {
  1041. var endTimeTemp time.Time
  1042. endTimeTemp = beginTime.AddDate(0, 0, 1)
  1043. cloudbrains, _, err := models.CloudbrainAllStatic(&models.CloudbrainsOptions{
  1044. Type: models.TypeCloudBrainAll,
  1045. BeginTimeUnix: beginTime.Unix(),
  1046. EndTimeUnix: endTime.Unix(),
  1047. })
  1048. if err != nil {
  1049. log.Error("Get cloudbrains failed:", err)
  1050. return nil, err
  1051. }
  1052. dayCloudbrainNum := make([]DateCloudbrainNum, 0)
  1053. for endTimeTemp.Before(endTime) || endTimeTemp.Equal(endTime) {
  1054. cloudOneJobTypeRes, cloudTwoJobTypeRes, intelligentNetJobTypeRes, cDCenterJobTypeRes, cloudBrainPeriodNum, cloudBrainComputeResource := getCloudbrainCount(beginTime, endTimeTemp, cloudbrains)
  1055. dayCloudbrainNum = append(dayCloudbrainNum, DateCloudbrainNum{
  1056. Date: beginTime.Format("2006/01/02"),
  1057. CloudOneJobTypeRes: cloudOneJobTypeRes,
  1058. CloudTwoJobTypeRes: cloudTwoJobTypeRes,
  1059. IntelligentNetJobTypeRes: intelligentNetJobTypeRes,
  1060. CDCenterJobTypeRes: cDCenterJobTypeRes,
  1061. CloudBrainPeriodNum: cloudBrainPeriodNum,
  1062. CloudBrainComputeResource: cloudBrainComputeResource,
  1063. })
  1064. if endTime.Before(endTimeTemp.AddDate(0, 0, 1)) && endTimeTemp.Before(endTime) {
  1065. beginTime = endTimeTemp
  1066. endTimeTemp = endTime
  1067. } else {
  1068. beginTime = endTimeTemp
  1069. endTimeTemp = beginTime.AddDate(0, 0, 1)
  1070. }
  1071. }
  1072. return dayCloudbrainNum, nil
  1073. }
  1074. func getMonthCloudbrainNum(beginTime time.Time, endTime time.Time) ([]DateCloudbrainNum, error) {
  1075. var endTimeTemp time.Time
  1076. now := time.Now()
  1077. endTimeTemp = beginTime.AddDate(0, 1, 0)
  1078. endTimeTemp = time.Date(endTimeTemp.Year(), endTimeTemp.Month(), 1, 0, 0, 0, 0, now.Location())
  1079. monthCloudbrainNum := make([]DateCloudbrainNum, 0)
  1080. cloudbrains, _, err := models.CloudbrainAllStatic(&models.CloudbrainsOptions{
  1081. Type: models.TypeCloudBrainAll,
  1082. BeginTimeUnix: beginTime.Unix(),
  1083. EndTimeUnix: endTime.Unix(),
  1084. })
  1085. if err != nil {
  1086. log.Error("Getcloudbrains failed:%v", err)
  1087. return nil, err
  1088. }
  1089. for endTimeTemp.Before(endTime) || endTimeTemp.Equal(endTime) {
  1090. cloudOneJobTypeRes, cloudTwoJobTypeRes, intelligentNetJobTypeRes, cDCenterJobTypeRes, cloudBrainPeriodNum, cloudBrainComputeResource := getCloudbrainCount(beginTime, endTimeTemp, cloudbrains)
  1091. monthCloudbrainNum = append(monthCloudbrainNum, DateCloudbrainNum{
  1092. Date: beginTime.Format("2006/01"),
  1093. CloudOneJobTypeRes: cloudOneJobTypeRes,
  1094. CloudTwoJobTypeRes: cloudTwoJobTypeRes,
  1095. IntelligentNetJobTypeRes: intelligentNetJobTypeRes,
  1096. CDCenterJobTypeRes: cDCenterJobTypeRes,
  1097. CloudBrainPeriodNum: cloudBrainPeriodNum,
  1098. CloudBrainComputeResource: cloudBrainComputeResource,
  1099. })
  1100. if endTime.Before(endTimeTemp.AddDate(0, 1, 0)) && endTimeTemp.Before(endTime) {
  1101. beginTime = endTimeTemp
  1102. endTimeTemp = endTime
  1103. } else {
  1104. beginTime = endTimeTemp
  1105. endTimeTemp = beginTime.AddDate(0, 1, 0)
  1106. }
  1107. }
  1108. return monthCloudbrainNum, nil
  1109. }
  1110. func getDayCloudbrainInfo(beginTime time.Time, endTime time.Time) ([]DateCloudbrainInfo, int, error) {
  1111. now := time.Now()
  1112. endTimeTemp := time.Date(endTime.Year(), endTime.Month(), endTime.Day(), 0, 0, 0, 0, now.Location())
  1113. if endTimeTemp.Equal(endTime) {
  1114. endTimeTemp = endTimeTemp.AddDate(0, 0, -1)
  1115. }
  1116. cloudbrains, _, err := models.CloudbrainAllStatic(&models.CloudbrainsOptions{
  1117. Type: models.TypeCloudBrainAll,
  1118. BeginTimeUnix: beginTime.Unix(),
  1119. EndTimeUnix: endTime.Unix(),
  1120. })
  1121. if err != nil {
  1122. log.Error("Getcloudbrains failed:%v", err)
  1123. return nil, 0, err
  1124. }
  1125. dayCloudbrainInfo := make([]DateCloudbrainInfo, 0)
  1126. count := 0
  1127. for beginTime.Before(endTimeTemp) || beginTime.Equal(endTimeTemp) {
  1128. _, _, _, _, cloudBrainPeriodNum, cloudBrainComputeResource := getCloudbrainCount(endTimeTemp, endTime, cloudbrains)
  1129. dayCloudbrainInfo = append(dayCloudbrainInfo, DateCloudbrainInfo{
  1130. Date: endTimeTemp.Format("2006/01/02"),
  1131. CloudBrainPeriodNum: cloudBrainPeriodNum,
  1132. CloudBrainComputeResource: cloudBrainComputeResource,
  1133. })
  1134. endTime = endTimeTemp
  1135. endTimeTemp = endTimeTemp.AddDate(0, 0, -1)
  1136. count += 1
  1137. }
  1138. return dayCloudbrainInfo, count, nil
  1139. }
  1140. func getMonthCloudbrainInfo(beginTime time.Time, endTime time.Time) ([]DateCloudbrainInfo, int, error) {
  1141. now := time.Now()
  1142. endTimeTemp := time.Date(endTime.Year(), endTime.Month(), 1, 0, 0, 0, 0, now.Location())
  1143. if endTimeTemp.Equal(endTime) {
  1144. endTimeTemp = endTimeTemp.AddDate(0, -1, 0)
  1145. }
  1146. cloudbrains, _, err := models.CloudbrainAllStatic(&models.CloudbrainsOptions{
  1147. Type: models.TypeCloudBrainAll,
  1148. BeginTimeUnix: beginTime.Unix(),
  1149. EndTimeUnix: endTime.Unix(),
  1150. })
  1151. if err != nil {
  1152. log.Error("Getcloudbrains failed:%v", err)
  1153. return nil, 0, err
  1154. }
  1155. dayCloudbrainInfo := make([]DateCloudbrainInfo, 0)
  1156. count := 0
  1157. for beginTime.Before(endTimeTemp) || beginTime.Equal(endTimeTemp) || (endTimeTemp.Before(beginTime) && beginTime.Before(endTime)) {
  1158. _, _, _, _, cloudBrainPeriodNum, cloudBrainComputeResource := getCloudbrainCount(endTimeTemp, endTime, cloudbrains)
  1159. dayCloudbrainInfo = append(dayCloudbrainInfo, DateCloudbrainInfo{
  1160. Date: endTimeTemp.Format("2006/01"),
  1161. CloudBrainPeriodNum: cloudBrainPeriodNum,
  1162. CloudBrainComputeResource: cloudBrainComputeResource,
  1163. })
  1164. endTime = endTimeTemp
  1165. endTimeTemp = endTimeTemp.AddDate(0, -1, 0)
  1166. count += 1
  1167. }
  1168. return dayCloudbrainInfo, count, nil
  1169. }
  1170. func DownloadCloudBrainBoard(ctx *context.Context) {
  1171. recordCloudbrain, err := models.GetRecordBeginTime()
  1172. if err != nil {
  1173. log.Error("Can not get recordCloudbrain", err)
  1174. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.record_begintime_get_err"))
  1175. return
  1176. }
  1177. page := 1
  1178. pageSize := 300
  1179. var cloudBrain = ctx.Tr("repo.cloudbrain")
  1180. fileName := getCloudbrainFileName(cloudBrain)
  1181. recordBeginTime := recordCloudbrain[0].Cloudbrain.CreatedUnix
  1182. now := time.Now()
  1183. endTime := now
  1184. _, total, err := models.CloudbrainAll(&models.CloudbrainsOptions{
  1185. ListOptions: models.ListOptions{
  1186. Page: page,
  1187. PageSize: pageSize,
  1188. },
  1189. Type: models.TypeCloudBrainAll,
  1190. BeginTimeUnix: int64(recordBeginTime),
  1191. EndTimeUnix: endTime.Unix(),
  1192. AccCardsNum: models.AccCardsNumAll,
  1193. })
  1194. if err != nil {
  1195. log.Warn("Can not get cloud brain info", err)
  1196. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.cloudbrain_query_fail"))
  1197. return
  1198. }
  1199. totalPage := getTotalPage(total, pageSize)
  1200. f := excelize.NewFile()
  1201. index := f.NewSheet(cloudBrain)
  1202. f.DeleteSheet("Sheet1")
  1203. for k, v := range allCloudbrainHeader(ctx) {
  1204. f.SetCellValue(cloudBrain, k, v)
  1205. }
  1206. var row = 2
  1207. for i := 0; i < totalPage; i++ {
  1208. pageRecords, _, err := models.CloudbrainAll(&models.CloudbrainsOptions{
  1209. ListOptions: models.ListOptions{
  1210. Page: page,
  1211. PageSize: pageSize,
  1212. },
  1213. Type: models.TypeCloudBrainAll,
  1214. BeginTimeUnix: int64(recordBeginTime),
  1215. EndTimeUnix: endTime.Unix(),
  1216. NeedRepoInfo: true,
  1217. AccCardsNum: models.AccCardsNumAll,
  1218. })
  1219. if err != nil {
  1220. log.Warn("Can not get cloud brain info", err)
  1221. continue
  1222. }
  1223. models.LoadSpecs4CloudbrainInfo(pageRecords)
  1224. for _, record := range pageRecords {
  1225. record = cloudbrainService.UpdateCloudbrainAiCenter(record)
  1226. record.Cloudbrain.AiCenter = repo.GetAiCenterNameByCode(record.Cloudbrain.AiCenter, ctx.Language())
  1227. for k, v := range allCloudbrainValues(row, record, ctx) {
  1228. f.SetCellValue(cloudBrain, k, v)
  1229. }
  1230. row++
  1231. }
  1232. page++
  1233. }
  1234. f.SetActiveSheet(index)
  1235. ctx.Resp.Header().Set("Content-Disposition", "attachment; filename="+url.QueryEscape(fileName))
  1236. ctx.Resp.Header().Set("Content-Type", "application/octet-stream")
  1237. f.WriteTo(ctx.Resp)
  1238. }
  1239. func getCloudbrainFileName(baseName string) string {
  1240. return baseName + "_" + time.Now().Format(EXCEL_DATE_FORMAT) + ".xlsx"
  1241. }
  1242. func allCloudbrainHeader(ctx *context.Context) map[string]string {
  1243. 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"),
  1244. "E1": ctx.Tr("repo.modelarts.createtime"), "F1": ctx.Tr("repo.modelarts.train_job.wait_time"), "G1": ctx.Tr("repo.modelarts.train_job.dura_time"),
  1245. "H1": ctx.Tr("cloudbrain.card_duration"),
  1246. "I1": ctx.Tr("repo.modelarts.train_job.start_time"), "J1": ctx.Tr("repo.modelarts.train_job.end_time"),
  1247. "K1": ctx.Tr("repo.modelarts.computing_resources"), "L1": ctx.Tr("cloudbrain.card_type"),
  1248. "M1": ctx.Tr("repo.modelarts.train_job.amount_of_compute_node"), "N1": ctx.Tr("repo.grampus.train_job.ai_center"),
  1249. "O1": ctx.Tr("cloudbrain.resource_specification"), "P1": ctx.Tr("repo.cloudbrain_creator"), "Q1": ctx.Tr("repo.repo_name"),
  1250. "R1": ctx.Tr("repo.cloudbrain_task_name"), "S1": ctx.Tr("repo.modelarts.deletetime")}
  1251. }
  1252. func allCloudbrainValues(row int, rs *models.CloudbrainInfo, ctx *context.Context) map[string]string {
  1253. 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,
  1254. getCellName("E", row): time.Unix(int64(rs.Cloudbrain.CreatedUnix), 0).Format(CREATE_TIME_FORMAT), getCellName("F", row): repo.GetCloudbrainWaitTime(rs.Cloudbrain),
  1255. getCellName("G", row): rs.TrainJobDuration, getCellName("H", row): repo.GetCloudbrainCardDuration(rs.Cloudbrain),
  1256. getCellName("I", row): getBrainStartTime(rs),
  1257. getCellName("J", row): getBrainEndTime(rs), getCellName("K", row): rs.ComputeResource, getCellName("L", row): getCloudbrainCardType(rs),
  1258. getCellName("M", row): getWorkServerNum(rs), getCellName("N", row): rs.Cloudbrain.AiCenter,
  1259. getCellName("O", row): getCloudbrainFlavorName(rs), getCellName("P", row): rs.Name,
  1260. getCellName("Q", row): getBrainRepo(rs), getCellName("R", row): rs.JobName, getCellName("S", row): getBrainDeleteTime(rs),
  1261. }
  1262. }
  1263. func getWorkServerNum(rs *models.CloudbrainInfo) string {
  1264. if rs.Cloudbrain.WorkServerNumber >= 1 {
  1265. return fmt.Sprint(rs.Cloudbrain.WorkServerNumber)
  1266. } else {
  1267. return "1"
  1268. }
  1269. }
  1270. func getBrainRepo(rs *models.CloudbrainInfo) string {
  1271. if rs.Repo != nil {
  1272. return rs.Repo.OwnerName + "/" + rs.Repo.Alias
  1273. }
  1274. return ""
  1275. }
  1276. func getBrainStartTime(rs *models.CloudbrainInfo) string {
  1277. timeString := time.Unix(int64(rs.Cloudbrain.StartTime), 0).Format(CREATE_TIME_FORMAT)
  1278. if timeString != "1970/01/01 08:00:00" {
  1279. return timeString
  1280. } else {
  1281. return "0"
  1282. }
  1283. }
  1284. func getBrainEndTime(rs *models.CloudbrainInfo) string {
  1285. timeString := time.Unix(int64(rs.Cloudbrain.EndTime), 0).Format(CREATE_TIME_FORMAT)
  1286. if timeString != "1970/01/01 08:00:00" {
  1287. return timeString
  1288. } else {
  1289. return "0"
  1290. }
  1291. }
  1292. func getCloudbrainType(rs *models.CloudbrainInfo, ctx *context.Context) string {
  1293. if rs.Cloudbrain.Type == models.TypeCloudBrainOne {
  1294. return ctx.Tr("repo.cloudbrain1")
  1295. } else if rs.Cloudbrain.Type == models.TypeCloudBrainTwo {
  1296. return ctx.Tr("repo.cloudbrain2")
  1297. } else if rs.Cloudbrain.Type == models.TypeC2Net {
  1298. return ctx.Tr("repo.intelligent_net")
  1299. } else {
  1300. return ctx.Tr("repo.cloudbrain_untype")
  1301. }
  1302. }
  1303. func getCloudbrainCardType(rs *models.CloudbrainInfo) string {
  1304. if rs.Cloudbrain.Spec != nil {
  1305. return rs.Cloudbrain.Spec.AccCardType
  1306. } else {
  1307. return ""
  1308. }
  1309. }
  1310. func getCloudbrainFlavorName(rs *models.CloudbrainInfo) string {
  1311. flavorName := repo.GetCloudbrainFlavorName(rs.Cloudbrain)
  1312. return flavorName
  1313. }
  1314. func getBrainDeleteTime(rs *models.CloudbrainInfo) string {
  1315. nilTime := time.Time{}
  1316. if rs.Cloudbrain.DeletedAt != nilTime {
  1317. return rs.Cloudbrain.DeletedAt.Format("2006-01-02 15:04:05")
  1318. } else {
  1319. return ""
  1320. }
  1321. }
  1322. func getCloudbrainTimePeroid(ctx *context.Context, recordBeginTime time.Time) (time.Time, time.Time, error) {
  1323. queryType := ctx.QueryTrim("type")
  1324. beginTimeStr := ctx.QueryTrim("beginTime")
  1325. endTimeStr := ctx.QueryTrim("endTime")
  1326. now := time.Now()
  1327. var beginTime time.Time
  1328. var endTime time.Time
  1329. var err error
  1330. if queryType != "" {
  1331. if queryType == "all" {
  1332. beginTime = recordBeginTime
  1333. endTime = now
  1334. } else if queryType == "today" {
  1335. endTime = now
  1336. beginTime = time.Date(endTime.Year(), endTime.Month(), endTime.Day(), 0, 0, 0, 0, now.Location())
  1337. } else if queryType == "yesterday" {
  1338. endTime = time.Date(now.Year(), now.Month(), now.Day(), 0, 0, 0, 0, now.Location())
  1339. beginTime = endTime.AddDate(0, 0, -1)
  1340. } else if queryType == "last_7day" {
  1341. beginTime = now.AddDate(0, 0, -6)
  1342. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  1343. endTime = now
  1344. } else if queryType == "last_30day" {
  1345. beginTime = now.AddDate(0, 0, -29)
  1346. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  1347. endTime = now
  1348. } else if queryType == "current_month" {
  1349. endTime = now
  1350. beginTime = time.Date(endTime.Year(), endTime.Month(), 1, 0, 0, 0, 0, now.Location())
  1351. } else if queryType == "monthly" {
  1352. endTime = now
  1353. beginTime = now.AddDate(0, -1, 1)
  1354. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  1355. } else if queryType == "current_year" {
  1356. endTime = now
  1357. beginTime = time.Date(endTime.Year(), 1, 1, 0, 0, 0, 0, now.Location())
  1358. } else if queryType == "last_month" {
  1359. lastMonthTime := now.AddDate(0, -1, 0)
  1360. beginTime = time.Date(lastMonthTime.Year(), lastMonthTime.Month(), 1, 0, 0, 0, 0, now.Location())
  1361. endTime = time.Date(now.Year(), now.Month(), 1, 0, 0, 0, 0, now.Location())
  1362. } else {
  1363. return now, now, fmt.Errorf("The value of type parameter is wrong.")
  1364. }
  1365. } else {
  1366. if beginTimeStr == "" || endTimeStr == "" {
  1367. //如果查询类型和开始时间结束时间都未设置,按queryType=all处理
  1368. beginTime = recordBeginTime
  1369. endTime = now
  1370. } else {
  1371. beginTime, err = time.ParseInLocation("2006-01-02", beginTimeStr, time.Local)
  1372. if err != nil {
  1373. return now, now, err
  1374. }
  1375. endTime, err = time.ParseInLocation("2006-01-02", endTimeStr, time.Local)
  1376. if err != nil {
  1377. return now, now, err
  1378. }
  1379. }
  1380. }
  1381. if beginTime.Before(recordBeginTime) {
  1382. beginTime = recordBeginTime
  1383. }
  1384. return beginTime, endTime, nil
  1385. }
  1386. func GetCloudbrainResourceOverview(ctx *context.Context) {
  1387. var recordBeginTime timeutil.TimeStamp
  1388. recordCloudbrainDuration, err := models.GetDurationRecordBeginTime()
  1389. if err != nil {
  1390. log.Error("Can not get GetDurationRecordBeginTime", err)
  1391. return
  1392. }
  1393. if len(recordCloudbrainDuration) > 0 && err == nil {
  1394. recordBeginTime = recordCloudbrainDuration[0].DateTimeUnix
  1395. } else {
  1396. recordBeginTime = timeutil.TimeStamp(time.Now().Unix())
  1397. }
  1398. recordUpdateTime := time.Now().Unix()
  1399. resourceQueues, err := models.GetCanUseCardInfo()
  1400. if err != nil {
  1401. log.Info("GetCanUseCardInfo err: %v", err)
  1402. return
  1403. }
  1404. OpenIResourceDetail := []models.ResourceDetail{}
  1405. C2NetResourceDetail := []models.ResourceDetail{}
  1406. for _, resourceQueue := range resourceQueues {
  1407. if resourceQueue.Cluster == models.OpenICluster {
  1408. aiCenterName := repo.GetAiCenterNameByCode(resourceQueue.AiCenterCode, ctx.Language())
  1409. var resourceDetail models.ResourceDetail
  1410. resourceDetail.QueueCode = resourceQueue.QueueCode
  1411. resourceDetail.Cluster = resourceQueue.Cluster
  1412. resourceDetail.AiCenterCode = resourceQueue.AiCenterCode
  1413. resourceDetail.AiCenterName = resourceQueue.AiCenterCode + "/" + aiCenterName
  1414. resourceDetail.ComputeResource = resourceQueue.ComputeResource
  1415. resourceDetail.AccCardType = resourceQueue.AccCardType + "(" + resourceQueue.ComputeResource + ")"
  1416. resourceDetail.CardsTotalNum = resourceQueue.CardsTotalNum
  1417. resourceDetail.IsAutomaticSync = resourceQueue.IsAutomaticSync
  1418. OpenIResourceDetail = append(OpenIResourceDetail, resourceDetail)
  1419. }
  1420. if resourceQueue.Cluster == models.C2NetCluster {
  1421. aiCenterName := repo.GetAiCenterNameByCode(resourceQueue.AiCenterCode, ctx.Language())
  1422. var resourceDetail models.ResourceDetail
  1423. resourceDetail.QueueCode = resourceQueue.QueueCode
  1424. resourceDetail.Cluster = resourceQueue.Cluster
  1425. resourceDetail.AiCenterCode = resourceQueue.AiCenterCode
  1426. resourceDetail.AiCenterName = resourceQueue.AiCenterCode + "/" + aiCenterName
  1427. resourceDetail.ComputeResource = resourceQueue.ComputeResource
  1428. resourceDetail.AccCardType = resourceQueue.AccCardType + "(" + resourceQueue.ComputeResource + ")"
  1429. resourceDetail.CardsTotalNum = resourceQueue.CardsTotalNum
  1430. resourceDetail.IsAutomaticSync = resourceQueue.IsAutomaticSync
  1431. C2NetResourceDetail = append(C2NetResourceDetail, resourceDetail)
  1432. }
  1433. }
  1434. openIResourceNum := make(map[string]map[string]int)
  1435. for _, openIResourceDetail := range OpenIResourceDetail {
  1436. if _, ok := openIResourceNum[openIResourceDetail.AiCenterName]; !ok {
  1437. openIResourceNum[openIResourceDetail.AiCenterName] = make(map[string]int)
  1438. }
  1439. if _, ok := openIResourceNum[openIResourceDetail.AiCenterName][openIResourceDetail.AccCardType]; !ok {
  1440. openIResourceNum[openIResourceDetail.AiCenterName][openIResourceDetail.AccCardType] = openIResourceDetail.CardsTotalNum
  1441. } else {
  1442. openIResourceNum[openIResourceDetail.AiCenterName][openIResourceDetail.AccCardType] += openIResourceDetail.CardsTotalNum
  1443. }
  1444. }
  1445. c2NetResourceNum := make(map[string]map[string]int)
  1446. for _, c2NetResourceDetail := range C2NetResourceDetail {
  1447. if _, ok := c2NetResourceNum[c2NetResourceDetail.AiCenterName]; !ok {
  1448. c2NetResourceNum[c2NetResourceDetail.AiCenterName] = make(map[string]int)
  1449. }
  1450. if _, ok := c2NetResourceNum[c2NetResourceDetail.AiCenterName][c2NetResourceDetail.AccCardType]; !ok {
  1451. c2NetResourceNum[c2NetResourceDetail.AiCenterName][c2NetResourceDetail.AccCardType] = c2NetResourceDetail.CardsTotalNum
  1452. } else {
  1453. c2NetResourceNum[c2NetResourceDetail.AiCenterName][c2NetResourceDetail.AccCardType] += c2NetResourceDetail.CardsTotalNum
  1454. }
  1455. }
  1456. ctx.JSON(http.StatusOK, map[string]interface{}{
  1457. "openI": openIResourceNum,
  1458. "c2Net": c2NetResourceNum,
  1459. "recordUpdateTime": recordUpdateTime,
  1460. "recordBeginTime": recordBeginTime,
  1461. })
  1462. }
  1463. func GetCloudbrainResourceUsageDetail(ctx *context.Context) {
  1464. aiCenterCode := ctx.QueryTrim("aiCenterCode")
  1465. if aiCenterCode == "" {
  1466. aiCenterCode = models.AICenterOfCloudBrainOne
  1467. }
  1468. beginTime, endTime := getBeginAndEndTime(ctx)
  1469. dayCloudbrainDuration, count, err := getDayCloudbrainDuration(beginTime, endTime, aiCenterCode)
  1470. if err != nil {
  1471. log.Error("Can not query dayCloudbrainDuration.", err)
  1472. return
  1473. }
  1474. hourCloudbrainDuration, err := getHourCloudbrainDuration(beginTime, endTime, aiCenterCode)
  1475. if err != nil {
  1476. log.Error("Can not query hourCloudbrainDuration.", err)
  1477. return
  1478. }
  1479. page := ctx.QueryInt("page")
  1480. if page <= 0 {
  1481. page = 1
  1482. }
  1483. pagesize := ctx.QueryInt("pagesize")
  1484. if pagesize <= 0 {
  1485. pagesize = 36500
  1486. }
  1487. pageDateCloudbrainDuration := getPageDateCloudbrainDuration(dayCloudbrainDuration, page, pagesize)
  1488. ctx.JSON(http.StatusOK, map[string]interface{}{
  1489. "totalCount": count,
  1490. "pageDateCloudbrainDuration": pageDateCloudbrainDuration,
  1491. "hourCloudbrainDuration": hourCloudbrainDuration,
  1492. })
  1493. }
  1494. func GetDurationRateStatistic(ctx *context.Context) {
  1495. beginTime, endTime := getBeginAndEndTime(ctx)
  1496. OpenIDurationRate, C2NetDurationRate, totalUsageRate := getDurationStatistic(beginTime, endTime)
  1497. ctx.JSON(http.StatusOK, map[string]interface{}{
  1498. "openIDurationRate": OpenIDurationRate,
  1499. "c2NetDurationRate": C2NetDurationRate,
  1500. "totalUsageRate": totalUsageRate,
  1501. })
  1502. }
  1503. func CloudbrainDurationStatisticForTest(ctx *context.Context) {
  1504. repo.CloudbrainDurationStatisticHour()
  1505. ctx.JSON(http.StatusOK, map[string]interface{}{
  1506. "message": 0,
  1507. })
  1508. }
  1509. func getBeginAndEndTime(ctx *context.Context) (time.Time, time.Time) {
  1510. queryType := ctx.QueryTrim("type")
  1511. now := time.Now()
  1512. beginTimeStr := ctx.QueryTrim("beginTime")
  1513. endTimeStr := ctx.QueryTrim("endTime")
  1514. var brainRecordBeginTime time.Time
  1515. var beginTime time.Time
  1516. var endTime time.Time
  1517. var err error
  1518. if queryType != "" {
  1519. if queryType == "all" {
  1520. recordCloudbrainDuration, err := models.GetDurationRecordBeginTime()
  1521. if err != nil {
  1522. log.Error("Can not get GetDurationRecordBeginTime", 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 if queryType == "today" {
  1534. beginTime = now.AddDate(0, 0, 0)
  1535. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  1536. endTime = now
  1537. } else if queryType == "yesterday" {
  1538. beginTime = now.AddDate(0, 0, -1)
  1539. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  1540. endTime = time.Date(now.Year(), now.Month(), now.Day(), 0, 0, 0, 0, now.Location())
  1541. } else if queryType == "last_7day" {
  1542. beginTime = now.AddDate(0, 0, -6)
  1543. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  1544. endTime = now
  1545. } else if queryType == "last_30day" {
  1546. beginTime = now.AddDate(0, 0, -29)
  1547. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  1548. endTime = now
  1549. } else if queryType == "current_month" {
  1550. endTime = now
  1551. beginTime = time.Date(endTime.Year(), endTime.Month(), 1, 0, 0, 0, 0, now.Location())
  1552. } else if queryType == "current_year" {
  1553. endTime = now
  1554. beginTime = time.Date(endTime.Year(), 1, 1, 0, 0, 0, 0, now.Location())
  1555. } else if queryType == "last_month" {
  1556. lastMonthTime := now.AddDate(0, -1, 0)
  1557. beginTime = time.Date(lastMonthTime.Year(), lastMonthTime.Month(), 1, 0, 0, 0, 0, now.Location())
  1558. endTime = time.Date(now.Year(), now.Month(), 1, 0, 0, 0, 0, now.Location())
  1559. }
  1560. } else {
  1561. if beginTimeStr == "" || endTimeStr == "" {
  1562. //如果查询类型和开始时间结束时间都未设置,按queryType=all处理
  1563. recordCloudbrainDuration, err := models.GetDurationRecordBeginTime()
  1564. if err != nil {
  1565. log.Error("Can not get recordCloudbrain", err)
  1566. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.record_begintime_get_err"))
  1567. return beginTime, endTime
  1568. }
  1569. if len(recordCloudbrainDuration) > 0 && err == nil {
  1570. brainRecordBeginTime = recordCloudbrainDuration[0].DateTimeUnix.AsTime()
  1571. } else {
  1572. brainRecordBeginTime = now
  1573. }
  1574. beginTime = brainRecordBeginTime
  1575. endTime = now
  1576. } else {
  1577. beginTime, err = time.ParseInLocation("2006-01-02", beginTimeStr, time.Local)
  1578. if err != nil {
  1579. log.Error("Can not ParseInLocation.", err)
  1580. ctx.Error(http.StatusBadRequest, ctx.Tr("ParseInLocation_get_error"))
  1581. return beginTime, endTime
  1582. }
  1583. endTime, err = time.ParseInLocation("2006-01-02", endTimeStr, time.Local)
  1584. if err != nil {
  1585. log.Error("Can not ParseInLocation.", err)
  1586. ctx.Error(http.StatusBadRequest, ctx.Tr("ParseInLocation_get_error"))
  1587. return beginTime, endTime
  1588. }
  1589. if endTime.After(time.Now()) {
  1590. endTime = time.Now()
  1591. }
  1592. }
  1593. }
  1594. return beginTime, endTime
  1595. }
  1596. func getAiCenterUsageDuration(beginTime time.Time, endTime time.Time, cloudbrainStatistics []*models.CloudbrainDurationStatistic) (int, int, float64) {
  1597. totalDuration := int(0)
  1598. usageDuration := int(0)
  1599. usageRate := float64(0)
  1600. for _, cloudbrainStatistic := range cloudbrainStatistics {
  1601. if int64(cloudbrainStatistic.DateTimeUnix) >= beginTime.Unix() && int64(cloudbrainStatistic.DateTimeUnix) < endTime.Unix() {
  1602. totalDuration += cloudbrainStatistic.CardsTotalDuration
  1603. usageDuration += cloudbrainStatistic.CardsUseDuration
  1604. }
  1605. }
  1606. if totalDuration == 0 || usageDuration == 0 {
  1607. usageRate = 0
  1608. } else {
  1609. usageRate = float64(usageDuration) / float64(totalDuration)
  1610. }
  1611. return totalDuration, usageDuration, usageRate
  1612. }
  1613. func getDurationStatistic(beginTime time.Time, endTime time.Time) (models.DurationRateStatistic, models.DurationRateStatistic, float64) {
  1614. OpenITotalDuration := make(map[string]int)
  1615. OpenIUsageDuration := make(map[string]int)
  1616. OpenIUsageRate := make(map[string]float64)
  1617. C2NetTotalDuration := make(map[string]int)
  1618. C2NetUsageDuration := make(map[string]int)
  1619. OpenIDurationRate := models.DurationRateStatistic{}
  1620. C2NetDurationRate := models.DurationRateStatistic{}
  1621. cardDurationStatistics, err := models.GetCardDurationStatistics(&models.DurationStatisticOptions{
  1622. BeginTime: beginTime,
  1623. EndTime: endTime,
  1624. })
  1625. if err != nil {
  1626. log.Error("GetCardDurationStatistics error:", err)
  1627. return OpenIDurationRate, C2NetDurationRate, 0
  1628. }
  1629. for _, cloudbrainStatistic := range cardDurationStatistics {
  1630. aiCenterName := cloudbrainStatistic.AiCenterCode + "/" + repo.GetAiCenterNameByCode(cloudbrainStatistic.AiCenterCode, "zh-CN")
  1631. if cloudbrainStatistic.Cluster == models.OpenICluster {
  1632. if _, ok := OpenITotalDuration[aiCenterName]; !ok {
  1633. OpenITotalDuration[aiCenterName] = cloudbrainStatistic.CardsTotalDuration
  1634. } else {
  1635. OpenITotalDuration[aiCenterName] += cloudbrainStatistic.CardsTotalDuration
  1636. }
  1637. if _, ok := OpenIUsageDuration[aiCenterName]; !ok {
  1638. OpenIUsageDuration[aiCenterName] = cloudbrainStatistic.CardsUseDuration
  1639. } else {
  1640. OpenIUsageDuration[aiCenterName] += cloudbrainStatistic.CardsUseDuration
  1641. }
  1642. }
  1643. if cloudbrainStatistic.Cluster == models.C2NetCluster {
  1644. if _, ok := C2NetTotalDuration[aiCenterName]; !ok {
  1645. C2NetTotalDuration[aiCenterName] = cloudbrainStatistic.CardsTotalDuration
  1646. } else {
  1647. C2NetTotalDuration[aiCenterName] += cloudbrainStatistic.CardsTotalDuration
  1648. }
  1649. if _, ok := C2NetUsageDuration[aiCenterName]; !ok {
  1650. C2NetUsageDuration[aiCenterName] = cloudbrainStatistic.CardsUseDuration
  1651. } else {
  1652. C2NetUsageDuration[aiCenterName] += cloudbrainStatistic.CardsUseDuration
  1653. }
  1654. }
  1655. }
  1656. ResourceAiCenterRes, err := models.GetResourceAiCenters()
  1657. if err != nil {
  1658. log.Error("Can not get ResourceAiCenterRes.", err)
  1659. return OpenIDurationRate, C2NetDurationRate, 0
  1660. }
  1661. for _, v := range ResourceAiCenterRes {
  1662. aiCenterName := v.AiCenterCode + "/" + repo.GetAiCenterNameByCode(v.AiCenterCode, "zh-CN")
  1663. if cutString(v.AiCenterCode, 4) == cutString(models.AICenterOfCloudBrainOne, 4) {
  1664. if _, ok := OpenIUsageDuration[aiCenterName]; !ok {
  1665. OpenIUsageDuration[aiCenterName] = 0
  1666. }
  1667. if _, ok := OpenITotalDuration[aiCenterName]; !ok {
  1668. OpenITotalDuration[aiCenterName] = 0
  1669. }
  1670. } else {
  1671. if _, ok := C2NetUsageDuration[aiCenterName]; !ok {
  1672. C2NetUsageDuration[aiCenterName] = 0
  1673. }
  1674. }
  1675. }
  1676. totalCanUse := float64(0)
  1677. totalUse := float64(0)
  1678. totalUsageRate := float64(0)
  1679. for k, v := range OpenITotalDuration {
  1680. for i, j := range OpenIUsageDuration {
  1681. if k == i {
  1682. OpenIUsageRate[k] = float64(j) / float64(v)
  1683. }
  1684. }
  1685. }
  1686. for _, v := range OpenITotalDuration {
  1687. totalCanUse += float64(v)
  1688. }
  1689. for _, v := range OpenIUsageDuration {
  1690. totalUse += float64(v)
  1691. }
  1692. if totalCanUse == 0 || totalUse == 0 {
  1693. totalUsageRate = 0
  1694. } else {
  1695. totalUsageRate = totalUse / totalCanUse
  1696. }
  1697. delete(C2NetUsageDuration, "/")
  1698. OpenIDurationRate.AiCenterTotalDurationStat = OpenITotalDuration
  1699. OpenIDurationRate.AiCenterUsageDurationStat = OpenIUsageDuration
  1700. OpenIDurationRate.UsageRate = OpenIUsageRate
  1701. C2NetDurationRate.AiCenterTotalDurationStat = C2NetTotalDuration
  1702. C2NetDurationRate.AiCenterUsageDurationStat = C2NetUsageDuration
  1703. return OpenIDurationRate, C2NetDurationRate, totalUsageRate
  1704. }
  1705. func cutString(str string, lens int) string {
  1706. if len(str) < lens {
  1707. return str
  1708. }
  1709. return str[:lens]
  1710. }
  1711. func getDayCloudbrainDuration(beginTime time.Time, endTime time.Time, aiCenterCode string) ([]models.DateUsageStatistic, int, error) {
  1712. now := time.Now()
  1713. endTimeTemp := time.Date(endTime.Year(), endTime.Month(), endTime.Day(), 0, 0, 0, 0, now.Location())
  1714. if endTimeTemp.Equal(endTime) {
  1715. endTimeTemp = endTimeTemp.AddDate(0, 0, -1)
  1716. }
  1717. cardDurationStatistics, err := models.GetCardDurationStatistics(&models.DurationStatisticOptions{
  1718. BeginTime: beginTime,
  1719. EndTime: endTime,
  1720. AiCenterCode: aiCenterCode,
  1721. })
  1722. if err != nil {
  1723. log.Error("GetCardDurationStatistics error:", err)
  1724. return nil, 0, err
  1725. }
  1726. dayCloudbrainInfo := make([]models.DateUsageStatistic, 0)
  1727. count := 0
  1728. for beginTime.Before(endTimeTemp) || beginTime.Equal(endTimeTemp) {
  1729. TotalDuration, UsageDuration, UsageRate := getAiCenterUsageDuration(endTimeTemp, endTime, cardDurationStatistics)
  1730. dayCloudbrainInfo = append(dayCloudbrainInfo, models.DateUsageStatistic{
  1731. Date: endTimeTemp.Format("2006/01/02"),
  1732. UsageDuration: UsageDuration,
  1733. TotalDuration: TotalDuration,
  1734. UsageRate: UsageRate,
  1735. })
  1736. endTime = endTimeTemp
  1737. endTimeTemp = endTimeTemp.AddDate(0, 0, -1)
  1738. if endTimeTemp.Before(beginTime) && beginTime.Before(endTime) {
  1739. endTimeTemp = beginTime
  1740. }
  1741. count += 1
  1742. }
  1743. return dayCloudbrainInfo, count, nil
  1744. }
  1745. func getHourCloudbrainDuration(beginTime time.Time, endTime time.Time, aiCenterCode string) (models.HourTimeStatistic, error) {
  1746. hourTimeTotalDuration := make(map[string]int)
  1747. hourTimeUsageDuration := make(map[string]int)
  1748. hourTimeUsageRate := make(map[string]float64)
  1749. hourTimeStatistic := models.HourTimeStatistic{}
  1750. cardDurationStatistics, err := models.GetCardDurationStatistics(&models.DurationStatisticOptions{
  1751. BeginTime: beginTime,
  1752. EndTime: endTime,
  1753. })
  1754. if err != nil {
  1755. log.Error("GetCardDurationStatistics error:", err)
  1756. return hourTimeStatistic, err
  1757. }
  1758. for _, cloudbrainStatistic := range cardDurationStatistics {
  1759. if cloudbrainStatistic.AiCenterCode == aiCenterCode {
  1760. if _, ok := hourTimeTotalDuration[strconv.Itoa(cloudbrainStatistic.HourTime)]; !ok {
  1761. hourTimeTotalDuration[strconv.Itoa(cloudbrainStatistic.HourTime)] = cloudbrainStatistic.CardsTotalDuration
  1762. } else {
  1763. hourTimeTotalDuration[strconv.Itoa(cloudbrainStatistic.HourTime)] += cloudbrainStatistic.CardsTotalDuration
  1764. }
  1765. if _, ok := hourTimeUsageDuration[strconv.Itoa(cloudbrainStatistic.HourTime)]; !ok {
  1766. hourTimeUsageDuration[strconv.Itoa(cloudbrainStatistic.HourTime)] = cloudbrainStatistic.CardsUseDuration
  1767. } else {
  1768. hourTimeUsageDuration[strconv.Itoa(cloudbrainStatistic.HourTime)] += cloudbrainStatistic.CardsUseDuration
  1769. }
  1770. }
  1771. }
  1772. 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"}
  1773. for _, v := range hourTimeList {
  1774. if _, ok := hourTimeUsageDuration[v]; !ok {
  1775. hourTimeUsageDuration[v] = 0
  1776. }
  1777. if _, ok := hourTimeTotalDuration[v]; !ok {
  1778. hourTimeTotalDuration[v] = 0
  1779. }
  1780. }
  1781. for k, v := range hourTimeTotalDuration {
  1782. for i, j := range hourTimeUsageDuration {
  1783. if k == i {
  1784. if v == 0 || j == 0 {
  1785. hourTimeUsageRate[k] = 0
  1786. } else {
  1787. hourTimeUsageRate[k] = float64(j) / float64(v)
  1788. }
  1789. }
  1790. }
  1791. }
  1792. hourTimeStatistic.HourTimeTotalDuration = hourTimeTotalDuration
  1793. hourTimeStatistic.HourTimeUsageDuration = hourTimeUsageDuration
  1794. hourTimeStatistic.HourTimeUsageRate = hourTimeUsageRate
  1795. return hourTimeStatistic, nil
  1796. }
  1797. func CloudbrainUpdateAiCenter(ctx *context.Context) {
  1798. repo.CloudbrainDurationStatisticHour()
  1799. ctx.JSON(http.StatusOK, map[string]interface{}{
  1800. "message": 0,
  1801. })
  1802. }
  1803. func GetResourceQueues(ctx *context.Context) {
  1804. resourceQueues, err := models.GetCanUseCardInfo()
  1805. if err != nil {
  1806. log.Error("GetCanUseCardInfo err: %v", err)
  1807. return
  1808. }
  1809. Resource := make([]*models.ResourceQueue, 0)
  1810. aiCenterCodeMap := make(map[string]string)
  1811. for _, resourceQueue := range resourceQueues {
  1812. if _, ok := aiCenterCodeMap[resourceQueue.AiCenterCode]; !ok {
  1813. resourceQueue.AiCenterName = repo.GetAiCenterNameByCode(resourceQueue.AiCenterCode, ctx.Language())
  1814. aiCenterCodeMap[resourceQueue.AiCenterCode] = resourceQueue.AiCenterCode
  1815. Resource = append(Resource, resourceQueue)
  1816. }
  1817. }
  1818. ctx.JSON(http.StatusOK, map[string]interface{}{
  1819. "resourceQueues": Resource,
  1820. })
  1821. }