aboutsummaryrefslogtreecommitdiff
path: root/routers
diff options
context:
space:
mode:
authorUnknown <joe2010xtmf@163.com>2014-03-13 01:01:28 -0400
committerUnknown <joe2010xtmf@163.com>2014-03-13 01:01:28 -0400
commit8c960917279d80c6137f7ccd9cc3cf9ed5fee098 (patch)
treeda0dddec61295e6c8e4f972ab942db9b7399f0dd /routers
parent6a75b1f7b37dead013f271936c274ac9506d7d41 (diff)
parentfecafdca2ac5884a4dbcef2b937dfc3d2bf27ef2 (diff)
Merge branch 'master' of github.com:gogits/gogs
Diffstat (limited to 'routers')
-rw-r--r--routers/repo/repo.go16
-rw-r--r--routers/repo/single.go66
2 files changed, 66 insertions, 16 deletions
diff --git a/routers/repo/repo.go b/routers/repo/repo.go
index 64440345..5769aff7 100644
--- a/routers/repo/repo.go
+++ b/routers/repo/repo.go
@@ -6,8 +6,6 @@ package repo
import (
"net/http"
-
- "github.com/codegangsta/martini"
"github.com/martini-contrib/render"
"github.com/martini-contrib/sessions"
@@ -87,20 +85,6 @@ func Delete(req *http.Request, r render.Render, data base.TmplData, session sess
}
}
-func Repo(params martini.Params, req *http.Request, r render.Render, data base.TmplData, session sessions.Session) {
- data["Title"] = "Repository"
- files, err := models.GetReposFiles(params["username"], params["reponame"], "HEAD", "/")
- if err != nil {
- data["ErrorMsg"] = err
- log.Error("repo.List: %v", err)
- r.HTML(200, "base/error", data)
- return
- }
-
- data["Files"] = files
- r.HTML(200, "repo/repo", data)
-}
-
func List(req *http.Request, r render.Render, data base.TmplData, session sessions.Session) {
u := auth.SignedInUser(session)
if u != nil {
diff --git a/routers/repo/single.go b/routers/repo/single.go
new file mode 100644
index 00000000..811aed39
--- /dev/null
+++ b/routers/repo/single.go
@@ -0,0 +1,66 @@
+package repo
+
+import (
+ "net/http"
+
+ "github.com/codegangsta/martini"
+ "github.com/gogits/gogs/models"
+ "github.com/gogits/gogs/modules/auth"
+ "github.com/gogits/gogs/modules/base"
+ "github.com/martini-contrib/render"
+ "github.com/martini-contrib/sessions"
+ "github.com/qiniu/log"
+)
+
+func Single(params martini.Params, req *http.Request, r render.Render, data base.TmplData, session sessions.Session) {
+ var (
+ user *models.User
+ err error
+ )
+ // get repository owner
+ isOwner := (data["SignedUserName"] == params["username"])
+ if !isOwner {
+ user, err = models.GetUserByName(params["username"])
+ if err != nil {
+ data["ErrorMsg"] = err
+ //log.Error("repo.Single: %v", err)
+ r.HTML(200, "base/error", data)
+ return
+ }
+ } else {
+ user = auth.SignedInUser(session)
+ }
+ if user == nil {
+ data["ErrorMsg"] = "invliad user account for single repository"
+ //log.Error("repo.Single: %v", err)
+ r.HTML(200, "base/error", data)
+ return
+ }
+ data["IsRepositoryOwner"] = isOwner
+
+ // get repository
+ repo, err := models.GetRepositoryByName(user, params["reponame"])
+ if err != nil {
+ data["ErrorMsg"] = err
+ //log.Error("repo.Single: %v", err)
+ r.HTML(200, "base/error", data)
+ return
+ }
+
+ data["Repository"] = repo
+ data["Owner"] = user
+ data["Title"] = user.Name + "/" + repo.Name
+ data["RepositoryLink"] = data["Title"]
+ data["IsRepoToolbarSource"] = true
+
+ files, err := models.GetReposFiles(params["username"], params["reponame"], "HEAD", "/")
+ if err != nil {
+ data["ErrorMsg"] = err
+ log.Error("repo.List: %v", err)
+ r.HTML(200, "base/error", data)
+ return
+ }
+
+ data["Files"] = files
+ r.HTML(200, "repo/single", data)
+}