AdminLocalSecurityContainer.js 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120
  1. import { isServer } from '@growi/core/dist/utils';
  2. import { Container } from 'unstated';
  3. import loggerFactory from '~/utils/logger';
  4. import { apiv3Get, apiv3Put } from '../util/apiv3-client';
  5. // eslint-disable-next-line no-unused-vars
  6. const logger = loggerFactory('growi:services:AdminLocalSecurityContainer');
  7. /**
  8. * Service container for admin security page (LocalSecuritySetting.jsx)
  9. * @extends {Container} unstated Container
  10. */
  11. export default class AdminLocalSecurityContainer extends Container {
  12. constructor(appContainer) {
  13. super();
  14. if (isServer()) {
  15. return;
  16. }
  17. this.appContainer = appContainer;
  18. this.dummyRegistrationMode = 0;
  19. this.dummyRegistrationModeForError = 1;
  20. this.state = {
  21. retrieveError: null,
  22. // set dummy value tile for using suspense
  23. registrationMode: this.dummyRegistrationMode,
  24. registrationWhitelist: [],
  25. useOnlyEnvVars: false,
  26. isPasswordResetEnabled: false,
  27. isEmailAuthenticationEnabled: false,
  28. };
  29. }
  30. async retrieveSecurityData() {
  31. try {
  32. const response = await apiv3Get('/security-setting/');
  33. const { localSetting } = response.data.securityParams;
  34. this.setState({
  35. useOnlyEnvVars: localSetting.useOnlyEnvVarsForSomeOptions,
  36. registrationMode: localSetting.registrationMode,
  37. registrationWhitelist: localSetting.registrationWhitelist,
  38. isPasswordResetEnabled: localSetting.isPasswordResetEnabled,
  39. isEmailAuthenticationEnabled: localSetting.isEmailAuthenticationEnabled,
  40. });
  41. }
  42. catch (err) {
  43. this.setState({ retrieveError: err });
  44. logger.error(err);
  45. throw new Error('Failed to fetch data');
  46. }
  47. }
  48. /**
  49. * Workaround for the mangling in production build to break constructor.name
  50. */
  51. static getClassName() {
  52. return 'AdminLocalSecurityContainer';
  53. }
  54. /**
  55. * Change registration mode
  56. */
  57. changeRegistrationMode(value) {
  58. this.setState({ registrationMode: value });
  59. }
  60. /**
  61. * Change registration whitelist
  62. */
  63. changeRegistrationWhitelist(value) {
  64. this.setState({ registrationWhitelist: value.split('\n') });
  65. }
  66. /**
  67. * Switch password reset enabled
  68. */
  69. switchIsPasswordResetEnabled() {
  70. this.setState({ isPasswordResetEnabled: !this.state.isPasswordResetEnabled });
  71. }
  72. /**
  73. * Switch email authentication enabled
  74. */
  75. switchIsEmailAuthenticationEnabled() {
  76. this.setState({ isEmailAuthenticationEnabled: !this.state.isEmailAuthenticationEnabled });
  77. }
  78. /**
  79. * update local security setting
  80. */
  81. async updateLocalSecuritySetting() {
  82. const { registrationWhitelist, isPasswordResetEnabled, isEmailAuthenticationEnabled } = this.state;
  83. const response = await apiv3Put('/security-setting/local-setting', {
  84. registrationMode: this.state.registrationMode,
  85. registrationWhitelist,
  86. isPasswordResetEnabled,
  87. isEmailAuthenticationEnabled,
  88. });
  89. const { localSettingParams } = response.data;
  90. this.setState({
  91. registrationMode: localSettingParams.registrationMode,
  92. registrationWhitelist: localSettingParams.registrationWhitelist,
  93. isPasswordResetEnabled: localSettingParams.isPasswordResetEnabled,
  94. isEmailAuthenticationEnabled: localSettingParams.isEmailAuthenticationEnabled,
  95. });
  96. return localSettingParams;
  97. }
  98. }