Add EULA config

Signed-off-by: Šimon Brandner <simon.bra.ag@gmail.com>
This commit is contained in:
Šimon Brandner 2023-07-06 08:53:57 +02:00
parent 0646f327df
commit e52b3e6d53
No known key found for this signature in database
GPG key ID: D1D45825D60C24D2
7 changed files with 24 additions and 17 deletions

View file

@ -4,5 +4,6 @@
"base_url": "https://call.ems.host", "base_url": "https://call.ems.host",
"server_name": "call.ems.host" "server_name": "call.ems.host"
} }
} },
"eula": "https://static.element.io/legal/online-EULA.pdf"
} }

View file

@ -54,8 +54,7 @@ export const RegisterPage: FC = () => {
const [error, setError] = useState<Error>(); const [error, setError] = useState<Error>();
const [password, setPassword] = useState(""); const [password, setPassword] = useState("");
const [passwordConfirmation, setPasswordConfirmation] = useState(""); const [passwordConfirmation, setPasswordConfirmation] = useState("");
const [privacyPolicyUrl, recaptchaKey, register] = const { recaptchaKey, register } = useInteractiveRegistration();
useInteractiveRegistration();
const { execute, reset, recaptchaId } = useRecaptcha(recaptchaKey); const { execute, reset, recaptchaId } = useRecaptcha(recaptchaKey);
const onSubmitRegisterForm = useCallback( const onSubmitRegisterForm = useCallback(
@ -211,7 +210,7 @@ export const RegisterPage: FC = () => {
apply. apply.
<br /> <br />
By clicking "Register", you agree to our{" "} By clicking "Register", you agree to our{" "}
<Link href={privacyPolicyUrl}> <Link href={Config.get().eula}>
End User Licensing Agreement (EULA) End User Licensing Agreement (EULA)
</Link> </Link>
</Trans> </Trans>

View file

@ -22,17 +22,17 @@ import { initClient } from "../matrix-utils";
import { Session } from "../ClientContext"; import { Session } from "../ClientContext";
import { Config } from "../config/Config"; import { Config } from "../config/Config";
export const useInteractiveRegistration = (): [ export const useInteractiveRegistration = (): {
string, privacyPolicyUrl: string;
string, recaptchaKey: string;
( register: (
username: string, username: string,
password: string, password: string,
displayName: string, displayName: string,
recaptchaResponse: string, recaptchaResponse: string,
passwordlessUser?: boolean passwordlessUser?: boolean
) => Promise<[MatrixClient, Session]> ) => Promise<[MatrixClient, Session]>;
] => { } => {
const [privacyPolicyUrl, setPrivacyPolicyUrl] = useState<string>(); const [privacyPolicyUrl, setPrivacyPolicyUrl] = useState<string>();
const [recaptchaKey, setRecaptchaKey] = useState<string>(); const [recaptchaKey, setRecaptchaKey] = useState<string>();
@ -126,5 +126,5 @@ export const useInteractiveRegistration = (): [
[] []
); );
return [privacyPolicyUrl, recaptchaKey, register]; return { privacyPolicyUrl, recaptchaKey, register };
}; };

View file

@ -30,7 +30,7 @@ interface UseRegisterPasswordlessUserType {
export function useRegisterPasswordlessUser(): UseRegisterPasswordlessUserType { export function useRegisterPasswordlessUser(): UseRegisterPasswordlessUserType {
const { setClient } = useClient(); const { setClient } = useClient();
const [privacyPolicyUrl, recaptchaKey, register] = const { privacyPolicyUrl, recaptchaKey, register } =
useInteractiveRegistration(); useInteractiveRegistration();
const { execute, reset, recaptchaId } = useRecaptcha(recaptchaKey); const { execute, reset, recaptchaId } = useRecaptcha(recaptchaKey);

View file

@ -66,6 +66,11 @@ export interface ConfigOptions {
features?: { features?: {
feature_group_calls_without_video_and_audio: boolean; feature_group_calls_without_video_and_audio: boolean;
}; };
/**
* A link to the end-user license agreement (EULA)
*/
eula: string;
} }
// Overrides members from ConfigOptions that are always provided by the // Overrides members from ConfigOptions that are always provided by the
@ -86,4 +91,5 @@ export const DEFAULT_CONFIG: ResolvedConfigOptions = {
server_name: "localhost", server_name: "localhost",
}, },
}, },
eula: "https://static.element.io/legal/online-EULA.pdf",
}; };

