security.page.tsx 3.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  1. import { isClient } from '@growi/core';
  2. import {
  3. NextPage, GetServerSideProps, GetServerSidePropsContext,
  4. } from 'next';
  5. import { useTranslation } from 'next-i18next';
  6. import dynamic from 'next/dynamic';
  7. import { Container, Provider } from 'unstated';
  8. import AdminGeneralSecurityContainer from '~/client/services/AdminGeneralSecurityContainer';
  9. import AdminGitHubSecurityContainer from '~/client/services/AdminGitHubSecurityContainer';
  10. import AdminGoogleSecurityContainer from '~/client/services/AdminGoogleSecurityContainer';
  11. import AdminLdapSecurityContainer from '~/client/services/AdminLdapSecurityContainer';
  12. import AdminLocalSecurityContainer from '~/client/services/AdminLocalSecurityContainer';
  13. import AdminOidcSecurityContainer from '~/client/services/AdminOidcSecurityContainer';
  14. import AdminSamlSecurityContainer from '~/client/services/AdminSamlSecurityContainer';
  15. import AdminTwitterSecurityContainer from '~/client/services/AdminTwitterSecurityContainer';
  16. import { CrowiRequest } from '~/interfaces/crowi-request';
  17. import { CommonProps, useCustomTitle } from '~/pages/utils/commons';
  18. import { useCurrentUser, useIsMailerSetup, useSiteUrl } from '~/stores/context';
  19. import { retrieveServerSideProps } from '../../utils/admin-page-util';
  20. const AdminLayout = dynamic(() => import('~/components/Layout/AdminLayout'), { ssr: false });
  21. const SecurityManagement = dynamic(() => import('~/components/Admin/Security/SecurityManagement'), { ssr: false });
  22. type Props = CommonProps & {
  23. isMailerSetup: boolean,
  24. siteUrl: string,
  25. };
  26. const AdminSecuritySettingsPage: NextPage<Props> = (props) => {
  27. const { t } = useTranslation('admin');
  28. useCurrentUser(props.currentUser ?? null);
  29. useSiteUrl(props.siteUrl);
  30. useIsMailerSetup(props.isMailerSetup);
  31. const title = t('security_settings.security_settings');
  32. const adminSecurityContainers: Container<any>[] = [];
  33. if (isClient()) {
  34. const adminSecuritySettingElem = document.getElementById('admin-security-setting');
  35. if (adminSecuritySettingElem != null) {
  36. const adminGeneralSecurityContainer = new AdminGeneralSecurityContainer();
  37. const adminLocalSecurityContainer = new AdminLocalSecurityContainer();
  38. const adminLdapSecurityContainer = new AdminLdapSecurityContainer();
  39. const adminSamlSecurityContainer = new AdminSamlSecurityContainer();
  40. const adminOidcSecurityContainer = new AdminOidcSecurityContainer();
  41. const adminGoogleSecurityContainer = new AdminGoogleSecurityContainer();
  42. const adminGitHubSecurityContainer = new AdminGitHubSecurityContainer();
  43. const adminTwitterSecurityContainer = new AdminTwitterSecurityContainer();
  44. adminSecurityContainers.push(
  45. adminGeneralSecurityContainer,
  46. adminLocalSecurityContainer,
  47. adminLdapSecurityContainer,
  48. adminSamlSecurityContainer,
  49. adminOidcSecurityContainer,
  50. adminGoogleSecurityContainer,
  51. adminGitHubSecurityContainer,
  52. adminTwitterSecurityContainer,
  53. );
  54. }
  55. }
  56. return (
  57. <Provider inject={[...adminSecurityContainers]}>
  58. <AdminLayout title={useCustomTitle(props, title)} componentTitle={title} >
  59. <SecurityManagement />
  60. </AdminLayout>
  61. </Provider>
  62. );
  63. };
  64. const injectServerConfigurations = async(context: GetServerSidePropsContext, props: Props): Promise<void> => {
  65. const req: CrowiRequest = context.req as CrowiRequest;
  66. const { crowi } = req;
  67. const { appService, mailService } = crowi;
  68. props.siteUrl = appService.getSiteUrl();
  69. props.isMailerSetup = mailService.isMailerSetup;
  70. };
  71. export const getServerSideProps: GetServerSideProps = async(context: GetServerSidePropsContext) => {
  72. const props = await retrieveServerSideProps(context, injectServerConfigurations);
  73. return props;
  74. };
  75. export default AdminSecuritySettingsPage;