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 () {
21 /* This request is done manually in a try block to allow it to fail
22 * silently if auth_proxy is not even running. TODO: Move this check
23 * to a module which should be always running, perhaps 'auth'.
25 var auth_proxy_enabled = false;
27 var request = new RemoteRequest( api.AUTH_PROXY_ENABLED.app, api.AUTH_PROXY_ENABLED.method );
29 request.setSecure(true);
30 if (request.getResultObject() == 1) {
31 auth_proxy_enabled = true;
37 if (!auth_proxy_enabled) {
38 var init = this.network.request(
41 [ this.view.name_prompt.value ]
45 if (init || auth_proxy_enabled) {
46 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
47 JSAN.use('OpenILS.data'); var data = new OpenILS.data(); data.stash_retrieve();
50 'username' : this.view.name_prompt.value,
52 'agent' : 'staffclient'
55 if (data.ws_info[ this.view.server_prompt.value ]) {
56 params.type = this.login_type;
57 params.workstation = data.ws_info[ this.view.server_prompt.value ].name;
58 data.ws_name = params.workstation; data.stash('ws_name');
63 params['password'] = hex_md5(
66 this.view.password_prompt.value
69 robj = this.network.simple_request( 'AUTH_COMPLETE', [ params ]);
70 } else if (auth_proxy_enabled) { // safety double-check
71 params['password'] = this.view.password_prompt.value;
72 robj = this.network.simple_request( 'AUTH_PROXY_LOGIN', [ params ] );
75 switch (Number(robj.ilsevent)) {
77 this.key = robj.payload.authtoken;
78 this.authtime = robj.payload.authtime;
80 case 1520 /* WORKSTATION_NOT_FOUND */:
81 alert(document.getElementById('authStrings').getFormattedString('staff.auth.session.unregistered', [params.workstation]));
82 delete(params.workstation);
83 delete(data.ws_info[ this.view.server_prompt.value ]);
84 data.stash('ws_info');
85 data.ws_name = null; data.stash('ws_name');
87 // We need to get a new seed
88 init = this.network.request(
91 [ this.view.name_prompt.value ]
94 params.password = hex_md5(init + hex_md5( this.view.password_prompt.value ));
96 robj = this.network.simple_request('AUTH_COMPLETE',[ params ]);
97 if (robj.ilsevent == 0) {
98 this.key = robj.payload.authtoken;
99 this.authtime = robj.payload.authtime;
101 //this.error.standard_unexpected_error_alert('auth.session.init',robj);
106 //obj.error.standard_unexpected_error_alert('auth.session.init',robj);
111 this.error.sdump('D_AUTH','auth.session.key = ' + this.key + '\n');
113 if (typeof this.on_init == 'function') {
114 this.error.sdump('D_AUTH','auth.session.on_init()\n');
120 var error = document.getElementById('authStrings').getString('staff.auth.session.init_false') + '\n';
121 this.error.sdump('D_ERROR',error);
126 alert(document.getElementById('authStrings').getString('staff.auth.session.login_failed'));
127 //obj.error.standard_unexpected_error_alert('Error on auth.session.init()',E);
129 if (typeof this.on_init_error == 'function') {
130 this.error.sdump('D_AUTH','auth.session.on_init_error()\n');
131 this.on_init_error(E);
133 if (typeof this.on_error == 'function') {
134 this.error.sdump('D_AUTH','auth.session.on_error()\n');
139 /* This was for testing
140 if (typeof this.on_init == 'function') {
141 this.error.sdump('D_AUTH','auth.session.on_init() despite error\n');
148 'close' : function () {
150 obj.error.sdump('D_AUTH','auth.session.close()\n');
152 netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
153 Components.classes["@mozilla.org/cookiemanager;1"]
154 .getService(Components.interfaces.nsICookieManager).removeAll();
156 dump('Error in auth/session.js, close(): ' + E + '\n');
158 if (obj.key) obj.network.request(
160 api.AUTH_DELETE.method,
165 if (typeof obj.on_close == 'function') {
166 obj.error.sdump('D_AUTH','auth.session.on_close()\n');
173 dump('exiting auth/session.js\n');