wiki.go 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277
  1. // Copyright 2015 The Gogs Authors. All rights reserved.
  2. // Copyright 2018 Gitote. All rights reserved.
  3. //
  4. // This source code is licensed under the MIT license found in the
  5. // LICENSE file in the root directory of this source tree.
  6. package repo
  7. import (
  8. "gitote/gitote/models"
  9. "gitote/gitote/pkg/context"
  10. "gitote/gitote/pkg/form"
  11. "gitote/gitote/pkg/markup"
  12. "io/ioutil"
  13. "strings"
  14. "time"
  15. "gitlab.com/gitote/git-module"
  16. )
  17. const (
  18. WIKI_START = "repo/wiki/start"
  19. WIKI_VIEW = "repo/wiki/view"
  20. WIKI_NEW = "repo/wiki/new"
  21. WIKI_PAGES = "repo/wiki/pages"
  22. )
  23. func MustEnableWiki(c *context.Context) {
  24. if !c.Repo.Repository.EnableWiki {
  25. c.Handle(404, "MustEnableWiki", nil)
  26. return
  27. }
  28. if c.Repo.Repository.EnableExternalWiki {
  29. c.Redirect(c.Repo.Repository.ExternalWikiURL)
  30. return
  31. }
  32. }
  33. type PageMeta struct {
  34. Name string
  35. URL string
  36. Updated time.Time
  37. }
  38. func renderWikiPage(c *context.Context, isViewPage bool) (*git.Repository, string) {
  39. wikiRepo, err := git.OpenRepository(c.Repo.Repository.WikiPath())
  40. if err != nil {
  41. c.Handle(500, "OpenRepository", err)
  42. return nil, ""
  43. }
  44. commit, err := wikiRepo.GetBranchCommit("master")
  45. if err != nil {
  46. c.Handle(500, "GetBranchCommit", err)
  47. return nil, ""
  48. }
  49. // Get page list.
  50. if isViewPage {
  51. entries, err := commit.ListEntries()
  52. if err != nil {
  53. c.Handle(500, "ListEntries", err)
  54. return nil, ""
  55. }
  56. pages := make([]PageMeta, 0, len(entries))
  57. for i := range entries {
  58. if entries[i].Type == git.OBJECT_BLOB && strings.HasSuffix(entries[i].Name(), ".md") {
  59. name := strings.TrimSuffix(entries[i].Name(), ".md")
  60. pages = append(pages, PageMeta{
  61. Name: name,
  62. URL: models.ToWikiPageURL(name),
  63. })
  64. }
  65. }
  66. c.Data["Pages"] = pages
  67. }
  68. pageURL := c.Params(":page")
  69. if len(pageURL) == 0 {
  70. pageURL = "Home"
  71. }
  72. c.Data["PageURL"] = pageURL
  73. pageName := models.ToWikiPageName(pageURL)
  74. c.Data["old_title"] = pageName
  75. c.Data["Title"] = pageName
  76. c.Data["title"] = pageName
  77. c.Data["RequireHighlightJS"] = true
  78. blob, err := commit.GetBlobByPath(pageName + ".md")
  79. if err != nil {
  80. if git.IsErrNotExist(err) {
  81. c.Redirect(c.Repo.RepoLink + "/wiki/_pages")
  82. } else {
  83. c.Handle(500, "GetBlobByPath", err)
  84. }
  85. return nil, ""
  86. }
  87. r, err := blob.Data()
  88. if err != nil {
  89. c.Handle(500, "Data", err)
  90. return nil, ""
  91. }
  92. data, err := ioutil.ReadAll(r)
  93. if err != nil {
  94. c.Handle(500, "ReadAll", err)
  95. return nil, ""
  96. }
  97. if isViewPage {
  98. c.Data["content"] = string(markup.Markdown(data, c.Repo.RepoLink, c.Repo.Repository.ComposeMetas()))
  99. } else {
  100. c.Data["content"] = string(data)
  101. }
  102. return wikiRepo, pageName
  103. }
  104. func Wiki(c *context.Context) {
  105. c.Data["PageIsWiki"] = true
  106. if !c.Repo.Repository.HasWiki() {
  107. c.Data["Title"] = c.Tr("repo.wiki")
  108. c.Data["PageIsRepoWiki"] = true
  109. c.HTML(200, WIKI_START)
  110. return
  111. }
  112. wikiRepo, pageName := renderWikiPage(c, true)
  113. if c.Written() {
  114. return
  115. }
  116. // Get last change information.
  117. lastCommit, err := wikiRepo.GetCommitByPath(pageName + ".md")
  118. if err != nil {
  119. c.Handle(500, "GetCommitByPath", err)
  120. return
  121. }
  122. c.Data["Author"] = lastCommit.Author
  123. c.HTML(200, WIKI_VIEW)
  124. }
  125. func WikiPages(c *context.Context) {
  126. c.Data["Title"] = c.Tr("repo.wiki.pages")
  127. c.Data["PageIsWiki"] = true
  128. if !c.Repo.Repository.HasWiki() {
  129. c.Redirect(c.Repo.RepoLink + "/wiki")
  130. return
  131. }
  132. wikiRepo, err := git.OpenRepository(c.Repo.Repository.WikiPath())
  133. if err != nil {
  134. c.Handle(500, "OpenRepository", err)
  135. return
  136. }
  137. commit, err := wikiRepo.GetBranchCommit("master")
  138. if err != nil {
  139. c.Handle(500, "GetBranchCommit", err)
  140. return
  141. }
  142. entries, err := commit.ListEntries()
  143. if err != nil {
  144. c.Handle(500, "ListEntries", err)
  145. return
  146. }
  147. pages := make([]PageMeta, 0, len(entries))
  148. for i := range entries {
  149. if entries[i].Type == git.OBJECT_BLOB && strings.HasSuffix(entries[i].Name(), ".md") {
  150. commit, err := wikiRepo.GetCommitByPath(entries[i].Name())
  151. if err != nil {
  152. c.ServerError("GetCommitByPath", err)
  153. return
  154. }
  155. name := strings.TrimSuffix(entries[i].Name(), ".md")
  156. pages = append(pages, PageMeta{
  157. Name: name,
  158. URL: models.ToWikiPageURL(name),
  159. Updated: commit.Author.When,
  160. })
  161. }
  162. }
  163. c.Data["Pages"] = pages
  164. c.HTML(200, WIKI_PAGES)
  165. }
  166. func NewWiki(c *context.Context) {
  167. c.Data["Title"] = c.Tr("repo.wiki.new_page")
  168. c.Data["PageIsWiki"] = true
  169. c.Data["RequireSimpleMDE"] = true
  170. if !c.Repo.Repository.HasWiki() {
  171. c.Data["title"] = "Home"
  172. }
  173. c.HTML(200, WIKI_NEW)
  174. }
  175. func NewWikiPost(c *context.Context, f form.NewWiki) {
  176. c.Data["Title"] = c.Tr("repo.wiki.new_page")
  177. c.Data["PageIsWiki"] = true
  178. c.Data["RequireSimpleMDE"] = true
  179. if c.HasError() {
  180. c.HTML(200, WIKI_NEW)
  181. return
  182. }
  183. if err := c.Repo.Repository.AddWikiPage(c.User, f.Title, f.Content, f.Message); err != nil {
  184. if models.IsErrWikiAlreadyExist(err) {
  185. c.Data["Err_Title"] = true
  186. c.RenderWithErr(c.Tr("repo.wiki.page_already_exists"), WIKI_NEW, &f)
  187. } else {
  188. c.Handle(500, "AddWikiPage", err)
  189. }
  190. return
  191. }
  192. c.Redirect(c.Repo.RepoLink + "/wiki/" + models.ToWikiPageURL(models.ToWikiPageName(f.Title)))
  193. }
  194. func EditWiki(c *context.Context) {
  195. c.Data["PageIsWiki"] = true
  196. c.Data["PageIsWikiEdit"] = true
  197. c.Data["RequireSimpleMDE"] = true
  198. if !c.Repo.Repository.HasWiki() {
  199. c.Redirect(c.Repo.RepoLink + "/wiki")
  200. return
  201. }
  202. renderWikiPage(c, false)
  203. if c.Written() {
  204. return
  205. }
  206. c.HTML(200, WIKI_NEW)
  207. }
  208. func EditWikiPost(c *context.Context, f form.NewWiki) {
  209. c.Data["Title"] = c.Tr("repo.wiki.new_page")
  210. c.Data["PageIsWiki"] = true
  211. c.Data["RequireSimpleMDE"] = true
  212. if c.HasError() {
  213. c.HTML(200, WIKI_NEW)
  214. return
  215. }
  216. if err := c.Repo.Repository.EditWikiPage(c.User, f.OldTitle, f.Title, f.Content, f.Message); err != nil {
  217. c.Handle(500, "EditWikiPage", err)
  218. return
  219. }
  220. c.Redirect(c.Repo.RepoLink + "/wiki/" + models.ToWikiPageURL(models.ToWikiPageName(f.Title)))
  221. }
  222. func DeleteWikiPagePost(c *context.Context) {
  223. pageURL := c.Params(":page")
  224. if len(pageURL) == 0 {
  225. pageURL = "Home"
  226. }
  227. pageName := models.ToWikiPageName(pageURL)
  228. if err := c.Repo.Repository.DeleteWikiPage(c.User, pageName); err != nil {
  229. c.Handle(500, "DeleteWikiPage", err)
  230. return
  231. }
  232. c.JSON(200, map[string]interface{}{
  233. "redirect": c.Repo.RepoLink + "/wiki/",
  234. })
  235. }