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 // We need to get a new seed
64 init = this.network.request(
67 [ this.view.name_prompt.value ]
70 params.password = hex_md5(init + hex_md5( this.view.password_prompt.value ));
72 robj = this.network.simple_request('AUTH_COMPLETE',[ params ]);
73 if (robj.ilsevent == 0) {
74 this.key = robj.payload.authtoken;
75 this.authtime = robj.payload.authtime;
77 //this.error.standard_unexpected_error_alert('auth.session.init',robj);
82 //obj.error.standard_unexpected_error_alert('auth.session.init',robj);
87 this.error.sdump('D_AUTH','auth.session.key = ' + this.key + '\n');
89 if (typeof this.on_init == 'function') {
90 this.error.sdump('D_AUTH','auth.session.on_init()\n');
96 var error = document.getElementById('authStrings').getString('staff.auth.session.init_false') + '\n';
97 this.error.sdump('D_ERROR',error);
102 alert(document.getElementById('authStrings').getString('staff.auth.session.login_failed'));
103 //obj.error.standard_unexpected_error_alert('Error on auth.session.init()',E);
105 if (typeof this.on_init_error == 'function') {
106 this.error.sdump('D_AUTH','auth.session.on_init_error()\n');
107 this.on_init_error(E);
109 if (typeof this.on_error == 'function') {
110 this.error.sdump('D_AUTH','auth.session.on_error()\n');
115 /* This was for testing
116 if (typeof this.on_init == 'function') {
117 this.error.sdump('D_AUTH','auth.session.on_init() despite error\n');
124 'close' : function () {
126 obj.error.sdump('D_AUTH','auth.session.close()\n');
128 netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
129 Components.classes["@mozilla.org/cookiemanager;1"]
130 .getService(Components.interfaces.nsICookieManager).removeAll();
132 dump('Error in auth/session.js, close(): ' + E + '\n');
134 if (obj.key) obj.network.request(
136 api.AUTH_DELETE.method,
141 if (typeof obj.on_close == 'function') {
142 obj.error.sdump('D_AUTH','auth.session.on_close()\n');
149 dump('exiting auth/session.js\n');