summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--models/repo.go11
-rw-r--r--routers/api/v1/api.go1
-rw-r--r--routers/api/v1/repo/subscriber.go25
3 files changed, 30 insertions, 7 deletions
diff --git a/models/repo.go b/models/repo.go
index 5f1cef3029..5868b8b705 100644
--- a/models/repo.go
+++ b/models/repo.go
@@ -2107,13 +2107,10 @@ func GetWatchers(repoID int64) ([]*Watch, error) {
// GetWatchers returns range of users watching given repository.
func (repo *Repository) GetWatchers(page int) ([]*User, error) {
users := make([]*User, 0, ItemsPerPage)
- sess := x.
- Limit(ItemsPerPage, (page-1)*ItemsPerPage).
- Where("watch.repo_id=?", repo.ID)
- if setting.UsePostgreSQL {
- sess = sess.Join("LEFT", "watch", `"user".id=watch.user_id`)
- } else {
- sess = sess.Join("LEFT", "watch", "user.id=watch.user_id")
+ sess := x.Where("watch.repo_id=?", repo.ID).
+ Join("LEFT", "watch", "`user`.id=`watch`.user_id")
+ if page > 0 {
+ sess = sess.Limit(ItemsPerPage, (page-1)*ItemsPerPage)
}
return users, sess.Find(&users)
}
diff --git a/routers/api/v1/api.go b/routers/api/v1/api.go
index cc773150e6..69b9a272e0 100644
--- a/routers/api/v1/api.go
+++ b/routers/api/v1/api.go
@@ -327,6 +327,7 @@ func RegisterRoutes(m *macaron.Macaron) {
Delete(reqRepoWriter(), repo.DeleteMilestone)
})
m.Get("/stargazers", repo.ListStargazers)
+ m.Get("/subscribers", repo.ListSubscribers)
m.Group("/subscription", func() {
m.Get("", user.IsWatching)
m.Put("", user.Watch)
diff --git a/routers/api/v1/repo/subscriber.go b/routers/api/v1/repo/subscriber.go
new file mode 100644
index 0000000000..d9d9a6c96d
--- /dev/null
+++ b/routers/api/v1/repo/subscriber.go
@@ -0,0 +1,25 @@
+// Copyright 2017 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 repo
+
+import (
+ api "code.gitea.io/sdk/gitea"
+
+ "code.gitea.io/gitea/modules/context"
+)
+
+// ListSubscribers list a repo's subscribers (i.e. watchers)
+func ListSubscribers(ctx *context.APIContext) {
+ subscribers, err := ctx.Repo.Repository.GetWatchers(0)
+ if err != nil {
+ ctx.Error(500, "GetWatchers", err)
+ return
+ }
+ users := make([]*api.User, len(subscribers))
+ for i, subscriber := range subscribers {
+ users[i] = subscriber.APIFormat()
+ }
+ ctx.JSON(200, users)
+}