common.js 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206
  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. * Health Endpoint
  19. */
  20. router.get('/healthz', (req, res, next) => {
  21. if (WIKI.models.knex.client.pool.numFree() < 1 && WIKI.models.knex.client.pool.numUsed() < 1) {
  22. res.status(503).json({ ok: false }).end()
  23. } else {
  24. res.status(200).json({ ok: true }).end()
  25. }
  26. })
  27. /**
  28. * Create/Edit document
  29. */
  30. router.get(['/e', '/e/*'], async (req, res, next) => {
  31. const pageArgs = pageHelper.parsePath(req.path, { stripExt: true })
  32. _.set(res, 'locals.siteConfig.lang', pageArgs.locale)
  33. if (pageHelper.isReservedPath(pageArgs.path)) {
  34. return next(new Error('Cannot create this page because it starts with a system reserved path.'))
  35. }
  36. let page = await WIKI.models.pages.getPageFromDb({
  37. path: pageArgs.path,
  38. locale: pageArgs.locale,
  39. userId: req.user.id,
  40. isPrivate: false
  41. })
  42. if (page) {
  43. if (!WIKI.auth.checkAccess(req.user, ['manage:pages'], pageArgs)) {
  44. _.set(res.locals, 'pageMeta.title', 'Unauthorized')
  45. return res.render('unauthorized', { action: 'edit' })
  46. }
  47. _.set(res.locals, 'pageMeta.title', `Edit ${page.title}`)
  48. _.set(res.locals, 'pageMeta.description', page.description)
  49. page.mode = 'update'
  50. page.isPublished = (page.isPublished === true || page.isPublished === 1) ? 'true' : 'false'
  51. page.content = Buffer.from(page.content).toString('base64')
  52. } else {
  53. if (!WIKI.auth.checkAccess(req.user, ['write:pages'], pageArgs)) {
  54. _.set(res.locals, 'pageMeta.title', 'Unauthorized')
  55. return res.render('unauthorized', { action: 'create' })
  56. }
  57. _.set(res.locals, 'pageMeta.title', `New Page`)
  58. page = {
  59. path: pageArgs.path,
  60. localeCode: pageArgs.locale,
  61. editorKey: null,
  62. mode: 'create',
  63. content: null
  64. }
  65. }
  66. res.render('editor', { page })
  67. })
  68. /**
  69. * Administration
  70. */
  71. router.get(['/a', '/a/*'], (req, res, next) => {
  72. _.set(res.locals, 'pageMeta.title', 'Admin')
  73. res.render('admin')
  74. })
  75. /**
  76. * Profile
  77. */
  78. router.get(['/p', '/p/*'], (req, res, next) => {
  79. _.set(res.locals, 'pageMeta.title', 'User Profile')
  80. res.render('profile')
  81. })
  82. /**
  83. * History
  84. */
  85. router.get(['/h', '/h/*'], async (req, res, next) => {
  86. const pageArgs = pageHelper.parsePath(req.path, { stripExt: true })
  87. _.set(res, 'locals.siteConfig.lang', pageArgs.locale)
  88. if (!WIKI.auth.checkAccess(req.user, ['read:pages'], pageArgs)) {
  89. _.set(res.locals, 'pageMeta.title', 'Unauthorized')
  90. return res.render('unauthorized', { action: 'history' })
  91. }
  92. const page = await WIKI.models.pages.getPageFromDb({
  93. path: pageArgs.path,
  94. locale: pageArgs.locale,
  95. userId: req.user.id,
  96. isPrivate: false
  97. })
  98. if (page) {
  99. _.set(res.locals, 'pageMeta.title', page.title)
  100. _.set(res.locals, 'pageMeta.description', page.description)
  101. res.render('history', { page })
  102. } else {
  103. res.redirect(`/${pageArgs.path}`)
  104. }
  105. })
  106. /**
  107. * Source
  108. */
  109. router.get(['/s', '/s/*'], async (req, res, next) => {
  110. const pageArgs = pageHelper.parsePath(req.path, { stripExt: true })
  111. _.set(res, 'locals.siteConfig.lang', pageArgs.locale)
  112. if (!WIKI.auth.checkAccess(req.user, ['read:pages'], pageArgs)) {
  113. return res.render('unauthorized', { action: 'source' })
  114. }
  115. const page = await WIKI.models.pages.getPageFromDb({
  116. path: pageArgs.path,
  117. locale: pageArgs.locale,
  118. userId: req.user.id,
  119. isPrivate: false
  120. })
  121. if (page) {
  122. _.set(res.locals, 'pageMeta.title', page.title)
  123. _.set(res.locals, 'pageMeta.description', page.description)
  124. res.render('source', { page })
  125. } else {
  126. res.redirect(`/${pageArgs.path}`)
  127. }
  128. })
  129. /**
  130. * View document / asset
  131. */
  132. router.get('/*', async (req, res, next) => {
  133. const stripExt = _.some(WIKI.data.pageExtensions, ext => _.endsWith(req.path, `.${ext}`))
  134. const pageArgs = pageHelper.parsePath(req.path, { stripExt })
  135. const isPage = (stripExt || pageArgs.path.indexOf('.') === -1)
  136. if (isPage) {
  137. if (!WIKI.auth.checkAccess(req.user, ['read:pages'], pageArgs)) {
  138. _.set(res.locals, 'pageMeta.title', 'Unauthorized')
  139. return res.status(403).render('unauthorized', { action: 'view' })
  140. }
  141. try {
  142. const page = await WIKI.models.pages.getPage({
  143. path: pageArgs.path,
  144. locale: pageArgs.locale,
  145. userId: req.user.id,
  146. isPrivate: false
  147. })
  148. _.set(res, 'locals.siteConfig.lang', pageArgs.locale)
  149. if (page) {
  150. _.set(res.locals, 'pageMeta.title', page.title)
  151. _.set(res.locals, 'pageMeta.description', page.description)
  152. const sidebar = await WIKI.models.navigation.getTree({ cache: true })
  153. const injectCode = {
  154. css: WIKI.config.theming.injectCSS,
  155. head: WIKI.config.theming.injectHead,
  156. body: WIKI.config.theming.injectBody
  157. }
  158. res.render('page', { page, sidebar, injectCode })
  159. } else if (pageArgs.path === 'home') {
  160. _.set(res.locals, 'pageMeta.title', 'Welcome')
  161. res.render('welcome')
  162. } else {
  163. _.set(res.locals, 'pageMeta.title', 'Page Not Found')
  164. if (WIKI.auth.checkAccess(req.user, ['write:pages'], pageArgs)) {
  165. res.status(404).render('new', { pagePath: req.path })
  166. } else {
  167. res.status(404).render('notfound', { action: 'view' })
  168. }
  169. }
  170. } catch (err) {
  171. next(err)
  172. }
  173. } else {
  174. if (!WIKI.auth.checkAccess(req.user, ['read:assets'], pageArgs)) {
  175. return res.sendStatus(403)
  176. }
  177. await WIKI.models.assets.getAsset(pageArgs.path, res)
  178. }
  179. })
  180. module.exports = router