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
41 'agent' : 'staffclient'
44 if (data.ws_info[ this.view.server_prompt.value ]) {
45 params.type = this.login_type;
46 params.workstation = data.ws_info[ this.view.server_prompt.value ].name;
47 data.ws_name = params.workstation; data.stash('ws_name');
50 var robj = this.network.simple_request( 'AUTH_COMPLETE', [ params ]);
52 switch (Number(robj.ilsevent)) {
54 this.key = robj.payload.authtoken;
55 this.authtime = robj.payload.authtime;
57 case 1520 /* WORKSTATION_NOT_FOUND */:
58 alert(document.getElementById('authStrings').getFormattedString('staff.auth.session.unregistered', [params.workstation]));
59 delete(params.workstation);
60 delete(data.ws_info[ this.view.server_prompt.value ]);
61 data.stash('ws_info');
62 data.ws_name = null; data.stash('ws_name');
64 // We need to get a new seed
65 init = this.network.request(
68 [ this.view.name_prompt.value ]
71 params.password = hex_md5(init + hex_md5( this.view.password_prompt.value ));
73 robj = this.network.simple_request('AUTH_COMPLETE',[ params ]);
74 if (robj.ilsevent == 0) {
75 this.key = robj.payload.authtoken;
76 this.authtime = robj.payload.authtime;
78 //this.error.standard_unexpected_error_alert('auth.session.init',robj);
83 //obj.error.standard_unexpected_error_alert('auth.session.init',robj);
88 this.error.sdump('D_AUTH','auth.session.key = ' + this.key + '\n');
90 if (typeof this.on_init == 'function') {
91 this.error.sdump('D_AUTH','auth.session.on_init()\n');
97 var error = document.getElementById('authStrings').getString('staff.auth.session.init_false') + '\n';
98 this.error.sdump('D_ERROR',error);
103 alert(document.getElementById('authStrings').getString('staff.auth.session.login_failed'));
104 //obj.error.standard_unexpected_error_alert('Error on auth.session.init()',E);
106 if (typeof this.on_init_error == 'function') {
107 this.error.sdump('D_AUTH','auth.session.on_init_error()\n');
108 this.on_init_error(E);
110 if (typeof this.on_error == 'function') {
111 this.error.sdump('D_AUTH','auth.session.on_error()\n');
116 /* This was for testing
117 if (typeof this.on_init == 'function') {
118 this.error.sdump('D_AUTH','auth.session.on_init() despite error\n');
125 'close' : function () {
127 obj.error.sdump('D_AUTH','auth.session.close()\n');
129 netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
130 Components.classes["@mozilla.org/cookiemanager;1"]
131 .getService(Components.interfaces.nsICookieManager).removeAll();
133 dump('Error in auth/session.js, close(): ' + E + '\n');
135 if (obj.key) obj.network.request(
137 api.AUTH_DELETE.method,
142 if (typeof obj.on_close == 'function') {
143 obj.error.sdump('D_AUTH','auth.session.on_close()\n');
150 dump('exiting auth/session.js\n');