summaryrefslogtreecommitdiffstats
path: root/models/statistic.go
diff options
context:
space:
mode:
authorLunny Xiao <xiaolunwen@gmail.com>2021-09-19 19:49:59 +0800
committerGitHub <noreply@github.com>2021-09-19 19:49:59 +0800
commita4bfef265d9e512830350635a0489c2cdcd6508f (patch)
tree1e3c2ec94276dfcb2f8ba73a2ac075ba39c4a34a /models/statistic.go
parent462306e263db5a809dbe2cdf62e99307aeff28de (diff)
downloadgitea-a4bfef265d9e512830350635a0489c2cdcd6508f.tar.gz
gitea-a4bfef265d9e512830350635a0489c2cdcd6508f.zip
Move db related basic functions to models/db (#17075)
* Move db related basic functions to models/db * Fix lint * Fix lint * Fix test * Fix lint * Fix lint * revert unnecessary change * Fix test * Fix wrong replace string * Use *Context * Correct committer spelling and fix wrong replaced words Co-authored-by: zeripath <art27@cantab.net>
Diffstat (limited to 'models/statistic.go')
-rw-r--r--models/statistic.go63
1 files changed, 63 insertions, 0 deletions
diff --git a/models/statistic.go b/models/statistic.go
new file mode 100644
index 0000000000..715a10e70d
--- /dev/null
+++ b/models/statistic.go
@@ -0,0 +1,63 @@
+// Copyright 2021 The Gitea Authors. All rights reserved.
+// Use of this source code is governed by a MIT-style
+// license that can be found in the LICENSE file.
+
+package models
+
+import "code.gitea.io/gitea/models/db"
+
+// Statistic contains the database statistics
+type Statistic struct {
+ Counter struct {
+ User, Org, PublicKey,
+ Repo, Watch, Star, Action, Access,
+ Issue, IssueClosed, IssueOpen,
+ Comment, Oauth, Follow,
+ Mirror, Release, LoginSource, Webhook,
+ Milestone, Label, HookTask,
+ Team, UpdateTask, Attachment int64
+ }
+}
+
+// GetStatistic returns the database statistics
+func GetStatistic() (stats Statistic) {
+ stats.Counter.User = CountUsers()
+ stats.Counter.Org = CountOrganizations()
+ stats.Counter.PublicKey, _ = db.DefaultContext().Engine().Count(new(PublicKey))
+ stats.Counter.Repo = CountRepositories(true)
+ stats.Counter.Watch, _ = db.DefaultContext().Engine().Count(new(Watch))
+ stats.Counter.Star, _ = db.DefaultContext().Engine().Count(new(Star))
+ stats.Counter.Action, _ = db.DefaultContext().Engine().Count(new(Action))
+ stats.Counter.Access, _ = db.DefaultContext().Engine().Count(new(Access))
+
+ type IssueCount struct {
+ Count int64
+ IsClosed bool
+ }
+ issueCounts := []IssueCount{}
+
+ _ = db.DefaultContext().Engine().Select("COUNT(*) AS count, is_closed").Table("issue").GroupBy("is_closed").Find(&issueCounts)
+ for _, c := range issueCounts {
+ if c.IsClosed {
+ stats.Counter.IssueClosed = c.Count
+ } else {
+ stats.Counter.IssueOpen = c.Count
+ }
+ }
+
+ stats.Counter.Issue = stats.Counter.IssueClosed + stats.Counter.IssueOpen
+
+ stats.Counter.Comment, _ = db.DefaultContext().Engine().Count(new(Comment))
+ stats.Counter.Oauth = 0
+ stats.Counter.Follow, _ = db.DefaultContext().Engine().Count(new(Follow))
+ stats.Counter.Mirror, _ = db.DefaultContext().Engine().Count(new(Mirror))
+ stats.Counter.Release, _ = db.DefaultContext().Engine().Count(new(Release))
+ stats.Counter.LoginSource = CountLoginSources()
+ stats.Counter.Webhook, _ = db.DefaultContext().Engine().Count(new(Webhook))
+ stats.Counter.Milestone, _ = db.DefaultContext().Engine().Count(new(Milestone))
+ stats.Counter.Label, _ = db.DefaultContext().Engine().Count(new(Label))
+ stats.Counter.HookTask, _ = db.DefaultContext().Engine().Count(new(HookTask))
+ stats.Counter.Team, _ = db.DefaultContext().Engine().Count(new(Team))
+ stats.Counter.Attachment, _ = db.DefaultContext().Engine().Count(new(Attachment))
+ return
+}