This repository has been archived by the owner on Jan 31, 2022. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 4
/
newLogin.jsx
118 lines (109 loc) · 2.88 KB
/
newLogin.jsx
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
import React from 'react';
import {withRouter} from 'react-router';
import 'whatwg-fetch';
import Layout from '../../components/layout.jsx';
import auth from '../../../utils/auth.js';
import utils from '../../../utils/utils.js';
var labelStyle = {
width: '4em'
};
module.exports = withRouter(React.createClass({
getInitialState: function(){
return{
error: false,
loading: false,
win: null,
};
},
setVisible: function(){
var popUp = document.getElementById('pu');
popUp.style.display = 'block';
},
setInvisible: function(){
var popUp = document.getElementById('pu');
popUp.style.display = 'none';
},
handleLogin: function(e){
e.preventDefault();
this.setState({
loading:true
});
var email = this.refs.email.value;
var password = this.refs.password.value;
auth.login(email, password, (loggedIn) => {
if(!loggedIn){
return this.setState({
error:true,
loading: false
});
}
const {location} = this.props;
if (location.state && location.state.nextPathname) {
this.props.router.replace(location.state.nextPathname);
} else {
this.props.router.replace('/');
}
});
},
messageReceived: function(text, id, channel){
var json = JSON.parse(atob(text));
this.state.win.close();
if(json.groups.indexOf('Group_3')>-1){
localStorage.g3 = true;
}
if(json.groups.indexOf('Group_4')>-1){
localStorage.g4 = true;
}
utils.setCookie('token', json.token, 7);
const {location} = this.props;
if (location.state && location.state.nextPathname) {
this.props.router.replace(location.state.nextPathname);
} else {
this.props.router.replace('/');
}
this.state.stream.disconnect();
},
login: function(){
this.setState({
win: window.open()
});
var that = this;
fetch('https://enghub.io/api/v1/user.login.getToken/', {
method: 'GET',
mode: 'cors'
}).then(function(res){
if(res.status === 200){
return res.json();
}
}).then(function(json){
var winRef = that.state.win;
winRef.location = json.loginUrl;
that.setState({
win: winRef
});
var pushstream = new PushStream({
useSSL: true,
host: 'enghub.io',
port: 443,
modes: "longpolling",
tagArgument: 'tag',
timeArgument: 'time',
timeout: 30000,
urlPrefixLongpolling: '/api/v1/push.subscribe_longpoll'
});
pushstream.onmessage = that.messageReceived;
pushstream.addChannel(json.sid);
pushstream.connect();
that.setState({
stream: pushstream
});
});
},
render: function() {
return (
<Layout title="Login">
<button className="pure-button pure-button-primary loginButton" onClick={this.login}>Login through UCL</button>
</Layout>
);
}
}));