aboutsummaryrefslogtreecommitdiffstats
path: root/routers/repo/wiki.go
diff options
context:
space:
mode:
Diffstat (limited to 'routers/repo/wiki.go')
-rw-r--r--routers/repo/wiki.go61
1 files changed, 58 insertions, 3 deletions
diff --git a/routers/repo/wiki.go b/routers/repo/wiki.go
index 30bd7b63c7..4ea41b347e 100644
--- a/routers/repo/wiki.go
+++ b/routers/repo/wiki.go
@@ -5,6 +5,10 @@
package repo
import (
+ "io/ioutil"
+
+ "github.com/gogits/git-shell"
+
"github.com/gogits/gogs/models"
"github.com/gogits/gogs/modules/auth"
"github.com/gogits/gogs/modules/base"
@@ -18,17 +22,68 @@ const (
)
func Wiki(ctx *middleware.Context) {
- ctx.Data["Title"] = ctx.Tr("repo.wiki")
ctx.Data["PageIsWiki"] = true
if !ctx.Repo.Repository.HasWiki() {
+ ctx.Data["Title"] = ctx.Tr("repo.wiki")
ctx.HTML(200, WIKI_START)
return
}
+ wikiRepo, err := git.OpenRepository(ctx.Repo.Repository.WikiPath())
+ if err != nil {
+ ctx.Handle(500, "OpenRepository", err)
+ return
+ }
+ commit, err := wikiRepo.GetCommitOfBranch("master")
+ if err != nil {
+ ctx.Handle(500, "GetCommitOfBranch", err)
+ return
+ }
+
+ page := models.ToWikiPageName(ctx.Params(":page"))
+ if len(page) == 0 {
+ page = "Home"
+ }
+ ctx.Data["Title"] = page
+ ctx.Data["RequireHighlightJS"] = true
+
+ blob, err := commit.GetBlobByPath(page + ".md")
+ if err != nil {
+ if git.IsErrNotExist(err) {
+ ctx.Redirect(ctx.Repo.RepoLink + "/wiki/_list")
+ } else {
+ ctx.Handle(500, "GetBlobByPath", err)
+ }
+ return
+ }
+ r, err := blob.Data()
+ if err != nil {
+ ctx.Handle(500, "Data", err)
+ return
+ }
+ data, err := ioutil.ReadAll(r)
+ if err != nil {
+ ctx.Handle(500, "ReadAll", err)
+ return
+ }
+ ctx.Data["Content"] = string(base.RenderMarkdown(data, ctx.Repo.RepoLink))
+
+ // Get last change information.
+ lastCommit, err := wikiRepo.GetCommitByPath(page + ".md")
+ if err != nil {
+ ctx.Handle(500, "GetCommitByPath", err)
+ return
+ }
+ ctx.Data["Author"] = lastCommit.Author
+
ctx.HTML(200, WIKI_VIEW)
}
+func WikiList(ctx *middleware.Context) {
+
+}
+
func NewWiki(ctx *middleware.Context) {
ctx.Data["Title"] = ctx.Tr("repo.wiki.new_page")
ctx.Data["PageIsWiki"] = true
@@ -51,12 +106,12 @@ func NewWikiPost(ctx *middleware.Context, form auth.NewWikiForm) {
return
}
- if err := ctx.Repo.Repository.AddWikiPage(form.Title, form.Content, form.Message); err != nil {
+ if err := ctx.Repo.Repository.AddWikiPage(ctx.User, form.Title, form.Content, form.Message); err != nil {
ctx.Handle(500, "AddWikiPage", err)
return
}
- ctx.Redirect(ctx.Repo.RepoLink + "/wiki/" + models.ToWikiPageName(form.Title))
+ ctx.Redirect(ctx.Repo.RepoLink + "/wiki/" + models.ToWikiPageURL(form.Title))
}
func EditWiki(ctx *middleware.Context) {