diff options
author | Lunny Xiao <xiaolunwen@gmail.com> | 2017-01-21 20:50:51 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-01-21 20:50:51 +0800 |
commit | f8c2903484f0db71b9d2ca29f67a38cb7d738699 (patch) | |
tree | 6d70f965eb150fc60b78c2c5d0ee3c01f56cc19a /routers/repo | |
parent | 369972b1164be38abd6769b79ecc5ad9c73d1b17 (diff) | |
download | gitea-f8c2903484f0db71b9d2ca29f67a38cb7d738699.tar.gz gitea-f8c2903484f0db71b9d2ca29f67a38cb7d738699.zip |
fixed bugs on Wiki and resolved #667 (#674)
Diffstat (limited to 'routers/repo')
-rw-r--r-- | routers/repo/wiki.go | 24 |
1 files changed, 14 insertions, 10 deletions
diff --git a/routers/repo/wiki.go b/routers/repo/wiki.go index 759b1b305e..ac979c1a9c 100644 --- a/routers/repo/wiki.go +++ b/routers/repo/wiki.go @@ -89,7 +89,7 @@ func renderWikiPage(ctx *context.Context, isViewPage bool) (*git.Repository, str ctx.Data["title"] = pageName ctx.Data["RequireHighlightJS"] = true - blob, err := commit.GetBlobByPath(pageName + ".md") + blob, err := commit.GetBlobByPath(pageURL + ".md") if err != nil { if git.IsErrNotExist(err) { ctx.Redirect(ctx.Repo.RepoLink + "/wiki/_pages") @@ -114,7 +114,7 @@ func renderWikiPage(ctx *context.Context, isViewPage bool) (*git.Repository, str ctx.Data["content"] = string(data) } - return wikiRepo, pageName + return wikiRepo, pageURL } // Wiki render wiki page @@ -127,13 +127,13 @@ func Wiki(ctx *context.Context) { return } - wikiRepo, pageName := renderWikiPage(ctx, true) + wikiRepo, pagePath := renderWikiPage(ctx, true) if ctx.Written() { return } // Get last change information. - lastCommit, err := wikiRepo.GetCommitByPath(pageName + ".md") + lastCommit, err := wikiRepo.GetCommitByPath(pagePath + ".md") if err != nil { ctx.Handle(500, "GetCommitByPath", err) return @@ -214,7 +214,9 @@ func NewWikiPost(ctx *context.Context, form auth.NewWikiForm) { return } - if err := ctx.Repo.Repository.AddWikiPage(ctx.User, form.Title, form.Content, form.Message); err != nil { + wikiPath := models.ToWikiPageURL(form.Title) + + if err := ctx.Repo.Repository.AddWikiPage(ctx.User, wikiPath, form.Content, form.Message); err != nil { if models.IsErrWikiAlreadyExist(err) { ctx.Data["Err_Title"] = true ctx.RenderWithErr(ctx.Tr("repo.wiki.page_already_exists"), tplWikiNew, &form) @@ -224,7 +226,7 @@ func NewWikiPost(ctx *context.Context, form auth.NewWikiForm) { return } - ctx.Redirect(ctx.Repo.RepoLink + "/wiki/" + models.ToWikiPageURL(form.Title)) + ctx.Redirect(ctx.Repo.RepoLink + "/wiki/" + wikiPath) } // EditWiki render wiki modify page @@ -257,12 +259,15 @@ func EditWikiPost(ctx *context.Context, form auth.NewWikiForm) { return } - if err := ctx.Repo.Repository.EditWikiPage(ctx.User, form.OldTitle, form.Title, form.Content, form.Message); err != nil { + oldWikiPath := ctx.Params(":page") + newWikiPath := models.ToWikiPageURL(form.Title) + + if err := ctx.Repo.Repository.EditWikiPage(ctx.User, oldWikiPath, newWikiPath, form.Content, form.Message); err != nil { ctx.Handle(500, "EditWikiPage", err) return } - ctx.Redirect(ctx.Repo.RepoLink + "/wiki/" + models.ToWikiPageURL(form.Title)) + ctx.Redirect(ctx.Repo.RepoLink + "/wiki/" + newWikiPath) } // DeleteWikiPagePost delete wiki page @@ -272,8 +277,7 @@ func DeleteWikiPagePost(ctx *context.Context) { pageURL = "Home" } - pageName := models.ToWikiPageName(pageURL) - if err := ctx.Repo.Repository.DeleteWikiPage(ctx.User, pageName); err != nil { + if err := ctx.Repo.Repository.DeleteWikiPage(ctx.User, pageURL); err != nil { ctx.Handle(500, "DeleteWikiPage", err) return } |