Welcome to mirror list, hosted at ThFree Co, Russian Federation.

u2f.js « src « js - github.com/phpmyadmin/phpmyadmin.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: ef0bb803eb5a473383524184c5be9bc9a9f29483 (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
window.AJAX.registerOnload('u2f.js', function () {
    var $inputReg = $('#u2f_registration_response');
    if ($inputReg.length > 0) {
        var $formReg = $inputReg.parents('form');
        $formReg.find('input[type=submit]').hide();
        setTimeout(function () {
            // A magic JS function that talks to the USB device. This function will keep polling for the USB device until it finds one.
            var request = JSON.parse($inputReg.attr('data-request'));
            window.u2f.register(request.appId, [request], JSON.parse($inputReg.attr('data-signatures')), function (data) {
                // Handle returning error data
                if (data.errorCode && data.errorCode !== 0) {
                    switch (data.errorCode) {
                    case 5:
                        Functions.ajaxShowMessage(window.Messages.strU2FTimeout, false, 'error');
                        break;
                    case 4:
                        Functions.ajaxShowMessage(window.Messages.strU2FErrorRegister, false, 'error');
                        break;
                    case 3:
                        Functions.ajaxShowMessage(window.Messages.strU2FInvalidClient, false, 'error');
                        break;
                    case 2:
                        Functions.ajaxShowMessage(window.Messages.strU2FBadRequest, false, 'error');
                        break;
                    default:
                        Functions.ajaxShowMessage(window.Messages.strU2FUnknown, false, 'error');
                        break;
                    }
                    return;
                }

                // Fill and submit form.
                $inputReg.val(JSON.stringify(data));
                $formReg.trigger('submit');
            });
        }, 1000);
    }
    var $inputAuth = $('#u2f_authentication_response');
    if ($inputAuth.length > 0) {
        var $formAuth = $inputAuth.parents('form');
        $formAuth.find('input[type=submit]').hide();
        setTimeout(function () {
            // Magic JavaScript talking to your HID
            // appid, challenge, authenticateRequests
            var request = JSON.parse($inputAuth.attr('data-request'));
            window.u2f.sign(request[0].appId, request[0].challenge, request, function (data) {
                // Handle returning error data
                if (data.errorCode && data.errorCode !== 0) {
                    switch (data.errorCode) {
                    case 5:
                        Functions.ajaxShowMessage(window.Messages.strU2FTimeout, false, 'error');
                        break;
                    case 4:
                        Functions.ajaxShowMessage(window.Messages.strU2FErrorAuthenticate, false, 'error');
                        break;
                    case 3:
                        Functions.ajaxShowMessage(window.Messages.strU2FInvalidClient, false, 'error');
                        break;
                    case 2:
                        Functions.ajaxShowMessage(window.Messages.strU2FBadRequest, false, 'error');
                        break;
                    default:
                        Functions.ajaxShowMessage(window.Messages.strU2FUnknown, false, 'error');
                        break;
                    }
                    return;
                }

                // Fill and submit form.
                $inputAuth.val(JSON.stringify(data));
                $formAuth.trigger('submit');
            });
        }, 1000);
    }
});