2020-05-08 06:30:40 -06:00
|
|
|
<!DOCTYPE html>
|
|
|
|
<html lang="en">
|
2021-02-01 11:01:15 -07:00
|
|
|
<head>
|
|
|
|
<meta charset="UTF-8">
|
|
|
|
<title>Authentication failed</title>
|
2022-08-11 07:04:20 -06:00
|
|
|
<meta http-equiv="X-UA-Compatible" content="IE=edge">
|
|
|
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
2021-02-01 11:01:15 -07:00
|
|
|
<style type="text/css">
|
|
|
|
{% include "sso.css" without context %}
|
|
|
|
|
|
|
|
#error_code {
|
|
|
|
margin-top: 56px;
|
|
|
|
}
|
|
|
|
</style>
|
|
|
|
</head>
|
|
|
|
<body class="error_page">
|
2020-09-14 07:05:36 -06:00
|
|
|
{# If an error of unauthorised is returned it means we have actively rejected their login #}
|
|
|
|
{% if error == "unauthorised" %}
|
2021-02-01 11:01:15 -07:00
|
|
|
<header>
|
|
|
|
<p>You are not allowed to log in here.</p>
|
|
|
|
</header>
|
2020-09-14 07:05:36 -06:00
|
|
|
{% else %}
|
2021-02-01 11:01:15 -07:00
|
|
|
<header>
|
|
|
|
<h1>There was an error</h1>
|
|
|
|
<p>
|
2021-02-01 11:46:12 -07:00
|
|
|
<strong id="errormsg">{{ error_description }}</strong>
|
2021-02-01 11:01:15 -07:00
|
|
|
</p>
|
|
|
|
<p>
|
|
|
|
If you are seeing this page after clicking a link sent to you via email,
|
|
|
|
make sure you only click the confirmation link once, and that you open
|
|
|
|
the validation link in the same client you're logging in from.
|
|
|
|
</p>
|
|
|
|
<p>
|
|
|
|
Try logging in again from your Matrix client and if the problem persists
|
|
|
|
please contact the server's administrator.
|
|
|
|
</p>
|
|
|
|
<div id="error_code">
|
|
|
|
<p><strong>Error code</strong></p>
|
2021-02-01 11:46:12 -07:00
|
|
|
<p>{{ error }}</p>
|
2021-02-01 11:01:15 -07:00
|
|
|
</div>
|
|
|
|
</header>
|
2021-02-03 13:31:23 -07:00
|
|
|
{% include "sso_footer.html" without context %}
|
2020-09-14 07:05:36 -06:00
|
|
|
|
2021-02-01 11:01:15 -07:00
|
|
|
<script type="text/javascript">
|
|
|
|
// Error handling to support Auth0 errors that we might get through a GET request
|
|
|
|
// to the validation endpoint. If an error is provided, it's either going to be
|
|
|
|
// located in the query string or in a query string-like URI fragment.
|
|
|
|
// We try to locate the error from any of these two locations, but if we can't
|
|
|
|
// we just don't print anything specific.
|
|
|
|
let searchStr = "";
|
|
|
|
if (window.location.search) {
|
|
|
|
// window.location.searchParams isn't always defined when
|
|
|
|
// window.location.search is, so it's more reliable to parse the latter.
|
|
|
|
searchStr = window.location.search;
|
|
|
|
} else if (window.location.hash) {
|
|
|
|
// Replace the # with a ? so that URLSearchParams does the right thing and
|
|
|
|
// doesn't parse the first parameter incorrectly.
|
|
|
|
searchStr = window.location.hash.replace("#", "?");
|
|
|
|
}
|
2020-09-14 07:05:36 -06:00
|
|
|
|
2021-02-01 11:01:15 -07:00
|
|
|
// We might end up with no error in the URL, so we need to check if we have one
|
|
|
|
// to print one.
|
|
|
|
let errorDesc = new URLSearchParams(searchStr).get("error_description")
|
|
|
|
if (errorDesc) {
|
|
|
|
document.getElementById("errormsg").innerText = errorDesc;
|
|
|
|
}
|
|
|
|
</script>
|
2020-09-14 07:05:36 -06:00
|
|
|
{% endif %}
|
2020-05-08 06:30:40 -06:00
|
|
|
</body>
|
|
|
|
</html>
|