Merge pull request #5755 from aaronraimist/warn-on-access-token-reveal
Warn on access token revealpull/21833/head
						commit
						4bc5990071
					
				|  | @ -22,3 +22,34 @@ limitations under the License. | |||
| .mx_HelpUserSettingsTab span.mx_AccessibleButton { | ||||
|     word-break: break-word; | ||||
| } | ||||
| 
 | ||||
| .mx_HelpUserSettingsTab code { | ||||
|     word-break: break-all; | ||||
|     user-select: all; | ||||
| } | ||||
| 
 | ||||
| .mx_HelpUserSettingsTab_accessToken { | ||||
|     display: flex; | ||||
|     justify-content: space-between; | ||||
|     border-radius: 5px; | ||||
|     border: solid 1px $light-fg-color; | ||||
|     margin-bottom: 10px; | ||||
|     margin-top: 10px; | ||||
|     padding: 10px; | ||||
| } | ||||
| 
 | ||||
| .mx_HelpUserSettingsTab_accessToken_copy { | ||||
|     flex-shrink: 0; | ||||
|     cursor: pointer; | ||||
|     margin-left: 20px; | ||||
|     display: inherit; | ||||
| } | ||||
| 
 | ||||
| .mx_HelpUserSettingsTab_accessToken_copy > div { | ||||
|     mask-image: url($copy-button-url); | ||||
|     background-color: $message-action-bar-fg-color; | ||||
|     margin-left: 5px; | ||||
|     width: 20px; | ||||
|     height: 20px; | ||||
|     background-repeat: no-repeat; | ||||
| } | ||||
|  |  | |||
|  | @ -18,6 +18,7 @@ import React from 'react'; | |||
| import {_t, getCurrentLanguage} from "../../../../../languageHandler"; | ||||
| import {MatrixClientPeg} from "../../../../../MatrixClientPeg"; | ||||
| import AccessibleButton from "../../../elements/AccessibleButton"; | ||||
| import AccessibleTooltipButton from '../../../elements/AccessibleTooltipButton'; | ||||
| import SdkConfig from "../../../../../SdkConfig"; | ||||
| import createRoom from "../../../../../createRoom"; | ||||
| import Modal from "../../../../../Modal"; | ||||
|  | @ -26,6 +27,9 @@ import PlatformPeg from "../../../../../PlatformPeg"; | |||
| import * as KeyboardShortcuts from "../../../../../accessibility/KeyboardShortcuts"; | ||||
| import UpdateCheckButton from "../../UpdateCheckButton"; | ||||
| import { replaceableComponent } from "../../../../../utils/replaceableComponent"; | ||||
| import { copyPlaintext } from "../../../../../utils/strings"; | ||||
| import * as ContextMenu from "../../../../structures/ContextMenu"; | ||||
| import { toRightOf } from "../../../../structures/ContextMenu"; | ||||
| 
 | ||||
| interface IProps { | ||||
|     closeSettingsFn: () => {}; | ||||
|  | @ -38,6 +42,8 @@ interface IState { | |||
| 
 | ||||
| @replaceableComponent("views.settings.tabs.user.HelpUserSettingsTab") | ||||
| export default class HelpUserSettingsTab extends React.Component<IProps, IState> { | ||||
|     protected closeCopiedTooltip: () => void; | ||||
| 
 | ||||
|     constructor(props) { | ||||
|         super(props); | ||||
| 
 | ||||
|  | @ -56,6 +62,12 @@ export default class HelpUserSettingsTab extends React.Component<IProps, IState> | |||
|         }); | ||||
|     } | ||||
| 
 | ||||
|     componentWillUnmount() { | ||||
|         // if the Copied tooltip is open then get rid of it, there are ways to close the modal which wouldn't close
 | ||||
|         // the tooltip otherwise, such as pressing Escape
 | ||||
|         if (this.closeCopiedTooltip) this.closeCopiedTooltip(); | ||||
|     } | ||||
| 
 | ||||
|     private onClearCacheAndReload = (e) => { | ||||
|         if (!PlatformPeg.get()) return; | ||||
| 
 | ||||
|  | @ -153,6 +165,20 @@ export default class HelpUserSettingsTab extends React.Component<IProps, IState> | |||
|         ); | ||||
|     } | ||||
| 
 | ||||
