page.js 8.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337
  1. const _ = require('lodash')
  2. const graphHelper = require('../../helpers/graph')
  3. /* global WIKI */
  4. module.exports = {
  5. Query: {
  6. async pages() { return {} }
  7. },
  8. Mutation: {
  9. async pages() { return {} }
  10. },
  11. PageQuery: {
  12. /**
  13. * PAGE HISTORY
  14. */
  15. async history(obj, args, context, info) {
  16. return WIKI.models.pageHistory.getHistory({
  17. pageId: args.id,
  18. offsetPage: args.offsetPage || 0,
  19. offsetSize: args.offsetSize || 100
  20. })
  21. },
  22. /**
  23. * SEARCH PAGES
  24. */
  25. async search (obj, args, context) {
  26. if (WIKI.data.searchEngine) {
  27. const resp = await WIKI.data.searchEngine.query(args.query, args)
  28. return {
  29. ...resp,
  30. results: _.filter(resp.results, r => {
  31. return WIKI.auth.checkAccess(context.req.user, ['read:pages'], {
  32. path: r.path,
  33. locale: r.locale
  34. })
  35. })
  36. }
  37. } else {
  38. return {
  39. results: [],
  40. suggestions: [],
  41. totalHits: 0
  42. }
  43. }
  44. },
  45. /**
  46. * LIST PAGES
  47. */
  48. async list (obj, args, context, info) {
  49. let results = await WIKI.models.pages.query().column([
  50. 'pages.id',
  51. 'path',
  52. { locale: 'localeCode' },
  53. 'title',
  54. 'description',
  55. 'isPublished',
  56. 'isPrivate',
  57. 'privateNS',
  58. 'contentType',
  59. 'createdAt',
  60. 'updatedAt'
  61. ])
  62. .withGraphJoined('tags')
  63. .modifyGraph('tags', builder => {
  64. builder.select('tag')
  65. })
  66. .modify(queryBuilder => {
  67. if (args.limit) {
  68. queryBuilder.limit(args.limit)
  69. }
  70. if (args.locale) {
  71. queryBuilder.where('localeCode', args.locale)
  72. }
  73. if (args.tags && args.tags.length > 0) {
  74. queryBuilder.whereIn('tags.tag', args.tags)
  75. }
  76. const orderDir = args.orderByDirection === 'DESC' ? 'desc' : 'asc'
  77. switch (args.orderBy) {
  78. case 'CREATED':
  79. queryBuilder.orderBy('createdAt', orderDir)
  80. break
  81. case 'PATH':
  82. queryBuilder.orderBy('path', orderDir)
  83. break
  84. case 'TITLE':
  85. queryBuilder.orderBy('title', orderDir)
  86. break
  87. case 'UPDATED':
  88. queryBuilder.orderBy('updatedAt', orderDir)
  89. break
  90. default:
  91. queryBuilder.orderBy('pages.id', orderDir)
  92. break
  93. }
  94. })
  95. results = _.filter(results, r => {
  96. return WIKI.auth.checkAccess(context.req.user, ['read:pages'], {
  97. path: r.path,
  98. locale: r.locale
  99. })
  100. }).map(r => ({
  101. ...r,
  102. tags: _.map(r.tags, 'tag')
  103. }))
  104. if (args.tags && args.tags.length > 0) {
  105. results = _.filter(results, r => _.every(args.tags, t => _.includes(r.tags, t)))
  106. }
  107. return results
  108. },
  109. /**
  110. * FETCH SINGLE PAGE
  111. */
  112. async single (obj, args, context, info) {
  113. let page = await WIKI.models.pages.getPageFromDb(args.id)
  114. if (page) {
  115. return {
  116. ...page,
  117. locale: page.localeCode,
  118. editor: page.editorKey
  119. }
  120. } else {
  121. throw new WIKI.Error.PageNotFound()
  122. }
  123. },
  124. /**
  125. * FETCH TAGS
  126. */
  127. async tags (obj, args, context, info) {
  128. return WIKI.models.tags.query().orderBy('tag', 'asc')
  129. },
  130. /**
  131. * FETCH PAGE TREE
  132. */
  133. async tree (obj, args, context, info) {
  134. let results = []
  135. let conds = {
  136. localeCode: args.locale
  137. }
  138. if (args.parent) {
  139. conds.parent = (args.parent < 1) ? null : args.parent
  140. } else if (args.path) {
  141. // conds.parent = (args.parent < 1) ? null : args.parent
  142. }
  143. switch (args.mode) {
  144. case 'FOLDERS':
  145. conds.isFolder = true
  146. results = await WIKI.models.knex('pageTree').where(conds)
  147. break
  148. case 'PAGES':
  149. await WIKI.models.knex('pageTree').where(conds).andWhereNotNull('pageId')
  150. break
  151. default:
  152. results = await WIKI.models.knex('pageTree').where(conds)
  153. break
  154. }
  155. return results.filter(r => {
  156. return WIKI.auth.checkAccess(context.req.user, ['read:pages'], {
  157. path: r.path,
  158. locale: r.localeCode
  159. })
  160. }).map(r => ({
  161. ...r,
  162. parent: r.parent || 0,
  163. locale: r.localeCode
  164. }))
  165. },
  166. /**
  167. * FETCH PAGE LINKS
  168. */
  169. async links (obj, args, context, info) {
  170. let results = []
  171. results = await WIKI.models.knex('pages')
  172. .column({ id: 'pages.id' }, { path: 'pages.path' }, 'title', { link: 'pageLinks.path' }, { locale: 'pageLinks.localeCode' })
  173. .fullOuterJoin('pageLinks', 'pages.id', 'pageLinks.pageId')
  174. .where({
  175. 'pages.localeCode': args.locale
  176. })
  177. return _.reduce(results, (result, val) => {
  178. // -> Check if user has access to source and linked page
  179. if (
  180. !WIKI.auth.checkAccess(context.req.user, ['read:pages'], { path: val.path, locale: args.locale }) ||
  181. !WIKI.auth.checkAccess(context.req.user, ['read:pages'], { path: val.link, locale: val.locale })
  182. ) {
  183. return result
  184. }
  185. const existingEntry = _.findIndex(result, ['id', val.id])
  186. if (existingEntry >= 0) {
  187. if (val.link) {
  188. result[existingEntry].links.push(`${val.locale}/${val.link}`)
  189. }
  190. } else {
  191. result.push({
  192. id: val.id,
  193. title: val.title,
  194. path: `${args.locale}/${val.path}`,
  195. links: val.link ? [`${val.locale}/${val.link}`] : []
  196. })
  197. }
  198. return result
  199. }, [])
  200. }
  201. },
  202. PageMutation: {
  203. /**
  204. * CREATE PAGE
  205. */
  206. async create(obj, args, context) {
  207. try {
  208. const page = await WIKI.models.pages.createPage({
  209. ...args,
  210. user: context.req.user
  211. })
  212. return {
  213. responseResult: graphHelper.generateSuccess('Page created successfully.'),
  214. page
  215. }
  216. } catch (err) {
  217. return graphHelper.generateError(err)
  218. }
  219. },
  220. /**
  221. * UPDATE PAGE
  222. */
  223. async update(obj, args, context) {
  224. try {
  225. const page = await WIKI.models.pages.updatePage({
  226. ...args,
  227. user: context.req.user
  228. })
  229. return {
  230. responseResult: graphHelper.generateSuccess('Page has been updated.'),
  231. page
  232. }
  233. } catch (err) {
  234. return graphHelper.generateError(err)
  235. }
  236. },
  237. /**
  238. * MOVE PAGE
  239. */
  240. async move(obj, args, context) {
  241. try {
  242. await WIKI.models.pages.movePage({
  243. ...args,
  244. user: context.req.user
  245. })
  246. return {
  247. responseResult: graphHelper.generateSuccess('Page has been moved.')
  248. }
  249. } catch (err) {
  250. return graphHelper.generateError(err)
  251. }
  252. },
  253. /**
  254. * DELETE PAGE
  255. */
  256. async delete(obj, args, context) {
  257. try {
  258. await WIKI.models.pages.deletePage({
  259. ...args,
  260. user: context.req.user
  261. })
  262. return {
  263. responseResult: graphHelper.generateSuccess('Page has been deleted.')
  264. }
  265. } catch (err) {
  266. return graphHelper.generateError(err)
  267. }
  268. },
  269. /**
  270. * FLUSH PAGE CACHE
  271. */
  272. async flushCache(obj, args, context) {
  273. try {
  274. await WIKI.models.pages.flushCache()
  275. return {
  276. responseResult: graphHelper.generateSuccess('Pages Cache has been flushed successfully.')
  277. }
  278. } catch (err) {
  279. return graphHelper.generateError(err)
  280. }
  281. },
  282. /**
  283. * MIGRATE ALL PAGES FROM SOURCE LOCALE TO TARGET LOCALE
  284. */
  285. async migrateToLocale(obj, args, context) {
  286. try {
  287. const count = await WIKI.models.pages.migrateToLocale(args)
  288. return {
  289. responseResult: graphHelper.generateSuccess('Migrated content to target locale successfully.'),
  290. count
  291. }
  292. } catch (err) {
  293. return graphHelper.generateError(err)
  294. }
  295. },
  296. /**
  297. * REBUILD TREE
  298. */
  299. async rebuildTree(obj, args, context) {
  300. try {
  301. await WIKI.models.pages.rebuildTree()
  302. return {
  303. responseResult: graphHelper.generateSuccess('Page tree rebuilt successfully.')
  304. }
  305. } catch (err) {
  306. return graphHelper.generateError(err)
  307. }
  308. },
  309. /**
  310. * RENDER PAGE
  311. */
  312. async render (obj, args, context) {
  313. try {
  314. const page = await WIKI.models.pages.query().findById(args.id)
  315. if (!page) {
  316. throw new Error('Invalid Page Id')
  317. }
  318. await WIKI.models.pages.renderPage(page)
  319. return {
  320. responseResult: graphHelper.generateSuccess('Page rendered successfully.')
  321. }
  322. } catch (err) {
  323. return graphHelper.generateError(err)
  324. }
  325. }
  326. },
  327. Page: {
  328. // comments(pg) {
  329. // return pg.$relatedQuery('comments')
  330. // }
  331. }
  332. }