Better handle ajax errors

This commit is contained in:
Bartek Fabiszewski 2017-05-19 10:59:27 +02:00
parent 4dd920ae41
commit 52a36c2957
6 changed files with 78 additions and 54 deletions

View File

@ -32,7 +32,7 @@ session_start();
$sid = session_id(); $sid = session_id();
// check for forced login to authorize admin in case of public access // check for forced login to authorize admin in case of public access
$force_login = (isset($_REQUEST['force_login']) ? $_REQUEST['force_login'] : false); $force_login = isset($_REQUEST['force_login']) ? $_REQUEST['force_login'] : false;
if ($force_login) { if ($force_login) {
uConfig::$require_authentication = true; uConfig::$require_authentication = true;
} }
@ -41,10 +41,10 @@ $user = new uUser();
$user->getFromSession(); $user->getFromSession();
if (!$user->isValid && (uConfig::$require_authentication || defined('client'))) { if (!$user->isValid && (uConfig::$require_authentication || defined('client'))) {
/* authentication */ /* authentication */
$login = (isset($_REQUEST['user']) ? $_REQUEST['user'] : NULL); $login = isset($_REQUEST['user']) ? $_REQUEST['user'] : NULL;
$pass = (isset($_REQUEST['pass']) ? $_REQUEST['pass'] : NULL); $pass = isset($_REQUEST['pass']) ? $_REQUEST['pass'] : NULL;
$ssl = ((!isset($_SERVER['HTTPS']) || $_SERVER['HTTPS'] == "" || $_SERVER['HTTPS'] == "off") ? "http" : "https"); $ssl = (!isset($_SERVER['HTTPS']) || $_SERVER['HTTPS'] == "" || $_SERVER['HTTPS'] == "off") ? "http" : "https";
$auth_error = (isset($_REQUEST['auth_error']) ? $_REQUEST['auth_error'] : 0); $auth_error = isset($_REQUEST['auth_error']) ? $_REQUEST['auth_error'] : false;
if (!$login) { if (!$login) {
// not authenticated and username not submited // not authenticated and username not submited
@ -87,9 +87,10 @@ if (!$user->isValid && (uConfig::$require_authentication || defined('client')))
<input type="password" name="pass"><br> <input type="password" name="pass"><br>
<br> <br>
<input type="submit" value="' . $lang["login"] . '"> <input type="submit" value="' . $lang["login"] . '">
' . (($force_login == 1) ? "<input type=\"hidden\" name=\"force_login\" value=\"1\">" : "") . ' ' . (($force_login) ? '<input type="hidden" name="force_login" value="1">
<div id="cancel"><a href="index.php">' . $lang["cancel"] . '</a></div>' : '') . '
</form> </form>
<div id="error">' . (($auth_error == 1) ? $lang["authfail"] : "") . '</div> <div id="error">' . (($auth_error) ? $lang["authfail"] : "") . '</div>
</div> </div>
</body> </body>
</html>'; </html>';
@ -114,6 +115,7 @@ if (!$user->isValid && (uConfig::$require_authentication || defined('client')))
} else { } else {
// unsuccessful // unsuccessful
$error = "?auth_error=1"; $error = "?auth_error=1";
if ($force_login) { $error .= "&force_login=1"; }
// destroy session // destroy session
$_SESSION = NULL; $_SESSION = NULL;
if (isset($_COOKIE[session_name('ulogger')])) { if (isset($_COOKIE[session_name('ulogger')])) {

View File

@ -278,6 +278,10 @@ button {
margin-right: 5px; margin-right: 5px;
} }
#cancel {
margin-top: 0.5em;
}
.red-button { .red-button {
color: white; color: white;
float: right; float: right;

View File

@ -28,7 +28,7 @@
*/ */
class uConfig { class uConfig {
// version number // version number
static $version = "0.2"; static $version = "0.3-beta";
// default map drawing framework // default map drawing framework
static $mapapi = "openlayers"; static $mapapi = "openlayers";

View File

@ -81,26 +81,32 @@ function submitUser(action) {
} }
var xhr = getXHR(); var xhr = getXHR();
xhr.onreadystatechange = function() { xhr.onreadystatechange = function() {
if (xhr.readyState == 4 && xhr.status == 200) { if (xhr.readyState == 4) {
var xml = xhr.responseXML; var error = true;
var message = ""; var message = "";
if (xml) { if (xhr.status == 200) {
var root = xml.getElementsByTagName('root'); var xml = xhr.responseXML;
if (root.length && getNode(root[0], 'error') == 0) { if (xml) {
removeModal(); var root = xml.getElementsByTagName('root');
alert(lang['actionsuccess']); if (root.length && getNode(root[0], 'error') == 0) {
if (action == 'delete') { removeModal();
// select current user in users form alert(lang['actionsuccess']);
var f = document.getElementsByName('user')[0]; if (action == 'delete') {
f.remove(f.selectedIndex); // select current user in users form
selectUser(f); var f = document.getElementsByName('user')[0];
f.remove(f.selectedIndex);
selectUser(f);
}
error = false;
} else if (root.length) {
errorMsg = getNode(root[0], 'message');
if (errorMsg) { message = errorMsg; }
} }
return;
} }
errorMsg = getNode(root[0], 'message');
if (errorMsg) { message = errorMsg; }
} }
alert(lang['actionfailure'] + '\n' + message); if (error) {
alert(lang['actionfailure'] + '\n' + message);
}
xhr = null; xhr = null;
} }
} }

View File

@ -46,20 +46,26 @@ function submitPass() {
var xhr = getXHR(); var xhr = getXHR();
xhr.onreadystatechange = function () { xhr.onreadystatechange = function () {
if (xhr.readyState == 4 && xhr.status == 200) { if (xhr.readyState == 4) {
var xml = xhr.responseXML; var error = true;
var message = ""; var message = "";
if (xml) { if (xhr.status == 200) {
var root = xml.getElementsByTagName('root'); var xml = xhr.responseXML;
if (root.length && getNode(root[0], 'error') == 0) { if (xml) {
removeModal(); var root = xml.getElementsByTagName('root');
alert(lang["actionsuccess"]); if (root.length && getNode(root[0], 'error') == 0) {
return; removeModal();
alert(lang["actionsuccess"]);
error = false;
} else if (root.length) {
errorMsg = getNode(root[0], 'message');
if (errorMsg) { message = errorMsg; }
}
} }
errorMsg = getNode(root[0], 'message');
if (errorMsg) { message = errorMsg; }
} }
alert(lang['actionfailure'] + '\n' + message); if (error) {
alert(lang['actionfailure'] + '\n' + message);
}
xhr = null; xhr = null;
} }
} }

View File

@ -65,29 +65,35 @@ function submitTrack(action) {
} }
var xhr = getXHR(); var xhr = getXHR();
xhr.onreadystatechange = function() { xhr.onreadystatechange = function() {
if (xhr.readyState == 4 && xhr.status == 200) { if (xhr.readyState == 4) {
var xml = xhr.responseXML; var error = true;
var message = ""; var message = "";
if (xml) { if (xhr.status == 200) {
var root = xml.getElementsByTagName('root'); var xml = xhr.responseXML;
if (root.length && getNode(root[0], 'error') == 0) { if (xml) {
removeModal(); var root = xml.getElementsByTagName('root');
alert(lang['actionsuccess']); if (root.length && getNode(root[0], 'error') == 0) {
var f = document.getElementsByName('track')[0]; removeModal();
if (action == 'delete') { alert(lang['actionsuccess']);
// select current track in tracks form var f = document.getElementsByName('track')[0];
f.remove(f.selectedIndex); if (action == 'delete') {
clearMap(); // select current track in tracks form
selectTrack(f); f.remove(f.selectedIndex);
} else { clearMap();
f.options[f.selectedIndex].innerHTML = htmlEncode(trackName); selectTrack(f);
} else {
f.options[f.selectedIndex].innerHTML = htmlEncode(trackName);
}
error = false;
} else if (root.length) {
errorMsg = getNode(root[0], 'message');
if (errorMsg) { message = errorMsg; }
} }
return;
} }
errorMsg = getNode(root[0], 'message');
if (errorMsg) { message = errorMsg; }
} }
alert(lang['actionfailure'] + '\n' + message); if (error) {
alert(lang['actionfailure'] + '\n' + message);
}
xhr = null; xhr = null;
} }
} }