[open-ils-commits] r11833 - trunk/Open-ILS/xul/staff_client/chrome/content/util
svn at svn.open-ils.org
svn at svn.open-ils.org
Wed Jan 14 17:27:44 EST 2009
Author: phasefx
Date: 2009-01-14 17:27:39 -0500 (Wed, 14 Jan 2009)
New Revision: 11833
Modified:
trunk/Open-ILS/xul/staff_client/chrome/content/util/network.js
Log:
Timing: Set offlineStrings variable after network.init, and not inline.
Refactor: Do not use null to represent an error anywhere in the stack.
New: Time the request, and if the return value is null and the duration is greater than 55 seconds, then treat it as a network timeout.
need to test it with async requests
Modified: trunk/Open-ILS/xul/staff_client/chrome/content/util/network.js
===================================================================
--- trunk/Open-ILS/xul/staff_client/chrome/content/util/network.js 2009-01-14 22:18:54 UTC (rev 11832)
+++ trunk/Open-ILS/xul/staff_client/chrome/content/util/network.js 2009-01-14 22:27:39 UTC (rev 11833)
@@ -2,7 +2,6 @@
// vim:noet:sw=4:ts=4:
var offlineStrings;
-offlineStrings = document.getElementById('offlineStrings');
if (typeof util == 'undefined') util = {};
util.network = function () {
@@ -10,6 +9,8 @@
JSAN.use('util.error'); this.error = new util.error();
JSAN.use('util.sound'); this.sound = new util.sound();
+ offlineStrings = document.getElementById('offlineStrings');
+
return this;
};
@@ -17,6 +18,8 @@
'link_id' : 0,
+ 'network_timeout' : 55, /* seconds */
+
'NETWORK_FAILURE' : null,
'simple_request' : function(method_id,params,f,override_params) {
@@ -34,8 +37,13 @@
'get_result' : function (req) {
var obj = this;
var result;
+ var fake_ilsevent_for_network_errors = { 'ilsevent' : -1, 'textcode' : offlineStrings.getString('network.server_or_method.error') };
try {
- result = req.getResultObject();
+ if (req.cancelled) {
+ result = fake_ilsevent_for_network_errors;
+ } else {
+ result = req.getResultObject();
+ }
} catch(E) {
try {
if (instanceOf(E, NetworkFailure)) {
@@ -46,8 +54,8 @@
} catch(I) {
obj.NETWORK_FAILURE = offlineStrings.getString('network.unknown_status');
}
- result = null;
- }
+ result = fake_ilsevent_for_network_errors;
+ }
return result;
},
@@ -69,7 +77,7 @@
}
} catch(E) {
- alert(E);
+ alert('1: ' + E);
}
},
@@ -90,11 +98,14 @@
for(var index in params) {
request.addParam(params[index]);
}
-
+
+ var start_timer = (new Date).getTime();
if (f) {
request.setCompleteCallback(
function(req) {
try {
+ var duration = ( (new Date).getTime() - start_timer )/1000;
+ if ( obj.get_result(req) == null && duration > obj.network_timeout ) req.cancelled = true;
var json_string = js2JSON(obj.get_result(req));
obj.error.sdump('D_SES_RESULT','asynced result #'
+ obj.link_id + '\n\n'
@@ -127,6 +138,8 @@
} else {
try {
request.send(true);
+ var duration = ( (new Date).getTime() - start_timer )/1000;
+ if ( obj.get_result(request) == null && duration > obj.network_timeout ) request.cancelled = true;
} catch(E) {
throw(E);
}
@@ -147,7 +160,7 @@
}
} catch(E) {
- alert(E);
+ alert('2: ' + E);
if (instanceOf(E,perm_ex)) {
alert('in util.network, _request : permission exception: ' + js2JSON(E));
}
@@ -156,75 +169,82 @@
},
'check_for_offline' : function (app,name,params,req,override_params,_params) {
- var obj = this;
- var result = obj.get_result(req);
- if (result != null) return req;
+ try {
+ var obj = this;
+ var result = obj.get_result(req);
+ if (result == null) return req;
+ if (typeof result.ilsevent == 'undefined') return req;
+ if (result.ilsevent != -1) return req;
- JSAN.use('OpenILS.data'); var data = new OpenILS.data(); data.init({'via':'stash'});
- var proceed = true;
+ JSAN.use('OpenILS.data'); var data = new OpenILS.data(); data.init({'via':'stash'});
+ var proceed = true;
- while(proceed) {
+ while(proceed) {
- proceed = false;
+ proceed = false;
- var r;
+ var r;
- if (data.proceed_offline) {
+ if (data.proceed_offline) {
- r = 1;
+ r = 1;
- } else {
+ } else {
- var network_failure_string;
- var network_failure_status_string;
- var msg;
+ var network_failure_string;
+ var network_failure_status_string;
+ var msg;
- try { network_failure_string = String( obj.NETWORK_FAILURE ); } catch(E) { network_failure_string = E; }
- try { network_failure_status_string = typeof obj.NETWORK_FAILURE == 'object' && typeof obj.NETWORK_FAILURE != 'null' && typeof obj.NETWORK_FAILURE.status == 'function' ? obj.NETWORK_FAILURE.status() : ''; } catch(E) { network_failure_status_string = ''; obj.error.sdump('D_ERROR', 'setting network_failure_status_string: ' + E); }
-
- try { msg = offlineStrings.getFormattedString('network.server.failure.exception', [data.server_unadorned]) + '\n' +
- offlineStrings.getFormattedString('network.server.method', [name]) + '\n' +
- offlineStrings.getFormattedString('network.server.params', [js2JSON(params)]) + '\n' +
- offlineStrings.getString('network.server.thrown_label') + '\n' + network_failure_string + '\n' +
- offlineStrings.getString('network.server.status_label') + '\n' + network_failure_status_string;
- } catch(E) { msg = E; }
+ try { network_failure_string = String( obj.NETWORK_FAILURE ); } catch(E) { network_failure_string = E; }
+ try { network_failure_status_string = typeof obj.NETWORK_FAILURE == 'object' && typeof obj.NETWORK_FAILURE != 'null' && typeof obj.NETWORK_FAILURE.status == 'function' ? obj.NETWORK_FAILURE.status() : ''; } catch(E) { network_failure_status_string = ''; obj.error.sdump('D_ERROR', 'setting network_failure_status_string: ' + E); }
+
+ try { msg = offlineStrings.getFormattedString('network.server.failure.exception', [data.server_unadorned]) + '\n' +
+ offlineStrings.getFormattedString('network.server.method', [name]) + '\n' +
+ offlineStrings.getFormattedString('network.server.params', [js2JSON(params)]) + '\n' +
+ offlineStrings.getString('network.server.thrown_label') + '\n' + network_failure_string + '\n' +
+ offlineStrings.getString('network.server.status_label') + '\n' + network_failure_status_string;
+ } catch(E) { msg = E; }
- try { obj.error.sdump('D_SES_ERROR',msg); } catch(E) { alert(E); }
+ try { obj.error.sdump('D_SES_ERROR',msg); } catch(E) { alert('3: ' + E); }
- r = obj.error.yns_alert(
- msg,
- offlineStrings.getString('network.network_failure'),
- offlineStrings.getString('network.retry_network'),
- offlineStrings.getString('network.ignore_errors'),
- null,
- offlineStrings.getString('common.confirm')
- );
- if (r == 1) {
- data.proceed_offline = true; data.stash('proceed_offline');
- dump('Remembering proceed_offline for 200000 ms.\n');
- setTimeout(
- function() {
- data.proceed_offline = false; data.stash('proceed_offline');
- dump('Setting proceed_offline back to false.\n');
- }, 200000
- );
- }
- }
+ r = obj.error.yns_alert(
+ msg,
+ offlineStrings.getString('network.network_failure'),
+ offlineStrings.getString('network.retry_network'),
+ offlineStrings.getString('network.ignore_errors'),
+ null,
+ offlineStrings.getString('common.confirm')
+ );
+ if (r == 1) {
+ data.proceed_offline = true; data.stash('proceed_offline');
+ dump('Remembering proceed_offline for 200000 ms.\n');
+ setTimeout(
+ function() {
+ data.proceed_offline = false; data.stash('proceed_offline');
+ dump('Setting proceed_offline back to false.\n');
+ }, 200000
+ );
+ }
+ }
- dump( r == 0 ? 'Retry Network\n' : 'Ignore Errors\n' );
+ dump( r == 0 ? 'Retry Network\n' : 'Ignore Errors\n' );
- switch(r) {
- case 0:
- req = obj._request(app,name,params,null,override_params,_params);
- if (obj.get_result(req)) proceed = true; /* daily WTF, why am I even doing this? :) */
- return req;
- break;
+ switch(r) {
+ case 0:
+ req = obj._request(app,name,params,null,override_params,_params);
+ if (obj.get_result(req)) proceed = true; /* daily WTF, why am I even doing this? :) */
+ return req;
+ break;
- case 1:
- return { 'getResultObject' : function() { return { 'ilsevent' : -1, 'textcode' : offlineStrings.getString('network.server_or_method.error') }; } };
- break;
- }
- }
+ case 1:
+ return req;
+ break;
+ }
+ }
+ } catch(E) {
+ alert('4: ' + E);
+ throw(E);
+ }
},
'reset_titlebars' : function(data) {
More information about the open-ils-commits
mailing list