Better handle ajax errors
This commit is contained in:
parent
4dd920ae41
commit
52a36c2957
16
auth.php
16
auth.php
@ -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')])) {
|
||||||
|
@ -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;
|
||||||
|
@ -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";
|
||||||
|
38
js/admin.js
38
js/admin.js
@ -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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
28
js/pass.js
28
js/pass.js
@ -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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
44
js/track.js
44
js/track.js
@ -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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user