about summary refs log tree commit diff
path: root/hosted/access.html
blob: 5a25fd0c343237af37c6dd106f6a4b8f6ba64e8b (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
<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8">
        <link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.1.3/css/bootstrap.min.css" integrity="sha384-MCw98/SFnGE8fJT3GXwEOngsV7Zt27NXFoaoApmYm81iuXoPkFOJwJ8ERdknLPMO" crossorigin="anonymous">
        <script type="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/handlebars.js/4.0.11/handlebars.min.js"></script>
        <script type="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
        <style type="text/css">
            body {
                overflow-y: scroll;
            }
        </style>
    </head>
    <body>
        <nav class="navbar navbar-expand-md navbar-dark bg-dark mb-4">
            <a class="navbar-brand" href="/">Companion</a>
            <button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbarCollapse" aria-controls="navbarCollapse" aria-expanded="false" aria-label="Toggle navigation">
                <span class="navbar-toggler-icon"></span>
            </button>
            <div class="collapse navbar-collapse" id="navbarCollapse">
                <ul class="navbar-nav mr-auto">
                    <li class="nav-item">
                        <a class="nav-link" href="/">Home <span class="sr-only">(current)</span></a>
                    </li>
                    <li class="nav-item active">
                        <a class="nav-link" href="/access">Access</a>
                    </li>
                    <li class="nav-item">
                        <a class="nav-link" href="/challenges">Challenges</a>
                    </li>
                </ul>
                <form class="form-inline mt-2 mt-md-0" action="/logout" method="post">
                    <button class="btn btn-outline-danger my-2 my-sm-0" type="submit">Logout</button>
                </form>
            </div>
        </nav>
        <main class="container" role="main">
            <div class="card">
                <div class="card-header">
                    Access
                </div>
                <div class="card-body">
                    Access to the challenge containers is provided via OpenVPN.
                    <hr>
                    <button class="btn btn-secondary" onclick="loadConfig()">Reload</button>
                    <button class="btn btn-primary" onclick="downloadConfig()">Download</button>
                    <hr>
                    <pre><code id="config">Loading...</code></pre>
                </div>
            </div>
            <br>
        </main>
        <script>
            function loadConfig() {
                $("#config").html("Loading...");
                $.get("/api/getAccess").done(function(data) {
                    var result = jQuery.parseJSON(data);
                    $("#config").text(result["credentials"]);
                });
            }

            function downloadConfig() {
                $.get("/api/getAccess").done(function(data) {
                    var result = jQuery.parseJSON(data);
                    var configBlob = new Blob([result["credentials"]], {'type':'application/x-openvpn-config'});
                    window.location = URL.createObjectURL(configBlob);
                });
            }

            $(document).ready(
                function(){
                    loadConfig()
                }
            );
        </script>
    </body>
</html>