|
|
@@ -62,7 +62,7 @@ type UserBusinessAnalysis struct { |
|
|
|
Name string `xorm:"NOT NULL"` |
|
|
|
} |
|
|
|
|
|
|
|
func countData() { |
|
|
|
func CountData(wikiCountMap map[int64]int) { |
|
|
|
log.Info("start to count data") |
|
|
|
sess := x.NewSession() |
|
|
|
defer sess.Close() |
|
|
@@ -88,6 +88,12 @@ func countData() { |
|
|
|
CommitCountMap := queryAction(start_unix, end_unix, 5) |
|
|
|
IssueCountMap := queryAction(start_unix, end_unix, 10) |
|
|
|
|
|
|
|
CommentCountMap := queryComment(start_unix, end_unix) |
|
|
|
FocusRepoCountMap := queryWatch(start_unix, end_unix) |
|
|
|
StarRepoCountMap := queryStar(start_unix, end_unix) |
|
|
|
WatchedCountMap := queryFollow(start_unix, end_unix) |
|
|
|
CommitDatasetSizeMap := queryDatasetSize(start_unix, end_unix) |
|
|
|
|
|
|
|
for i, userRecord := range userList { |
|
|
|
var dateRecord UserBusinessAnalysis |
|
|
|
dateRecord.ID = userRecord.ID |
|
|
@@ -96,7 +102,7 @@ func countData() { |
|
|
|
dateRecord.Email = userRecord.Email |
|
|
|
dateRecord.RegistDate = userRecord.CreatedUnix |
|
|
|
dateRecord.Name = userRecord.Name |
|
|
|
|
|
|
|
dateRecord.GiteaAgeMonth = subMonth(currentTimeNow, userRecord.CreatedUnix.AsTime()) |
|
|
|
if _, ok := CodeMergeCountMap[dateRecord.ID]; !ok { |
|
|
|
dateRecord.CodeMergeCount = 0 |
|
|
|
} else { |
|
|
@@ -115,11 +121,65 @@ func countData() { |
|
|
|
dateRecord.IssueCount = IssueCountMap[dateRecord.ID] |
|
|
|
} |
|
|
|
|
|
|
|
if _, ok := CommentCountMap[dateRecord.ID]; !ok { |
|
|
|
dateRecord.CommentCount = 0 |
|
|
|
} else { |
|
|
|
dateRecord.CommentCount = CommentCountMap[dateRecord.ID] |
|
|
|
} |
|
|
|
|
|
|
|
if _, ok := FocusRepoCountMap[dateRecord.ID]; !ok { |
|
|
|
dateRecord.FocusRepoCount = 0 |
|
|
|
} else { |
|
|
|
dateRecord.FocusRepoCount = FocusRepoCountMap[dateRecord.ID] |
|
|
|
} |
|
|
|
|
|
|
|
if _, ok := StarRepoCountMap[dateRecord.ID]; !ok { |
|
|
|
dateRecord.StarRepoCount = 0 |
|
|
|
} else { |
|
|
|
dateRecord.StarRepoCount = StarRepoCountMap[dateRecord.ID] |
|
|
|
} |
|
|
|
|
|
|
|
if _, ok := WatchedCountMap[dateRecord.ID]; !ok { |
|
|
|
dateRecord.WatchedCount = 0 |
|
|
|
} else { |
|
|
|
dateRecord.WatchedCount = WatchedCountMap[dateRecord.ID] |
|
|
|
} |
|
|
|
|
|
|
|
if _, ok := CommitDatasetSizeMap[dateRecord.ID]; !ok { |
|
|
|
dateRecord.CommitDatasetSize = 0 |
|
|
|
} else { |
|
|
|
dateRecord.CommitDatasetSize = CommitDatasetSizeMap[dateRecord.ID] |
|
|
|
} |
|
|
|
|
|
|
|
dateRecord.CommitModelCount = 0 |
|
|
|
|
|
|
|
sess.Insert(&dateRecord) |
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
func querySolveIssue(start_unix int64, end_unix int64) map[int64]int { |
|
|
|
//select issue_assignees.* from issue_assignees,issue where issue.is_closed=true and issue.id=issue_assignees.issue_id |
|
|
|
sess := x.NewSession() |
|
|
|
defer sess.Close() |
|
|
|
sess.Select("issue_assignees.*").Table("issue_assignees"). |
|
|
|
Join("inner", "issue", "issue.id=issue_assignees.issue_id"). |
|
|
|
Where("issue.is_closed=true and issue.closed_unix>=" + fmt.Sprint(start_unix) + " and issue.closed_unix<=" + fmt.Sprint(end_unix)) |
|
|
|
issueAssigneesList := make([]*IssueAssignees, 0) |
|
|
|
sess.Find(&issueAssigneesList) |
|
|
|
resultMap := make(map[int64]int) |
|
|
|
log.Info("query IssueAssignees size=" + fmt.Sprint(len(issueAssigneesList))) |
|
|
|
for _, issueAssigneesRecord := range issueAssigneesList { |
|
|
|
if _, ok := resultMap[issueAssigneesRecord.AssigneeID]; !ok { |
|
|
|
resultMap[issueAssigneesRecord.AssigneeID] = 1 |
|
|
|
} else { |
|
|
|
resultMap[issueAssigneesRecord.AssigneeID] += 1 |
|
|
|
} |
|
|
|
} |
|
|
|
return resultMap |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
func queryAction(start_unix int64, end_unix int64, actionType int64) map[int64]int { |
|
|
|
sess := x.NewSession() |
|
|
|
defer sess.Close() |
|
|
@@ -137,3 +197,133 @@ func queryAction(start_unix int64, end_unix int64, actionType int64) map[int64]i |
|
|
|
} |
|
|
|
return resultMap |
|
|
|
} |
|
|
|
|
|
|
|
func queryComment(start_unix int64, end_unix int64) map[int64]int { |
|
|
|
|
|
|
|
sess := x.NewSession() |
|
|
|
defer sess.Close() |
|
|
|
sess.Select("id,type,poster_id").Table("comment").Where(" created_unix>=" + fmt.Sprint(start_unix) + " and created_unix<=" + fmt.Sprint(end_unix)) |
|
|
|
commentList := make([]*Comment, 0) |
|
|
|
sess.Find(&commentList) |
|
|
|
resultMap := make(map[int64]int) |
|
|
|
log.Info("query Comment size=" + fmt.Sprint(len(commentList))) |
|
|
|
for _, commentRecord := range commentList { |
|
|
|
if _, ok := resultMap[commentRecord.PosterID]; !ok { |
|
|
|
resultMap[commentRecord.PosterID] = 1 |
|
|
|
} else { |
|
|
|
resultMap[commentRecord.PosterID] += 1 |
|
|
|
} |
|
|
|
} |
|
|
|
return resultMap |
|
|
|
} |
|
|
|
|
|
|
|
func queryWatch(start_unix int64, end_unix int64) map[int64]int { |
|
|
|
|
|
|
|
sess := x.NewSession() |
|
|
|
defer sess.Close() |
|
|
|
sess.Select("id,user_id,repo_id").Table("watch").Where(" created_unix>=" + fmt.Sprint(start_unix) + " and created_unix<=" + fmt.Sprint(end_unix)) |
|
|
|
watchList := make([]*Watch, 0) |
|
|
|
sess.Find(&watchList) |
|
|
|
resultMap := make(map[int64]int) |
|
|
|
log.Info("query Watch size=" + fmt.Sprint(len(watchList))) |
|
|
|
for _, watchRecord := range watchList { |
|
|
|
if _, ok := resultMap[watchRecord.UserID]; !ok { |
|
|
|
resultMap[watchRecord.UserID] = 1 |
|
|
|
} else { |
|
|
|
resultMap[watchRecord.UserID] += 1 |
|
|
|
} |
|
|
|
} |
|
|
|
return resultMap |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
func queryStar(start_unix int64, end_unix int64) map[int64]int { |
|
|
|
|
|
|
|
sess := x.NewSession() |
|
|
|
defer sess.Close() |
|
|
|
sess.Select("id,uid,repo_id").Table("star").Where(" created_unix>=" + fmt.Sprint(start_unix) + " and created_unix<=" + fmt.Sprint(end_unix)) |
|
|
|
starList := make([]*Star, 0) |
|
|
|
sess.Find(&starList) |
|
|
|
resultMap := make(map[int64]int) |
|
|
|
log.Info("query Star size=" + fmt.Sprint(len(starList))) |
|
|
|
for _, starRecord := range starList { |
|
|
|
if _, ok := resultMap[starRecord.UID]; !ok { |
|
|
|
resultMap[starRecord.UID] = 1 |
|
|
|
} else { |
|
|
|
resultMap[starRecord.UID] += 1 |
|
|
|
} |
|
|
|
} |
|
|
|
return resultMap |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
func queryFollow(start_unix int64, end_unix int64) map[int64]int { |
|
|
|
|
|
|
|
sess := x.NewSession() |
|
|
|
defer sess.Close() |
|
|
|
sess.Select("id,user_id,follow_id").Table("follow").Where(" created_unix>=" + fmt.Sprint(start_unix) + " and created_unix<=" + fmt.Sprint(end_unix)) |
|
|
|
followList := make([]*Follow, 0) |
|
|
|
sess.Find(&followList) |
|
|
|
resultMap := make(map[int64]int) |
|
|
|
log.Info("query Follow size=" + fmt.Sprint(len(followList))) |
|
|
|
for _, followRecord := range followList { |
|
|
|
if _, ok := resultMap[followRecord.UserID]; !ok { |
|
|
|
resultMap[followRecord.UserID] = 1 |
|
|
|
} else { |
|
|
|
resultMap[followRecord.UserID] += 1 |
|
|
|
} |
|
|
|
} |
|
|
|
return resultMap |
|
|
|
} |
|
|
|
|
|
|
|
func queryDatasetSize(start_unix int64, end_unix int64) map[int64]int { |
|
|
|
sess := x.NewSession() |
|
|
|
defer sess.Close() |
|
|
|
sess.Select("id,uploader_id,size").Table("attachment").Where(" created_unix>=" + fmt.Sprint(start_unix) + " and created_unix<=" + fmt.Sprint(end_unix)) |
|
|
|
attachmentList := make([]*Attachment, 0) |
|
|
|
sess.Find(&attachmentList) |
|
|
|
resultMap := make(map[int64]int) |
|
|
|
log.Info("query Attachment size=" + fmt.Sprint(len(attachmentList))) |
|
|
|
for _, attachRecord := range attachmentList { |
|
|
|
if _, ok := resultMap[attachRecord.UploaderID]; !ok { |
|
|
|
resultMap[attachRecord.UploaderID] = int(attachRecord.Size / (1024 * 1024)) //MB |
|
|
|
} else { |
|
|
|
resultMap[attachRecord.UploaderID] += int(attachRecord.Size / (1024 * 1024)) //MB |
|
|
|
} |
|
|
|
} |
|
|
|
return resultMap |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
func subMonth(t1, t2 time.Time) (month int) { |
|
|
|
y1 := t1.Year() |
|
|
|
y2 := t2.Year() |
|
|
|
m1 := int(t1.Month()) |
|
|
|
m2 := int(t2.Month()) |
|
|
|
d1 := t1.Day() |
|
|
|
d2 := t2.Day() |
|
|
|
|
|
|
|
yearInterval := y1 - y2 |
|
|
|
// 如果 d1的 月-日 小于 d2的 月-日 那么 yearInterval-- 这样就得到了相差的年数 |
|
|
|
if m1 < m2 || m1 == m2 && d1 < d2 { |
|
|
|
yearInterval-- |
|
|
|
} |
|
|
|
// 获取月数差值 |
|
|
|
monthInterval := (m1 + 12) - m2 |
|
|
|
if d1 < d2 { |
|
|
|
monthInterval-- |
|
|
|
} |
|
|
|
monthInterval %= 12 |
|
|
|
month = yearInterval*12 + monthInterval |
|
|
|
return month |
|
|
|
} |
|
|
|
|
|
|
|
func QueryAllRepo() []*Repository { |
|
|
|
sess := x.NewSession() |
|
|
|
defer sess.Close() |
|
|
|
sess.Select("*").Table("repository") |
|
|
|
repositoryList := make([]*Repository, 0) |
|
|
|
sess.Find(&repositoryList) |
|
|
|
|
|
|
|
return repositoryList |
|
|
|
} |