1
0
mirror of https://github.com/Unleash/unleash.git synced 2025-01-25 00:07:47 +01:00

fix: add check for obscure error (#305)

This commit is contained in:
Fredrik Strand Oseberg 2021-06-07 10:09:49 +02:00 committed by GitHub
parent 281e027c8a
commit 0e32583fa0
3 changed files with 52 additions and 10 deletions

View File

@ -4,7 +4,7 @@ export const useStyles = makeStyles(theme => ({
container: {
border: '1px solid #f1f1f1',
borderRadius: '3px',
right: '100px',
position: 'relative',
maxWidth: '350px',
color: '#44606e',
},
@ -41,4 +41,9 @@ export const useStyles = makeStyles(theme => ({
helpIcon: {
height: '17.5px',
},
repeatingError: {
marginTop: '0.5rem',
bottom: '0',
position: 'absolute',
},
}));

View File

@ -6,6 +6,8 @@ import { useStyles } from './PasswordChecker.styles';
import HelpIcon from '@material-ui/icons/Help';
import { useCallback } from 'react';
import { formatApiPath } from '../../../../../utils/format-path';
import { Alert } from '@material-ui/lab';
import ConditionallyRender from '../../../../common/ConditionallyRender';
interface IPasswordCheckerProps {
password: string;
@ -31,6 +33,8 @@ const UPPERCASE_ERROR =
'The password must contain at least one uppercase letter.';
const LOWERCASE_ERROR =
'The password must contain at least one lowercase letter.';
const REPEATING_CHARACTER_ERROR =
'The password may not contain sequences of three or more repeated characters.';
const PasswordChecker = ({
password,
@ -42,6 +46,7 @@ const PasswordChecker = ({
const [numberError, setNumberError] = useState(true);
const [symbolError, setSymbolError] = useState(true);
const [lengthError, setLengthError] = useState(true);
const [repeatingCharError, setRepeatingCharError] = useState(false);
const makeValidatePassReq = useCallback(() => {
const path = formatApiPath('auth/reset/validate-password');
@ -54,9 +59,19 @@ const PasswordChecker = ({
});
}, [password]);
const clearCheckerErrors = useCallback(() => {
setAllErrors(false);
}, []);
const checkPassword = useCallback(async () => {
if (!password) return;
if (password.length < 3) return;
if (!password) {
setAllErrors(true);
return;
}
if (password.length < 3) {
setLengthError(true);
return;
}
try {
const res = await makeValidatePassReq();
if (res.status === BAD_REQUEST) {
@ -66,24 +81,25 @@ const PasswordChecker = ({
}
if (res.status === OK) {
clearErrors();
clearCheckerErrors();
setRepeatingCharError(false);
callback(true);
}
} catch (e) {
// ResetPasswordForm handles errors related to submitting the form.
console.log('An exception was caught and handled');
}
}, [makeValidatePassReq, callback, password]);
}, [makeValidatePassReq, callback, password, clearCheckerErrors]);
useEffect(() => {
checkPassword();
}, [password, checkPassword]);
const clearErrors = () => {
setCasingError(false);
setNumberError(false);
setSymbolError(false);
setLengthError(false);
const setAllErrors = (flag: boolean) => {
setCasingError(flag);
setNumberError(flag);
setSymbolError(flag);
setLengthError(flag);
};
const handleErrorResponse = (data: IErrorResponse) => {
@ -115,6 +131,12 @@ const PasswordChecker = ({
} else {
setCasingError(false);
}
if (errors.includes(REPEATING_CHARACTER_ERROR)) {
setRepeatingCharError(true);
} else {
setRepeatingCharError(false);
}
};
const lengthStatusBarClasses = classnames(styles.statusBar, {
@ -191,6 +213,17 @@ const PasswordChecker = ({
<div className={symbolStatusBarClasses} data-loading />
</div>
</div>
<ConditionallyRender
condition={repeatingCharError}
show={
<Alert
severity="error"
className={styles.repeatingError}
>
You may not repeat three characters in a row.
</Alert>
}
/>
</div>
</>
);

View File

@ -41,6 +41,10 @@ const ResetPasswordForm = ({ token, setLoading }: IResetPasswordProps) => {
]);
useEffect(() => {
if (!password) {
setValidOwaspPassword(false);
}
if (password === confirmPassword) {
setMatchingPasswords(true);
} else {