Login: strip whitespace around username, strip leading @

This commit is contained in:
Alex Gleason 2022-07-18 21:50:02 -05:00
parent b176d03c71
commit fb45d62d70
No known key found for this signature in database
GPG key ID: 7211D1F99744FBB7
3 changed files with 20 additions and 2 deletions

View file

@ -207,9 +207,19 @@ export const loadCredentials = (token: string, accountUrl: string) =>
}) })
.catch(() => dispatch(verifyCredentials(token, accountUrl))); .catch(() => dispatch(verifyCredentials(token, accountUrl)));
/** Trim the username and strip the leading @. */
const normalizeUsername = (username: string): string => {
const trimmed = username.trim();
if (trimmed[0] === '@') {
return trimmed.slice(1);
} else {
return trimmed;
}
};
export const logIn = (username: string, password: string) => export const logIn = (username: string, password: string) =>
(dispatch: AppDispatch) => dispatch(getAuthApp()).then(() => { (dispatch: AppDispatch) => dispatch(getAuthApp()).then(() => {
return dispatch(createUserToken(username, password)); return dispatch(createUserToken(normalizeUsername(username), password));
}).catch((error: AxiosError) => { }).catch((error: AxiosError) => {
if ((error.response?.data as any).error === 'mfa_required') { if ((error.response?.data as any).error === 'mfa_required') {
// If MFA is required, throw the error and handle it in the component. // If MFA is required, throw the error and handle it in the component.

View file

@ -40,6 +40,7 @@ const LoginForm: React.FC<ILoginForm> = ({ isLoading, handleSubmit }) => {
autoComplete='off' autoComplete='off'
autoCorrect='off' autoCorrect='off'
autoCapitalize='off' autoCapitalize='off'
pattern='^[@a-zA-Z\d_-]+$'
required required
/> />
</FormGroup> </FormGroup>

View file

@ -128,10 +128,14 @@ const Header = () => {
<Input <Input
required required
value={username} value={username}
onChange={(event) => setUsername(event.target.value)} onChange={(event) => setUsername(event.target.value.trim())}
type='text' type='text'
placeholder={intl.formatMessage(messages.username)} placeholder={intl.formatMessage(messages.username)}
className='max-w-[200px]' className='max-w-[200px]'
autoComplete='off'
autoCorrect='off'
autoCapitalize='off'
pattern='^[@a-zA-Z\d_-]+$'
/> />
<Input <Input
@ -141,6 +145,9 @@ const Header = () => {
type='password' type='password'
placeholder={intl.formatMessage(messages.password)} placeholder={intl.formatMessage(messages.password)}
className='max-w-[200px]' className='max-w-[200px]'
autoComplete='off'
autoCorrect='off'
autoCapitalize='off'
/> />
<Link to='/reset-password'> <Link to='/reset-password'>