diff --git a/src/components/structures/RoomView.js b/src/components/structures/RoomView.js index 8ad81a13432..6c17aa415a9 100644 --- a/src/components/structures/RoomView.js +++ b/src/components/structures/RoomView.js @@ -151,6 +151,10 @@ module.exports = React.createClass({ auxPanelMaxHeight: undefined, statusBarVisible: false, + + // We load this later by asking the js-sdk to suggest a version for us. + // This object is the result of Room#getRecommendedVersion() + upgradeRecommendation: null, }; }, @@ -637,6 +641,13 @@ module.exports = React.createClass({ this._calculatePeekRules(room); this._updatePreviewUrlVisibility(room); this._loadMembersIfJoined(room); + this._calculateRecommendedVersion(room); + }, + + _calculateRecommendedVersion: async function(room) { + this.setState({ + upgradeRecommendation: await room.getRecommendedVersion(), + }); }, _loadMembersIfJoined: async function(room) { @@ -1661,8 +1672,10 @@ module.exports = React.createClass({ />; } + const roomVersionRecommendation = this.state.upgradeRecommendation; const showRoomUpgradeBar = ( - this.state.room.shouldUpgradeToVersion() && + roomVersionRecommendation && + roomVersionRecommendation.needsUpgrade && this.state.room.userMayUpgradeRoom(MatrixClientPeg.get().credentials.userId) ); @@ -1685,7 +1698,7 @@ module.exports = React.createClass({ hideCancel = true; // has own cancel aux = ; } else if (showRoomUpgradeBar) { - aux = ; + aux = ; hideCancel = true; } else if (showRoomRecoveryReminder) { aux = ; diff --git a/src/components/views/dialogs/RoomUpgradeDialog.js b/src/components/views/dialogs/RoomUpgradeDialog.js index 936ff745d1a..403fbf4f777 100644 --- a/src/components/views/dialogs/RoomUpgradeDialog.js +++ b/src/components/views/dialogs/RoomUpgradeDialog.js @@ -29,13 +29,15 @@ export default React.createClass({ onFinished: PropTypes.func.isRequired, }, - componentWillMount: function() { - this._targetVersion = this.props.room.shouldUpgradeToVersion(); + componentWillMount: async function() { + const recommended = await this.props.room.getRecommendedVersion(); + this._targetVersion = recommended.version; + this.setState({busy: false}); }, getInitialState: function() { return { - busy: false, + busy: true, }; }, diff --git a/src/components/views/rooms/RoomUpgradeWarningBar.js b/src/components/views/rooms/RoomUpgradeWarningBar.js index 75a5901fc9c..3a11f46e51f 100644 --- a/src/components/views/rooms/RoomUpgradeWarningBar.js +++ b/src/components/views/rooms/RoomUpgradeWarningBar.js @@ -26,6 +26,7 @@ module.exports = React.createClass({ propTypes: { room: PropTypes.object.isRequired, + recommendation: PropTypes.object.isRequired, }, onUpgradeClick: function() { @@ -35,19 +36,42 @@ module.exports = React.createClass({ render: function() { const AccessibleButton = sdk.getComponent('elements.AccessibleButton'); - return ( -
-
- {_t("There is a known vulnerability affecting this room.")} -
+ + let upgradeText = ( +
- {_t("This room version is vulnerable to malicious modification of room state.")} + {_t("This room is using an unstable room version. If you aren't expecting " + + "this, please upgrade the room.")}

- {_t("Click here to upgrade to the latest room version and ensure room integrity is protected.")} + {_t("Click here to upgrade to the latest room version.")}

+
+ ); + if (this.props.recommendation.urgent) { + upgradeText = ( +
+
+ {_t("There is a known vulnerability affecting this room.")} +
+
+ {_t("This room version is vulnerable to malicious modification of room state.")} +
+

+ + {_t("Click here to upgrade to the latest room version and ensure room integrity " + + "is protected.")} + +

+
+ ); + } + + return ( +
+ {upgradeText}
{_t("Only room administrators will see this warning")}
diff --git a/src/i18n/strings/en_EN.json b/src/i18n/strings/en_EN.json index f04c62cbbb4..884c2c471ed 100644 --- a/src/i18n/strings/en_EN.json +++ b/src/i18n/strings/en_EN.json @@ -743,6 +743,8 @@ "Internal room ID: ": "Internal room ID: ", "Room version number: ": "Room version number: ", "Add a topic": "Add a topic", + "This room is using an unstable room version. If you aren't expecting this, please upgrade the room.": "This room is using an unstable room version. If you aren't expecting this, please upgrade the room.", + "Click here to upgrade to the latest room version.": "Click here to upgrade to the latest room version.", "There is a known vulnerability affecting this room.": "There is a known vulnerability affecting this room.", "This room version is vulnerable to malicious modification of room state.": "This room version is vulnerable to malicious modification of room state.", "Click here to upgrade to the latest room version and ensure room integrity is protected.": "Click here to upgrade to the latest room version and ensure room integrity is protected.",