about summary refs log tree commit diff
path: root/hosted/challenges.html
diff options
context:
space:
mode:
Diffstat (limited to 'hosted/challenges.html')
-rw-r--r--hosted/challenges.html73
1 files changed, 73 insertions, 0 deletions
diff --git a/hosted/challenges.html b/hosted/challenges.html
new file mode 100644
index 0000000..067a110
--- /dev/null
+++ b/hosted/challenges.html
@@ -0,0 +1,73 @@
+<!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>
+    </head>
+    <script id="body-template" type="text/x-handlebars-template">
+        <div class="container">
+            {{#each challenges}}
+                <div class="card {{#if foundFlag}}border-success{{/if}}" style="margin-bottom: 20px">
+                    <div class="card-header">
+                        {{ name }}
+                        <span class="badge badge-light">
+                            {{ category }}
+                        </span>
+                    </div>
+                    <div class="card-body">
+                        <p>
+                            {{{ description }}}
+                        </p>
+                        {{#if foundFlag}}
+                            <p class="text-success">Flag found!</p>
+                        {{else}}
+                            <form class="input-group mb-3" method="POST" action="/api/submitFlag">
+                                <input type="hidden" name="challengeName" value="{{ name }}">
+                                <input type="text" class="form-control" placeholder="Case-sensitive flag, like: CIRCUS{this-is-an-3x4mpl3!}" aria-label="Flag" aria-describedby="button-submit" name="flag">
+                                <div class="input-group-append">
+                                    <button class="btn btn-outline-primary" type="submit" id="button-submit">Submit flag</button>
+                                </div>
+                            </form>
+                        {{/if}}
+                    </div>
+                </div>
+            {{/each}}
+        </div>
+    </script>
+    <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="/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" id="challenge-list">
+        </main>
+    </body>
+    <script type="text/javascript">
+        var template = Handlebars.compile($("#body-template").html());
+        $.ajax({
+            url: "/api/getChallenges",
+            success: function(result) {
+                $("#challenge-list").html(
+                    template(jQuery.parseJSON(result))
+                );
+            }
+        });
+    </script>
+</html>
\ No newline at end of file