2 <!-- Application: Evergreen Staff Client -->
3 <!-- Screen: Example Template for remote xul -->
8 <!-- ///////////////////////////////////////////////////////////////////////////////////////////////////////////// -->
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"?>
14 <!-- ///////////////////////////////////////////////////////////////////////////////////////////////////////////// -->
16 <!DOCTYPE window PUBLIC "" ""[
17 <!--#include virtual="/opac/locale/${locale}/lang.dtd"-->
20 <!-- ///////////////////////////////////////////////////////////////////////////////////////////////////////////// -->
22 <?xul-overlay href="/xul/server/OpenILS/util_overlay.xul"?>
24 <window id="simple_auth_win" oils_persist="height width sizemode"
25 onload="try { my_init(); font_helper(); persist_helper(); } catch(E) { alert(E); }"
26 xmlns="http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul">
28 <!-- ///////////////////////////////////////////////////////////////////////////////////////////////////////////// -->
30 <script type="text/javascript">
31 var myPackageDir = 'open_ils_staff_client'; var IAMXUL = true; var g = {};
33 <scripts id="openils_util_scripts"/>
35 <script type="text/javascript" src="/xul/server/main/JSAN.js"/>
39 var offlineStrings = document.getElementById('offlineStrings');
40 var login_type = 'temp';
44 if (typeof JSAN == 'undefined') {
45 throw( offlineStrings.getString('common.jsan.missing'));
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');
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');
55 $('server').value = g.data.server_unadorned;
57 login_type = xul_param('login_type') || 'temp';
58 addCSSClass(document.documentElement,login_type)
59 if(login_type == 'ochange')
60 $('change_type_row').hidden = false;
62 if (xul_param('desc_brief')) {
63 $('desc').hidden = false;
64 $('desc_brief').appendChild( document.createTextNode( xul_param('desc_brief') ) );
66 if (xul_param('desc_full')) {
67 $('desc').hidden = false;
68 $('desc_full').appendChild( document.createTextNode( xul_param('desc_full') ) );
71 $('username').focus();
73 $('username').addEventListener('keypress',handle_keypress,false);
74 $('password').addEventListener('keypress',handle_keypress,false);
77 var err_msg = offlineStrings.getFormattedString('common.exception', ['simple_auth.xul', E]);
78 try { g.error.sdump('D_ERROR',err_msg); } catch(E) { dump(err_msg); }
83 function $(id) { return document.getElementById(id); }
85 function handle_keypress(ev) {
86 if ( (! ev.keyCode) || (ev.keyCode != 13) ) return;
88 case $('username') : $('password').focus(); break;
89 case $('password') : authorize(); break;
94 function authorize() {
96 var my_login_type = login_type;
98 if(login_type == 'ochange') {
99 my_login_type = $('change_type').value;
100 if(my_login_type == 'perm') {
101 my_login_type = 'staff';
105 JSAN.use('auth.session');
106 g.session = new auth.session(
108 'name_prompt' : $('username'),
109 'password_prompt' : $('password'),
110 'server_prompt' : $('server'),
114 g.session.on_init = function() {
116 JSAN.use('util.network'); var n = new util.network();
117 var staff = n.simple_request('FM_AU_RETRIEVE_VIA_SESSION',[ g.session.key ]);
118 g.data.temporary_session = { // old way because of local chrome still out there
119 'key' : g.session.key,
120 'authtime' : g.session.authtime,
121 'usr' : js2JSON(staff),
123 'login_type' : my_login_type
125 g.data.stash('temporary_session');
126 xulG.temporary_session = g.data.temporary_session;
129 g.error.standard_unexpected_error_alert('simple_auth.session.on_init',E);
132 g.session.on_init_error = function() {
133 $('password').value = '';
134 $('username').focus();
135 $('username').select();
146 <commandset id="simple_auth_cmds">
147 <command id="cmd_broken" />
150 <vbox id="simple_auth_main" flex="1">
151 <groupbox id="desc" hidden="true">
152 <caption label="&staff.main.simple_auth.exception.label;"/>
153 <description id="desc_brief" style="color: red"/>
154 <description id="desc_full"/>
157 <caption label="&staff.main.simple_auth.authorization.label;"/>
159 <columns><column /><column /><column flex="1" /></columns>
162 <label value="&common.username.label;" control="username" accesskey="&common.username.accesskey;"/>
163 <textbox id="username" />
166 <label value="&staff.auth.password_prompt;" control="password" accesskey="&staff.auth.password_prompt.accesskey;"/>
167 <textbox id="password" type="password"/>
169 <row id="change_type_row" hidden="true">
170 <label value="&staff.auth.change_type.label;" control="change_type" accesskey="&staff.auth.change_type.accesskey;"/>
171 <menulist id="change_type">
173 <menuitem label="&staff.auth.change_type_temporary;" value="temp" selected="true"/>
174 <menuitem label="&staff.auth.change_type_staff;" value="staff"/>
175 <menuitem label="&staff.auth.change_type_permanent;" value="perm"/>
178 <description>&staff.auth.change_type_description;</description>
181 <button label="&common.cancel;" accesskey="&common.cancel.accesskey;" oncommand="window.close()"/>
182 <button label="&staff.main.simple_auth.authorize.label;" accesskey="&staff.main.simple_auth.authorize.accesskey;" oncommand="authorize()"/>
186 <label id="server" hidden="true"/>