matrix-react-sdk
Version:
SDK for matrix.org using React
116 lines (114 loc) • 19 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _react = _interopRequireWildcard(require("react"));
var _classnames = _interopRequireDefault(require("classnames"));
var _SdkConfig = _interopRequireDefault(require("../../../SdkConfig"));
var _Validation = _interopRequireDefault(require("../elements/Validation"));
var _languageHandler = require("../../../languageHandler");
var _Field = _interopRequireDefault(require("../elements/Field"));
var _MatrixClientPeg = require("../../../MatrixClientPeg");
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; } /*
Copyright 2024 New Vector Ltd.
Copyright 2020 The Matrix.org Foundation C.I.C.
SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only
Please see LICENSE files in the repository root for full details.
*/
class PassphraseField extends _react.PureComponent {
constructor(...args) {
super(...args);
(0, _defineProperty2.default)(this, "validate", (0, _Validation.default)({
description: function (complexity) {
const score = complexity ? complexity.score : 0;
return /*#__PURE__*/_react.default.createElement("progress", {
className: "mx_PassphraseField_progress",
max: 4,
value: score
});
},
deriveData: async ({
value
}) => {
if (!value) return null;
const {
scorePassword
} = await Promise.resolve().then(() => _interopRequireWildcard(require("../../../utils/PasswordScorer")));
return scorePassword(_MatrixClientPeg.MatrixClientPeg.get(), value, this.props.userInputs);
},
rules: [{
key: "required",
test: ({
value,
allowEmpty
}) => allowEmpty || !!value,
invalid: () => (0, _languageHandler._t)(this.props.labelEnterPassword)
}, {
key: "complexity",
test: async function ({
value
}, complexity) {
if (!value || !complexity) {
return false;
}
const safe = complexity.score >= this.props.minScore;
const allowUnsafe = _SdkConfig.default.get("dangerously_allow_unsafe_and_insecure_passwords");
return allowUnsafe || safe;
},
valid: function (complexity) {
// Unsafe passwords that are valid are only possible through a
// configuration flag. We'll print some helper text to signal
// to the user that their password is allowed, but unsafe.
if (complexity && complexity.score >= this.props.minScore) {
return (0, _languageHandler._t)(this.props.labelStrongPassword);
}
return (0, _languageHandler._t)(this.props.labelAllowedButUnsafe);
},
invalid: function (complexity) {
if (!complexity) {
return null;
}
const {
feedback
} = complexity;
return feedback.warning || feedback.suggestions[0] || (0, _languageHandler._t)("auth|password_field_keep_going_prompt");
}
}],
memoize: true
}));
(0, _defineProperty2.default)(this, "onValidate", async fieldState => {
const result = await this.validate(fieldState);
if (this.props.onValidate) {
this.props.onValidate(result);
}
return result;
});
}
render() {
return /*#__PURE__*/_react.default.createElement(_Field.default, {
id: this.props.id,
autoFocus: this.props.autoFocus,
className: (0, _classnames.default)("mx_PassphraseField", this.props.className),
ref: this.props.fieldRef,
type: "password",
autoComplete: "new-password",
label: (0, _languageHandler._t)(this.props.label),
value: this.props.value,
onChange: this.props.onChange,
onValidate: this.onValidate,
tooltipAlignment: this.props.tooltipAlignment
});
}
}
(0, _defineProperty2.default)(PassphraseField, "defaultProps", {
label: (0, _languageHandler._td)("common|password"),
labelEnterPassword: (0, _languageHandler._td)("auth|password_field_label"),
labelStrongPassword: (0, _languageHandler._td)("auth|password_field_strong_label"),
labelAllowedButUnsafe: (0, _languageHandler._td)("auth|password_field_weak_label")
});
var _default = exports.default = PassphraseField;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_classnames","_interopRequireDefault","_SdkConfig","_Validation","_languageHandler","_Field","_MatrixClientPeg","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","PassphraseField","PureComponent","constructor","args","_defineProperty2","withValidation","description","complexity","score","createElement","className","max","value","deriveData","scorePassword","Promise","resolve","then","MatrixClientPeg","props","userInputs","rules","key","test","allowEmpty","invalid","_t","labelEnterPassword","safe","minScore","allowUnsafe","SdkConfig","valid","labelStrongPassword","labelAllowedButUnsafe","feedback","warning","suggestions","memoize","fieldState","result","validate","onValidate","render","id","autoFocus","classNames","ref","fieldRef","type","autoComplete","label","onChange","tooltipAlignment","_td","_default","exports"],"sources":["../../../../src/components/views/auth/PassphraseField.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2020 The Matrix.org Foundation C.I.C.\n\nSPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only\nPlease see LICENSE files in the repository root for full details.\n*/\n\nimport React, { PureComponent, RefCallback, RefObject } from \"react\";\nimport classNames from \"classnames\";\n\nimport type { ZxcvbnResult } from \"@zxcvbn-ts/core\";\nimport SdkConfig from \"../../../SdkConfig\";\nimport withValidation, { IFieldState, IValidationResult } from \"../elements/Validation\";\nimport { _t, _td, TranslationKey } from \"../../../languageHandler\";\nimport Field, { IInputProps } from \"../elements/Field\";\nimport { MatrixClientPeg } from \"../../../MatrixClientPeg\";\nimport { Alignment } from \"../elements/Tooltip\";\n\ninterface IProps extends Omit<IInputProps, \"onValidate\" | \"element\"> {\n    autoFocus?: boolean;\n    id?: string;\n    className?: string;\n    minScore: 0 | 1 | 2 | 3 | 4;\n    value: string;\n    fieldRef?: RefCallback<Field> | RefObject<Field>;\n    // Additional strings such as a username used to catch bad passwords\n    userInputs?: string[];\n\n    label: TranslationKey;\n    labelEnterPassword: TranslationKey;\n    labelStrongPassword: TranslationKey;\n    labelAllowedButUnsafe: TranslationKey;\n    tooltipAlignment?: Alignment;\n\n    onChange(ev: React.FormEvent<HTMLElement>): void;\n    onValidate?(result: IValidationResult): void;\n}\n\nclass PassphraseField extends PureComponent<IProps> {\n    public static defaultProps = {\n        label: _td(\"common|password\"),\n        labelEnterPassword: _td(\"auth|password_field_label\"),\n        labelStrongPassword: _td(\"auth|password_field_strong_label\"),\n        labelAllowedButUnsafe: _td(\"auth|password_field_weak_label\"),\n    };\n\n    public readonly validate = withValidation<this, ZxcvbnResult | null>({\n        description: function (complexity) {\n            const score = complexity ? complexity.score : 0;\n            return <progress className=\"mx_PassphraseField_progress\" max={4} value={score} />;\n        },\n        deriveData: async ({ value }): Promise<ZxcvbnResult | null> => {\n            if (!value) return null;\n            const { scorePassword } = await import(\"../../../utils/PasswordScorer\");\n            return scorePassword(MatrixClientPeg.get(), value, this.props.userInputs);\n        },\n        rules: [\n            {\n                key: \"required\",\n                test: ({ value, allowEmpty }) => allowEmpty || !!value,\n                invalid: () => _t(this.props.labelEnterPassword),\n            },\n            {\n                key: \"complexity\",\n                test: async function ({ value }, complexity): Promise<boolean> {\n                    if (!value || !complexity) {\n                        return false;\n                    }\n                    const safe = complexity.score >= this.props.minScore;\n                    const allowUnsafe = SdkConfig.get(\"dangerously_allow_unsafe_and_insecure_passwords\");\n                    return allowUnsafe || safe;\n                },\n                valid: function (complexity) {\n                    // Unsafe passwords that are valid are only possible through a\n                    // configuration flag. We'll print some helper text to signal\n                    // to the user that their password is allowed, but unsafe.\n                    if (complexity && complexity.score >= this.props.minScore) {\n                        return _t(this.props.labelStrongPassword);\n                    }\n                    return _t(this.props.labelAllowedButUnsafe);\n                },\n                invalid: function (complexity) {\n                    if (!complexity) {\n                        return null;\n                    }\n                    const { feedback } = complexity;\n                    return feedback.warning || feedback.suggestions[0] || _t(\"auth|password_field_keep_going_prompt\");\n                },\n            },\n        ],\n        memoize: true,\n    });\n\n    public onValidate = async (fieldState: IFieldState): Promise<IValidationResult> => {\n        const result = await this.validate(fieldState);\n        if (this.props.onValidate) {\n            this.props.onValidate(result);\n        }\n        return result;\n    };\n\n    public render(): React.ReactNode {\n        return (\n            <Field\n                id={this.props.id}\n                autoFocus={this.props.autoFocus}\n                className={classNames(\"mx_PassphraseField\", this.props.className)}\n                ref={this.props.fieldRef}\n                type=\"password\"\n                autoComplete=\"new-password\"\n                label={_t(this.props.label)}\n                value={this.props.value}\n                onChange={this.props.onChange}\n                onValidate={this.onValidate}\n                tooltipAlignment={this.props.tooltipAlignment}\n            />\n        );\n    }\n}\n\nexport default PassphraseField;\n"],"mappings":"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","ignoreList":[]}