site.js 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121
  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. ...WIKI.config.seo,
  20. ...WIKI.config.features,
  21. ...WIKI.config.security,
  22. authAutoLogin: WIKI.config.auth.autoLogin,
  23. authEnforce2FA: WIKI.config.auth.enforce2FA,
  24. authHideLocal: WIKI.config.auth.hideLocal,
  25. authLoginBgUrl: WIKI.config.auth.loginBgUrl,
  26. authJwtAudience: WIKI.config.auth.audience,
  27. authJwtExpiration: WIKI.config.auth.tokenExpiration,
  28. authJwtRenewablePeriod: WIKI.config.auth.tokenRenewal,
  29. uploadMaxFileSize: WIKI.config.uploads.maxFileSize,
  30. uploadMaxFiles: WIKI.config.uploads.maxFiles,
  31. uploadScanSVG: WIKI.config.uploads.scanSVG
  32. }
  33. }
  34. },
  35. SiteMutation: {
  36. async updateConfig(obj, args, context) {
  37. try {
  38. if (args.host) {
  39. let siteHost = _.trim(args.host)
  40. if (siteHost.endsWith('/')) {
  41. siteHost = siteHost.slice(0, -1)
  42. }
  43. WIKI.config.host = siteHost
  44. }
  45. if (args.title) {
  46. WIKI.config.title = _.trim(args.title)
  47. }
  48. if (args.company) {
  49. WIKI.config.company = _.trim(args.company)
  50. }
  51. if (args.contentLicense) {
  52. WIKI.config.contentLicense = args.contentLicense
  53. }
  54. if (args.logoUrl) {
  55. WIKI.config.logoUrl = _.trim(args.logoUrl)
  56. }
  57. WIKI.config.seo = {
  58. description: _.get(args, 'description', WIKI.config.seo.description),
  59. robots: _.get(args, 'robots', WIKI.config.seo.robots),
  60. analyticsService: _.get(args, 'analyticsService', WIKI.config.seo.analyticsService),
  61. analyticsId: _.get(args, 'analyticsId', WIKI.config.seo.analyticsId)
  62. }
  63. WIKI.config.auth = {
  64. autoLogin: _.get(args, 'authAutoLogin', WIKI.config.auth.autoLogin),
  65. enforce2FA: _.get(args, 'authEnforce2FA', WIKI.config.auth.enforce2FA),
  66. hideLocal: _.get(args, 'authHideLocal', WIKI.config.auth.hideLocal),
  67. loginBgUrl: _.get(args, 'authLoginBgUrl', WIKI.config.auth.loginBgUrl),
  68. audience: _.get(args, 'authJwtAudience', WIKI.config.auth.audience),
  69. tokenExpiration: _.get(args, 'authJwtExpiration', WIKI.config.auth.tokenExpiration),
  70. tokenRenewal: _.get(args, 'authJwtRenewablePeriod', WIKI.config.auth.tokenRenewal)
  71. }
  72. WIKI.config.features = {
  73. featurePageRatings: _.get(args, 'featurePageRatings', WIKI.config.features.featurePageRatings),
  74. featurePageComments: _.get(args, 'featurePageComments', WIKI.config.features.featurePageComments),
  75. featurePersonalWikis: _.get(args, 'featurePersonalWikis', WIKI.config.features.featurePersonalWikis)
  76. }
  77. WIKI.config.security = {
  78. securityOpenRedirect: _.get(args, 'securityOpenRedirect', WIKI.config.security.securityOpenRedirect),
  79. securityIframe: _.get(args, 'securityIframe', WIKI.config.security.securityIframe),
  80. securityReferrerPolicy: _.get(args, 'securityReferrerPolicy', WIKI.config.security.securityReferrerPolicy),
  81. securityTrustProxy: _.get(args, 'securityTrustProxy', WIKI.config.security.securityTrustProxy),
  82. securitySRI: _.get(args, 'securitySRI', WIKI.config.security.securitySRI),
  83. securityHSTS: _.get(args, 'securityHSTS', WIKI.config.security.securityHSTS),
  84. securityHSTSDuration: _.get(args, 'securityHSTSDuration', WIKI.config.security.securityHSTSDuration),
  85. securityCSP: _.get(args, 'securityCSP', WIKI.config.security.securityCSP),
  86. securityCSPDirectives: _.get(args, 'securityCSPDirectives', WIKI.config.security.securityCSPDirectives)
  87. }
  88. WIKI.config.uploads = {
  89. maxFileSize: _.get(args, 'uploadMaxFileSize', WIKI.config.uploads.maxFileSize),
  90. maxFiles: _.get(args, 'uploadMaxFiles', WIKI.config.uploads.maxFiles),
  91. scanSVG: _.get(args, 'uploadScanSVG', WIKI.config.uploads.scanSVG)
  92. }
  93. await WIKI.configSvc.saveToDb(['host', 'title', 'company', 'contentLicense', 'seo', 'logoUrl', 'auth', 'features', 'security', 'uploads'])
  94. if (WIKI.config.security.securityTrustProxy) {
  95. WIKI.app.enable('trust proxy')
  96. } else {
  97. WIKI.app.disable('trust proxy')
  98. }
  99. return {
  100. responseResult: graphHelper.generateSuccess('Site configuration updated successfully')
  101. }
  102. } catch (err) {
  103. return graphHelper.generateError(err)
  104. }
  105. }
  106. }
  107. }