diff options
author | Unknwon <u@gogs.io> | 2016-01-07 11:07:17 +0800 |
---|---|---|
committer | Unknwon <u@gogs.io> | 2016-01-07 11:07:17 +0800 |
commit | e0f0f72a362e98073980d9e3c70cde8cd161614b (patch) | |
tree | a72af07a4e04a0e748e27221a6076915c8a06dc8 | |
parent | ca35ddd07880b71296b9f80e5f803f120bd392b4 (diff) | |
download | gitea-e0f0f72a362e98073980d9e3c70cde8cd161614b.tar.gz gitea-e0f0f72a362e98073980d9e3c70cde8cd161614b.zip |
#2345 disallow access of some pages for empty repo
-rw-r--r-- | README.md | 2 | ||||
-rw-r--r-- | cmd/web.go | 13 | ||||
-rw-r--r-- | gogs.go | 2 | ||||
-rw-r--r-- | routers/repo/repo.go | 8 | ||||
-rw-r--r-- | templates/.VERSION | 2 |
5 files changed, 17 insertions, 10 deletions
@@ -3,7 +3,7 @@ Gogs - Go Git Service [![Build Status](https://travis-ci.org/gogits/gogs.svg?bra ![](https://github.com/gogits/gogs/blob/master/public/img/gogs-large-resize.png?raw=true) -##### Current version: 0.8.16 +##### Current version: 0.8.17 | Web | UI | Preview | |:-------------:|:-------:|:-------:| diff --git a/cmd/web.go b/cmd/web.go index 3edeb8d8a5..9867c8c30c 100644 --- a/cmd/web.go +++ b/cmd/web.go @@ -432,9 +432,8 @@ func runWeb(ctx *cli.Context) { }) }, reqSignIn, middleware.RepoAssignment(), reqRepoAdmin, middleware.RepoRef()) + m.Get("/:username/:reponame/action/:action", reqSignIn, middleware.RepoAssignment(), repo.Action) m.Group("/:username/:reponame", func() { - m.Get("/action/:action", repo.Action) - m.Group("/issues", func() { m.Combo("/new", repo.MustEnableIssues).Get(middleware.RepoRef(), repo.NewIssue). Post(bindIgnErr(auth.CreateIssueForm{}), repo.NewIssuePost) @@ -476,7 +475,7 @@ func runWeb(ctx *cli.Context) { m.Combo("/compare/*", repo.MustEnablePulls).Get(repo.CompareAndPullRequest). Post(bindIgnErr(auth.CreateIssueForm{}), repo.CompareAndPullRequestPost) - }, reqSignIn, middleware.RepoAssignment()) + }, reqSignIn, middleware.RepoAssignment(), repo.MustBeNotBare) m.Group("/:username/:reponame", func() { m.Group("", func() { @@ -514,13 +513,15 @@ func runWeb(ctx *cli.Context) { m.Get("/raw/*", repo.SingleDownload) m.Get("/commits/*", repo.RefCommits) m.Get("/commit/*", repo.Diff) - m.Get("/stars", repo.Stars) - m.Get("/watchers", repo.Watchers) m.Get("/forks", repo.Forks) }, middleware.RepoRef()) m.Get("/compare/:before([a-z0-9]{40})...:after([a-z0-9]{40})", repo.CompareDiff) - }, ignSignIn, middleware.RepoAssignment()) + }, ignSignIn, middleware.RepoAssignment(), repo.MustBeNotBare) + m.Group("/:username/:reponame", func() { + m.Get("/stars", repo.Stars) + m.Get("/watchers", repo.Watchers) + }, ignSignIn, middleware.RepoAssignment(), middleware.RepoRef()) m.Group("/:username", func() { m.Group("/:reponame", func() { @@ -17,7 +17,7 @@ import ( "github.com/gogits/gogs/modules/setting" ) -const APP_VER = "0.8.16.0107" +const APP_VER = "0.8.17.0107" func init() { runtime.GOMAXPROCS(runtime.NumCPU()) diff --git a/routers/repo/repo.go b/routers/repo/repo.go index 2879599744..43672ff107 100644 --- a/routers/repo/repo.go +++ b/routers/repo/repo.go @@ -27,6 +27,12 @@ const ( MIGRATE base.TplName = "repo/migrate" ) +func MustBeNotBare(ctx *middleware.Context) { + if ctx.Repo.Repository.IsBare { + ctx.Handle(404, "MustBeNotBare", nil) + } +} + func checkContextUser(ctx *middleware.Context, uid int64) *models.User { orgs, err := models.GetOwnedOrgsByUserIDDesc(ctx.User.Id, "updated") if err != nil { @@ -232,7 +238,7 @@ func Action(ctx *middleware.Context) { err = models.StarRepo(ctx.User.Id, ctx.Repo.Repository.ID, true) case "unstar": err = models.StarRepo(ctx.User.Id, ctx.Repo.Repository.ID, false) - case "desc": + case "desc": // FIXME: this is not used if !ctx.Repo.IsOwner() { ctx.Error(404) return diff --git a/templates/.VERSION b/templates/.VERSION index dbc2d69c24..a1a3a849bc 100644 --- a/templates/.VERSION +++ b/templates/.VERSION @@ -1 +1 @@ -0.8.16.0107
\ No newline at end of file +0.8.17.0107
\ No newline at end of file |