mirror of
https://github.com/navidrome/navidrome.git
synced 2025-04-03 20:47:35 +03:00
"Spell-Jacking" mitigation ~ prevent sensitive data leak from spell checker. (#2091)
@see https://www.otto-js.com/news/article/chrome-and-edge-enhanced-spellcheck-features-expose-pii-even-your-passwords Co-authored-by: Daniel Hammer <daniel.hammer+oss@gmail.com>
This commit is contained in:
parent
9d459fbd0a
commit
fc8462dc8a
3 changed files with 27 additions and 7 deletions
|
@ -138,6 +138,7 @@ const FormLogin = ({ loading, handleSubmit, validate }) => {
|
|||
component={renderInput}
|
||||
label={translate('ra.auth.username')}
|
||||
disabled={loading}
|
||||
spellCheck={false}
|
||||
/>
|
||||
</div>
|
||||
<div className={classes.input}>
|
||||
|
@ -201,6 +202,7 @@ const FormSignUp = ({ loading, handleSubmit, validate }) => {
|
|||
component={renderInput}
|
||||
label={translate('ra.auth.username')}
|
||||
disabled={loading}
|
||||
spellCheck={false}
|
||||
/>
|
||||
</div>
|
||||
<div className={classes.input}>
|
||||
|
|
|
@ -51,10 +51,18 @@ const UserCreate = (props) => {
|
|||
return (
|
||||
<Create title={<Title subTitle={title} />} {...props}>
|
||||
<SimpleForm save={save} variant={'outlined'}>
|
||||
<TextInput source="userName" validate={[required()]} />
|
||||
<TextInput
|
||||
spellCheck={false}
|
||||
source="userName"
|
||||
validate={[required()]}
|
||||
/>
|
||||
<TextInput source="name" validate={[required()]} />
|
||||
<TextInput source="email" validate={[email()]} />
|
||||
<PasswordInput source="password" validate={[required()]} />
|
||||
<TextInput spellCheck={false} source="email" validate={[email()]} />
|
||||
<PasswordInput
|
||||
spellCheck={false}
|
||||
source="password"
|
||||
validate={[required()]}
|
||||
/>
|
||||
<BooleanInput source="isAdmin" defaultValue={false} />
|
||||
</SimpleForm>
|
||||
</Create>
|
||||
|
|
|
@ -108,22 +108,32 @@ const UserEdit = (props) => {
|
|||
save={save}
|
||||
>
|
||||
{permissions === 'admin' && (
|
||||
<TextInput source="userName" validate={[required()]} />
|
||||
<TextInput
|
||||
spellCheck={false}
|
||||
source="userName"
|
||||
validate={[required()]}
|
||||
/>
|
||||
)}
|
||||
<TextInput
|
||||
source="name"
|
||||
validate={[required()]}
|
||||
{...getNameHelperText()}
|
||||
/>
|
||||
<TextInput source="email" validate={[email()]} />
|
||||
<TextInput spellCheck={false} source="email" validate={[email()]} />
|
||||
<BooleanInput source="changePassword" />
|
||||
<FormDataConsumer>
|
||||
{(formDataProps) => (
|
||||
<CurrentPasswordInput isMyself={isMyself} {...formDataProps} />
|
||||
<CurrentPasswordInput
|
||||
spellCheck={false}
|
||||
isMyself={isMyself}
|
||||
{...formDataProps}
|
||||
/>
|
||||
)}
|
||||
</FormDataConsumer>
|
||||
<FormDataConsumer>
|
||||
{(formDataProps) => <NewPasswordInput {...formDataProps} />}
|
||||
{(formDataProps) => (
|
||||
<NewPasswordInput spellCheck={false} {...formDataProps} />
|
||||
)}
|
||||
</FormDataConsumer>
|
||||
|
||||
{permissions === 'admin' && (
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue