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