AdminLocalSecurityContainer.js 3.5 KB

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