1 dojo.require('dijit.Dialog');
2 dojo.require('dojo.cookie');
3 dojo.require('fieldmapper.AutoIDL'); // make conditional. TT variable sets JS var to enable/disable?
4 dojo.require('openils.User');
5 dojo.require('openils.CGI');
6 dojo.require('openils.Event');
7 dojo.require('openils.Util');
8 dojo.require('openils.XUL');
10 var cgi = new openils.CGI();
12 function oilsSetupUser() {
13 var authtoken = cgi.param('ses') || dojo.cookie('ses');
14 var workstation = cgi.param('ws') || dojo.cookie('ws');
18 openils.User.user = null;
19 openils.User.authtoken = null;
20 openils.User.workstation = null;
22 if(openils.XUL.isXUL()) {
23 stash = openils.XUL.getStash();
24 authtoken = stash.session.key
25 ses_user = stash.list.au[0];
29 user = new openils.User();
30 delete user.sessionCache[authtoken];
31 user.authtoken = authtoken;
34 user.sessionCache[authtoken] = ses_user;
36 user.user = user.getBySession();
39 if(!authtoken || openils.Event.parse(user.user)) {
41 authtoken = oilsLoginFromCookies();
45 dojo.cookie('ses', null, {expires:-1, path:'/'}); // remove the cookie
47 dojo.addOnLoad(function(){
48 if(openils.XUL.isXUL()) {
49 // let XUL handle the login dialog
50 dump('getNewSession in base.js\n');
51 openils.XUL.getNewSession( function() { location.href = location.href } );
53 // in web-only mode, use the dojo login dialog
54 oilsLoginDialog.show();
55 var func = function(){ oilsDoLogin(); };
56 openils.Util.registerEnterHandler(dojo.byId('oils-login-username'), func);
57 openils.Util.registerEnterHandler(dojo.byId('oils-login-password'), func);
58 dojo.byId('oils-login-workstation').innerHTML = workstation || '';
65 dojo.cookie('ses', authtoken, {path:'/'});
66 openils.User.authtoken = authtoken;
67 openils.User.workstation = workstation;
71 // pulls username / password and optional workstation from cgi params or cookies
72 function oilsLoginFromCookies() {
74 var username = cgi.param('username') || dojo.cookie('username');
75 var password = cgi.param('password') || dojo.cookie('password');
76 var workstation = cgi.param('ws') || dojo.cookie('ws');
78 if(username && password) {
80 var user = new openils.User();
88 args.workstation = workstation;
90 if(user.login(args)) {
91 // fetches the login session and sets the global vars
92 user = new openils.User({authtoken : user.authtoken});
93 return (user && !openils.Event.parse(user.user)) ? user.authtoken : null;
100 function oilsDoLogin() {
101 openils.Util.hide('oils-login-failed');
102 var workstation = cgi.param('ws') || dojo.cookie('ws');
103 var user = new openils.User();
105 username: dojo.byId('oils-login-username').value,
106 passwd: dojo.byId('oils-login-password').value,
107 type: 'staff', // hardcode for now
110 args.workstation = workstation;
112 if(user.login(args)) {
113 dojo.cookie('ses', user.authtoken, {path : '/'});
114 location.href = location.href;
116 openils.Util.show('oils-login-failed');