site.js 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  1. const graphHelper = require('../../helpers/graph')
  2. const _ = require('lodash')
  3. /* global WIKI */
  4. module.exports = {
  5. Query: {
  6. async site() { return {} }
  7. },
  8. Mutation: {
  9. async site() { return {} }
  10. },
  11. SiteQuery: {
  12. async config(obj, args, context, info) {
  13. return {
  14. host: WIKI.config.host,
  15. title: WIKI.config.title,
  16. company: WIKI.config.company,
  17. contentLicense: WIKI.config.contentLicense,
  18. logoUrl: WIKI.config.logoUrl,
  19. pageExtensions: WIKI.config.pageExtensions.join(', '),
  20. ...WIKI.config.seo,
  21. ...WIKI.config.features,
  22. ...WIKI.config.security,
  23. authAutoLogin: WIKI.config.auth.autoLogin,
  24. authEnforce2FA: WIKI.config.auth.enforce2FA,
  25. authHideLocal: WIKI.config.auth.hideLocal,
  26. authLoginBgUrl: WIKI.config.auth.loginBgUrl,
  27. authJwtAudience: WIKI.config.auth.audience,
  28. authJwtExpiration: WIKI.config.auth.tokenExpiration,
  29. authJwtRenewablePeriod: WIKI.config.auth.tokenRenewal,
  30. uploadMaxFileSize: WIKI.config.uploads.maxFileSize,
  31. uploadMaxFiles: WIKI.config.uploads.maxFiles,
  32. uploadScanSVG: WIKI.config.uploads.scanSVG,
  33. uploadForceDownload: WIKI.config.uploads.forceDownload
  34. }
  35. }
  36. },
  37. SiteMutation: {
  38. async updateConfig(obj, args, context) {
  39. try {
  40. if (args.hasOwnProperty('host')) {
  41. let siteHost = _.trim(args.host)
  42. if (siteHost.endsWith('/')) {
  43. siteHost = siteHost.slice(0, -1)
  44. }
  45. WIKI.config.host = siteHost
  46. }
  47. if (args.hasOwnProperty('title')) {
  48. WIKI.config.title = _.trim(args.title)
  49. }
  50. if (args.hasOwnProperty('company')) {
  51. WIKI.config.company = _.trim(args.company)
  52. }
  53. if (args.hasOwnProperty('contentLicense')) {
  54. WIKI.config.contentLicense = args.contentLicense
  55. }
  56. if (args.hasOwnProperty('logoUrl')) {
  57. WIKI.config.logoUrl = _.trim(args.logoUrl)
  58. }
  59. if (args.hasOwnProperty('pageExtensions')) {
  60. WIKI.config.pageExtensions = _.trim(args.pageExtensions).split(',').map(p => p.trim().toLowerCase()).filter(p => p !== '')
  61. }
  62. WIKI.config.seo = {
  63. description: _.get(args, 'description', WIKI.config.seo.description),
  64. robots: _.get(args, 'robots', WIKI.config.seo.robots),
  65. analyticsService: _.get(args, 'analyticsService', WIKI.config.seo.analyticsService),
  66. analyticsId: _.get(args, 'analyticsId', WIKI.config.seo.analyticsId)
  67. }
  68. WIKI.config.auth = {
  69. autoLogin: _.get(args, 'authAutoLogin', WIKI.config.auth.autoLogin),
  70. enforce2FA: _.get(args, 'authEnforce2FA', WIKI.config.auth.enforce2FA),
  71. hideLocal: _.get(args, 'authHideLocal', WIKI.config.auth.hideLocal),
  72. loginBgUrl: _.get(args, 'authLoginBgUrl', WIKI.config.auth.loginBgUrl),
  73. audience: _.get(args, 'authJwtAudience', WIKI.config.auth.audience),
  74. tokenExpiration: _.get(args, 'authJwtExpiration', WIKI.config.auth.tokenExpiration),
  75. tokenRenewal: _.get(args, 'authJwtRenewablePeriod', WIKI.config.auth.tokenRenewal)
  76. }
  77. WIKI.config.features = {
  78. featurePageRatings: _.get(args, 'featurePageRatings', WIKI.config.features.featurePageRatings),
  79. featurePageComments: _.get(args, 'featurePageComments', WIKI.config.features.featurePageComments),
  80. featurePersonalWikis: _.get(args, 'featurePersonalWikis', WIKI.config.features.featurePersonalWikis)
  81. }
  82. WIKI.config.security = {
  83. securityOpenRedirect: _.get(args, 'securityOpenRedirect', WIKI.config.security.securityOpenRedirect),
  84. securityIframe: _.get(args, 'securityIframe', WIKI.config.security.securityIframe),
  85. securityReferrerPolicy: _.get(args, 'securityReferrerPolicy', WIKI.config.security.securityReferrerPolicy),
  86. securityTrustProxy: _.get(args, 'securityTrustProxy', WIKI.config.security.securityTrustProxy),
  87. securitySRI: _.get(args, 'securitySRI', WIKI.config.security.securitySRI),
  88. securityHSTS: _.get(args, 'securityHSTS', WIKI.config.security.securityHSTS),
  89. securityHSTSDuration: _.get(args, 'securityHSTSDuration', WIKI.config.security.securityHSTSDuration),
  90. securityCSP: _.get(args, 'securityCSP', WIKI.config.security.securityCSP),
  91. securityCSPDirectives: _.get(args, 'securityCSPDirectives', WIKI.config.security.securityCSPDirectives)
  92. }
  93. WIKI.config.uploads = {
  94. maxFileSize: _.get(args, 'uploadMaxFileSize', WIKI.config.uploads.maxFileSize),
  95. maxFiles: _.get(args, 'uploadMaxFiles', WIKI.config.uploads.maxFiles),
  96. scanSVG: _.get(args, 'uploadScanSVG', WIKI.config.uploads.scanSVG),
  97. forceDownload: _.get(args, 'uploadForceDownload', WIKI.config.uploads.forceDownload)
  98. }
  99. await WIKI.configSvc.saveToDb(['host', 'title', 'company', 'contentLicense', 'seo', 'logoUrl', 'pageExtensions', 'auth', 'features', 'security', 'uploads'])
  100. if (WIKI.config.security.securityTrustProxy) {
  101. WIKI.app.enable('trust proxy')
  102. } else {
  103. WIKI.app.disable('trust proxy')
  104. }
  105. return {
  106. responseResult: graphHelper.generateSuccess('Site configuration updated successfully')
  107. }
  108. } catch (err) {
  109. return graphHelper.generateError(err)
  110. }
  111. }
  112. }
  113. }