From 3f67d8541ff37bc6474720812dd771f10bf2aaf2 Mon Sep 17 00:00:00 2001 From: Steven Hammerton Date: Thu, 8 Oct 2015 22:25:33 +0100 Subject: [PATCH 1/3] Add support for CAS login --- src/controllers/pages/MatrixChat.js | 30 +++++++++++++++++++++++++++++ 1 file changed, 30 insertions(+) diff --git a/src/controllers/pages/MatrixChat.js b/src/controllers/pages/MatrixChat.js index d1e289c9cc..f92fe51ce2 100644 --- a/src/controllers/pages/MatrixChat.js +++ b/src/controllers/pages/MatrixChat.js @@ -126,6 +126,31 @@ module.exports = { screen: 'login' }); this.notifyNewScreen('login'); + break; + case 'cas_login': + if (this.state.logged_in) return; + + var self = this; + var client = MatrixClientPeg.get(); + var splitLocation = window.location.href.split('/'); + var serviceUrl = splitLocation[0] + "//" + splitLocation[2]; + + client.loginWithCas(payload.params.ticket, serviceUrl).done(function(data) { + MatrixClientPeg.replaceUsingAccessToken( + client.getHsUrl(), client.getIsUrl(), + data.user_id, data.access_token + ); + self.setState({ + screen: undefined, + logged_in: true + }); + self.startMatrixClient(); + self.notifyNewScreen(''); + }, function(error) { + self.notifyNewScreen('login'); + self.setState({errorText: 'Login failed.'}); + }); + break; case 'view_room': this.focusComposer = true; @@ -314,6 +339,11 @@ module.exports = { action: 'start_login', params: params }); + } else if (screen == 'cas_login') { + dis.dispatch({ + action: 'cas_login', + params: params + }); } else if (screen.indexOf('room/') == 0) { var roomString = screen.split('/')[1]; if (roomString[0] == '#') { From 4e0d930014975394b17cff54e06666ccd1e4f6fb Mon Sep 17 00:00:00 2001 From: Steven Hammerton Date: Mon, 12 Oct 2015 10:13:01 +0100 Subject: [PATCH 2/3] Pull down some CAS stuff from vector into controller and logic class --- src/CasLogic.js | 28 ++++++++++++++++++++ src/controllers/organisms/CasLogin.js | 37 +++++++++++++++++++++++++++ src/controllers/pages/MatrixChat.js | 7 ++--- 3 files changed, 69 insertions(+), 3 deletions(-) create mode 100644 src/CasLogic.js create mode 100644 src/controllers/organisms/CasLogin.js diff --git a/src/CasLogic.js b/src/CasLogic.js new file mode 100644 index 0000000000..cd25f8e067 --- /dev/null +++ b/src/CasLogic.js @@ -0,0 +1,28 @@ +/* +Copyright 2015 OpenMarket Ltd + +Licensed under the Apache License, Version 2.0 (the "License"); +you may not use this file except in compliance with the License. +You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + +Unless required by applicable law or agreed to in writing, software +distributed under the License is distributed on an "AS IS" BASIS, +WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +See the License for the specific language governing permissions and +limitations under the License. +*/ + +'use strict'; + +var Url = require ('url'); + +function getServiceUrl() { + var parsedUrl = Url.parse(window.location.href); + return parsedUrl.protocol + "//" + parsedUrl.host + parsedUrl.pathname; +} + +module.exports = { + getServiceUrl: getServiceUrl +}; diff --git a/src/controllers/organisms/CasLogin.js b/src/controllers/organisms/CasLogin.js new file mode 100644 index 0000000000..9c58d32c06 --- /dev/null +++ b/src/controllers/organisms/CasLogin.js @@ -0,0 +1,37 @@ +/* +Copyright 2015 OpenMarket Ltd + +Licensed under the Apache License, Version 2.0 (the "License"); +you may not use this file except in compliance with the License. +You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + +Unless required by applicable law or agreed to in writing, software +distributed under the License is distributed on an "AS IS" BASIS, +WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +See the License for the specific language governing permissions and +limitations under the License. +*/ + +'use strict'; + +var React = require("react"); +var MatrixClientPeg = require("../../MatrixClientPeg"); +var Cas = require("../../CasLogic"); + +module.exports = { + + onCasClicked: function(ev) { + var serviceRedirectUrl = Cas.getServiceUrl() + "#/login/cas"; + var self = this; + MatrixClientPeg.get().getCasServer().done(function(data) { + var serverUrl = data.serverUrl + "/login?service=" + encodeURIComponent(serviceRedirectUrl); + window.location.href = serverUrl; + }, function(error) { + self.setStep("stage_m.login.cas"); + self.setState({errorText: 'Login failed.'}); + }); + }, + +}; diff --git a/src/controllers/pages/MatrixChat.js b/src/controllers/pages/MatrixChat.js index f92fe51ce2..2e93ed184f 100644 --- a/src/controllers/pages/MatrixChat.js +++ b/src/controllers/pages/MatrixChat.js @@ -23,6 +23,8 @@ var q = require("q"); var sdk = require('../../index'); var MatrixTools = require('../../MatrixTools'); +var Cas = require("../../CasLogic"); + module.exports = { PageTypes: { RoomView: "room_view", @@ -132,12 +134,11 @@ module.exports = { var self = this; var client = MatrixClientPeg.get(); - var splitLocation = window.location.href.split('/'); - var serviceUrl = splitLocation[0] + "//" + splitLocation[2]; + var serviceUrl = Cas.getServiceUrl(); client.loginWithCas(payload.params.ticket, serviceUrl).done(function(data) { MatrixClientPeg.replaceUsingAccessToken( - client.getHsUrl(), client.getIsUrl(), + client.getHomeserverUrl(), client.getIdentityServerUrl(), data.user_id, data.access_token ); self.setState({ From fc333067c2fd4eadfa0e25fa92a21c126c8bce5f Mon Sep 17 00:00:00 2001 From: Steven Hammerton Date: Mon, 12 Oct 2015 17:38:04 +0100 Subject: [PATCH 3/3] Rename required var to match convention --- src/CasLogic.js | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/CasLogic.js b/src/CasLogic.js index cd25f8e067..1bcc6d5c78 100644 --- a/src/CasLogic.js +++ b/src/CasLogic.js @@ -16,10 +16,10 @@ limitations under the License. 'use strict'; -var Url = require ('url'); +var url = require ('url'); function getServiceUrl() { - var parsedUrl = Url.parse(window.location.href); + var parsedUrl = url.parse(window.location.href); return parsedUrl.protocol + "//" + parsedUrl.host + parsedUrl.pathname; }