|     onAccessTokenCopyClick = async (e) => { | ||||
|         e.preventDefault(); | ||||
|         const target = e.target; // copy target before we go async and React throws it away
 | ||||
| 
 | ||||
|         const successful = await copyPlaintext(MatrixClientPeg.get().getAccessToken()); | ||||
|         const buttonRect = target.getBoundingClientRect(); | ||||
|         const GenericTextContextMenu = sdk.getComponent('context_menus.GenericTextContextMenu'); | ||||
|         const {close} = ContextMenu.createMenu(GenericTextContextMenu, { | ||||
|             ...toRightOf(buttonRect, 2), | ||||
|             message: successful ? _t('Copied!') : _t('Failed to copy'), | ||||
|         }); | ||||
|         this.closeCopiedTooltip = target.onmouseleave = close; | ||||
|     } | ||||
| 
 | ||||
|     render() { | ||||
|         const brand = SdkConfig.get().brand; | ||||
| 
 | ||||
|  | @ -269,12 +295,20 @@ export default class HelpUserSettingsTab extends React.Component<IProps, IState> | |||
|                     <div className='mx_SettingsTab_subsectionText'> | ||||
|                         {_t("Homeserver is")} <code>{MatrixClientPeg.get().getHomeserverUrl()}</code><br /> | ||||
|                         {_t("Identity Server is")} <code>{MatrixClientPeg.get().getIdentityServerUrl()}</code><br /> | ||||
|                         {_t("Access Token:") + ' '} | ||||
|                         <AccessibleButton element="span" onClick={this.showSpoiler} | ||||
|                             data-spoiler={MatrixClientPeg.get().getAccessToken()} | ||||
|                         > | ||||
|                             <{ _t("click to reveal") }> | ||||
|                         </AccessibleButton> | ||||
|                         <br /> | ||||
|                         <details> | ||||
|                             <summary>{_t("Access Token")}</summary><br /> | ||||
|                             <b>{_t("Your access token gives full access to your account." | ||||
|                                + " Do not share it with anyone." )}</b> | ||||
|                             <div className="mx_HelpUserSettingsTab_accessToken"> | ||||
|                                 <code>{MatrixClientPeg.get().getAccessToken()}</code> | ||||
|                                 <AccessibleTooltipButton | ||||
|                                     title={_t("Copy")} | ||||
|                                     onClick={this.onAccessTokenCopyClick} | ||||
|                                     className="mx_HelpUserSettingsTab_accessToken_copy" | ||||
|                                 /> | ||||
|                             </div> | ||||
|                         </details><br /> | ||||
|                         <div className='mx_HelpUserSettingsTab_debugButton'> | ||||
|                             <AccessibleButton onClick={this.onClearCacheAndReload} kind='danger'> | ||||
|                                 {_t("Clear cache and reload")} | ||||
|  |  | |||
|  | @ -1252,8 +1252,9 @@ | |||
|     "olm version:": "olm version:", | ||||
|     "Homeserver is": "Homeserver is", | ||||
|     "Identity Server is": "Identity Server is", | ||||
|     "Access Token:": "Access Token:", | ||||
|     "click to reveal": "click to reveal", | ||||
|     "Access Token": "Access Token", | ||||
|     "Your access token gives full access to your account. Do not share it with anyone.": "Your access token gives full access to your account. Do not share it with anyone.", | ||||
|     "Copy": "Copy", | ||||
|     "Clear cache and reload": "Clear cache and reload", | ||||
|     "Labs": "Labs", | ||||
|     "Customise your experience with experimental labs features. <a>Learn more</a>.": "Customise your experience with experimental labs features. <a>Learn more</a>.", | ||||
|  | @ -2347,7 +2348,6 @@ | |||
|     "Share Community": "Share Community", | ||||
|     "Share Room Message": "Share Room Message", | ||||
|     "Link to selected message": "Link to selected message", | ||||
|     "Copy": "Copy", | ||||
|     "Command Help": "Command Help", | ||||
|     "Failed to save space settings.": "Failed to save space settings.", | ||||
|     "Space settings": "Space settings", | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue
	
	 J. Ryan Stinnett
						J. Ryan Stinnett