Add implementation of class-of-service
[rahunas] / weblogin / login.php
1 <?php
2 /*
3   Copyright (c) 2008-2009, Neutron Soutmun <neo.neutron@gmail.com>
4   All rights reserved.
5
6   Redistribution and use in source and binary forms, with or without 
7   modification, are permitted provided that the following conditions 
8   are met:
9
10   1. Redistributions of source code must retain the above copyright 
11      notice, this list of conditions and the following disclaimer.
12   2. Redistributions in binary form must reproduce the above copyright 
13      notice, this list of conditions and the following disclaimer in the 
14      documentation and/or other materials provided with the distribution.
15   3. The names of the authors may not be used to endorse or promote products 
16      derived from this software without specific prior written permission.
17
18   THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" 
19   AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, 
20   THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 
21   PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS
22   BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, 
23   OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 
24   SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 
25   INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 
26   CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 
27   ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 
28   POSSIBILITY OF SUCH DAMAGE.
29
30   This code cannot simply be copied and put under the GNU Public License or 
31     any other GPL-like (LGPL, GPL2) License.
32 */
33
34 session_start();
35 ob_start();
36 require_once 'rahu_radius.class.php';
37 require_once 'rahu_xmlrpc.class.php';
38 require_once 'getmacaddr.php';
39 require_once 'config.php';
40 require_once 'header.php';
41 require_once 'locale.php';
42 require_once 'messages.php';
43 require_once 'networkchk.php';
44
45 $ip = $_SERVER['REMOTE_ADDR'];
46 $config = get_config_by_network($ip, $config_list);
47 $vserver_id = $config["VSERVER_ID"];
48
49 $forward = false;
50 $LogoutURL  = $config['NAS_LOGIN_PROTO'] . "://" . $config['NAS_LOGIN_HOST'];
51 $LogoutURL .= !empty($config['NAS_LOGIN_PORT']) ? 
52                 ":" . $config['NAS_LOGIN_PORT'] : "";
53 $LogoutURL .= "/logout.php";
54 $RequestURL = empty($_GET['request_url']) ? 
55                 $config['DEFAULT_REDIRECT_URL']
56                 : urldecode($_GET['request_url']);
57 $_SESSION['request_url'] = $RequestURL;
58
59 // Verify if the user already login
60 $xmlrpc = new rahu_xmlrpc_client();
61 $xmlrpc->host = $config["RAHUNAS_HOST"];
62 $xmlrpc->port = $config["RAHUNAS_PORT"];
63 try {
64   $retinfo = $xmlrpc->do_getsessioninfo($vserver_id, $ip);
65   if (is_array($retinfo) && !empty($retinfo['session_id'])) {
66     $forward = true;
67   }
68 } catch (XML_RPC2_FaultException $e) {
69   $message = get_message('ERR_CONNECT_SERVER');
70   $forward = false;
71 } catch (XML_RPC2_CurlExeption $e) {
72   $message = get_message('ERR_CONNECT_SERVER');
73   $forward = false;
74 } catch (Exception $e) {
75   $message = get_message('ERR_CONNECT_SERVER');
76   $forward = false;
77 }
78
79 if (!empty($_POST['user']) && !empty($_POST['passwd'])) {
80
81   $message = "";
82   $rauth = new rahu_radius_auth ($_POST['user'], $_POST['passwd'], $config['RADIUS_ENCRYPT']);
83   $rauth->host = $config["RADIUS_HOST"];
84   $rauth->port = $config["RADIUS_AUTH_PORT"];
85   $rauth->secret = $config["RADIUS_SECRET"];
86   $rauth->start();
87
88   if ($rauth->isError()) {
89     $message = get_message('ERR_CONNECT_RADIUS');
90   } else if ($rauth->isAccept()) {
91     $message = get_message('OK_USER_AUTHORIZED');
92     $forward = true;
93     $racct = new rahu_radius_acct ($_POST['user']);
94     $racct->host = $config["RADIUS_HOST"];
95     $racct->port = $config["RADIUS_ACCT_PORT"];
96     $racct->secret = $config["RADIUS_SECRET"];
97     $racct->nas_identifier = $config["NAS_IDENTIFIER"];
98     $racct->nas_ip_address = $config["NAS_IP_ADDRESS"];
99     $racct->nas_port = $config["NAS_PORT"];
100     $racct->framed_ip_address  = $_SERVER['REMOTE_ADDR'];
101     $racct->calling_station_id = returnMacAddress();
102     $racct->gen_session_id();
103
104     try {
105       $prepareData = array (
106         "IP" => $ip,
107         "Username" => $_POST['user'],
108         "SessionID" => $racct->session_id,
109         "MAC" => returnMacAddress(),
110         "Session-Timeout" => $rauth->attributes['session_timeout'],
111         "Bandwidth-Max-Down" => $rauth->attributes['WISPr-Bandwidth-Max-Down'],
112         "Bandwidth-Max-Up" => $rauth->attributes['WISPr-Bandwidth-Max-Up'],
113         "Class-Of-Service" => $rauth->attributes['WISPr-Billing-Class-Of-Service'],
114       );
115       $result = $xmlrpc->do_startsession($vserver_id, $prepareData);
116       if (strstr($result,"Client already login")) {
117         $message = get_message('ERR_ALREADY_LOGIN');
118         $forward = false;
119       } else if (strstr($result, "Greeting")) {
120         $split = explode ("Mapping ", $result);
121         $called_station_id = $split[1];
122         if (!empty ($called_station_id))
123           $racct->called_station_id = $called_station_id;
124
125         $racct->acctStart();
126       } else if (strstr($result, "Invalid IP Address")) {
127         $message = get_message('ERR_INVALID_IP');
128         $forward = false;
129       }
130     } catch (XML_RPC2_FaultException $e) {
131       $message = get_message('ERR_CONNECT_SERVER');
132       $forward = false;
133     } catch (Exception $e) {
134       $message = get_message('ERR_CONNECT_SERVER');
135       $forward = false;
136     }
137   } else {
138     if ($rauth->isLoggedIn()) {
139       $message = get_message('ERR_MAXIMUM_LOGIN');
140     } else if ($rauth->isTimeout()) {
141       $message = get_message('ERR_USER_EXPIRED');
142     } else {
143       $message = get_message('ERR_INVALID_USERNAME_OR_PASSWORD');
144     }
145   }
146 }
147
148 if ($forward) {
149   $_SESSION['firstlogin'] = true;
150 }
151 ?>
152
153 <?php
154 // Login box
155 $request_uri = $_SERVER['REQUEST_URI'];
156
157 $loginbox = "<form name='login' action='$request_uri' method='post'>" .
158             "<table>" .
159             "<tr><td id='rh_login_text'>" . _("Username") . "</td>" .
160             "<td><input type='text' name='user' size='22'></td></tr>" .
161             "<tr><td id='rh_login_text'>" . _("Password") . "</td>" .
162             "<td><input type='password' name='passwd' size='22'></td></tr>" .
163             "<tr><td>&nbsp;</td>" .
164             "<td><input type='submit' value='" . _("Login") . "' id='rh_login_button'>" .
165             "</td></tr>" .
166             "</table>" .
167             "</form>";
168
169 $forward_script  = $forward ? "window.open('$RequestURL');" : "";
170 $forward_script .= $forward ? "self.location.replace('$LogoutURL');" : "";
171 $waiting_show  = $forward ? "visible_hide(wt, 'show');" 
172                           : "visible_hide(wt, 'hide');";
173 $message_show  = !empty($message) ? "visible_hide(msg, 'show');" 
174                                   : "visible_hide(msg, 'hide');";
175 $hide_wait = !empty($message) ? "setTimeout('hide_wait();', 2000);\n" : "";
176 $force_forward = $hide_wait == "" && $forward ? 
177                    "self.location.replace('$LogoutURL');" : "";
178
179 $loginscript = "<script>" .
180                "var msg=(document.all);\n" .  
181                "var ns4=document.layers;\n" .
182                "var ns6=document.getElementById&&!document.all;\n" .
183                "var ie4=document.all;\n" .
184                "if (ns4)" .
185                "  msg=document.rh_message;\n" .
186                "else if (ns6)" .
187                "  msg=document.getElementById('rh_message').style;\n" .
188                "else if (ie4)" .
189                "  msg=document.all.rh_message.style;\n\n" .
190                "var wt=(document.all);\n" .  
191                "if (ns4)" .
192                "  wt=document.rh_waiting;\n" .
193                "else if (ns6)" .
194                "  wt=document.getElementById('rh_waiting').style;\n" .
195                "else if (ie4)" .
196                "  wt=document.all.rh_waiting.style;\n\n" .
197                "function visible_hide(obj, type)\n" .
198                "{\n" .
199                "  if(type == 'show') {\n" .
200                "    if(ns4){obj.visibility='visible';} \n" .
201                "    else if (ns6||ie4) obj.display='block';\n".
202                "  } else {\n".
203                "    if(ns4){obj.visibility='hidden';} \n" .
204                "    else if (ns6||ie4) obj.display='none';\n".
205                "  }\n".
206                "}\n".
207                "function hide_wait() {\n".
208                "  visible_hide(msg, 'hide');\n".
209                "  visible_hide(wt, 'hide');\n".
210                "  $forward_script \n" .
211                "}\n".
212                "  $message_show \n".
213                "  $waiting_show \n".
214                "  $hide_wait \n".
215                "  $force_forward \n".
216                "</script>";
217 $watting_script="";
218
219 $waiting  = "<div id='rh_waiting'><img src='loading.gif'></div>";
220 $loginmsg = "<div id='rh_message'>$message</div>";
221 $loginbox .= $waiting;
222 $loginbox .= $loginmsg;
223 ?>
224
225 <?php
226 // Template loading
227 $tpl_path = "templates/" . $config['UAM_TEMPLATE'] . "/";
228 $tpl_file = $tpl_path . $config['UAM_TEMPLATE'] . ".html";
229 $handle = @fopen($tpl_file, "r");
230 $html_buffer = "";
231 if ($handle) {  
232   $css = "<link rel='stylesheet' type='text/css' href='" . $tpl_path . "rahunas.css'>";
233   $loginbox = $css . $loginbox;
234
235   while (!feof($handle)) {
236     $html_buffer .= fgets($handle, 4096);
237   }
238   fclose($handle);
239
240   $html_buffer = str_replace("images/", $tpl_path."images/", $html_buffer);
241   $html_buffer = str_replace("<!-- Title -->", $config["NAS_LOGIN_TITLE"], 
242                              $html_buffer);
243   $html_buffer = str_replace("<!-- Login -->", $loginbox, $html_buffer);
244   $html_buffer = str_replace("<!-- JavaScript -->", $loginscript, $html_buffer);
245   $html_buffer = str_replace("<body", 
246                              "<body onload='document.login.user.focus();'",
247                              $html_buffer);
248   print $html_buffer;
249 }
250
251 ob_end_flush();
252 ?>