Skip to content

Commit 5c41625

Browse files
Guido Gröönmrts
authored andcommitted
WE2-759 Log extension unavailable and user cancelled events
1 parent 78df3ac commit 5c41625

File tree

3 files changed

+49
-0
lines changed

3 files changed

+49
-0
lines changed

examples/src/LogWriter.php

Lines changed: 42 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,42 @@
1+
<?php
2+
3+
/*
4+
* Copyright (c) 2020-2021 Estonian Information System Authority
5+
*
6+
* Permission is hereby granted, free of charge, to any person obtaining a copy
7+
* of this software and associated documentation files (the "Software"), to deal
8+
* in the Software without restriction, including without limitation the rights
9+
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
10+
* copies of the Software, and to permit persons to whom the Software is
11+
* furnished to do so, subject to the following conditions:
12+
*
13+
* The above copyright notice and this permission notice shall be included in all
14+
* copies or substantial portions of the Software.
15+
*
16+
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17+
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18+
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
19+
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20+
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
21+
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
22+
* SOFTWARE.
23+
*/
24+
25+
class LogWriter
26+
{
27+
public function add()
28+
{
29+
$code = isset($_POST["code"]) ? $_POST["code"] : "";
30+
$message = isset($_POST["message"]) ? $_POST["message"] : "";
31+
32+
// Allow only certain type error codes
33+
if ($code != "ERR_WEBEID_USER_CANCELLED" || $code != "ERR_WEBEID_EXTENSION_UNAVAILABLE") {
34+
header("HTTP/1.0 405 Method Not Allowed");
35+
echo "Error code is not valid for logging";
36+
}
37+
38+
$logger = new Logger();
39+
$logger->error(sprintf("Code: %s Message: %s", $code, $message));
40+
echo "success";
41+
}
42+
}

examples/src/Router.php

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -35,6 +35,8 @@ public function init()
3535
// Page routes
3636
$router->map("GET", "/", ["controller" => "Pages", "method" => "login"]);
3737
$router->map("GET", "/logout", ["controller" => "Auth", "method" => "logout"]);
38+
// Endpoint for extension errors logging
39+
$router->map("POST", "/logger", ["controller" => "LogWriter", "method" => "add"]);
3840

3941
// Web eID routes
4042
$router->map("GET", "/nonce", ["controller" => "Auth", "method" => "getNonce"]);

examples/tpl/login.phtml

Lines changed: 5 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -60,6 +60,11 @@
6060

6161
} catch (error) {
6262
showErrorMessage(error);
63+
// Log extension error
64+
let formData = new FormData();
65+
formData.append("code", error.code);
66+
formData.append("message", error.message);
67+
fetch("./logger", {method: "POST", body: formData});
6368
throw error;
6469
} finally {
6570
authButton.disabled = false;

0 commit comments

Comments
 (0)