b04adc21eae721c913a460641e450aab890f8062
[kivitendo-erp.git] / bin / mozilla / login.pl
1 #=====================================================================
2 # LX-Office ERP
3 # Copyright (C) 2004
4 # Based on SQL-Ledger Version 2.1.9
5 # Web http://www.lx-office.org
6 #
7 ######################################################################
8 # SQL-Ledger Accounting
9 # Copyright (c) 1998-2002
10 #
11 #  Author: Dieter Simader
12 #   Email: dsimader@sql-ledger.org
13 #     Web: http://www.sql-ledger.org
14 #
15 #
16 # This program is free software; you can redistribute it and/or modify
17 # it under the terms of the GNU General Public License as published by
18 # the Free Software Foundation; either version 2 of the License, or
19 # (at your option) any later version.
20 #
21 # This program is distributed in the hope that it will be useful,
22 # but WITHOUT ANY WARRANTY; without even the implied warranty of
23 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
24 # GNU General Public License for more details.
25 # You should have received a copy of the GNU General Public License
26 # along with this program; if not, write to the Free Software
27 # Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
28 #######################################################################
29
30 use DBI;
31 use SL::Auth;
32 use SL::User;
33 use SL::Form;
34
35 require "bin/mozilla/common.pl";
36 require "bin/mozilla/todo.pl";
37
38 use strict;
39
40 our $cgi;
41 our $form;
42 our $auth;
43
44 sub run {
45   $::lxdebug->enter_sub;
46   my $session_result = shift;
47
48   $cgi    = $::cgi;
49   $form   = $::form;
50   $auth   = $::auth;
51
52   $form->{stylesheet} = "lx-office-erp.css";
53   $form->{favicon}    = "favicon.ico";
54
55   if (SL::Auth::SESSION_EXPIRED == $session_result) {
56     $form->{error_message} = $::locale->text('The session is invalid or has expired.');
57     login_screen();
58     ::end_of_request();
59   }
60   my $action = $form->{action};
61   if (!$action && $auth->{SESSION}->{login}) {
62     $action = 'login';
63   }
64   if ($action) {
65     our %myconfig = $auth->read_user($form->{login}) if ($form->{login});
66
67     if (!$myconfig{login} || (SL::Auth::OK != $auth->authenticate($form->{login}, $form->{password}, 0))) {
68       $form->{error_message} = $::locale->text('Incorrect Password!');
69       login_screen();
70     } else {
71       $auth->set_session_value('login', $form->{login}, 'password', $form->{password});
72       $auth->create_or_refresh_session();
73
74       $form->{titlebar} .= " - $myconfig{name} - $myconfig{dbname}";
75       call_sub($::locale->findsub($action));
76     }
77   } else {
78     login_screen();
79   }
80
81   $::lxdebug->leave_sub;
82 }
83
84 sub login_screen {
85   $main::lxdebug->enter_sub();
86   my ($msg) = @_;
87
88   if (-f "css/lx-office-erp.css") {
89     $form->{stylesheet} = "lx-office-erp.css";
90   }
91
92   $form->{msg} = $msg;
93   $form->header();
94
95   print $form->parse_html_template('login/login_screen');
96
97   $main::lxdebug->leave_sub();
98 }
99
100 sub login {
101   $main::lxdebug->enter_sub();
102
103   unless ($form->{login}) {
104     login_screen($::locale->text('You did not enter a name!'));
105     ::end_of_request();
106   }
107
108   my $user = new User $form->{login};
109
110   # if we get an error back, bale out
111   my $result;
112   if (($result = $user->login($form)) <= -1) {
113     ::end_of_request() if $result == -2;
114     login_screen($::locale->text('Incorrect username or password!'));
115     ::end_of_request();
116   }
117
118   my %style_to_script_map = ( 'v3'  => 'v3',
119                               'neu' => 'new',
120                               'v4' => 'v4',
121                               'xml' => 'XML',
122     );
123
124   my $menu_script = $style_to_script_map{$user->{menustyle}} || '';
125
126   # made it this far, execute the menu
127   # standard redirect does not seem to work for this invocation, (infinite loops?)
128   # do a manual invocation instead
129 #  $form->{callback} = build_std_url("script=menu${menu_script}.pl", 'action=display', "callback=" . $form->escape($form->{callback}));
130
131   $main::auth->set_cookie_environment_variable();
132
133   $::form->{script}   = "menu${menu_script}.pl";
134   $::form->{action}   = 'display';
135   $::form->{callback} = $::form->escape($::form->{callback});
136
137   require "bin/mozilla/$::form->{script}";
138   display();
139
140 #  $form->redirect();
141
142   $main::lxdebug->leave_sub();
143 }
144
145 sub logout {
146   $main::lxdebug->enter_sub();
147
148   $main::auth->destroy_session();
149
150   # remove the callback to display the message
151   $form->{callback} = "login.pl?action=";
152   $form->redirect($::locale->text('You are logged out!'));
153
154   $main::lxdebug->leave_sub();
155 }
156
157 sub company_logo {
158   $main::lxdebug->enter_sub();
159
160   my %myconfig = %main::myconfig;
161   $form->{todo_list}  =  create_todo_list('login_screen' => 1) if (!$form->{no_todo_list});
162
163   $form->{stylesheet} =  $myconfig{stylesheet};
164   $form->{title}      =  $::locale->text('About');
165
166   # create the logo screen
167   $form->header() unless $form->{noheader};
168
169   print $form->parse_html_template('login/company_logo');
170
171   $main::lxdebug->leave_sub();
172 }
173
174 sub show_error {
175   my $template           = shift;
176   my %myconfig           = %main::myconfig;
177   $myconfig{countrycode} = $main::language;
178   $form->{stylesheet}    = 'css/lx-office-erp.css';
179
180   $form->header();
181   print $form->parse_html_template($template);
182
183   # $form->parse_html_template('login/auth_db_unreachable');
184   # $form->parse_html_template('login/authentication_pl_missing');
185
186   ::end_of_request();
187 }
188
189 1;
190
191 __END__