import {Fragment, useEffect, useState} from 'react'; import {addErrorMessage} from 'sentry/actionCreators/indicator'; import {updateOrganization} from 'sentry/actionCreators/organizations'; import Form from 'sentry/components/forms/form'; import JsonForm from 'sentry/components/forms/jsonForm'; import SentryDocumentTitle from 'sentry/components/sentryDocumentTitle'; import organizationSecurityAndPrivacyGroups from 'sentry/data/forms/organizationSecurityAndPrivacyGroups'; import {t} from 'sentry/locale'; import {Organization} from 'sentry/types'; import useApi from 'sentry/utils/useApi'; import useOrganization from 'sentry/utils/useOrganization'; import SettingsPageHeader from 'sentry/views/settings/components/settingsPageHeader'; import {DataScrubbing} from '../components/dataScrubbing'; export default function OrganizationSecurityAndPrivacyContent() { const api = useApi(); const organization = useOrganization(); const [authProvider, setAuthProvider] = useState(null); useEffect(() => { async function fetchAuthProvider() { try { const response = await api.requestPromise( `/organizations/${organization.slug}/auth-provider/` ); setAuthProvider(response); } catch { addErrorMessage(t('Unable to fetch authentication provider')); } } fetchAuthProvider(); }, [organization.slug, api]); const initialData = organization; const endpoint = `/organizations/${organization.slug}/`; const access = new Set(organization.access); const features = new Set(organization.features); const relayPiiConfig = organization.relayPiiConfig; const title = t('Security & Privacy'); function handleUpdateOrganization(data: Organization) { // This will update OrganizationStore (as well as OrganizationsStore // which is slightly incorrect because it has summaries vs a detailed org) updateOrganization(data); } return (
addErrorMessage(t('Unable to save change'))} saveOnBlur allowUndo > handleUpdateOrganization({...organization, ...data})} />
); }