common.js 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176
  1. const express = require('express')
  2. const router = express.Router()
  3. const pageHelper = require('../helpers/page')
  4. const _ = require('lodash')
  5. /* global WIKI */
  6. /**
  7. * Robots.txt
  8. */
  9. router.get('/robots.txt', (req, res, next) => {
  10. res.type('text/plain')
  11. if (_.includes(WIKI.config.seo.robots, 'noindex')) {
  12. res.send('User-agent: *\nDisallow: /')
  13. } else {
  14. res.status(200).end()
  15. }
  16. })
  17. /**
  18. * Create/Edit document
  19. */
  20. router.get(['/e', '/e/*'], async (req, res, next) => {
  21. const pageArgs = pageHelper.parsePath(req.path)
  22. if (pageHelper.isReservedPath(pageArgs.path)) {
  23. return next(new Error('Cannot create this page because it starts with a system reserved path.'))
  24. }
  25. let page = await WIKI.models.pages.getPageFromDb({
  26. path: pageArgs.path,
  27. locale: pageArgs.locale,
  28. userId: req.user.id,
  29. isPrivate: false
  30. })
  31. if (page) {
  32. if (!WIKI.auth.checkAccess(req.user, ['manage:pages'], pageArgs)) {
  33. _.set(res.locals, 'pageMeta.title', 'Unauthorized')
  34. return res.render('unauthorized', { action: 'edit' })
  35. }
  36. _.set(res.locals, 'pageMeta.title', `Edit ${page.title}`)
  37. _.set(res.locals, 'pageMeta.description', page.description)
  38. page.mode = 'update'
  39. page.isPublished = (page.isPublished === true || page.isPublished === 1) ? 'true' : 'false'
  40. page.content = Buffer.from(page.content).toString('base64')
  41. } else {
  42. if (!WIKI.auth.checkAccess(req.user, ['write:pages'], pageArgs)) {
  43. _.set(res.locals, 'pageMeta.title', 'Unauthorized')
  44. return res.render('unauthorized', { action: 'create' })
  45. }
  46. _.set(res.locals, 'pageMeta.title', `New Page`)
  47. page = {
  48. path: pageArgs.path,
  49. localeCode: pageArgs.locale,
  50. editorKey: null,
  51. mode: 'create',
  52. content: null
  53. }
  54. }
  55. res.render('editor', { page })
  56. })
  57. /**
  58. * Administration
  59. */
  60. router.get(['/a', '/a/*'], (req, res, next) => {
  61. _.set(res.locals, 'pageMeta.title', 'Admin')
  62. res.render('admin')
  63. })
  64. /**
  65. * Profile
  66. */
  67. router.get(['/p', '/p/*'], (req, res, next) => {
  68. _.set(res.locals, 'pageMeta.title', 'User Profile')
  69. res.render('profile')
  70. })
  71. /**
  72. * History
  73. */
  74. router.get(['/h', '/h/*'], async (req, res, next) => {
  75. const pageArgs = pageHelper.parsePath(req.path)
  76. if (!WIKI.auth.checkAccess(req.user, ['read:pages'], pageArgs)) {
  77. _.set(res.locals, 'pageMeta.title', 'Unauthorized')
  78. return res.render('unauthorized', { action: 'history' })
  79. }
  80. const page = await WIKI.models.pages.getPageFromDb({
  81. path: pageArgs.path,
  82. locale: pageArgs.locale,
  83. userId: req.user.id,
  84. isPrivate: false
  85. })
  86. if (page) {
  87. _.set(res.locals, 'pageMeta.title', page.title)
  88. _.set(res.locals, 'pageMeta.description', page.description)
  89. res.render('history', { page })
  90. } else {
  91. res.redirect(`/${pageArgs.path}`)
  92. }
  93. })
  94. /**
  95. * Source
  96. */
  97. router.get(['/s', '/s/*'], async (req, res, next) => {
  98. const pageArgs = pageHelper.parsePath(req.path)
  99. if (!WIKI.auth.checkAccess(req.user, ['read:pages'], pageArgs)) {
  100. return res.render('unauthorized', { action: 'source' })
  101. }
  102. const page = await WIKI.models.pages.getPageFromDb({
  103. path: pageArgs.path,
  104. locale: pageArgs.locale,
  105. userId: req.user.id,
  106. isPrivate: false
  107. })
  108. if (page) {
  109. _.set(res.locals, 'pageMeta.title', page.title)
  110. _.set(res.locals, 'pageMeta.description', page.description)
  111. res.render('source', { page })
  112. } else {
  113. res.redirect(`/${pageArgs.path}`)
  114. }
  115. })
  116. /**
  117. * View document
  118. */
  119. router.get('/*', async (req, res, next) => {
  120. const pageArgs = pageHelper.parsePath(req.path)
  121. if (!WIKI.auth.checkAccess(req.user, ['read:pages'], pageArgs)) {
  122. if (pageArgs.path === 'home') {
  123. return res.redirect('/login')
  124. } else {
  125. _.set(res.locals, 'pageMeta.title', 'Unauthorized')
  126. return res.render('unauthorized', { action: 'view' })
  127. }
  128. }
  129. const page = await WIKI.models.pages.getPage({
  130. path: pageArgs.path,
  131. locale: pageArgs.locale,
  132. userId: req.user.id,
  133. isPrivate: false
  134. })
  135. if (page) {
  136. _.set(res.locals, 'pageMeta.title', page.title)
  137. _.set(res.locals, 'pageMeta.description', page.description)
  138. const sidebar = await WIKI.models.navigation.getTree({ cache: true })
  139. const injectCode = {
  140. css: WIKI.config.theming.injectCSS,
  141. head: WIKI.config.theming.injectHead,
  142. body: WIKI.config.theming.injectBody
  143. }
  144. res.render('page', { page, sidebar, injectCode })
  145. } else if (pageArgs.path === 'home') {
  146. _.set(res.locals, 'pageMeta.title', 'Welcome')
  147. res.render('welcome')
  148. } else {
  149. _.set(res.locals, 'pageMeta.title', 'Page Not Found')
  150. if (WIKI.auth.checkAccess(req.user, ['write:pages'], pageArgs)) {
  151. res.status(404).render('new', { pagePath: req.path })
  152. } else {
  153. res.render('notfound', { action: 'view' })
  154. }
  155. }
  156. })
  157. module.exports = router