From e6ca581f10acfd33f5c43c772e331748a0538445 Mon Sep 17 00:00:00 2001 From: Bruno Windels Date: Tue, 18 Feb 2020 15:57:17 +0100 Subject: [PATCH 1/2] get local aliases from /aliases in room settings --- .../views/room_settings/AliasSettings.js | 55 +++++++++++++------ .../tabs/room/GeneralRoomSettingsTab.js | 3 +- 2 files changed, 40 insertions(+), 18 deletions(-) diff --git a/src/components/views/room_settings/AliasSettings.js b/src/components/views/room_settings/AliasSettings.js index ee5a505b32..e441ebfb8a 100644 --- a/src/components/views/room_settings/AliasSettings.js +++ b/src/components/views/room_settings/AliasSettings.js @@ -74,7 +74,6 @@ export default class AliasSettings extends React.Component { roomId: PropTypes.string.isRequired, canSetCanonicalAlias: PropTypes.bool.isRequired, canSetAliases: PropTypes.bool.isRequired, - aliasEvents: PropTypes.array, // [MatrixEvent] canonicalAliasEvent: PropTypes.object, // MatrixEvent }; @@ -94,27 +93,49 @@ export default class AliasSettings extends React.Component { updatingCanonicalAlias: false, }; - const localDomain = MatrixClientPeg.get().getDomain(); - state.domainToAliases = this.aliasEventsToDictionary(props.aliasEvents || []); - state.remoteDomains = Object.keys(state.domainToAliases).filter((domain) => { - return domain !== localDomain && state.domainToAliases[domain].length > 0; - }); - if (props.canonicalAliasEvent) { + const cli = MatrixClientPeg.get(); + const localDomain = cli.getDomain(); + state.domainToAliases = this.aliasesToDictionary(this._getAltAliases()); + state.remoteDomains = Object.keys(state.domainToAliases).filter((domain) => { + return domain !== localDomain && state.domainToAliases[domain].length > 0; + }); state.canonicalAlias = props.canonicalAliasEvent.getContent().alias; } this.state = state; } - aliasEventsToDictionary(aliasEvents) { // m.room.alias events - const dict = {}; - aliasEvents.forEach((event) => { - dict[event.getStateKey()] = ( - (event.getContent().aliases || []).slice() // shallow-copy - ); - }); - return dict; + async componentWillMount() { + const cli = MatrixClientPeg.get(); + const response = await cli.getLocalAliases(this.props.roomId); + const localAliases = response.aliases; + const localDomain = cli.getDomain(); + const domainToAliases = Object.assign( + {}, + this.state.domainToAliases, + {[localDomain]: localAliases || []}, + ); + this.setState({ domainToAliases }); + } + + aliasesToDictionary(aliases) { + return aliases.reduce((dict, alias) => { + const domain = alias.split(":")[1]; + dict[domain] = dict[domain] || []; + dict[domain].push(alias); + return dict; + }, {}); + } + + _getAltAliases() { + if (this.props.canonicalAliasEvent) { + const altAliases = this.props.canonicalAliasEvent.getContent().alt_aliases; + if (Array.isArray(altAliases)) { + return altAliases; + } + } + return []; } changeCanonicalAlias(alias) { @@ -125,7 +146,9 @@ export default class AliasSettings extends React.Component { updatingCanonicalAlias: true, }); - const eventContent = {}; + const eventContent = { + alt_aliases: this._getAltAliases(), + }; if (alias) eventContent["alias"] = alias; MatrixClientPeg.get().sendStateEvent(this.props.roomId, "m.room.canonical_alias", diff --git a/src/components/views/settings/tabs/room/GeneralRoomSettingsTab.js b/src/components/views/settings/tabs/room/GeneralRoomSettingsTab.js index b65f8d49a4..098c07b825 100644 --- a/src/components/views/settings/tabs/room/GeneralRoomSettingsTab.js +++ b/src/components/views/settings/tabs/room/GeneralRoomSettingsTab.js @@ -78,7 +78,6 @@ export default class GeneralRoomSettingsTab extends React.Component { const canActuallySetAliases = room.currentState.mayClientSendStateEvent("m.room.aliases", client); const canSetCanonical = room.currentState.mayClientSendStateEvent("m.room.canonical_alias", client); const canonicalAliasEv = room.currentState.getStateEvents("m.room.canonical_alias", ''); - const aliasEvents = room.currentState.getStateEvents("m.room.aliases"); const canChangeGroups = room.currentState.mayClientSendStateEvent("m.room.related_groups", client); const groupsEvent = room.currentState.getStateEvents("m.room.related_groups", ""); @@ -94,7 +93,7 @@ export default class GeneralRoomSettingsTab extends React.Component {
+ canonicalAliasEvent={canonicalAliasEv} />
Date: Wed, 19 Feb 2020 10:06:52 +0100 Subject: [PATCH 2/2] check server feature flag if not available, revert to old behavior --- .../views/room_settings/AliasSettings.js | 54 ++++++++++++------- .../tabs/room/GeneralRoomSettingsTab.js | 3 +- 2 files changed, 38 insertions(+), 19 deletions(-) diff --git a/src/components/views/room_settings/AliasSettings.js b/src/components/views/room_settings/AliasSettings.js index e441ebfb8a..d7befa488d 100644 --- a/src/components/views/room_settings/AliasSettings.js +++ b/src/components/views/room_settings/AliasSettings.js @@ -94,12 +94,6 @@ export default class AliasSettings extends React.Component { }; if (props.canonicalAliasEvent) { - const cli = MatrixClientPeg.get(); - const localDomain = cli.getDomain(); - state.domainToAliases = this.aliasesToDictionary(this._getAltAliases()); - state.remoteDomains = Object.keys(state.domainToAliases).filter((domain) => { - return domain !== localDomain && state.domainToAliases[domain].length > 0; - }); state.canonicalAlias = props.canonicalAliasEvent.getContent().alias; } @@ -108,15 +102,29 @@ export default class AliasSettings extends React.Component { async componentWillMount() { const cli = MatrixClientPeg.get(); - const response = await cli.getLocalAliases(this.props.roomId); - const localAliases = response.aliases; - const localDomain = cli.getDomain(); - const domainToAliases = Object.assign( - {}, - this.state.domainToAliases, - {[localDomain]: localAliases || []}, - ); - this.setState({ domainToAliases }); + if (await cli.doesServerSupportUnstableFeature("org.matrix.msc2432")) { + const response = await cli.unstableGetLocalAliases(this.props.roomId); + const localAliases = response.aliases; + const localDomain = cli.getDomain(); + const domainToAliases = Object.assign( + {}, + // FIXME, any localhost alt_aliases will be ignored as they are overwritten by localAliases + this.aliasesToDictionary(this._getAltAliases()), + {[localDomain]: localAliases || []}, + ); + const remoteDomains = Object.keys(domainToAliases).filter((domain) => { + return domain !== localDomain && domainToAliases[domain].length > 0; + }); + this.setState({ domainToAliases, remoteDomains }); + } else { + const state = {}; + const localDomain = cli.getDomain(); + state.domainToAliases = this.aliasEventsToDictionary(this.props.aliasEvents || []); + state.remoteDomains = Object.keys(state.domainToAliases).filter((domain) => { + return domain !== localDomain && state.domainToAliases[domain].length > 0; + }); + this.setState(state); + } } aliasesToDictionary(aliases) { @@ -128,6 +136,16 @@ export default class AliasSettings extends React.Component { }, {}); } + aliasEventsToDictionary(aliasEvents) { // m.room.alias events + const dict = {}; + aliasEvents.forEach((event) => { + dict[event.getStateKey()] = ( + (event.getContent().aliases || []).slice() // shallow-copy + ); + }); + return dict; + } + _getAltAliases() { if (this.props.canonicalAliasEvent) { const altAliases = this.props.canonicalAliasEvent.getContent().alt_aliases; @@ -146,9 +164,9 @@ export default class AliasSettings extends React.Component { updatingCanonicalAlias: true, }); - const eventContent = { - alt_aliases: this._getAltAliases(), - }; + const eventContent = {}; + const altAliases = this._getAltAliases(); + if (altAliases) eventContent["alt_aliases"] = altAliases; if (alias) eventContent["alias"] = alias; MatrixClientPeg.get().sendStateEvent(this.props.roomId, "m.room.canonical_alias", diff --git a/src/components/views/settings/tabs/room/GeneralRoomSettingsTab.js b/src/components/views/settings/tabs/room/GeneralRoomSettingsTab.js index 098c07b825..b65f8d49a4 100644 --- a/src/components/views/settings/tabs/room/GeneralRoomSettingsTab.js +++ b/src/components/views/settings/tabs/room/GeneralRoomSettingsTab.js @@ -78,6 +78,7 @@ export default class GeneralRoomSettingsTab extends React.Component { const canActuallySetAliases = room.currentState.mayClientSendStateEvent("m.room.aliases", client); const canSetCanonical = room.currentState.mayClientSendStateEvent("m.room.canonical_alias", client); const canonicalAliasEv = room.currentState.getStateEvents("m.room.canonical_alias", ''); + const aliasEvents = room.currentState.getStateEvents("m.room.aliases"); const canChangeGroups = room.currentState.mayClientSendStateEvent("m.room.related_groups", client); const groupsEvent = room.currentState.getStateEvents("m.room.related_groups", ""); @@ -93,7 +94,7 @@ export default class GeneralRoomSettingsTab extends React.Component {
+ canonicalAliasEvent={canonicalAliasEv} aliasEvents={aliasEvents} />