View file

@ -41,6 +41,7 @@ import commonStyles from "./common.module.css";
import { generateRandomName } from "../auth/generateRandomName"; import { generateRandomName } from "../auth/generateRandomName";
import { AnalyticsNotice } from "../analytics/AnalyticsNotice"; import { AnalyticsNotice } from "../analytics/AnalyticsNotice";
import { useOptInAnalytics } from "../settings/useSetting"; import { useOptInAnalytics } from "../settings/useSetting";
import { Config } from "../config/Config";
export const UnauthenticatedView: FC = () => { export const UnauthenticatedView: FC = () => {
const { setClient } = useClient(); const { setClient } = useClient();
@ -48,8 +49,7 @@ export const UnauthenticatedView: FC = () => {
const [loading, setLoading] = useState(false); const [loading, setLoading] = useState(false);
const [error, setError] = useState<Error>(); const [error, setError] = useState<Error>();
const [optInAnalytics] = useOptInAnalytics(); const [optInAnalytics] = useOptInAnalytics();
const [privacyPolicyUrl, recaptchaKey, register] = const { recaptchaKey, register } = useInteractiveRegistration();
useInteractiveRegistration();
const { execute, reset, recaptchaId } = useRecaptcha(recaptchaKey); const { execute, reset, recaptchaId } = useRecaptcha(recaptchaKey);
const { modalState, modalProps } = useModalTriggerState(); const { modalState, modalProps } = useModalTriggerState();
@ -165,7 +165,7 @@ export const UnauthenticatedView: FC = () => {
<Caption className={styles.notice}> <Caption className={styles.notice}>
<Trans> <Trans>
By clicking "Go", you agree to our{" "} By clicking "Go", you agree to our{" "}
<Link href={privacyPolicyUrl}> <Link href={Config.get().eula}>
End User Licensing Agreement (EULA) End User Licensing Agreement (EULA)
</Link> </Link>
</Trans> </Trans>

View file

@ -26,12 +26,13 @@ import { FieldRow, InputField, ErrorMessage } from "../input/Input";
import { Form } from "../form/Form"; import { Form } from "../form/Form";
import { UserMenuContainer } from "../UserMenuContainer"; import { UserMenuContainer } from "../UserMenuContainer";
import { useRegisterPasswordlessUser } from "../auth/useRegisterPasswordlessUser"; import { useRegisterPasswordlessUser } from "../auth/useRegisterPasswordlessUser";
import { Config } from "../config/Config";
export function RoomAuthView() { export function RoomAuthView() {
const [loading, setLoading] = useState(false); const [loading, setLoading] = useState(false);
const [error, setError] = useState<Error>(); const [error, setError] = useState<Error>();
const { registerPasswordlessUser, recaptchaId, privacyPolicyUrl } = const { registerPasswordlessUser, recaptchaId } =
useRegisterPasswordlessUser(); useRegisterPasswordlessUser();
const onSubmit = useCallback( const onSubmit = useCallback(
@ -83,7 +84,7 @@ export function RoomAuthView() {
<Caption> <Caption>
<Trans> <Trans>
By clicking "Join call now", you agree to our{" "} By clicking "Join call now", you agree to our{" "}
<Link href={privacyPolicyUrl}> <Link href={Config.get().eula}>
End User Licensing Agreement (EULA) End User Licensing Agreement (EULA)
</Link> </Link>
</Trans> </Trans>