2015-11-25 20:10:25 -05:00
// Copyright 2015 The Gogs Authors. All rights reserved.
2018-11-28 19:26:14 +08:00
// Copyright 2018 The Gitea Authors. All rights reserved.
2015-11-25 20:10:25 -05:00
// Use of this source code is governed by a MIT-style
// license that can be found in the LICENSE file.
package repo
import (
2017-02-14 08:13:59 +07:00
"fmt"
2015-11-27 00:24:24 -05:00
"io/ioutil"
2017-02-14 08:13:59 +07:00
"path/filepath"
2015-11-27 01:50:38 -05:00
"strings"
2015-11-27 00:24:24 -05:00
2016-11-10 17:24:48 +01:00
"code.gitea.io/gitea/models"
"code.gitea.io/gitea/modules/auth"
"code.gitea.io/gitea/modules/base"
"code.gitea.io/gitea/modules/context"
2019-03-27 17:33:00 +08:00
"code.gitea.io/gitea/modules/git"
2019-04-22 21:40:51 +01:00
"code.gitea.io/gitea/modules/log"
2017-04-21 15:01:08 +08:00
"code.gitea.io/gitea/modules/markup"
2017-09-21 13:20:14 +08:00
"code.gitea.io/gitea/modules/markup/markdown"
2019-08-15 22:46:21 +08:00
"code.gitea.io/gitea/modules/timeutil"
2017-12-13 15:46:56 +02:00
"code.gitea.io/gitea/modules/util"
2015-11-25 20:10:25 -05:00
)
const (
2019-07-08 10:20:22 +02:00
tplWikiStart base . TplName = "repo/wiki/start"
tplWikiView base . TplName = "repo/wiki/view"
tplWikiRevision base . TplName = "repo/wiki/revision"
tplWikiNew base . TplName = "repo/wiki/new"
tplWikiPages base . TplName = "repo/wiki/pages"
2015-11-25 20:10:25 -05:00
)
2016-11-21 18:03:42 +08:00
// MustEnableWiki check if wiki is enabled, if external then redirect
2016-03-11 11:56:52 -05:00
func MustEnableWiki ( ctx * context . Context ) {
2018-11-28 19:26:14 +08:00
if ! ctx . Repo . CanRead ( models . UnitTypeWiki ) &&
! ctx . Repo . CanRead ( models . UnitTypeExternalWiki ) {
2019-04-22 21:40:51 +01:00
if log . IsTrace ( ) {
log . Trace ( "Permission Denied: User %-v cannot read %-v or %-v of repo %-v\n" +
"User in repo has Permissions: %-+v" ,
ctx . User ,
models . UnitTypeWiki ,
models . UnitTypeExternalWiki ,
ctx . Repo . Repository ,
ctx . Repo . Permission )
}
2018-01-10 22:34:17 +01:00
ctx . NotFound ( "MustEnableWiki" , nil )
2015-12-11 04:55:08 -05:00
return
}
2017-02-04 23:53:46 +08:00
unit , err := ctx . Repo . Repository . GetUnit ( models . UnitTypeExternalWiki )
if err == nil {
ctx . Redirect ( unit . ExternalWikiConfig ( ) . ExternalWikiURL )
2015-12-11 04:55:08 -05:00
return
2015-12-04 21:30:33 -05:00
}
}
2016-11-21 18:03:42 +08:00
// PageMeta wiki page meat information
2015-11-27 01:50:38 -05:00
type PageMeta struct {
2017-12-13 15:46:56 +02:00
Name string
SubURL string
2019-08-15 22:46:21 +08:00
UpdatedUnix timeutil . TimeStamp
2015-11-27 01:50:38 -05:00
}
2015-11-25 20:10:25 -05:00
2017-11-28 01:43:51 -08:00
// findEntryForFile finds the tree entry for a target filepath.
func findEntryForFile ( commit * git . Commit , target string ) ( * git . TreeEntry , error ) {
2017-02-14 08:13:59 +07:00
entries , err := commit . ListEntries ( )
if err != nil {
return nil , err
}
2017-11-28 01:43:51 -08:00
for _ , entry := range entries {
2019-04-19 14:17:27 +02:00
if entry . IsRegular ( ) && entry . Name ( ) == target {
2017-11-28 01:43:51 -08:00
return entry , nil
2017-02-14 08:13:59 +07:00
}
}
2017-11-28 01:43:51 -08:00
return nil , nil
2017-02-14 08:13:59 +07:00
}
func findWikiRepoCommit ( ctx * context . Context ) ( * git . Repository , * git . Commit , error ) {
2015-11-27 00:24:24 -05:00
wikiRepo , err := git . OpenRepository ( ctx . Repo . Repository . WikiPath ( ) )
if err != nil {
2018-01-10 22:34:17 +01:00
ctx . ServerError ( "OpenRepository" , err )
2017-02-14 08:13:59 +07:00
return nil , nil , err
2015-11-27 00:24:24 -05:00
}
2017-03-20 21:36:19 +08:00
2015-12-09 20:46:05 -05:00
commit , err := wikiRepo . GetBranchCommit ( "master" )
2015-11-27 00:24:24 -05:00
if err != nil {
2017-02-14 08:13:59 +07:00
return wikiRepo , nil , err
}
return wikiRepo , commit , nil
}
2017-11-28 01:43:51 -08:00
// wikiContentsByEntry returns the contents of the wiki page referenced by the
// given tree entry. Writes to ctx if an error occurs.
func wikiContentsByEntry ( ctx * context . Context , entry * git . TreeEntry ) [ ] byte {
2019-04-19 14:17:27 +02:00
reader , err := entry . Blob ( ) . DataAsync ( )
2017-11-28 01:43:51 -08:00
if err != nil {
2018-01-10 22:34:17 +01:00
ctx . ServerError ( "Blob.Data" , err )
2017-11-28 01:43:51 -08:00
return nil
}
2019-04-19 14:17:27 +02:00
defer reader . Close ( )
2017-11-28 01:43:51 -08:00
content , err := ioutil . ReadAll ( reader )
if err != nil {
2018-01-10 22:34:17 +01:00
ctx . ServerError ( "ReadAll" , err )
2017-11-28 01:43:51 -08:00
return nil
}
return content
}
// wikiContentsByName returns the contents of a wiki page, along with a boolean
// indicating whether the page exists. Writes to ctx if an error occurs.
2019-07-08 10:20:22 +02:00
func wikiContentsByName ( ctx * context . Context , commit * git . Commit , wikiName string ) ( [ ] byte , * git . TreeEntry , string , bool ) {
var entry * git . TreeEntry
var err error
pageFilename := models . WikiNameToFilename ( wikiName )
if entry , err = findEntryForFile ( commit , pageFilename ) ; err != nil {
2018-01-10 22:34:17 +01:00
ctx . ServerError ( "findEntryForFile" , err )
2019-07-08 10:20:22 +02:00
return nil , nil , "" , false
2017-11-28 01:43:51 -08:00
} else if entry == nil {
2019-07-08 10:20:22 +02:00
return nil , nil , "" , true
2017-11-28 01:43:51 -08:00
}
2019-07-08 10:20:22 +02:00
return wikiContentsByEntry ( ctx , entry ) , entry , pageFilename , false
2017-11-28 01:43:51 -08:00
}
2019-07-08 10:20:22 +02:00
func renderViewPage ( ctx * context . Context ) ( * git . Repository , * git . TreeEntry ) {
2017-02-14 08:13:59 +07:00
wikiRepo , commit , err := findWikiRepoCommit ( ctx )
if err != nil {
2018-12-10 06:45:44 +08:00
if ! git . IsErrNotExist ( err ) {
ctx . ServerError ( "GetBranchCommit" , err )
}
2017-02-14 08:13:59 +07:00
return nil , nil
2015-11-27 01:50:38 -05:00
}
// Get page list.
2019-07-08 10:20:22 +02:00
entries , err := commit . ListEntries ( )
if err != nil {
ctx . ServerError ( "ListEntries" , err )
return nil , nil
}
pages := make ( [ ] PageMeta , 0 , len ( entries ) )
for _ , entry := range entries {
if ! entry . IsRegular ( ) {
continue
2015-11-27 01:50:38 -05:00
}
2019-07-08 10:20:22 +02:00
wikiName , err := models . WikiFilenameToName ( entry . Name ( ) )
if err != nil {
if models . IsErrWikiInvalidFileName ( err ) {
2017-11-28 01:43:51 -08:00
continue
}
2019-07-08 10:20:22 +02:00
ctx . ServerError ( "WikiFilenameToName" , err )
return nil , nil
} else if wikiName == "_Sidebar" || wikiName == "_Footer" {
continue
2015-11-27 01:50:38 -05:00
}
2019-07-08 10:20:22 +02:00
pages = append ( pages , PageMeta {
Name : wikiName ,
SubURL : models . WikiNameToSubURL ( wikiName ) ,
} )
2015-11-27 00:24:24 -05:00
}
2019-07-08 10:20:22 +02:00
ctx . Data [ "Pages" ] = pages
2015-11-27 00:24:24 -05:00
2019-07-08 10:20:22 +02:00
// get requested pagename
2017-11-28 01:43:51 -08:00
pageName := models . NormalizeWikiName ( ctx . Params ( ":page" ) )
if len ( pageName ) == 0 {
pageName = "Home"
2015-11-27 00:24:24 -05:00
}
2017-11-28 01:43:51 -08:00
ctx . Data [ "PageURL" ] = models . WikiNameToSubURL ( pageName )
2015-11-27 01:50:38 -05:00
ctx . Data [ "old_title" ] = pageName
ctx . Data [ "Title" ] = pageName
ctx . Data [ "title" ] = pageName
2015-11-27 00:24:24 -05:00
ctx . Data [ "RequireHighlightJS" ] = true
2019-07-08 10:20:22 +02:00
//lookup filename in wiki - get filecontent, gitTree entry , real filename
data , entry , pageFilename , noEntry := wikiContentsByName ( ctx , commit , pageName )
if noEntry {
2017-02-14 08:13:59 +07:00
ctx . Redirect ( ctx . Repo . RepoLink + "/wiki/_pages" )
2019-07-08 10:20:22 +02:00
}
if entry == nil || ctx . Written ( ) {
2017-02-14 08:13:59 +07:00
return nil , nil
2015-11-27 00:24:24 -05:00
}
2019-07-08 10:20:22 +02:00
sidebarContent , _ , _ , _ := wikiContentsByName ( ctx , commit , "_Sidebar" )
2017-11-28 01:43:51 -08:00
if ctx . Written ( ) {
2017-02-14 08:13:59 +07:00
return nil , nil
}
2017-11-28 01:43:51 -08:00
2019-07-08 10:20:22 +02:00
footerContent , _ , _ , _ := wikiContentsByName ( ctx , commit , "_Footer" )
if ctx . Written ( ) {
return nil , nil
}
2017-11-28 01:43:51 -08:00
2019-07-08 10:20:22 +02:00
metas := ctx . Repo . Repository . ComposeMetas ( )
ctx . Data [ "content" ] = markdown . RenderWiki ( data , ctx . Repo . RepoLink , metas )
ctx . Data [ "sidebarPresent" ] = sidebarContent != nil
ctx . Data [ "sidebarContent" ] = markdown . RenderWiki ( sidebarContent , ctx . Repo . RepoLink , metas )
ctx . Data [ "footerPresent" ] = footerContent != nil
ctx . Data [ "footerContent" ] = markdown . RenderWiki ( footerContent , ctx . Repo . RepoLink , metas )
// get commit count - wiki revisions
commitsCount , _ := wikiRepo . FileCommitsCount ( "master" , pageFilename )
ctx . Data [ "CommitCount" ] = commitsCount
return wikiRepo , entry
}
func renderRevisionPage ( ctx * context . Context ) ( * git . Repository , * git . TreeEntry ) {
wikiRepo , commit , err := findWikiRepoCommit ( ctx )
if err != nil {
if ! git . IsErrNotExist ( err ) {
ctx . ServerError ( "GetBranchCommit" , err )
2017-02-14 08:13:59 +07:00
}
2019-07-08 10:20:22 +02:00
return nil , nil
}
// get requested pagename
pageName := models . NormalizeWikiName ( ctx . Params ( ":page" ) )
if len ( pageName ) == 0 {
pageName = "Home"
}
ctx . Data [ "PageURL" ] = models . WikiNameToSubURL ( pageName )
ctx . Data [ "old_title" ] = pageName
ctx . Data [ "Title" ] = pageName
ctx . Data [ "title" ] = pageName
ctx . Data [ "RequireHighlightJS" ] = true
2017-11-28 01:43:51 -08:00
2019-07-08 10:20:22 +02:00
//lookup filename in wiki - get filecontent, gitTree entry , real filename
data , entry , pageFilename , noEntry := wikiContentsByName ( ctx , commit , pageName )
if noEntry {
ctx . Redirect ( ctx . Repo . RepoLink + "/wiki/_pages" )
}
if entry == nil || ctx . Written ( ) {
return nil , nil
2015-11-27 01:50:38 -05:00
}
2019-07-08 10:20:22 +02:00
ctx . Data [ "content" ] = string ( data )
ctx . Data [ "sidebarPresent" ] = false
ctx . Data [ "sidebarContent" ] = ""
ctx . Data [ "footerPresent" ] = false
ctx . Data [ "footerContent" ] = ""
// get commit count - wiki revisions
commitsCount , _ := wikiRepo . FileCommitsCount ( "master" , pageFilename )
ctx . Data [ "CommitCount" ] = commitsCount
// get page
page := ctx . QueryInt ( "page" )
if page <= 1 {
page = 1
}
// get Commit Count
2019-07-11 16:45:10 +02:00
commitsHistory , err := wikiRepo . CommitsByFileAndRangeNoFollow ( "master" , pageFilename , page )
2019-07-08 10:20:22 +02:00
if err != nil {
2019-07-11 16:45:10 +02:00
ctx . ServerError ( "CommitsByFileAndRangeNoFollow" , err )
2019-07-08 10:20:22 +02:00
return nil , nil
}
commitsHistory = models . ValidateCommitsWithEmails ( commitsHistory )
commitsHistory = models . ParseCommitsWithSignature ( commitsHistory )
ctx . Data [ "Commits" ] = commitsHistory
pager := context . NewPagination ( int ( commitsCount ) , git . CommitsRangeSize , page , 5 )
pager . SetDefaultParams ( ctx )
ctx . Data [ "Page" ] = pager
2017-02-14 08:13:59 +07:00
return wikiRepo , entry
2015-11-27 01:50:38 -05:00
}
2019-07-08 10:20:22 +02:00
func renderEditPage ( ctx * context . Context ) {
_ , commit , err := findWikiRepoCommit ( ctx )
if err != nil {
if ! git . IsErrNotExist ( err ) {
ctx . ServerError ( "GetBranchCommit" , err )
}
return
}
// get requested pagename
pageName := models . NormalizeWikiName ( ctx . Params ( ":page" ) )
if len ( pageName ) == 0 {
pageName = "Home"
}
ctx . Data [ "PageURL" ] = models . WikiNameToSubURL ( pageName )
ctx . Data [ "old_title" ] = pageName
ctx . Data [ "Title" ] = pageName
ctx . Data [ "title" ] = pageName
ctx . Data [ "RequireHighlightJS" ] = true
//lookup filename in wiki - get filecontent, gitTree entry , real filename
data , entry , _ , noEntry := wikiContentsByName ( ctx , commit , pageName )
if noEntry {
ctx . Redirect ( ctx . Repo . RepoLink + "/wiki/_pages" )
}
if entry == nil || ctx . Written ( ) {
return
}
ctx . Data [ "content" ] = string ( data )
ctx . Data [ "sidebarPresent" ] = false
ctx . Data [ "sidebarContent" ] = ""
ctx . Data [ "footerPresent" ] = false
ctx . Data [ "footerContent" ] = ""
}
2017-02-14 08:13:59 +07:00
// Wiki renders single wiki page
2016-03-11 11:56:52 -05:00
func Wiki ( ctx * context . Context ) {
2015-11-27 01:50:38 -05:00
ctx . Data [ "PageIsWiki" ] = true
2019-01-23 19:58:38 +01:00
ctx . Data [ "CanWriteWiki" ] = ctx . Repo . CanWrite ( models . UnitTypeWiki ) && ! ctx . Repo . Repository . IsArchived
2015-11-27 01:50:38 -05:00
if ! ctx . Repo . Repository . HasWiki ( ) {
ctx . Data [ "Title" ] = ctx . Tr ( "repo.wiki" )
2016-11-21 18:03:42 +08:00
ctx . HTML ( 200 , tplWikiStart )
2015-11-27 01:50:38 -05:00
return
}
2019-07-08 10:20:22 +02:00
wikiRepo , entry := renderViewPage ( ctx )
2015-11-27 01:50:38 -05:00
if ctx . Written ( ) {
2015-11-27 00:24:24 -05:00
return
}
2017-03-20 21:36:19 +08:00
if entry == nil {
ctx . Data [ "Title" ] = ctx . Tr ( "repo.wiki" )
ctx . HTML ( 200 , tplWikiStart )
return
}
2015-11-27 00:24:24 -05:00
2017-11-28 01:43:51 -08:00
wikiPath := entry . Name ( )
if markup . Type ( wikiPath ) != markdown . MarkupName {
ext := strings . ToUpper ( filepath . Ext ( wikiPath ) )
2017-02-14 08:13:59 +07:00
ctx . Data [ "FormatWarning" ] = fmt . Sprintf ( "%s rendering is not supported at the moment. Rendered as Markdown." , ext )
}
2015-11-27 00:24:24 -05:00
// Get last change information.
2017-11-28 01:43:51 -08:00
lastCommit , err := wikiRepo . GetCommitByPath ( wikiPath )
2015-11-27 00:24:24 -05:00
if err != nil {
2018-01-10 22:34:17 +01:00
ctx . ServerError ( "GetCommitByPath" , err )
2015-11-27 00:24:24 -05:00
return
}
ctx . Data [ "Author" ] = lastCommit . Author
2016-11-21 18:03:42 +08:00
ctx . HTML ( 200 , tplWikiView )
2015-11-25 20:10:25 -05:00
}
2019-07-08 10:20:22 +02:00
// WikiRevision renders file revision list of wiki page
func WikiRevision ( ctx * context . Context ) {
ctx . Data [ "PageIsWiki" ] = true
ctx . Data [ "CanWriteWiki" ] = ctx . Repo . CanWrite ( models . UnitTypeWiki ) && ! ctx . Repo . Repository . IsArchived
if ! ctx . Repo . Repository . HasWiki ( ) {
ctx . Data [ "Title" ] = ctx . Tr ( "repo.wiki" )
ctx . HTML ( 200 , tplWikiStart )
return
}
wikiRepo , entry := renderRevisionPage ( ctx )
if ctx . Written ( ) {
return
}
if entry == nil {
ctx . Data [ "Title" ] = ctx . Tr ( "repo.wiki" )
ctx . HTML ( 200 , tplWikiStart )
return
}
// Get last change information.
wikiPath := entry . Name ( )
lastCommit , err := wikiRepo . GetCommitByPath ( wikiPath )
if err != nil {
ctx . ServerError ( "GetCommitByPath" , err )
return
}
ctx . Data [ "Author" ] = lastCommit . Author
ctx . HTML ( 200 , tplWikiRevision )
}
2016-11-21 18:03:42 +08:00
// WikiPages render wiki pages list page
2016-03-11 11:56:52 -05:00
func WikiPages ( ctx * context . Context ) {
2015-11-27 02:16:12 -05:00
if ! ctx . Repo . Repository . HasWiki ( ) {
ctx . Redirect ( ctx . Repo . RepoLink + "/wiki" )
return
}
2018-11-28 19:26:14 +08:00
ctx . Data [ "Title" ] = ctx . Tr ( "repo.wiki.pages" )
ctx . Data [ "PageIsWiki" ] = true
2019-01-23 19:58:38 +01:00
ctx . Data [ "CanWriteWiki" ] = ctx . Repo . CanWrite ( models . UnitTypeWiki ) && ! ctx . Repo . Repository . IsArchived
2018-11-28 19:26:14 +08:00
2017-02-14 08:13:59 +07:00
wikiRepo , commit , err := findWikiRepoCommit ( ctx )
2015-11-27 02:16:12 -05:00
if err != nil {
return
}
entries , err := commit . ListEntries ( )
if err != nil {
2018-01-10 22:34:17 +01:00
ctx . ServerError ( "ListEntries" , err )
2015-11-27 02:16:12 -05:00
return
}
pages := make ( [ ] PageMeta , 0 , len ( entries ) )
2017-11-28 01:43:51 -08:00
for _ , entry := range entries {
2019-04-19 14:17:27 +02:00
if ! entry . IsRegular ( ) {
2017-11-28 01:43:51 -08:00
continue
}
c , err := wikiRepo . GetCommitByPath ( entry . Name ( ) )
if err != nil {
2018-01-10 22:34:17 +01:00
ctx . ServerError ( "GetCommit" , err )
2017-11-28 01:43:51 -08:00
return
}
wikiName , err := models . WikiFilenameToName ( entry . Name ( ) )
if err != nil {
2018-02-05 16:56:30 +02:00
if models . IsErrWikiInvalidFileName ( err ) {
continue
}
2018-01-10 22:34:17 +01:00
ctx . ServerError ( "WikiFilenameToName" , err )
2017-11-28 01:43:51 -08:00
return
2015-11-27 02:16:12 -05:00
}
2017-11-28 01:43:51 -08:00
pages = append ( pages , PageMeta {
2017-12-13 15:46:56 +02:00
Name : wikiName ,
SubURL : models . WikiNameToSubURL ( wikiName ) ,
2019-08-15 22:46:21 +08:00
UpdatedUnix : timeutil . TimeStamp ( c . Author . When . Unix ( ) ) ,
2017-11-28 01:43:51 -08:00
} )
2015-11-27 02:16:12 -05:00
}
ctx . Data [ "Pages" ] = pages
2015-11-27 00:24:24 -05:00
2016-11-21 18:03:42 +08:00
ctx . HTML ( 200 , tplWikiPages )
2015-11-27 00:24:24 -05:00
}
2017-02-14 08:13:59 +07:00
// WikiRaw outputs raw blob requested by user (image for example)
func WikiRaw ( ctx * context . Context ) {
wikiRepo , commit , err := findWikiRepoCommit ( ctx )
if err != nil {
if wikiRepo != nil {
return
}
}
2019-02-05 20:58:55 -05:00
2017-11-28 01:43:51 -08:00
providedPath := ctx . Params ( "*" )
2019-02-05 20:58:55 -05:00
2017-02-14 08:13:59 +07:00
var entry * git . TreeEntry
if commit != nil {
2019-02-05 20:58:55 -05:00
// Try to find a file with that name
entry , err = findEntryForFile ( commit , providedPath )
if err != nil {
ctx . ServerError ( "findFile" , err )
return
}
if entry == nil {
// Try to find a wiki page with that name
if strings . HasSuffix ( providedPath , ".md" ) {
providedPath = providedPath [ : len ( providedPath ) - 3 ]
}
wikiPath := models . WikiNameToFilename ( providedPath )
entry , err = findEntryForFile ( commit , wikiPath )
if err != nil {
ctx . ServerError ( "findFile" , err )
return
}
}
2017-02-14 08:13:59 +07:00
}
2019-02-05 20:58:55 -05:00
if entry != nil {
if err = ServeBlob ( ctx , entry . Blob ( ) ) ; err != nil {
ctx . ServerError ( "ServeBlob" , err )
}
2017-11-28 01:43:51 -08:00
return
}
2019-02-05 20:58:55 -05:00
ctx . NotFound ( "findEntryForFile" , nil )
2017-02-14 08:13:59 +07:00
}
2016-11-21 18:03:42 +08:00
// NewWiki render wiki create page
2016-03-11 11:56:52 -05:00
func NewWiki ( ctx * context . Context ) {
2015-11-25 20:10:25 -05:00
ctx . Data [ "Title" ] = ctx . Tr ( "repo.wiki.new_page" )
ctx . Data [ "PageIsWiki" ] = true
ctx . Data [ "RequireSimpleMDE" ] = true
2015-11-26 17:33:45 -05:00
if ! ctx . Repo . Repository . HasWiki ( ) {
2015-11-25 20:10:25 -05:00
ctx . Data [ "title" ] = "Home"
}
2016-11-21 18:03:42 +08:00
ctx . HTML ( 200 , tplWikiNew )
2015-11-25 20:10:25 -05:00
}
2017-11-28 01:43:51 -08:00
// NewWikiPost response for wiki create request
2016-03-11 11:56:52 -05:00
func NewWikiPost ( ctx * context . Context , form auth . NewWikiForm ) {
2015-11-26 17:33:45 -05:00
ctx . Data [ "Title" ] = ctx . Tr ( "repo.wiki.new_page" )
ctx . Data [ "PageIsWiki" ] = true
ctx . Data [ "RequireSimpleMDE" ] = true
if ctx . HasError ( ) {
2016-11-21 18:03:42 +08:00
ctx . HTML ( 200 , tplWikiNew )
2015-11-26 17:33:45 -05:00
return
}
2019-01-21 12:45:32 +01:00
if util . IsEmptyString ( form . Title ) {
ctx . RenderWithErr ( ctx . Tr ( "repo.issues.new.title_empty" ) , tplWikiNew , form )
return
}
2017-11-28 01:43:51 -08:00
wikiName := models . NormalizeWikiName ( form . Title )
if err := ctx . Repo . Repository . AddWikiPage ( ctx . User , wikiName , form . Content , form . Message ) ; err != nil {
if models . IsErrWikiReservedName ( err ) {
ctx . Data [ "Err_Title" ] = true
ctx . RenderWithErr ( ctx . Tr ( "repo.wiki.reserved_page" , wikiName ) , tplWikiNew , & form )
} else if models . IsErrWikiAlreadyExist ( err ) {
2015-11-27 01:50:38 -05:00
ctx . Data [ "Err_Title" ] = true
2016-11-21 18:03:42 +08:00
ctx . RenderWithErr ( ctx . Tr ( "repo.wiki.page_already_exists" ) , tplWikiNew , & form )
2015-11-27 01:50:38 -05:00
} else {
2018-01-10 22:34:17 +01:00
ctx . ServerError ( "AddWikiPage" , err )
2015-11-27 01:50:38 -05:00
}
2015-11-26 17:33:45 -05:00
return
}
2018-05-28 15:38:20 +02:00
ctx . Redirect ( ctx . Repo . RepoLink + "/wiki/" + models . WikiNameToSubURL ( wikiName ) )
2015-11-26 17:33:45 -05:00
}
2016-11-21 18:03:42 +08:00
// EditWiki render wiki modify page
2016-03-11 11:56:52 -05:00
func EditWiki ( ctx * context . Context ) {
2015-11-27 01:50:38 -05:00
ctx . Data [ "PageIsWiki" ] = true
ctx . Data [ "PageIsWikiEdit" ] = true
ctx . Data [ "RequireSimpleMDE" ] = true
if ! ctx . Repo . Repository . HasWiki ( ) {
ctx . Redirect ( ctx . Repo . RepoLink + "/wiki" )
return
}
2019-07-08 10:20:22 +02:00
renderEditPage ( ctx )
2015-11-27 01:50:38 -05:00
if ctx . Written ( ) {
return
}
2016-11-21 18:03:42 +08:00
ctx . HTML ( 200 , tplWikiNew )
2015-11-27 01:50:38 -05:00
}
2017-11-28 01:43:51 -08:00
// EditWikiPost response for wiki modify request
2016-03-11 11:56:52 -05:00
func EditWikiPost ( ctx * context . Context , form auth . NewWikiForm ) {
2015-11-27 01:50:38 -05:00
ctx . Data [ "Title" ] = ctx . Tr ( "repo.wiki.new_page" )
ctx . Data [ "PageIsWiki" ] = true
ctx . Data [ "RequireSimpleMDE" ] = true
if ctx . HasError ( ) {
2016-11-21 18:03:42 +08:00
ctx . HTML ( 200 , tplWikiNew )
2015-11-27 01:50:38 -05:00
return
}
2017-11-28 01:43:51 -08:00
oldWikiName := models . NormalizeWikiName ( ctx . Params ( ":page" ) )
newWikiName := models . NormalizeWikiName ( form . Title )
2017-01-21 20:50:51 +08:00
2017-11-28 01:43:51 -08:00
if err := ctx . Repo . Repository . EditWikiPage ( ctx . User , oldWikiName , newWikiName , form . Content , form . Message ) ; err != nil {
2018-01-10 22:34:17 +01:00
ctx . ServerError ( "EditWikiPage" , err )
2015-11-27 01:50:38 -05:00
return
}
2018-05-28 15:38:20 +02:00
ctx . Redirect ( ctx . Repo . RepoLink + "/wiki/" + models . WikiNameToSubURL ( newWikiName ) )
2015-11-25 20:10:25 -05:00
}
2016-03-03 17:06:50 -05:00
2016-11-21 18:03:42 +08:00
// DeleteWikiPagePost delete wiki page
2016-03-11 11:56:52 -05:00
func DeleteWikiPagePost ( ctx * context . Context ) {
2017-11-28 01:43:51 -08:00
wikiName := models . NormalizeWikiName ( ctx . Params ( ":page" ) )
if len ( wikiName ) == 0 {
wikiName = "Home"
2016-03-03 17:06:50 -05:00
}
2017-11-28 01:43:51 -08:00
if err := ctx . Repo . Repository . DeleteWikiPage ( ctx . User , wikiName ) ; err != nil {
2018-01-10 22:34:17 +01:00
ctx . ServerError ( "DeleteWikiPage" , err )
2016-03-03 17:06:50 -05:00
return
}
ctx . JSON ( 200 , map [ string ] interface { } {
"redirect" : ctx . Repo . RepoLink + "/wiki/" ,
} )
}