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.

user_business_analysis.go 32 kB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926
  1. package models
  2. import (
  3. "encoding/json"
  4. "fmt"
  5. "sort"
  6. "strconv"
  7. "time"
  8. "code.gitea.io/gitea/modules/log"
  9. "code.gitea.io/gitea/modules/timeutil"
  10. "xorm.io/builder"
  11. "xorm.io/xorm"
  12. )
  13. type UserBusinessAnalysisAll struct {
  14. ID int64 `xorm:"pk"`
  15. CountDate int64 `xorm:"pk"`
  16. //action :ActionMergePullRequest // 11
  17. CodeMergeCount int `xorm:"NOT NULL DEFAULT 0"`
  18. //action :ActionCommitRepo // 5
  19. CommitCount int `xorm:"NOT NULL DEFAULT 0"`
  20. //action :ActionCreateIssue // 10
  21. IssueCount int `xorm:"NOT NULL DEFAULT 0"`
  22. //comment table current date
  23. CommentCount int `xorm:"NOT NULL DEFAULT 0"`
  24. //watch table current date
  25. FocusRepoCount int `xorm:"NOT NULL DEFAULT 0"`
  26. //star table current date
  27. StarRepoCount int `xorm:"NOT NULL DEFAULT 0"`
  28. //follow table
  29. WatchedCount int `xorm:"NOT NULL DEFAULT 0"`
  30. // user table
  31. GiteaAgeMonth int `xorm:"NOT NULL DEFAULT 0"`
  32. //
  33. CommitCodeSize int `xorm:"NOT NULL DEFAULT 0"`
  34. //attachement table
  35. CommitDatasetSize int `xorm:"NOT NULL DEFAULT 0"`
  36. //0
  37. CommitModelCount int `xorm:"NOT NULL DEFAULT 0"`
  38. //issue, issueassignees
  39. SolveIssueCount int `xorm:"NOT NULL DEFAULT 0"`
  40. //baike
  41. EncyclopediasCount int `xorm:"NOT NULL DEFAULT 0"`
  42. //user
  43. RegistDate timeutil.TimeStamp `xorm:"NOT NULL"`
  44. //repo
  45. CreateRepoCount int `xorm:"NOT NULL DEFAULT 0"`
  46. //login count, from elk
  47. LoginCount int `xorm:"NOT NULL DEFAULT 0"`
  48. //openi index
  49. OpenIIndex float64 `xorm:"NOT NULL DEFAULT 0"`
  50. //user
  51. Email string `xorm:"NOT NULL"`
  52. //user
  53. Name string `xorm:"NOT NULL"`
  54. DataDate string `xorm:"NULL"`
  55. }
  56. type UserBusinessAnalysis struct {
  57. ID int64 `xorm:"pk"`
  58. CountDate int64 `xorm:"pk"`
  59. //action :ActionMergePullRequest // 11
  60. CodeMergeCount int `xorm:"NOT NULL DEFAULT 0"`
  61. //action :ActionCommitRepo // 5
  62. CommitCount int `xorm:"NOT NULL DEFAULT 0"`
  63. //action :ActionCreateIssue // 6
  64. IssueCount int `xorm:"NOT NULL DEFAULT 0"`
  65. //comment table current date
  66. CommentCount int `xorm:"NOT NULL DEFAULT 0"`
  67. //watch table current date
  68. FocusRepoCount int `xorm:"NOT NULL DEFAULT 0"`
  69. //star table current date
  70. StarRepoCount int `xorm:"NOT NULL DEFAULT 0"`
  71. //follow table
  72. WatchedCount int `xorm:"NOT NULL DEFAULT 0"`
  73. // user table
  74. GiteaAgeMonth int `xorm:"NOT NULL DEFAULT 0"`
  75. //
  76. CommitCodeSize int `xorm:"NOT NULL DEFAULT 0"`
  77. //attachement table
  78. CommitDatasetSize int `xorm:"NOT NULL DEFAULT 0"`
  79. //0
  80. CommitModelCount int `xorm:"NOT NULL DEFAULT 0"`
  81. //issue, issueassignees
  82. SolveIssueCount int `xorm:"NOT NULL DEFAULT 0"`
  83. //baike
  84. EncyclopediasCount int `xorm:"NOT NULL DEFAULT 0"`
  85. //user
  86. RegistDate timeutil.TimeStamp `xorm:"NOT NULL"`
  87. //repo
  88. CreateRepoCount int `xorm:"NOT NULL DEFAULT 0"`
  89. //login count, from elk
  90. LoginCount int `xorm:"NOT NULL DEFAULT 0"`
  91. //openi index
  92. OpenIIndex float64 `xorm:"NOT NULL DEFAULT 0"`
  93. //user
  94. Email string `xorm:"NOT NULL"`
  95. //user
  96. Name string `xorm:"NOT NULL"`
  97. DataDate string `xorm:"NULL"`
  98. }
  99. type UserBusinessAnalysisQueryOptions struct {
  100. ListOptions
  101. UserName string
  102. SortType string
  103. StartTime int64
  104. EndTime int64
  105. IsAll bool
  106. }
  107. type UserBusinessAnalysisList []*UserBusinessAnalysis
  108. func (ulist UserBusinessAnalysisList) Swap(i, j int) { ulist[i], ulist[j] = ulist[j], ulist[i] }
  109. func (ulist UserBusinessAnalysisList) Len() int { return len(ulist) }
  110. func (ulist UserBusinessAnalysisList) Less(i, j int) bool {
  111. return ulist[i].ID > ulist[j].ID
  112. }
  113. type UserBusinessAnalysisAllList []*UserBusinessAnalysisAll
  114. func (ulist UserBusinessAnalysisAllList) Swap(i, j int) { ulist[i], ulist[j] = ulist[j], ulist[i] }
  115. func (ulist UserBusinessAnalysisAllList) Len() int { return len(ulist) }
  116. func (ulist UserBusinessAnalysisAllList) Less(i, j int) bool {
  117. return ulist[i].ID > ulist[j].ID
  118. }
  119. func getLastCountDate() int64 {
  120. statictisSess := xStatistic.NewSession()
  121. defer statictisSess.Close()
  122. statictisSess.Limit(1, 0)
  123. userBusinessAnalysisList := make([]*UserBusinessAnalysis, 0)
  124. if err := statictisSess.Table("user_business_analysis").OrderBy("count_date desc").Limit(1, 0).
  125. Find(&userBusinessAnalysisList); err == nil {
  126. for _, userRecord := range userBusinessAnalysisList {
  127. return userRecord.CountDate - 10000
  128. }
  129. } else {
  130. log.Info("query error." + err.Error())
  131. }
  132. currentTimeNow := time.Now()
  133. pageStartTime := time.Date(currentTimeNow.Year(), currentTimeNow.Month(), currentTimeNow.Day(), 0, 0, 0, 0, currentTimeNow.Location())
  134. return pageStartTime.Unix()
  135. }
  136. func QueryUserStaticDataAll(opts *UserBusinessAnalysisQueryOptions) ([]*UserBusinessAnalysisAll, int64) {
  137. log.Info("query startTime =" + fmt.Sprint(opts.StartTime) + " endTime=" + fmt.Sprint(opts.EndTime) + " isAll=" + fmt.Sprint(opts.IsAll))
  138. statictisSess := xStatistic.NewSession()
  139. defer statictisSess.Close()
  140. allCount, err := statictisSess.Count(new(UserBusinessAnalysisAll))
  141. if err != nil {
  142. log.Info("query error." + err.Error())
  143. return nil, 0
  144. }
  145. log.Info("query return total:" + fmt.Sprint(allCount))
  146. if allCount == 0 {
  147. RefreshUserStaticAllTabel()
  148. }
  149. pageSize := 1000
  150. totalPage := int(allCount) / pageSize
  151. userBusinessAnalysisReturnList := UserBusinessAnalysisAllList{}
  152. for i := 0; i <= int(totalPage); i++ {
  153. userBusinessAnalysisAllList := make([]*UserBusinessAnalysisAll, 0)
  154. if err := statictisSess.Table("user_business_analysis_all").OrderBy("id desc").Limit(pageSize, i*pageSize).
  155. Find(&userBusinessAnalysisAllList); err != nil {
  156. return nil, 0
  157. }
  158. log.Info("query " + fmt.Sprint(i+1) + " result size=" + fmt.Sprint(len(userBusinessAnalysisAllList)))
  159. for _, userRecord := range userBusinessAnalysisAllList {
  160. userBusinessAnalysisReturnList = append(userBusinessAnalysisReturnList, userRecord)
  161. }
  162. }
  163. sort.Sort(userBusinessAnalysisReturnList)
  164. log.Info("return size=" + fmt.Sprint(len(userBusinessAnalysisReturnList)))
  165. return userBusinessAnalysisReturnList, allCount
  166. }
  167. func QueryUserStaticDataPage(opts *UserBusinessAnalysisQueryOptions) ([]*UserBusinessAnalysis, int64) {
  168. log.Info("query startTime =" + fmt.Sprint(opts.StartTime) + " endTime=" + fmt.Sprint(opts.EndTime) + " isAll=" + fmt.Sprint(opts.IsAll))
  169. statictisSess := xStatistic.NewSession()
  170. defer statictisSess.Close()
  171. currentTimeNow := time.Now()
  172. pageStartTime := getLastCountDate()
  173. pageEndTime := time.Date(currentTimeNow.Year(), currentTimeNow.Month(), currentTimeNow.Day(), 23, 59, 59, 0, currentTimeNow.Location()).Unix()
  174. var cond = builder.NewCond()
  175. if len(opts.UserName) > 0 {
  176. cond = cond.And(
  177. builder.Like{"name", opts.UserName},
  178. )
  179. }
  180. cond = cond.And(
  181. builder.Gte{"count_date": pageStartTime},
  182. )
  183. cond = cond.And(
  184. builder.Lte{"count_date": pageEndTime},
  185. )
  186. count, err := statictisSess.Where(cond).Count(new(UserBusinessAnalysis))
  187. if err != nil {
  188. log.Info("query error." + err.Error())
  189. return nil, 0
  190. }
  191. if opts.Page >= 0 && opts.PageSize > 0 {
  192. var start int
  193. if opts.Page == 0 {
  194. start = 0
  195. } else {
  196. start = (opts.Page - 1) * opts.PageSize
  197. }
  198. statictisSess.Limit(opts.PageSize, start)
  199. }
  200. userBusinessAnalysisList := make([]*UserBusinessAnalysis, 0)
  201. if err := statictisSess.Table("user_business_analysis").Where(cond).OrderBy("id desc").
  202. Find(&userBusinessAnalysisList); err != nil {
  203. return nil, 0
  204. }
  205. resultMap := make(map[int64]*UserBusinessAnalysis)
  206. if len(userBusinessAnalysisList) > 0 {
  207. var newAndCond = builder.NewCond()
  208. var newOrCond = builder.NewCond()
  209. for _, userRecord := range userBusinessAnalysisList {
  210. newOrCond = newOrCond.Or(
  211. builder.Eq{"id": userRecord.ID},
  212. )
  213. }
  214. newAndCond = newAndCond.And(
  215. newOrCond,
  216. )
  217. if !opts.IsAll {
  218. newAndCond = newAndCond.And(
  219. builder.Gte{"count_date": opts.StartTime},
  220. )
  221. newAndCond = newAndCond.And(
  222. builder.Lte{"count_date": opts.EndTime},
  223. )
  224. }
  225. allCount, err := statictisSess.Where(newAndCond).Count(new(UserBusinessAnalysis))
  226. if err != nil {
  227. log.Info("query error." + err.Error())
  228. return nil, 0
  229. }
  230. pageSize := 1000
  231. totalPage := int(allCount) / pageSize
  232. for i := 0; i <= int(totalPage); i++ {
  233. userBusinessAnalysisList = make([]*UserBusinessAnalysis, 0)
  234. if err := statictisSess.Table("user_business_analysis").Where(newAndCond).OrderBy("count_date desc").Limit(pageSize, i*pageSize).
  235. Find(&userBusinessAnalysisList); err != nil {
  236. return nil, 0
  237. }
  238. log.Info("query result size=" + fmt.Sprint(len(userBusinessAnalysisList)))
  239. for _, userRecord := range userBusinessAnalysisList {
  240. if _, ok := resultMap[userRecord.ID]; !ok {
  241. resultMap[userRecord.ID] = userRecord
  242. } else {
  243. resultMap[userRecord.ID].CodeMergeCount += userRecord.CodeMergeCount
  244. resultMap[userRecord.ID].CommitCount += userRecord.CommitCount
  245. resultMap[userRecord.ID].IssueCount += userRecord.IssueCount
  246. resultMap[userRecord.ID].CommentCount += userRecord.CommentCount
  247. resultMap[userRecord.ID].FocusRepoCount += userRecord.FocusRepoCount
  248. resultMap[userRecord.ID].StarRepoCount += userRecord.StarRepoCount
  249. resultMap[userRecord.ID].WatchedCount += userRecord.WatchedCount
  250. resultMap[userRecord.ID].CommitCodeSize += userRecord.CommitCodeSize
  251. resultMap[userRecord.ID].CommitDatasetSize += userRecord.CommitDatasetSize
  252. resultMap[userRecord.ID].CommitModelCount += userRecord.CommitModelCount
  253. resultMap[userRecord.ID].SolveIssueCount += userRecord.SolveIssueCount
  254. resultMap[userRecord.ID].EncyclopediasCount += userRecord.EncyclopediasCount
  255. resultMap[userRecord.ID].CreateRepoCount += userRecord.CreateRepoCount
  256. resultMap[userRecord.ID].LoginCount += userRecord.LoginCount
  257. }
  258. }
  259. }
  260. }
  261. userBusinessAnalysisReturnList := UserBusinessAnalysisList{}
  262. for _, v := range resultMap {
  263. userBusinessAnalysisReturnList = append(userBusinessAnalysisReturnList, v)
  264. }
  265. sort.Sort(userBusinessAnalysisReturnList)
  266. log.Info("return size=" + fmt.Sprint(len(userBusinessAnalysisReturnList)))
  267. return userBusinessAnalysisReturnList, count
  268. }
  269. func RefreshUserStaticAllTabel() {
  270. statictisSess := xStatistic.NewSession()
  271. defer statictisSess.Close()
  272. log.Info("delete all data from table: user_business_analysis_all")
  273. statictisSess.Exec("delete from user_business_analysis_all")
  274. currentTimeNow := time.Now()
  275. pageStartTime := getLastCountDate()
  276. pageEndTime := time.Date(currentTimeNow.Year(), currentTimeNow.Month(), currentTimeNow.Day(), 23, 59, 59, 0, currentTimeNow.Location()).Unix()
  277. var cond = builder.NewCond()
  278. cond = cond.And(
  279. builder.Gte{"count_date": pageStartTime},
  280. )
  281. cond = cond.And(
  282. builder.Lte{"count_date": pageEndTime},
  283. )
  284. userBusinessAnalysisList := make([]*UserBusinessAnalysis, 0)
  285. if err := statictisSess.Table("user_business_analysis").Where(cond).OrderBy("id desc").
  286. Find(&userBusinessAnalysisList); err != nil {
  287. return
  288. }
  289. log.Info("query all data from table: user_business_analysis,len=" + fmt.Sprint(len(userBusinessAnalysisList)))
  290. for _, userRecord := range userBusinessAnalysisList {
  291. log.Info("insert to UserBusinessAnalysisAll table,user id=" + fmt.Sprint(userRecord.ID))
  292. allData := getAllData(userRecord.ID, statictisSess)
  293. allData.ID = userRecord.ID
  294. allData.CountDate = 0
  295. allData.DataDate = userRecord.DataDate
  296. allData.Email = userRecord.Email
  297. allData.OpenIIndex = userRecord.OpenIIndex
  298. allData.GiteaAgeMonth = userRecord.GiteaAgeMonth
  299. allData.Name = userRecord.Name
  300. allData.RegistDate = userRecord.RegistDate
  301. _, err := statictisSess.Insert(&allData)
  302. if err != nil {
  303. log.Info("insert all data failed." + err.Error())
  304. }
  305. }
  306. log.Info("refresh all data finished.")
  307. }
  308. func CounDataByDateAndReCount(wikiCountMap map[string]int, startTime time.Time, endTime time.Time, isReCount bool) error {
  309. log.Info("start to count other user info data")
  310. sess := x.NewSession()
  311. defer sess.Close()
  312. sess.Select("`user`.*").Table("user").Where("type != 1 and is_active=true")
  313. userList := make([]*User, 0)
  314. sess.Find(&userList)
  315. currentTimeNow := time.Now()
  316. log.Info("current time:" + currentTimeNow.Format("2006-01-02 15:04:05"))
  317. //yesterday := currentTimeNow.AddDate(0, 0, -1)
  318. //startTime := time.Date(yesterday.Year(), yesterday.Month(), yesterday.Day(), 0, 0, 0, 0, yesterday.Location())
  319. start_unix := startTime.Unix()
  320. log.Info("DB query time:" + startTime.Format("2006-01-02 15:04:05"))
  321. //endTime := time.Date(currentTimeNow.Year(), currentTimeNow.Month(), currentTimeNow.Day(), 0, 0, 0, 0, currentTimeNow.Location())
  322. end_unix := endTime.Unix()
  323. CountDate := time.Date(currentTimeNow.Year(), currentTimeNow.Month(), currentTimeNow.Day(), 0, 1, 0, 0, currentTimeNow.Location())
  324. if isReCount {
  325. CountDate = time.Date(startTime.Year(), startTime.Month(), startTime.Day(), 0, 1, 0, 0, currentTimeNow.Location())
  326. }
  327. DataDate := startTime.Format("2006-01-02")
  328. CodeMergeCountMap := queryPullRequest(start_unix, end_unix)
  329. CommitCountMap := queryCommitAction(start_unix, end_unix, 5)
  330. IssueCountMap := queryAction(start_unix, end_unix, 6)
  331. CommentCountMap := queryComment(start_unix, end_unix)
  332. FocusRepoCountMap := queryWatch(start_unix, end_unix)
  333. StarRepoCountMap := queryStar(start_unix, end_unix)
  334. WatchedCountMap := queryFollow(start_unix, end_unix)
  335. CommitCodeSizeMap, err := GetAllUserKPIStats()
  336. if err != nil {
  337. log.Info("query commit code errr.")
  338. } else {
  339. log.Info("query commit code size, len=" + fmt.Sprint(len(CommitCodeSizeMap)))
  340. }
  341. CommitDatasetSizeMap := queryDatasetSize(start_unix, end_unix)
  342. SolveIssueCountMap := querySolveIssue(start_unix, end_unix)
  343. CreateRepoCountMap := queryUserCreateRepo(start_unix, end_unix)
  344. LoginCountMap := queryLoginCount(start_unix, end_unix)
  345. OpenIIndexMap := queryUserRepoOpenIIndex(start_unix, end_unix)
  346. statictisSess := xStatistic.NewSession()
  347. defer statictisSess.Close()
  348. for i, userRecord := range userList {
  349. var dateRecord UserBusinessAnalysis
  350. dateRecord.ID = userRecord.ID
  351. log.Info("i=" + fmt.Sprint(i) + " userName=" + userRecord.Name)
  352. dateRecord.CountDate = CountDate.Unix()
  353. statictisSess.Delete(&dateRecord)
  354. dateRecord.Email = userRecord.Email
  355. dateRecord.RegistDate = userRecord.CreatedUnix
  356. dateRecord.Name = userRecord.Name
  357. dateRecord.GiteaAgeMonth = subMonth(currentTimeNow, userRecord.CreatedUnix.AsTime())
  358. dateRecord.DataDate = DataDate
  359. if _, ok := CodeMergeCountMap[dateRecord.ID]; !ok {
  360. dateRecord.CodeMergeCount = 0
  361. } else {
  362. dateRecord.CodeMergeCount = CodeMergeCountMap[dateRecord.ID]
  363. }
  364. if _, ok := CommitCountMap[dateRecord.ID]; !ok {
  365. dateRecord.CommitCount = 0
  366. } else {
  367. dateRecord.CommitCount = CommitCountMap[dateRecord.ID]
  368. }
  369. if _, ok := IssueCountMap[dateRecord.ID]; !ok {
  370. dateRecord.IssueCount = 0
  371. } else {
  372. dateRecord.IssueCount = IssueCountMap[dateRecord.ID]
  373. }
  374. if _, ok := CommentCountMap[dateRecord.ID]; !ok {
  375. dateRecord.CommentCount = 0
  376. } else {
  377. dateRecord.CommentCount = CommentCountMap[dateRecord.ID]
  378. }
  379. if _, ok := FocusRepoCountMap[dateRecord.ID]; !ok {
  380. dateRecord.FocusRepoCount = 0
  381. } else {
  382. dateRecord.FocusRepoCount = FocusRepoCountMap[dateRecord.ID]
  383. }
  384. if _, ok := StarRepoCountMap[dateRecord.ID]; !ok {
  385. dateRecord.StarRepoCount = 0
  386. } else {
  387. dateRecord.StarRepoCount = StarRepoCountMap[dateRecord.ID]
  388. }
  389. if _, ok := WatchedCountMap[dateRecord.ID]; !ok {
  390. dateRecord.WatchedCount = 0
  391. } else {
  392. dateRecord.WatchedCount = WatchedCountMap[dateRecord.ID]
  393. }
  394. if _, ok := CommitCodeSizeMap[dateRecord.Email]; !ok {
  395. dateRecord.CommitCodeSize = 0
  396. } else {
  397. dateRecord.CommitCodeSize = int(CommitCodeSizeMap[dateRecord.Email].CommitLines)
  398. }
  399. if _, ok := CommitDatasetSizeMap[dateRecord.ID]; !ok {
  400. dateRecord.CommitDatasetSize = 0
  401. } else {
  402. dateRecord.CommitDatasetSize = CommitDatasetSizeMap[dateRecord.ID]
  403. }
  404. if _, ok := SolveIssueCountMap[dateRecord.ID]; !ok {
  405. dateRecord.SolveIssueCount = 0
  406. } else {
  407. dateRecord.SolveIssueCount = SolveIssueCountMap[dateRecord.ID]
  408. }
  409. if _, ok := wikiCountMap[dateRecord.Name]; !ok {
  410. dateRecord.EncyclopediasCount = 0
  411. } else {
  412. dateRecord.EncyclopediasCount = wikiCountMap[dateRecord.Name]
  413. }
  414. if _, ok := CreateRepoCountMap[dateRecord.ID]; !ok {
  415. dateRecord.CreateRepoCount = 0
  416. } else {
  417. dateRecord.CreateRepoCount = CreateRepoCountMap[dateRecord.ID]
  418. }
  419. if _, ok := LoginCountMap[dateRecord.ID]; !ok {
  420. dateRecord.LoginCount = 0
  421. } else {
  422. dateRecord.LoginCount = LoginCountMap[dateRecord.ID]
  423. }
  424. if _, ok := OpenIIndexMap[dateRecord.ID]; !ok {
  425. dateRecord.OpenIIndex = 0
  426. } else {
  427. dateRecord.OpenIIndex = OpenIIndexMap[dateRecord.ID]
  428. }
  429. dateRecord.CommitModelCount = 0
  430. _, err = statictisSess.Insert(&dateRecord)
  431. if err != nil {
  432. log.Info("insert daterecord failed." + err.Error())
  433. return err
  434. }
  435. if isExistUserInAllTable(dateRecord.ID, statictisSess) {
  436. updateCurrentData(dateRecord.ID, statictisSess, dateRecord)
  437. } else {
  438. log.Info("insert to UserBusinessAnalysisAll table,user id=" + fmt.Sprint(dateRecord.ID))
  439. allData := getAllData(dateRecord.ID, statictisSess)
  440. allData.ID = dateRecord.ID
  441. allData.CountDate = 0
  442. allData.DataDate = dateRecord.DataDate
  443. allData.Email = dateRecord.Email
  444. allData.OpenIIndex = dateRecord.OpenIIndex
  445. allData.GiteaAgeMonth = dateRecord.GiteaAgeMonth
  446. allData.Name = dateRecord.Name
  447. allData.RegistDate = dateRecord.RegistDate
  448. _, err = statictisSess.Insert(&allData)
  449. if err != nil {
  450. log.Info("insert all data failed." + err.Error())
  451. return err
  452. }
  453. }
  454. }
  455. return nil
  456. }
  457. func updateCurrentData(userId int64, statictisSess *xorm.Session, currentData UserBusinessAnalysis) {
  458. _, err := statictisSess.Update("update user_business_analysis_all set code_merge_count+=" + fmt.Sprint(currentData.CodeMergeCount) +
  459. ",commit_count+=" + fmt.Sprint(currentData.CommitCount) +
  460. ",issue_count+=" + fmt.Sprint(currentData.IssueCount) +
  461. ",comment_count+=" + fmt.Sprint(currentData.CommentCount) +
  462. ",focus_repo_count+=" + fmt.Sprint(currentData.FocusRepoCount) +
  463. ",star_repo_count+=" + fmt.Sprint(currentData.StarRepoCount) +
  464. ",watched_count+=" + fmt.Sprint(currentData.WatchedCount) +
  465. ",commit_code_size+=" + fmt.Sprint(currentData.CommitCodeSize) +
  466. ",commit_dataset_size+=" + fmt.Sprint(currentData.CommitDatasetSize) +
  467. ",commit_model_count+=" + fmt.Sprint(currentData.CommitModelCount) +
  468. ",solve_issue_count+=" + fmt.Sprint(currentData.SolveIssueCount) +
  469. ",encyclopedias_count+=" + fmt.Sprint(currentData.EncyclopediasCount) +
  470. ",create_repo_count+=" + fmt.Sprint(currentData.CreateRepoCount) +
  471. ",login_count+=" + fmt.Sprint(currentData.LoginCount) +
  472. " where id=" + fmt.Sprint(userId))
  473. if err != nil {
  474. log.Info("update table failed." + err.Error())
  475. }
  476. }
  477. func isExistUserInAllTable(userId int64, statictisSess *xorm.Session) bool {
  478. allCount, err := statictisSess.Where("id=" + fmt.Sprint(userId)).Count(new(UserBusinessAnalysisAll))
  479. if err != nil {
  480. return false
  481. }
  482. return allCount > 0
  483. }
  484. func getAllData(userId int64, statictisSess *xorm.Session) UserBusinessAnalysisAll {
  485. var dateRecord UserBusinessAnalysisAll
  486. rows, err := statictisSess.Query("select sum(code_merge_count) as code_merge_count,sum(commit_count) as commit_count,sum(issue_count) as issue_count,sum(issue_count) as issue_count,sum(comment_count) as comment_count,sum(focus_repo_count) as focus_repo_count,sum(star_repo_count) as star_repo_count,sum(watched_count) as watched_count,sum(commit_code_size) as commit_code_size,sum(commit_dataset_size) as commit_dataset_size, sum(commit_model_count) as commit_model_count,sum(solve_issue_count) as solve_issue_count,sum(encyclopedias_count) as encyclopedias_count, sum(create_repo_count) as create_repo_count,sum(login_count) as login_count from public.user_business_analysis where id=" + fmt.Sprint(userId) + " group by id")
  487. if err == nil {
  488. for i, row := range rows {
  489. log.Info("query user info, i=" + fmt.Sprint(i) + " code_merge_count=" + string(row["code_merge_count"]))
  490. dateRecord.CodeMergeCount = getInt(string(row["code_merge_count"]))
  491. dateRecord.CommitCount = getInt(string(row["commit_count"]))
  492. dateRecord.IssueCount = getInt(string(row["issue_count"]))
  493. dateRecord.CommentCount = getInt(string(row["comment_count"]))
  494. dateRecord.FocusRepoCount = getInt(string(row["focus_repo_count"]))
  495. dateRecord.StarRepoCount = getInt(string(row["star_repo_count"]))
  496. dateRecord.WatchedCount = getInt(string(row["watched_count"]))
  497. dateRecord.CommitCodeSize = getInt(string(row["commit_code_size"]))
  498. dateRecord.CommitDatasetSize = getInt(string(row["commit_dataset_size"]))
  499. dateRecord.CommitModelCount = getInt(string(row["commit_model_count"]))
  500. dateRecord.SolveIssueCount = getInt(string(row["solve_issue_count"]))
  501. dateRecord.EncyclopediasCount = getInt(string(row["encyclopedias_count"]))
  502. dateRecord.CreateRepoCount = getInt(string(row["create_repo_count"]))
  503. dateRecord.LoginCount = getInt(string(row["login_count"]))
  504. }
  505. }
  506. return dateRecord
  507. }
  508. func getInt(str string) int {
  509. re, err := strconv.ParseInt(str, 10, 32)
  510. if err != nil {
  511. return 0
  512. }
  513. return int(re)
  514. }
  515. func CounDataByDate(wikiCountMap map[string]int, startTime time.Time, endTime time.Time) {
  516. CounDataByDateAndReCount(wikiCountMap, startTime, endTime, false)
  517. }
  518. func querySolveIssue(start_unix int64, end_unix int64) map[int64]int {
  519. //select issue_assignees.* from issue_assignees,issue where issue.is_closed=true and issue.id=issue_assignees.issue_id
  520. sess := x.NewSession()
  521. defer sess.Close()
  522. sess.Select("issue_assignees.*").Table("issue_assignees").
  523. Join("inner", "issue", "issue.id=issue_assignees.issue_id").
  524. Where("issue.is_closed=true and issue.closed_unix>=" + fmt.Sprint(start_unix) + " and issue.closed_unix<=" + fmt.Sprint(end_unix))
  525. issueAssigneesList := make([]*IssueAssignees, 0)
  526. sess.Find(&issueAssigneesList)
  527. resultMap := make(map[int64]int)
  528. log.Info("query IssueAssignees size=" + fmt.Sprint(len(issueAssigneesList)))
  529. for _, issueAssigneesRecord := range issueAssigneesList {
  530. if _, ok := resultMap[issueAssigneesRecord.AssigneeID]; !ok {
  531. resultMap[issueAssigneesRecord.AssigneeID] = 1
  532. } else {
  533. resultMap[issueAssigneesRecord.AssigneeID] += 1
  534. }
  535. }
  536. return resultMap
  537. }
  538. func queryPullRequest(start_unix int64, end_unix int64) map[int64]int {
  539. sess := x.NewSession()
  540. defer sess.Close()
  541. sess.Select("issue.*").Table("issue").
  542. Join("inner", "pull_request", "issue.id=pull_request.issue_id").
  543. Where("pull_request.merged_unix>=" + fmt.Sprint(start_unix) + " and pull_request.merged_unix<=" + fmt.Sprint(end_unix))
  544. issueList := make([]*Issue, 0)
  545. sess.Find(&issueList)
  546. resultMap := make(map[int64]int)
  547. log.Info("query issue(PR) size=" + fmt.Sprint(len(issueList)))
  548. for _, issueRecord := range issueList {
  549. if _, ok := resultMap[issueRecord.PosterID]; !ok {
  550. resultMap[issueRecord.PosterID] = 1
  551. } else {
  552. resultMap[issueRecord.PosterID] += 1
  553. }
  554. }
  555. return resultMap
  556. }
  557. func queryCommitAction(start_unix int64, end_unix int64, actionType int64) map[int64]int {
  558. sess := x.NewSession()
  559. defer sess.Close()
  560. sess.Select("id,user_id,op_type,act_user_id").Table("action").Where("user_id=act_user_id and op_type=" + fmt.Sprint(actionType) + " and created_unix>=" + fmt.Sprint(start_unix) + " and created_unix<=" + fmt.Sprint(end_unix))
  561. actionList := make([]*Action, 0)
  562. sess.Find(&actionList)
  563. resultMap := make(map[int64]int)
  564. log.Info("query action size=" + fmt.Sprint(len(actionList)))
  565. for _, actionRecord := range actionList {
  566. if _, ok := resultMap[actionRecord.UserID]; !ok {
  567. resultMap[actionRecord.UserID] = 1
  568. } else {
  569. resultMap[actionRecord.UserID] += 1
  570. }
  571. }
  572. return resultMap
  573. }
  574. func queryAction(start_unix int64, end_unix int64, actionType int64) map[int64]int {
  575. sess := x.NewSession()
  576. defer sess.Close()
  577. sess.Select("id,user_id,op_type,act_user_id").Table("action").Where("op_type=" + fmt.Sprint(actionType) + " and created_unix>=" + fmt.Sprint(start_unix) + " and created_unix<=" + fmt.Sprint(end_unix))
  578. actionList := make([]*Action, 0)
  579. sess.Find(&actionList)
  580. resultMap := make(map[int64]int)
  581. log.Info("query action size=" + fmt.Sprint(len(actionList)))
  582. for _, actionRecord := range actionList {
  583. if _, ok := resultMap[actionRecord.UserID]; !ok {
  584. resultMap[actionRecord.UserID] = 1
  585. } else {
  586. resultMap[actionRecord.UserID] += 1
  587. }
  588. }
  589. return resultMap
  590. }
  591. func queryComment(start_unix int64, end_unix int64) map[int64]int {
  592. sess := x.NewSession()
  593. defer sess.Close()
  594. sess.Select("id,type,poster_id").Table("comment").Where(" created_unix>=" + fmt.Sprint(start_unix) + " and created_unix<=" + fmt.Sprint(end_unix))
  595. commentList := make([]*Comment, 0)
  596. sess.Find(&commentList)
  597. resultMap := make(map[int64]int)
  598. log.Info("query Comment size=" + fmt.Sprint(len(commentList)))
  599. for _, commentRecord := range commentList {
  600. if _, ok := resultMap[commentRecord.PosterID]; !ok {
  601. resultMap[commentRecord.PosterID] = 1
  602. } else {
  603. resultMap[commentRecord.PosterID] += 1
  604. }
  605. }
  606. return resultMap
  607. }
  608. func queryWatch(start_unix int64, end_unix int64) map[int64]int {
  609. sess := x.NewSession()
  610. defer sess.Close()
  611. sess.Select("id,user_id,repo_id").Table("watch").Where(" created_unix>=" + fmt.Sprint(start_unix) + " and created_unix<=" + fmt.Sprint(end_unix))
  612. watchList := make([]*Watch, 0)
  613. sess.Find(&watchList)
  614. resultMap := make(map[int64]int)
  615. log.Info("query Watch size=" + fmt.Sprint(len(watchList)))
  616. for _, watchRecord := range watchList {
  617. if _, ok := resultMap[watchRecord.UserID]; !ok {
  618. resultMap[watchRecord.UserID] = 1
  619. } else {
  620. resultMap[watchRecord.UserID] += 1
  621. }
  622. }
  623. return resultMap
  624. }
  625. func queryStar(start_unix int64, end_unix int64) map[int64]int {
  626. sess := x.NewSession()
  627. defer sess.Close()
  628. sess.Select("id,uid,repo_id").Table("star").Where(" created_unix>=" + fmt.Sprint(start_unix) + " and created_unix<=" + fmt.Sprint(end_unix))
  629. starList := make([]*Star, 0)
  630. sess.Find(&starList)
  631. resultMap := make(map[int64]int)
  632. log.Info("query Star size=" + fmt.Sprint(len(starList)))
  633. for _, starRecord := range starList {
  634. if _, ok := resultMap[starRecord.UID]; !ok {
  635. resultMap[starRecord.UID] = 1
  636. } else {
  637. resultMap[starRecord.UID] += 1
  638. }
  639. }
  640. return resultMap
  641. }
  642. func queryFollow(start_unix int64, end_unix int64) map[int64]int {
  643. sess := x.NewSession()
  644. defer sess.Close()
  645. sess.Select("id,user_id,follow_id").Table("follow").Where(" created_unix>=" + fmt.Sprint(start_unix) + " and created_unix<=" + fmt.Sprint(end_unix))
  646. followList := make([]*Follow, 0)
  647. sess.Find(&followList)
  648. resultMap := make(map[int64]int)
  649. log.Info("query Follow size=" + fmt.Sprint(len(followList)))
  650. for _, followRecord := range followList {
  651. if _, ok := resultMap[followRecord.FollowID]; !ok {
  652. resultMap[followRecord.FollowID] = 1
  653. } else {
  654. resultMap[followRecord.FollowID] += 1
  655. }
  656. }
  657. return resultMap
  658. }
  659. func queryDatasetSize(start_unix int64, end_unix int64) map[int64]int {
  660. sess := x.NewSession()
  661. defer sess.Close()
  662. sess.Select("id,uploader_id,size").Table("attachment").Where(" created_unix>=" + fmt.Sprint(start_unix) + " and created_unix<=" + fmt.Sprint(end_unix))
  663. attachmentList := make([]*Attachment, 0)
  664. sess.Find(&attachmentList)
  665. resultMap := make(map[int64]int)
  666. log.Info("query Attachment size=" + fmt.Sprint(len(attachmentList)))
  667. for _, attachRecord := range attachmentList {
  668. if _, ok := resultMap[attachRecord.UploaderID]; !ok {
  669. resultMap[attachRecord.UploaderID] = int(attachRecord.Size / (1024 * 1024)) //MB
  670. } else {
  671. resultMap[attachRecord.UploaderID] += int(attachRecord.Size / (1024 * 1024)) //MB
  672. }
  673. }
  674. return resultMap
  675. }
  676. func queryUserCreateRepo(start_unix int64, end_unix int64) map[int64]int {
  677. sess := x.NewSession()
  678. defer sess.Close()
  679. sess.Select("id,owner_id,name").Table("repository").Where("is_fork=false and created_unix>=" + fmt.Sprint(start_unix) + " and created_unix<=" + fmt.Sprint(end_unix))
  680. repoList := make([]*Repository, 0)
  681. sess.Find(&repoList)
  682. resultMap := make(map[int64]int)
  683. log.Info("query Repository size=" + fmt.Sprint(len(repoList)))
  684. for _, repoRecord := range repoList {
  685. if _, ok := resultMap[repoRecord.OwnerID]; !ok {
  686. resultMap[repoRecord.OwnerID] = 1
  687. } else {
  688. resultMap[repoRecord.OwnerID] += 1
  689. }
  690. }
  691. return resultMap
  692. }
  693. func queryUserRepoOpenIIndex(start_unix int64, end_unix int64) map[int64]float64 {
  694. statictisSess := xStatistic.NewSession()
  695. defer statictisSess.Close()
  696. statictisSess.Select("repo_id,radar_total").Table("repo_statistic").Where("created_unix>=" + fmt.Sprint(start_unix) + " and created_unix<=" + fmt.Sprint(end_unix))
  697. repoStatisticList := make([]*RepoStatistic, 0)
  698. statictisSess.Find(&repoStatisticList)
  699. repoOpenIIndexMap := make(map[int64]float64)
  700. log.Info("query repo_statistic size=" + fmt.Sprint(len(repoStatisticList)))
  701. for _, repoRecord := range repoStatisticList {
  702. if _, ok := repoOpenIIndexMap[repoRecord.RepoID]; !ok {
  703. repoOpenIIndexMap[repoRecord.RepoID] = repoRecord.RadarTotal
  704. }
  705. }
  706. sess := x.NewSession()
  707. defer sess.Close()
  708. sess.Select("id,owner_id,name").Table("repository").Where("is_fork=false")
  709. repoList := make([]*Repository, 0)
  710. sess.Find(&repoList)
  711. userMap := make(map[int64]float64)
  712. log.Info("query Repository size=" + fmt.Sprint(len(repoList)))
  713. for _, repoRecord := range repoList {
  714. if _, ok := userMap[repoRecord.OwnerID]; !ok {
  715. if _, ok := repoOpenIIndexMap[repoRecord.ID]; ok {
  716. userMap[repoRecord.OwnerID] = repoOpenIIndexMap[repoRecord.ID]
  717. }
  718. }
  719. }
  720. //query collaboration
  721. sess.Select("repo_id,user_id,mode").Table("collaboration")
  722. collaborationList := make([]*Collaboration, 0)
  723. sess.Find(&collaborationList)
  724. log.Info("query collaborationList size=" + fmt.Sprint(len(collaborationList)))
  725. for _, collaborationRecord := range collaborationList {
  726. if _, ok := userMap[collaborationRecord.UserID]; !ok {
  727. if _, ok := repoOpenIIndexMap[collaborationRecord.RepoID]; ok {
  728. userMap[collaborationRecord.UserID] = repoOpenIIndexMap[collaborationRecord.RepoID]
  729. }
  730. } else {
  731. if _, ok := repoOpenIIndexMap[collaborationRecord.RepoID]; ok {
  732. userMap[collaborationRecord.UserID] += repoOpenIIndexMap[collaborationRecord.RepoID]
  733. }
  734. }
  735. }
  736. userMapJson, _ := json.Marshal(userMap)
  737. log.Info("userMapJson=" + string(userMapJson))
  738. return userMap
  739. }
  740. func queryLoginCount(start_unix int64, end_unix int64) map[int64]int {
  741. statictisSess := xStatistic.NewSession()
  742. defer statictisSess.Close()
  743. statictisSess.Select("id,u_id").Table("user_login_log").Where("created_unix>=" + fmt.Sprint(start_unix) + " and created_unix<=" + fmt.Sprint(end_unix))
  744. userLoginLogList := make([]*UserLoginLog, 0)
  745. statictisSess.Find(&userLoginLogList)
  746. resultMap := make(map[int64]int)
  747. log.Info("query user login size=" + fmt.Sprint(len(userLoginLogList)))
  748. for _, loginRecord := range userLoginLogList {
  749. if _, ok := resultMap[loginRecord.UId]; !ok {
  750. resultMap[loginRecord.UId] = 1
  751. } else {
  752. resultMap[loginRecord.UId] += 1
  753. }
  754. }
  755. return resultMap
  756. }
  757. func subMonth(t1, t2 time.Time) (month int) {
  758. y1 := t1.Year()
  759. y2 := t2.Year()
  760. m1 := int(t1.Month())
  761. m2 := int(t2.Month())
  762. d1 := t1.Day()
  763. d2 := t2.Day()
  764. yearInterval := y1 - y2
  765. // 如果 d1的 月-日 小于 d2的 月-日 那么 yearInterval-- 这样就得到了相差的年数
  766. if m1 < m2 || m1 == m2 && d1 < d2 {
  767. yearInterval--
  768. }
  769. // 获取月数差值
  770. monthInterval := (m1 + 12) - m2
  771. if d1 < d2 {
  772. monthInterval--
  773. }
  774. monthInterval %= 12
  775. month = yearInterval*12 + monthInterval
  776. if month == 0 {
  777. month = 1
  778. }
  779. return month
  780. }