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

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