summaryrefslogtreecommitdiff
path: root/js/codeq/upgrade_to_aai.js
blob: 88dd26db15ed87457422700ea4eabf38324e8d79 (plain)
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
/* CodeQ: an online programming tutor.
   Copyright (C) 2015 UL FRI

This program is free software: you can redistribute it and/or modify it under
the terms of the GNU Affero General Public License as published by the Free
Software Foundation, either version 3 of the License, or (at your option) any
later version.

This program is distributed in the hope that it will be useful, but WITHOUT
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more
details.

You should have received a copy of the GNU Affero General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>. */

/**
 * Created by markop on 11/02/15.
 *
 */
(function(){
    "use strict";
    var jqScreen = $("#screen-upgrade-to-aai"),
        jqForm = $('#upgrade-to-aai-form'),
        jqNoBtn = $('#upgrade-to-aai-cancel'),
        jqPassword = $('#upgrade-to-aai-password'),
        jqLangSelect = jqScreen.find('.lang-select'),
        jqMessages = jqForm.find('.error,.success');

    codeq.globalStateMachine.register('upgradeToAAI',{
        'jqScreen': jqScreen,

        'enter': function () {
            jqMessages.hide();

            jqNoBtn.on('click',function(){
                codeq.comms.samlLogin(false)
                    .then(codeq.loginCallbackFunction)
                    .fail(function(reason){
                        if(codeq.samlLogin){//if the user goes back to the normal login screen the timeout (which will happen) mustn't do anything
                            codeq.log.error('SAML login failed: ' + reason);
                            alert('SAML login failed: ' + reason);
                            codeq.globalStateMachine.transition('login');
                        }
                    })
                    .done();
            });
            jqForm.on('submit', function (e) {
                e.preventDefault();
                jqMessages.hide();
                codeq.comms.samlLogin(true, jqPassword.val())
                    .then(function(data){
                        if (data.code == 4) {  // incorrect password
                            jqForm.find('.error.wrong-password').show();
                        }
                        else {  // ok or other
                            codeq.loginCallbackFunction(data);
                        }
                    })
                    .fail(function(reason){
                        if(codeq.samlLogin){//if the user goes back to the normal login screen the timeout (which will happen) mustn't do anything
                            codeq.log.error('SAML login failed: ' + reason);
                            alert('SAML login failed: ' + reason);
                            codeq.globalStateMachine.transition('login');
                        }
                    })
                    .done();

            });

            // setup language selection links
            jqLangSelect.on('click', function (e) {
                codeq.setLang($(this).data('lang'));
                e.preventDefault();
            });

            jqScreen.css('display', '');
            $('#disabled').css('display', 'none');
        },
        'exit' : function(){
            jqMessages.hide();
            jqNoBtn.off('click');
            jqForm.off('submit');
            jqLangSelect.off('click');
            jqScreen.css('display', 'none');
            jqPassword.val('');
        }
    });
})();