UNPKG

matrix-react-sdk

Version:
250 lines (210 loc) 29.9 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _react = _interopRequireWildcard(require("react")); var _autodiscovery = require("matrix-js-sdk/src/autodiscovery"); var _AutoDiscoveryUtils = _interopRequireDefault(require("../../../utils/AutoDiscoveryUtils")); var _BaseDialog = _interopRequireDefault(require("./BaseDialog")); var _languageHandler = require("../../../languageHandler"); var _AccessibleButton = _interopRequireDefault(require("../elements/AccessibleButton")); var _SdkConfig = _interopRequireDefault(require("../../../SdkConfig")); var _Field = _interopRequireDefault(require("../elements/Field")); var _StyledRadioButton = _interopRequireDefault(require("../elements/StyledRadioButton")); var _TextWithTooltip = _interopRequireDefault(require("../elements/TextWithTooltip")); var _Validation = _interopRequireDefault(require("../elements/Validation")); var _replaceableComponent = require("../../../utils/replaceableComponent"); var _dec, _class, _temp; let ServerPickerDialog = (_dec = (0, _replaceableComponent.replaceableComponent)("views.dialogs.ServerPickerDialog"), _dec(_class = (_temp = class ServerPickerDialog extends _react.default.PureComponent /*:: <IProps, IState>*/ { constructor(props) { super(props); (0, _defineProperty2.default)(this, "defaultServer", void 0); (0, _defineProperty2.default)(this, "fieldRef", /*#__PURE__*/(0, _react.createRef)()); (0, _defineProperty2.default)(this, "validatedConf", void 0); (0, _defineProperty2.default)(this, "onDefaultChosen", () => { this.setState({ defaultChosen: true }); }); (0, _defineProperty2.default)(this, "onOtherChosen", () => { this.setState({ defaultChosen: false }); }); (0, _defineProperty2.default)(this, "onHomeserverChange", ev => { this.setState({ otherHomeserver: ev.target.value }); }); (0, _defineProperty2.default)(this, "validate", (0, _Validation.default)({ deriveData: async ({ value }) => { let hsUrl = value.trim(); // trim to account for random whitespace // if the URL has no protocol, try validate it as a serverName via well-known if (!hsUrl.includes("://")) { try { const discoveryResult = await _autodiscovery.AutoDiscovery.findClientConfig(hsUrl); this.validatedConf = _AutoDiscoveryUtils.default.buildValidatedConfigFromDiscovery(hsUrl, discoveryResult); return {}; // we have a validated config, we don't need to try the other paths } catch (e) { console.error(`Attempted ${hsUrl} as a server_name but it failed`, e); } } // if we got to this stage then either the well-known failed or the URL had a protocol specified, // so validate statically only. If the URL has no protocol, default to https. if (!hsUrl.includes("://")) { hsUrl = "https://" + hsUrl; } try { this.validatedConf = await _AutoDiscoveryUtils.default.validateServerConfigWithStaticUrls(hsUrl); return {}; } catch (e) { console.error(e); const stateForError = _AutoDiscoveryUtils.default.authComponentStateForError(e); if (stateForError.serverErrorIsFatal) { let error = (0, _languageHandler._t)("Unable to validate homeserver"); if (e.translatedMessage) { error = e.translatedMessage; } return { error }; } // try to carry on anyway try { this.validatedConf = await _AutoDiscoveryUtils.default.validateServerConfigWithStaticUrls(hsUrl, null, true); return {}; } catch (e) { console.error(e); return { error: (0, _languageHandler._t)("Invalid URL") }; } } }, rules: [{ key: "required", test: ({ value, allowEmpty }) => allowEmpty || !!value, invalid: () => (0, _languageHandler._t)("Specify a homeserver") }, { key: "valid", test: async function ({ value }, { error }) { if (!value) return true; return !error; }, invalid: function ({ error }) { return error; } }] })); (0, _defineProperty2.default)(this, "onHomeserverValidate", (fieldState /*: IFieldState*/ ) => this.validate(fieldState)); (0, _defineProperty2.default)(this, "onSubmit", async ev => { ev.preventDefault(); const valid = await this.fieldRef.current.validate({ allowEmpty: false }); if (!valid && !this.state.defaultChosen) { this.fieldRef.current.focus(); this.fieldRef.current.validate({ allowEmpty: false, focused: true }); return; } this.props.onFinished(this.state.defaultChosen ? this.defaultServer : this.validatedConf); }); const config = _SdkConfig.default.get(); this.defaultServer = config["validated_server_config"]; const { serverConfig } = this.props; let otherHomeserver = ""; if (!serverConfig.isDefault) { if (serverConfig.isNameResolvable && serverConfig.hsName) { otherHomeserver = serverConfig.hsName; } else { otherHomeserver = serverConfig.hsUrl; } } this.state = { defaultChosen: serverConfig.isDefault, otherHomeserver }; } render() { let text; if (this.defaultServer.hsName === "matrix.org") { text = (0, _languageHandler._t)("Matrix.org is the biggest public homeserver in the world, so it’s a good place for many."); } let defaultServerName /*: React.ReactNode*/ = this.defaultServer.hsName; if (this.defaultServer.hsNameIsDifferent) { defaultServerName = /*#__PURE__*/_react.default.createElement(_TextWithTooltip.default, { class: "mx_Login_underlinedServerName", tooltip: this.defaultServer.hsUrl }, this.defaultServer.hsName); } return /*#__PURE__*/_react.default.createElement(_BaseDialog.default, { title: this.props.title || (0, _languageHandler._t)("Sign into your homeserver"), className: "mx_ServerPickerDialog", contentId: "mx_ServerPickerDialog", onFinished: this.props.onFinished, fixedWidth: false, hasCancel: true }, /*#__PURE__*/_react.default.createElement("form", { className: "mx_Dialog_content", id: "mx_ServerPickerDialog", onSubmit: this.onSubmit }, /*#__PURE__*/_react.default.createElement("p", null, (0, _languageHandler._t)("We call the places where you can host your account ‘homeservers’."), " ", text), /*#__PURE__*/_react.default.createElement(_StyledRadioButton.default, { name: "defaultChosen", value: "true", checked: this.state.defaultChosen, onChange: this.onDefaultChosen }, defaultServerName), /*#__PURE__*/_react.default.createElement(_StyledRadioButton.default, { name: "defaultChosen", value: "false", className: "mx_ServerPickerDialog_otherHomeserverRadio", checked: !this.state.defaultChosen, onChange: this.onOtherChosen }, /*#__PURE__*/_react.default.createElement(_Field.default, { type: "text", className: "mx_ServerPickerDialog_otherHomeserver", label: (0, _languageHandler._t)("Other homeserver"), onChange: this.onHomeserverChange, onClick: this.onOtherChosen, ref: this.fieldRef, onValidate: this.onHomeserverValidate, value: this.state.otherHomeserver, validateOnChange: false, validateOnFocus: false, id: "mx_homeserverInput" })), /*#__PURE__*/_react.default.createElement("p", null, (0, _languageHandler._t)("Use your preferred Matrix homeserver if you have one, or host your own.")), /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, { className: "mx_ServerPickerDialog_continue", kind: "primary", onClick: this.onSubmit }, (0, _languageHandler._t)("Continue")), /*#__PURE__*/_react.default.createElement("h4", null, (0, _languageHandler._t)("Learn more")), /*#__PURE__*/_react.default.createElement("a", { href: "https://matrix.org/faq/#what-is-a-homeserver%3F", target: "_blank", rel: "noreferrer noopener" }, (0, _languageHandler._t)("About homeservers")))); } }, _temp)) || _class); exports.default = ServerPickerDialog; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/views/dialogs/ServerPickerDialog.tsx"],"names":["ServerPickerDialog","React","PureComponent","constructor","props","setState","defaultChosen","ev","otherHomeserver","target","value","deriveData","hsUrl","trim","includes","discoveryResult","AutoDiscovery","findClientConfig","validatedConf","AutoDiscoveryUtils","buildValidatedConfigFromDiscovery","e","console","error","validateServerConfigWithStaticUrls","stateForError","authComponentStateForError","serverErrorIsFatal","translatedMessage","rules","key","test","allowEmpty","invalid","fieldState","validate","preventDefault","valid","fieldRef","current","state","focus","focused","onFinished","defaultServer","config","SdkConfig","get","serverConfig","isDefault","isNameResolvable","hsName","render","text","defaultServerName","hsNameIsDifferent","title","onSubmit","onDefaultChosen","onOtherChosen","onHomeserverChange","onHomeserverValidate"],"mappings":"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","sourcesContent":["/*\nCopyright 2020-2021 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n    http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport React, {createRef} from \"react\";\nimport {AutoDiscovery} from \"matrix-js-sdk/src/autodiscovery\";\n\nimport AutoDiscoveryUtils, {ValidatedServerConfig} from \"../../../utils/AutoDiscoveryUtils\";\nimport BaseDialog from './BaseDialog';\nimport { _t } from '../../../languageHandler';\nimport AccessibleButton from \"../elements/AccessibleButton\";\nimport SdkConfig from \"../../../SdkConfig\";\nimport Field from \"../elements/Field\";\nimport StyledRadioButton from \"../elements/StyledRadioButton\";\nimport TextWithTooltip from \"../elements/TextWithTooltip\";\nimport withValidation, {IFieldState} from \"../elements/Validation\";\nimport {replaceableComponent} from \"../../../utils/replaceableComponent\";\n\ninterface IProps {\n    title?: string;\n    serverConfig: ValidatedServerConfig;\n    onFinished(config?: ValidatedServerConfig): void;\n}\n\ninterface IState {\n    defaultChosen: boolean;\n    otherHomeserver: string;\n}\n\n@replaceableComponent(\"views.dialogs.ServerPickerDialog\")\nexport default class ServerPickerDialog extends React.PureComponent<IProps, IState> {\n    private readonly defaultServer: ValidatedServerConfig;\n    private readonly fieldRef = createRef<Field>();\n    private validatedConf: ValidatedServerConfig;\n\n    constructor(props) {\n        super(props);\n\n        const config = SdkConfig.get();\n        this.defaultServer = config[\"validated_server_config\"] as ValidatedServerConfig;\n        const { serverConfig } = this.props;\n\n        let otherHomeserver = \"\";\n        if (!serverConfig.isDefault) {\n            if (serverConfig.isNameResolvable && serverConfig.hsName) {\n                otherHomeserver = serverConfig.hsName;\n            } else {\n                otherHomeserver = serverConfig.hsUrl;\n            }\n        }\n\n        this.state = {\n            defaultChosen: serverConfig.isDefault,\n            otherHomeserver,\n        };\n    }\n\n    private onDefaultChosen = () => {\n        this.setState({ defaultChosen: true });\n    };\n\n    private onOtherChosen = () => {\n        this.setState({ defaultChosen: false });\n    };\n\n    private onHomeserverChange = (ev) => {\n        this.setState({ otherHomeserver: ev.target.value });\n    };\n\n    // TODO: Do we want to support .well-known lookups here?\n    // If for some reason someone enters \"matrix.org\" for a URL, we could do a lookup to\n    // find their homeserver without demanding they use \"https://matrix.org\"\n    private validate = withValidation<this, { error?: string }>({\n        deriveData: async ({ value }) => {\n            let hsUrl = value.trim(); // trim to account for random whitespace\n\n            // if the URL has no protocol, try validate it as a serverName via well-known\n            if (!hsUrl.includes(\"://\")) {\n                try {\n                    const discoveryResult = await AutoDiscovery.findClientConfig(hsUrl);\n                    this.validatedConf = AutoDiscoveryUtils.buildValidatedConfigFromDiscovery(hsUrl, discoveryResult);\n                    return {}; // we have a validated config, we don't need to try the other paths\n                } catch (e) {\n                    console.error(`Attempted ${hsUrl} as a server_name but it failed`, e);\n                }\n            }\n\n            // if we got to this stage then either the well-known failed or the URL had a protocol specified,\n            // so validate statically only. If the URL has no protocol, default to https.\n            if (!hsUrl.includes(\"://\")) {\n                hsUrl = \"https://\" + hsUrl;\n            }\n\n            try {\n                this.validatedConf = await AutoDiscoveryUtils.validateServerConfigWithStaticUrls(hsUrl);\n                return {};\n            } catch (e) {\n                console.error(e);\n\n                const stateForError = AutoDiscoveryUtils.authComponentStateForError(e);\n                if (stateForError.serverErrorIsFatal) {\n                    let error = _t(\"Unable to validate homeserver\");\n                    if (e.translatedMessage) {\n                        error = e.translatedMessage;\n                    }\n                    return { error };\n                }\n\n                // try to carry on anyway\n                try {\n                    this.validatedConf = await AutoDiscoveryUtils.validateServerConfigWithStaticUrls(hsUrl, null, true);\n                    return {};\n                } catch (e) {\n                    console.error(e);\n                    return { error: _t(\"Invalid URL\") };\n                }\n            }\n        },\n        rules: [\n            {\n                key: \"required\",\n                test: ({ value, allowEmpty }) => allowEmpty || !!value,\n                invalid: () => _t(\"Specify a homeserver\"),\n            }, {\n                key: \"valid\",\n                test: async function({ value }, { error }) {\n                    if (!value) return true;\n                    return !error;\n                },\n                invalid: function({ error }) {\n                    return error;\n                },\n            },\n        ],\n    });\n\n    private onHomeserverValidate = (fieldState: IFieldState) => this.validate(fieldState);\n\n    private onSubmit = async (ev) => {\n        ev.preventDefault();\n\n        const valid = await this.fieldRef.current.validate({ allowEmpty: false });\n\n        if (!valid && !this.state.defaultChosen) {\n            this.fieldRef.current.focus();\n            this.fieldRef.current.validate({ allowEmpty: false, focused: true });\n            return;\n        }\n\n        this.props.onFinished(this.state.defaultChosen ? this.defaultServer : this.validatedConf);\n    };\n\n    public render() {\n        let text;\n        if (this.defaultServer.hsName === \"matrix.org\") {\n            text = _t(\"Matrix.org is the biggest public homeserver in the world, so it’s a good place for many.\");\n        }\n\n        let defaultServerName: React.ReactNode = this.defaultServer.hsName;\n        if (this.defaultServer.hsNameIsDifferent) {\n            defaultServerName = (\n                <TextWithTooltip class=\"mx_Login_underlinedServerName\" tooltip={this.defaultServer.hsUrl}>\n                    {this.defaultServer.hsName}\n                </TextWithTooltip>\n            );\n        }\n\n        return <BaseDialog\n            title={this.props.title || _t(\"Sign into your homeserver\")}\n            className=\"mx_ServerPickerDialog\"\n            contentId=\"mx_ServerPickerDialog\"\n            onFinished={this.props.onFinished}\n            fixedWidth={false}\n            hasCancel={true}\n        >\n            <form className=\"mx_Dialog_content\" id=\"mx_ServerPickerDialog\" onSubmit={this.onSubmit}>\n                <p>\n                    {_t(\"We call the places where you can host your account ‘homeservers’.\")} {text}\n                </p>\n\n                <StyledRadioButton\n                    name=\"defaultChosen\"\n                    value=\"true\"\n                    checked={this.state.defaultChosen}\n                    onChange={this.onDefaultChosen}\n                >\n                    {defaultServerName}\n                </StyledRadioButton>\n\n                <StyledRadioButton\n                    name=\"defaultChosen\"\n                    value=\"false\"\n                    className=\"mx_ServerPickerDialog_otherHomeserverRadio\"\n                    checked={!this.state.defaultChosen}\n                    onChange={this.onOtherChosen}\n                >\n                    <Field\n                        type=\"text\"\n                        className=\"mx_ServerPickerDialog_otherHomeserver\"\n                        label={_t(\"Other homeserver\")}\n                        onChange={this.onHomeserverChange}\n                        onClick={this.onOtherChosen}\n                        ref={this.fieldRef}\n                        onValidate={this.onHomeserverValidate}\n                        value={this.state.otherHomeserver}\n                        validateOnChange={false}\n                        validateOnFocus={false}\n                        id=\"mx_homeserverInput\"\n                    />\n                </StyledRadioButton>\n                <p>\n                    {_t(\"Use your preferred Matrix homeserver if you have one, or host your own.\")}\n                </p>\n\n                <AccessibleButton className=\"mx_ServerPickerDialog_continue\" kind=\"primary\" onClick={this.onSubmit}>\n                    {_t(\"Continue\")}\n                </AccessibleButton>\n\n                <h4>{_t(\"Learn more\")}</h4>\n                <a href=\"https://matrix.org/faq/#what-is-a-homeserver%3F\" target=\"_blank\" rel=\"noreferrer noopener\">\n                    {_t(\"About homeservers\")}\n                </a>\n            </form>\n        </BaseDialog>;\n    }\n}\n"]}