You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

123 lines
5.0 KiB

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