Merge pull request #5763 from uhoreg/room-history-key-sharing2
Share keys for historical messages when inviting users to encrypted roomspull/21833/head
						commit
						e23583db40
					
				|  | @ -43,6 +43,7 @@ import {Room} from "matrix-js-sdk/src/models/room"; | |||
| import { MatrixCall } from 'matrix-js-sdk/src/webrtc/call'; | ||||
| import {replaceableComponent} from "../../../utils/replaceableComponent"; | ||||
| import {mediaFromMxc} from "../../../customisations/Media"; | ||||
| import {getAddressType} from "../../../UserAddress"; | ||||
| 
 | ||||
| // we have a number of types defined from the Matrix spec which can't reasonably be altered here.
 | ||||
| /* eslint-disable camelcase */ | ||||
|  | @ -678,14 +679,15 @@ export default class InviteDialog extends React.PureComponent<IInviteDialogProps | |||
|         }); | ||||
|     }; | ||||
| 
 | ||||
|     _inviteUsers = () => { | ||||
|     _inviteUsers = async () => { | ||||
|         const startTime = CountlyAnalytics.getTimestamp(); | ||||
|         this.setState({busy: true}); | ||||
|         this._convertFilter(); | ||||
|         const targets = this._convertFilter(); | ||||
|         const targetIds = targets.map(t => t.userId); | ||||
| 
 | ||||
|         const room = MatrixClientPeg.get().getRoom(this.props.roomId); | ||||
|         const cli = MatrixClientPeg.get(); | ||||
|         const room = cli.getRoom(this.props.roomId); | ||||
|         if (!room) { | ||||
|             console.error("Failed to find the room to invite users to"); | ||||
|             this.setState({ | ||||
|  | @ -695,12 +697,34 @@ export default class InviteDialog extends React.PureComponent<IInviteDialogProps | |||
|             return; | ||||
|         } | ||||
| 
 | ||||
|         inviteMultipleToRoom(this.props.roomId, targetIds).then(result => { | ||||
|         try { | ||||
|             const result = await inviteMultipleToRoom(this.props.roomId, targetIds) | ||||
|             CountlyAnalytics.instance.trackSendInvite(startTime, this.props.roomId, targetIds.length); | ||||
|             if (!this._shouldAbortAfterInviteError(result)) { // handles setting error message too
 | ||||
|                 this.props.onFinished(); | ||||
|             } | ||||
|         }).catch(err => { | ||||
| 
 | ||||
|             if (cli.isRoomEncrypted(this.props.roomId) && | ||||
|                 SettingsStore.getValue("feature_room_history_key_sharing")) { | ||||
|                 const visibilityEvent = room.currentState.getStateEvents( | ||||
|                     "m.room.history_visibility", "", | ||||
|                 ); | ||||
|                 const visibility = visibilityEvent && visibilityEvent.getContent() && | ||||
|                     visibilityEvent.getContent().history_visibility; | ||||
|                 if (visibility == "world_readable" || visibility == "shared") { | ||||
|                     const invitedUsers = []; | ||||
|                     for (const [addr, state] of Object.entries(result.states)) { | ||||
|                         if (state === "invited" && getAddressType(addr) === "mx-user-id") { | ||||
|                             invitedUsers.push(addr); | ||||
|                         } | ||||
|                     } | ||||
|                     console.log("Sharing history with", invitedUsers); | ||||
|                     cli.sendSharedHistoryKeys( | ||||
|                         this.props.roomId, invitedUsers, | ||||
|                     ); | ||||
|                 } | ||||
|             } | ||||
|         } catch (err) { | ||||
|             console.error(err); | ||||
|             this.setState({ | ||||
|                 busy: false, | ||||
|  | @ -708,7 +732,7 @@ export default class InviteDialog extends React.PureComponent<IInviteDialogProps | |||
|                     "We couldn't invite those users. Please check the users you want to invite and try again.", | ||||
|                 ), | ||||
|             }); | ||||
|         }); | ||||
|         } | ||||
|     }; | ||||
| 
 | ||||
|     _transferCall = async () => { | ||||
|  | @ -1191,10 +1215,12 @@ export default class InviteDialog extends React.PureComponent<IInviteDialogProps | |||
|         let helpText; | ||||
|         let buttonText; | ||||
|         let goButtonFn; | ||||
|         let keySharingWarning = <span />; | ||||
| 
 | ||||
|         const identityServersEnabled = SettingsStore.getValue(UIFeature.IdentityServer); | ||||
| 
 | ||||
|         const userId = MatrixClientPeg.get().getUserId(); | ||||
|         const cli = MatrixClientPeg.get(); | ||||
|         const userId = cli.getUserId(); | ||||
|         if (this.props.kind === KIND_DM) { | ||||
|             title = _t("Direct Messages"); | ||||
| 
 | ||||
|  | @ -1290,6 +1316,25 @@ export default class InviteDialog extends React.PureComponent<IInviteDialogProps | |||
| 
 | ||||
|             buttonText = _t("Invite"); | ||||
|             goButtonFn = this._inviteUsers; | ||||
| 
 | ||||
|             if (SettingsStore.getValue("feature_room_history_key_sharing") && | ||||
|                 cli.isRoomEncrypted(this.props.roomId)) { | ||||
|                 const room = cli.getRoom(this.props.roomId); | ||||
|                 const visibilityEvent = room.currentState.getStateEvents( | ||||
|                     "m.room.history_visibility", "", | ||||
|                 ); | ||||
|                 const visibility = visibilityEvent && visibilityEvent.getContent() && | ||||
|                     visibilityEvent.getContent().history_visibility; | ||||
|                 if (visibility === "world_readable" || visibility === "shared") { | ||||
|                     keySharingWarning = | ||||
|                         <p className='mx_InviteDialog_helpText'> | ||||
|                             <img | ||||
|                                 src={require("../../../../res/img/element-icons/info.svg")} | ||||
|                                 width={14} height={14} /> | ||||
|                             {" " + _t("Invited people will be able to read old messages.")} | ||||
|                         </p>; | ||||
|                 } | ||||
|             } | ||||
|         } else if (this.props.kind === KIND_CALL_TRANSFER) { | ||||
|             title = _t("Transfer"); | ||||
|             buttonText = _t("Transfer"); | ||||
|  | @ -1323,6 +1368,7 @@ export default class InviteDialog extends React.PureComponent<IInviteDialogProps | |||
|                             {spinner} | ||||
|                         </div> | ||||
|                     </div> | ||||
|                     {keySharingWarning} | ||||
|                     {this._renderIdentityServerWarning()} | ||||
|                     <div className='error'>{this.state.errorText}</div> | ||||
|                     <div className='mx_InviteDialog_userSections'> | ||||
|  |  | |||
|  | @ -797,6 +797,7 @@ | |||
|     "Show message previews for reactions in DMs": "Show message previews for reactions in DMs", | ||||
|     "Show message previews for reactions in all rooms": "Show message previews for reactions in all rooms", | ||||
|     "Offline encrypted messaging using dehydrated devices": "Offline encrypted messaging using dehydrated devices", | ||||
|     "Share decryption keys for room history when inviting users": "Share decryption keys for room history when inviting users", | ||||
|     "Enable advanced debugging for the room list": "Enable advanced debugging for the room list", | ||||
|     "Show info about bridges in room settings": "Show info about bridges in room settings", | ||||
|     "Font size": "Font size", | ||||
|  | @ -2208,6 +2209,7 @@ | |||
|     "Invite someone using their name, username (like <userId/>) or <a>share this space</a>.": "Invite someone using their name, username (like <userId/>) or <a>share this space</a>.", | ||||
|     "Invite someone using their name, email address, username (like <userId/>) or <a>share this room</a>.": "Invite someone using their name, email address, username (like <userId/>) or <a>share this room</a>.", | ||||
|     "Invite someone using their name, username (like <userId/>) or <a>share this room</a>.": "Invite someone using their name, username (like <userId/>) or <a>share this room</a>.", | ||||
|     "Invited people will be able to read old messages.": "Invited people will be able to read old messages.", | ||||
|     "Transfer": "Transfer", | ||||
|     "a new master key signature": "a new master key signature", | ||||
|     "a new cross-signing key signature": "a new cross-signing key signature", | ||||
|  |  | |||
|  | @ -220,6 +220,12 @@ export const SETTINGS: {[setting: string]: ISetting} = { | |||
|         supportedLevels: LEVELS_FEATURE, | ||||
|         default: false, | ||||
|     }, | ||||
|     "feature_room_history_key_sharing": { | ||||
|         isFeature: true, | ||||
|         displayName: _td("Share decryption keys for room history when inviting users"), | ||||
|         supportedLevels: LEVELS_FEATURE, | ||||
|         default: false, | ||||
|     }, | ||||
|     "advancedRoomListLogging": { | ||||
|         // TODO: Remove flag before launch: https://github.com/vector-im/element-web/issues/14231
 | ||||
|         displayName: _td("Enable advanced debugging for the room list"), | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue
	
	 Hubert Chathi
						Hubert Chathi