]> git.evergreen-ils.org Git - Evergreen.git/blob - Open-ILS/xul/staff_client/server/main/simple_auth.xul
simple auth was buggy; due to chrome/remote restrictions in xulrunner 1.9? made separ...
[Evergreen.git] / Open-ILS / xul / staff_client / server / main / simple_auth.xul
1 <?xml version="1.0"?>
2 <!-- Application: Evergreen Staff Client -->
3 <!-- Screen: Example Template for remote xul -->
4 <!--
5  vim:noet:sw=4:ts=4:
6 -->
7
8 <!-- ///////////////////////////////////////////////////////////////////////////////////////////////////////////// -->
9 <!-- STYLESHEETS -->
10 <?xml-stylesheet href="chrome://global/skin/" type="text/css"?>
11 <?xml-stylesheet href="/xul/server/skin/global.css" type="text/css"?>
12 <?xml-stylesheet href="/xul/server/skin/simple_auth.css" type="text/css"?>
13
14 <!-- ///////////////////////////////////////////////////////////////////////////////////////////////////////////// -->
15 <!-- LOCALIZATION -->
16 <!DOCTYPE window PUBLIC "" ""[
17         <!--#include virtual="/opac/locale/${locale}/lang.dtd"-->
18 ]>
19
20 <!-- ///////////////////////////////////////////////////////////////////////////////////////////////////////////// -->
21 <!-- OVERLAYS -->
22 <?xul-overlay href="/xul/server/OpenILS/util_overlay.xul"?>
23
24 <window id="simple_auth_win" 
25         onload="try { my_init(); font_helper(); } catch(E) { alert(E); }"
26         xmlns="http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul">
27
28         <!-- ///////////////////////////////////////////////////////////////////////////////////////////////////////////// -->
29         <!-- BEHAVIOR -->
30         <script type="text/javascript">
31                 var myPackageDir = 'open_ils_staff_client'; var IAMXUL = true; var g = {};
32         </script>
33         <scripts id="openils_util_scripts"/>
34
35         <script type="text/javascript" src="/xul/server/main/JSAN.js"/>
36         <script>
37         <![CDATA[
38
39         var offlineStrings = document.getElementById('offlineStrings');
40
41                 function my_init() {
42                         try {
43                                 netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect");
44                                 if (typeof JSAN == 'undefined') { 
45                                         throw( offlineStrings.getString('common.jsan.missing'));
46                                 }
47                                 JSAN.errorLevel = "die"; // none, warn, or die
48                                 JSAN.addRepository('/xul/server/');
49                                 JSAN.use('util.error'); g.error = new util.error();
50                                 g.error.sdump('D_TRACE','my_init() for simple_auth.xul');
51
52                                 JSAN.use('OpenILS.data'); g.data = new OpenILS.data(); g.data.init({'via':'stash'});
53                                 g.data.temporary_session = ''; g.data.stash('temporary_session');
54
55                                 $('server').value = g.data.server_unadorned;
56
57                                 addCSSClass(document.documentElement,xul_param('login_type',{'modal_xulG':true}))
58
59                                 if (xul_param('desc_brief',{'modal_xulG':true})) {
60                                         $('desc').hidden = false;
61                                         $('desc_brief').appendChild( document.createTextNode( xul_param('desc_brief',{'modal_xulG':true}) ) );
62                                 }
63                                 if (xul_param('desc_full',{'modal_xulG':true})) {
64                                         $('desc').hidden = false;
65                                         $('desc_full').appendChild( document.createTextNode( xul_param('desc_full',{'modal_xulG':true}) ) );
66                                 }
67
68                                 $('username').focus();
69
70                                 $('username').addEventListener('keypress',handle_keypress,false);
71                                 $('password').addEventListener('keypress',handle_keypress,false);
72
73                         } catch(E) {
74                                 var err_msg =  offlineStrings.getFormattedString('common.exception', ['simple_auth.xul', E]);
75                                 try { g.error.sdump('D_ERROR',err_msg); } catch(E) { dump(err_msg); }
76                                 alert(err_msg);
77                         }
78                 }
79
80                 function $(id) { return document.getElementById(id); }
81
82                 function handle_keypress(ev) {
83                         if ( (! ev.keyCode) || (ev.keyCode != 13) ) return;
84                         switch(ev.target) {
85                                 case $('username') : $('password').focus(); break;
86                                 case $('password') : authorize(); break;
87                                 default: break;
88                         }
89                 }
90
91                 function authorize() {
92                         try {
93                                 JSAN.use('auth.session');
94                                 g.session = new auth.session(
95                                         {
96                                                 'name_prompt' : $('username'),
97                                                 'password_prompt' : $('password'),
98                                                 'server_prompt' : $('server'),
99                                         },
100                                         xul_param('login_type',{'modal_xulG':true}) || 'temp'
101                                 );
102                                 g.session.on_init = function() { 
103                                         try {
104                                                 JSAN.use('util.network'); var n = new util.network();
105                                                 var staff = n.simple_request('FM_AU_RETRIEVE_VIA_SESSION',[ g.session.key ]);
106                                                 g.data.temporary_session = {  // old way because of local chrome still out there
107                                                         'key' : g.session.key, 
108                                                         'authtime' : g.session.authtime, 
109                                                         'usr' : js2JSON(staff)
110                                                 }
111                                                 g.data.stash('temporary_session');
112                                                 var my_xulG = { // new way, to minimize the use of global spaces
113                                                         'temporary_session' : g.data.temporary_session
114                                                 };
115                                                 update_modal_xulG(my_xulG);
116                                                 window.close();
117                                         } catch(E) {
118                                                 g.error.standard_unexpected_error_alert('simple_auth.session.on_init',E);
119                                         }
120                                 }
121                                 g.session.on_init_error = function() { 
122                                         $('password').value = '';
123                                         $('username').focus();
124                                         $('username').select();
125                                  }
126                                 g.session.init();
127                         } catch(E) {
128                                 alert(E);
129                         }
130                 }
131
132         ]]>
133         </script>
134
135         <commandset id="simple_auth_cmds">
136                 <command id="cmd_broken" />
137         </commandset>
138
139         <vbox id="simple_auth_main" flex="1">
140         <groupbox id="desc" hidden="true">
141                 <caption label="&staff.main.simple_auth.exception.label;"/>
142                 <description id="desc_brief" style="color: red"/>
143                 <description id="desc_full"/>
144         </groupbox>
145         <groupbox>
146                 <caption label="&staff.main.simple_auth.authorization.label;"/>
147                 <grid>
148                         <columns><column /><column /></columns>
149                         <rows>
150                                 <row>
151                                         <label value="&common.username.label;" control="username" accesskey="&common.username.accesskey;"/>
152                                         <textbox id="username" />
153                                 </row>
154                                 <row>
155                                         <label value="&staff.auth.password_prompt;" control="password" accesskey="&staff.auth.password_prompt.accesskey;"/>
156                                         <textbox id="password" type="password"/>
157                                 </row>
158                                 <row>
159                                         <button label="&common.cancel;" accesskey="&common.cancel.accesskey;" oncommand="window.close()"/>
160                                         <button label="&staff.main.simple_auth.authorize.label;" accesskey="&staff.main.simple_auth.authorize.accesskey;" oncommand="authorize()"/>
161                                 </row>
162                         </rows>
163                 </grid>
164                 <label id="server" hidden="true"/>
165         </groupbox>
166         <spacer flex="1"/>
167         </vbox>
168 </window>
169