]> git.evergreen-ils.org Git - Evergreen.git/blob - Open-ILS/xul/staff_client/chrome/content/auth/session.js
c3f9a13b52fedfba68d7d1dee142eb34c74c7965
[Evergreen.git] / Open-ILS / xul / staff_client / chrome / content / auth / session.js
1 dump('entering auth/session.js\n');
2 // vim:sw=4:ts=4:noet:
3
4 if (typeof auth == 'undefined') auth = {};
5 auth.session = function (view,login_type) {
6
7     JSAN.use('util.error'); this.error = new util.error();
8     JSAN.use('util.network'); this.network = new util.network();
9     this.view = view;
10     this.login_type = login_type || 'staff';
11
12     return this;
13 };
14
15 auth.session.prototype = {
16
17     'init' : function () {
18
19         var obj = this;
20
21         try {
22             var init = this.network.request(
23                 api.AUTH_INIT.app,
24                 api.AUTH_INIT.method,
25                 [ this.view.name_prompt.value ]
26             );
27
28             if (init) {
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();
31
32                 var params = { 
33                     'username' : this.view.name_prompt.value,
34                     'password' : hex_md5(
35                         init +
36                         hex_md5(
37                             this.view.password_prompt.value
38                         )
39                     ),
40                     'type' : 'temp',
41                 };
42
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');
47                 }
48
49                 var robj = this.network.simple_request( 'AUTH_COMPLETE', [ params ]);
50
51                 switch (Number(robj.ilsevent)) {
52                     case 0:
53                         this.key = robj.payload.authtoken;
54                         this.authtime = robj.payload.authtime;
55                     break;
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');
62                         params.type = 'temp';
63                         // We need to get a new seed
64                         init = this.network.request(
65                             api.AUTH_INIT.app,
66                             api.AUTH_INIT.method,
67                             [ this.view.name_prompt.value ]
68                         );
69                         if(init) {
70                             params.password = hex_md5(init + hex_md5( this.view.password_prompt.value ));
71                         }
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;
76                         } else {
77                             //this.error.standard_unexpected_error_alert('auth.session.init',robj);
78                             throw(robj);
79                         }
80                     break;
81                     default:
82                     //obj.error.standard_unexpected_error_alert('auth.session.init',robj);
83                     throw(robj);
84                     break;
85                 }
86
87                 this.error.sdump('D_AUTH','auth.session.key = ' + this.key + '\n');
88
89                 if (typeof this.on_init == 'function') {
90                     this.error.sdump('D_AUTH','auth.session.on_init()\n');
91                     this.on_init();
92                 }
93
94             } else {
95
96                 var error = document.getElementById('authStrings').getString('staff.auth.session.init_false') + '\n';
97                 this.error.sdump('D_ERROR',error);
98                 throw(error);
99             }
100
101         } catch(E) {
102             alert(document.getElementById('authStrings').getString('staff.auth.session.login_failed'));
103             //obj.error.standard_unexpected_error_alert('Error on auth.session.init()',E); 
104
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);
108             }
109             if (typeof this.on_error == 'function') {
110                 this.error.sdump('D_AUTH','auth.session.on_error()\n');
111                 this.on_error();
112             }
113
114             //throw(E);
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');
118                 this.on_init();
119             }
120             */
121         }
122     },
123
124     'close' : function () { 
125         var obj = this;
126         obj.error.sdump('D_AUTH','auth.session.close()\n'); 
127         try {
128             netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
129             Components.classes["@mozilla.org/cookiemanager;1"]
130                 .getService(Components.interfaces.nsICookieManager).removeAll();
131         } catch(E) {
132             dump('Error in auth/session.js, close(): ' + E + '\n');
133         }
134         if (obj.key) obj.network.request(
135             api.AUTH_DELETE.app,
136             api.AUTH_DELETE.method,
137             [ obj.key ],
138             function(req) {}
139         );
140         obj.key = null;
141         if (typeof obj.on_close == 'function') {
142             obj.error.sdump('D_AUTH','auth.session.on_close()\n');
143             obj.on_close();
144         }
145     }
146
147 }
148
149 dump('exiting auth/session.js\n');