/* eslint-disable react/no-danger */ import React from 'react'; import PropTypes from 'prop-types'; import { withTranslation } from 'react-i18next'; import { withUnstatedContainers } from '../../UnstatedUtils'; import { toastSuccess, toastError } from '~/client/util/apiNotification'; import { PageDeleteConfigValue } from '~/interfaces/page-delete-config'; import AppContainer from '~/client/services/AppContainer'; import AdminGeneralSecurityContainer from '~/client/services/AdminGeneralSecurityContainer'; // used as the prefix of translation const DeletionType = Object.freeze({ Deletion: 'deletion', CompleteDeletion: 'complete_deletion', RecursiveDeletion: 'recursive_deletion', RecursiveCompleteDeletion: 'recursive_complete_deletion', }); class SecuritySetting extends React.Component { constructor(props) { super(props); this.putSecuritySetting = this.putSecuritySetting.bind(this); this.renderPageDeletePermissionDropdown = this.renderPageDeletePermissionDropdown.bind(this); } async putSecuritySetting() { const { t, adminGeneralSecurityContainer } = this.props; try { await adminGeneralSecurityContainer.updateGeneralSecuritySetting(); toastSuccess(t('security_setting.updated_general_security_setting')); } catch (err) { toastError(err); } } renderPageDeletePermissionDropdown(currentState, setState, deletionType, t) { const isRecursiveDeletion = deletionType === DeletionType.RecursiveDeletion || deletionType === DeletionType.RecursiveCompleteDeletion; return (
{t(`security_setting.${deletionType}`)}
{ isRecursiveDeletion ? ( ) : ( ) }

{t(`security_setting.${deletionType}_explain`)}

); } render() { const { t, adminGeneralSecurityContainer } = this.props; const { currentRestrictGuestMode, currentPageDeletionAuthority, currentPageCompleteDeletionAuthority, currentPageRecursiveDeletionAuthority, currentPageRecursiveCompleteDeletionAuthority, } = adminGeneralSecurityContainer.state; return (

{t('security_settings')}

{adminGeneralSecurityContainer.retrieveError != null && (

{t('Error occurred')} : {adminGeneralSecurityContainer.retrieveError}

)}

{ t('security_setting.page_list_and_search_results') }

{ t('scope_of_page_disclosure') } { t('set_point') }
{ t('Public') } { t('always_displayed') }
{ t('Anyone with the link') } { t('always_hidden') }
{ t('Only me') }
{ adminGeneralSecurityContainer.switchIsShowRestrictedByOwner() }} />
{ t('Only inside the group') }
{ adminGeneralSecurityContainer.switchIsShowRestrictedByGroup() }} />

{t('security_setting.page_access_and_delete_rights')}

{t('security_setting.Guest Users Access')}
{adminGeneralSecurityContainer.isWikiModeForced && (

FIXED

)}
{/* Render PageDeletePermissionDropdown */} { [ [currentPageDeletionAuthority, adminGeneralSecurityContainer.changePageDeletionAuthority, DeletionType.Deletion], [currentPageCompleteDeletionAuthority, adminGeneralSecurityContainer.changePageCompleteDeletionAuthority, DeletionType.CompleteDeletion], [currentPageRecursiveDeletionAuthority, adminGeneralSecurityContainer.changePageRecursiveDeletionAuthority, DeletionType.RecursiveDeletion], // eslint-disable-next-line max-len [currentPageRecursiveCompleteDeletionAuthority, adminGeneralSecurityContainer.changePageRecursiveCompleteDeletionAuthority, DeletionType.RecursiveCompleteDeletion], ].map(arr => this.renderPageDeletePermissionDropdown(arr[0], arr[1], arr[2], t)) }

{t('security_setting.session')}

{ adminGeneralSecurityContainer.setSessionMaxAge(e.target.value); }} placeholder="2592000000" /> {/* eslint-disable-next-line react/no-danger */}

{t('security_setting.max_age_caution')}

); } } SecuritySetting.propTypes = { t: PropTypes.func.isRequired, // i18next appContainer: PropTypes.instanceOf(AppContainer).isRequired, csrf: PropTypes.string, adminGeneralSecurityContainer: PropTypes.instanceOf(AdminGeneralSecurityContainer).isRequired, }; const SecuritySettingWrapper = withUnstatedContainers(SecuritySetting, [AppContainer, AdminGeneralSecurityContainer]); export default withTranslation()(SecuritySettingWrapper);