1 dump('entering auth/session.js\n');
4 if (typeof auth == 'undefined') auth = {};
5 auth.session = function (view,login_type) {
7 JSAN.use('util.error'); this.error = new util.error();
8 JSAN.use('util.network'); this.network = new util.network();
10 this.login_type = login_type || 'staff';
15 auth.session.prototype = {
17 'init' : function () {
22 var init = this.network.request(
25 [ this.view.name_prompt.value ]
29 if (xulG._data) { delete xulG._data; } // quick kludge; we were re-using a poisoned OpenILS.data (from ws_info.xul?) where js2JSON (and maybe other stuff) does not exist
30 JSAN.use('OpenILS.data'); var data = new OpenILS.data(); data.stash_retrieve();
33 'username' : this.view.name_prompt.value,
37 this.view.password_prompt.value
43 if (data.ws_info[ this.view.server_prompt.value ]) {
44 params.type = this.login_type;
45 params.workstation = data.ws_info[ this.view.server_prompt.value ].name;
46 data.ws_name = params.workstation; data.stash('ws_name');
49 var robj = this.network.simple_request( 'AUTH_COMPLETE', [ params ]);
51 switch (Number(robj.ilsevent)) {
53 this.key = robj.payload.authtoken;
54 this.authtime = robj.payload.authtime;
56 case 1520 /* WORKSTATION_NOT_FOUND */:
57 alert(document.getElementById('authStrings').getFormattedString('staff.auth.session.unregistered', [params.workstation]));
58 delete(params.workstation);
59 delete(data.ws_info[ this.view.server_prompt.value ]);
60 data.stash('ws_info');
61 data.ws_name = null; data.stash('ws_name');
63 robj = this.network.simple_request('AUTH_COMPLETE',[ params ]);
64 if (robj.ilsevent == 0) {
65 this.key = robj.payload.authtoken;
66 this.authtime = robj.payload.authtime;
68 //this.error.standard_unexpected_error_alert('auth.session.init',robj);
73 //obj.error.standard_unexpected_error_alert('auth.session.init',robj);
78 this.error.sdump('D_AUTH','auth.session.key = ' + this.key + '\n');
80 if (typeof this.on_init == 'function') {
81 this.error.sdump('D_AUTH','auth.session.on_init()\n');
87 var error = document.getElementById('authStrings').getString('staff.auth.session.init_false') + '\n';
88 this.error.sdump('D_ERROR',error);
93 alert(document.getElementById('authStrings').getString('staff.auth.session.login_failed'));
94 //obj.error.standard_unexpected_error_alert('Error on auth.session.init()',E);
96 if (typeof this.on_init_error == 'function') {
97 this.error.sdump('D_AUTH','auth.session.on_init_error()\n');
98 this.on_init_error(E);
100 if (typeof this.on_error == 'function') {
101 this.error.sdump('D_AUTH','auth.session.on_error()\n');
106 /* This was for testing
107 if (typeof this.on_init == 'function') {
108 this.error.sdump('D_AUTH','auth.session.on_init() despite error\n');
115 'close' : function () {
117 obj.error.sdump('D_AUTH','auth.session.close()\n');
119 netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
120 Components.classes["@mozilla.org/cookiemanager;1"]
121 .getService(Components.interfaces.nsICookieManager).removeAll();
123 dump('Error in auth/session.js, close(): ' + E + '\n');
125 if (obj.key) obj.network.request(
127 api.AUTH_DELETE.method,
132 if (typeof obj.on_close == 'function') {
133 obj.error.sdump('D_AUTH','auth.session.on_close()\n');
140 dump('exiting auth/session.js\n');