Add support for CAS auth
This commit is contained in:
parent
a05437e81f
commit
a8d51cdf58
|
@ -64,6 +64,7 @@ skin['molecules.UserSelector'] = require('./views/molecules/UserSelector');
|
||||||
skin['molecules.voip.CallView'] = require('./views/molecules/voip/CallView');
|
skin['molecules.voip.CallView'] = require('./views/molecules/voip/CallView');
|
||||||
skin['molecules.voip.IncomingCallBox'] = require('./views/molecules/voip/IncomingCallBox');
|
skin['molecules.voip.IncomingCallBox'] = require('./views/molecules/voip/IncomingCallBox');
|
||||||
skin['molecules.voip.VideoView'] = require('./views/molecules/voip/VideoView');
|
skin['molecules.voip.VideoView'] = require('./views/molecules/voip/VideoView');
|
||||||
|
skin['organisms.CasLogin'] = require('./views/organisms/CasLogin');
|
||||||
skin['organisms.CreateRoom'] = require('./views/organisms/CreateRoom');
|
skin['organisms.CreateRoom'] = require('./views/organisms/CreateRoom');
|
||||||
skin['organisms.ErrorDialog'] = require('./views/organisms/ErrorDialog');
|
skin['organisms.ErrorDialog'] = require('./views/organisms/ErrorDialog');
|
||||||
skin['organisms.LeftPanel'] = require('./views/organisms/LeftPanel');
|
skin['organisms.LeftPanel'] = require('./views/organisms/LeftPanel');
|
||||||
|
|
|
@ -0,0 +1,50 @@
|
||||||
|
/*
|
||||||
|
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('matrix-react-sdk/lib/MatrixClientPeg');
|
||||||
|
|
||||||
|
module.exports = React.createClass({
|
||||||
|
displayName: 'CasLogin',
|
||||||
|
|
||||||
|
getInitialState: function() {
|
||||||
|
var splitLocation = window.location.href.split('/');
|
||||||
|
return {serviceUrl: splitLocation[0] + "//" + splitLocation[2]};
|
||||||
|
},
|
||||||
|
|
||||||
|
onCasClicked: function(ev) {
|
||||||
|
var serviceRedirectUrl = this.state.serviceUrl + "/#/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.'});
|
||||||
|
});
|
||||||
|
},
|
||||||
|
|
||||||
|
render: function() {
|
||||||
|
return (
|
||||||
|
<div>
|
||||||
|
<button onClick={this.onCasClicked}>Sign in with CAS</button>
|
||||||
|
</div>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
});
|
|
@ -141,6 +141,11 @@ module.exports = React.createClass({
|
||||||
</form>
|
</form>
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
|
case 'stage_m.login.cas':
|
||||||
|
var CasLogin = sdk.getComponent('organisms.CasLogin');
|
||||||
|
return (
|
||||||
|
<CasLogin />
|
||||||
|
);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
|
|
@ -23,22 +23,29 @@ sdk.loadModule(require('../modules/VectorConferenceHandler'));
|
||||||
|
|
||||||
var lastLocationHashSet = null;
|
var lastLocationHashSet = null;
|
||||||
|
|
||||||
|
|
||||||
|
function parseQueryParams(location) {
|
||||||
|
var hashparts = location.hash.split('?');
|
||||||
|
var params = {};
|
||||||
|
if (hashparts.length == 2) {
|
||||||
|
var pairs = hashparts[1].split('&');
|
||||||
|
for (var i = 0; i < pairs.length; ++i) {
|
||||||
|
var parts = pairs[i].split('=');
|
||||||
|
if (parts.length != 2) continue;
|
||||||
|
params[decodeURIComponent(parts[0])] = decodeURIComponent(parts[1]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return params
|
||||||
|
}
|
||||||
|
|
||||||
// Here, we do some crude URL analysis to allow
|
// Here, we do some crude URL analysis to allow
|
||||||
// deep-linking. We only support registration
|
// deep-linking. We only support registration
|
||||||
// deep-links in this example.
|
// deep-links in this example.
|
||||||
function routeUrl(location) {
|
function routeUrl(location) {
|
||||||
if (location.hash.indexOf('#/register') == 0) {
|
if (location.hash.indexOf('#/register') == 0) {
|
||||||
var hashparts = location.hash.split('?');
|
window.matrixChat.showScreen('register', parseQueryParams(location));
|
||||||
var params = {};
|
} else if (location.hash.indexOf('#/login/cas') == 0) {
|
||||||
if (hashparts.length == 2) {
|
window.matrixChat.showScreen('cas_login', parseQueryParams(location));
|
||||||
var pairs = hashparts[1].split('&');
|
|
||||||
for (var i = 0; i < pairs.length; ++i) {
|
|
||||||
var parts = pairs[i].split('=');
|
|
||||||
if (parts.length != 2) continue;
|
|
||||||
params[decodeURIComponent(parts[0])] = decodeURIComponent(parts[1]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
window.matrixChat.showScreen('register', params);
|
|
||||||
} else {
|
} else {
|
||||||
window.matrixChat.showScreen(location.hash.substring(2));
|
window.matrixChat.showScreen(location.hash.substring(2));
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue