2013-06-19 13:27:14 +02:00
|
|
|
<?php
|
2017-01-30 21:36:44 +01:00
|
|
|
/* μlogger
|
2013-06-19 13:27:14 +02:00
|
|
|
*
|
2017-01-30 21:36:44 +01:00
|
|
|
* Copyright(C) 2017 Bartek Fabiszewski (www.fabiszewski.net)
|
2013-06-19 13:27:14 +02:00
|
|
|
*
|
|
|
|
* This is free software; you can redistribute it and/or modify it under
|
|
|
|
* the terms of the GNU Library General Public License as published by
|
|
|
|
* the Free Software Foundation; either version 2 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful, but
|
|
|
|
* WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
* General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Library General Public
|
|
|
|
* License along with this program; if not, write to the Free Software
|
|
|
|
* Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
|
|
|
*/
|
|
|
|
require_once("auth.php");
|
2014-04-01 17:28:27 +11:00
|
|
|
|
2017-02-17 16:41:39 +01:00
|
|
|
if ($auth && !$admin && !$public_tracks) {
|
|
|
|
// only authorized user tracks
|
2013-06-19 13:27:14 +02:00
|
|
|
// get username
|
2017-01-30 21:36:44 +01:00
|
|
|
$query = "SELECT login FROM users WHERE id='$auth' LIMIT 1";
|
2013-06-19 13:27:14 +02:00
|
|
|
$result = $mysqli->query($query);
|
|
|
|
$row = $result->fetch_assoc();
|
2017-01-30 21:36:44 +01:00
|
|
|
$user = $row["login"];
|
2016-10-29 14:05:13 +02:00
|
|
|
|
2013-06-19 13:27:14 +02:00
|
|
|
// users
|
|
|
|
$user_form = '<u>'.$lang_user.'</u><br />'.$user.' (<a href="logout.php">'.$lang_logout.'</a>)';
|
2016-10-29 14:05:13 +02:00
|
|
|
}
|
2013-06-19 13:27:14 +02:00
|
|
|
else {
|
2017-02-17 16:41:39 +01:00
|
|
|
// public access or admin user
|
2013-06-19 13:27:14 +02:00
|
|
|
// prepare user select form
|
2014-09-07 21:19:43 +02:00
|
|
|
if ($admin) {
|
|
|
|
$user = $admin_user;
|
2014-04-01 17:28:27 +11:00
|
|
|
}
|
2013-06-19 13:27:14 +02:00
|
|
|
$user_form = '
|
2014-09-07 21:19:43 +02:00
|
|
|
<u>'.$lang_user.'</u> ';
|
|
|
|
if ($auth) {
|
|
|
|
$user_form .= ' '.$user.' (<a href="logout.php">'.$lang_logout.'</a>)';
|
2017-03-16 14:11:01 +01:00
|
|
|
} else {
|
|
|
|
$user_form .= ' <a href="index.php?force_login=1">'.$lang_login.'</a>';
|
2016-10-29 14:05:13 +02:00
|
|
|
}
|
2014-09-07 21:19:43 +02:00
|
|
|
$user_form .= '
|
|
|
|
<br />
|
2013-06-19 13:27:14 +02:00
|
|
|
<form>
|
|
|
|
<select name="user" onchange="selectUser(this)">
|
2016-10-29 14:05:13 +02:00
|
|
|
<option value="0">'.$lang_suser.'</option>';
|
2014-09-07 21:19:43 +02:00
|
|
|
// get last position user
|
2017-01-30 21:36:44 +01:00
|
|
|
$query = "SELECT p.user_id FROM positions p ORDER BY p.time LIMIT 1";
|
2014-09-07 21:19:43 +02:00
|
|
|
$result = $mysqli->query($query);
|
|
|
|
if ($result->num_rows) {
|
|
|
|
$last = $result->fetch_row();
|
|
|
|
$last_id = $last[0];
|
|
|
|
} else {
|
|
|
|
$last_id = "";
|
|
|
|
}
|
2017-01-30 21:36:44 +01:00
|
|
|
$query = "SELECT id, login FROM users ORDER BY login";
|
2013-06-19 13:27:14 +02:00
|
|
|
$result = $mysqli->query($query);
|
|
|
|
while ($row = $result->fetch_assoc()) {
|
2017-01-30 21:36:44 +01:00
|
|
|
$user_form .= sprintf("<option %svalue=\"%s\">%s</option>\n", ($row["id"] == $last_id)?"selected ":"",$row["id"], $row["login"]);
|
2013-06-19 13:27:14 +02:00
|
|
|
}
|
2014-09-07 21:19:43 +02:00
|
|
|
$user_form .= '
|
|
|
|
</select>
|
|
|
|
</form>
|
|
|
|
';
|
2013-06-19 13:27:14 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// prepare track select form
|
|
|
|
$track_form = '
|
|
|
|
<u>'.$lang_track.'</u><br />
|
|
|
|
<form>
|
|
|
|
<select name="track" onchange="selectTrack(this)">';
|
2014-09-07 21:19:43 +02:00
|
|
|
$userid = "";
|
2017-02-17 16:41:39 +01:00
|
|
|
if ($auth && !$admin && !$public_tracks) {
|
2014-09-07 21:19:43 +02:00
|
|
|
// display track of authenticated user
|
|
|
|
$userid = $auth;
|
|
|
|
} elseif ($last_id) {
|
|
|
|
// or user who did last move
|
|
|
|
$userid = $last_id;
|
|
|
|
}
|
2017-01-30 21:36:44 +01:00
|
|
|
$query = "SELECT * FROM tracks WHERE user_id='$userid' ORDER BY id DESC";
|
2013-06-19 13:27:14 +02:00
|
|
|
$result = $mysqli->query($query);
|
2014-04-01 17:28:27 +11:00
|
|
|
|
2013-06-19 13:27:14 +02:00
|
|
|
$trackid = "";
|
|
|
|
while ($row = $result->fetch_assoc()) {
|
2017-01-30 21:36:44 +01:00
|
|
|
if ($trackid == "") { $trackid = $row["id"]; } // get first row
|
|
|
|
$track_form .= sprintf("<option value=\"%s\">%s</option>\n", $row["id"], $row["name"]);
|
2013-06-19 13:27:14 +02:00
|
|
|
}
|
|
|
|
$track_form .= '
|
|
|
|
</select>
|
|
|
|
<input id="latest" type="checkbox" onchange="toggleLatest();"> '.$lang_latest.'<br />
|
|
|
|
</form>
|
|
|
|
';
|
2013-06-21 11:15:09 +02:00
|
|
|
// map api select form
|
|
|
|
$api_form = '
|
|
|
|
<u>'.$lang_api.'</u><br />
|
|
|
|
<form>
|
2013-06-23 23:43:09 +02:00
|
|
|
<select name="api" onchange="loadMapAPI(this.options[this.selectedIndex].value);">
|
2013-06-21 11:15:09 +02:00
|
|
|
<option value="gmaps"'.(($mapapi=="gmaps")?' selected':'').'>Google Maps</option>
|
|
|
|
<option value="openlayers"'.(($mapapi=="openlayers")?' selected':'').'>OpenLayers</option>
|
|
|
|
</select>
|
|
|
|
</form>
|
|
|
|
';
|
|
|
|
|
2013-06-23 23:43:09 +02:00
|
|
|
// language select form
|
|
|
|
$lang_form = '
|
|
|
|
<u>'.$lang_language.'</u><br />
|
|
|
|
<form>
|
|
|
|
<select name="units" onchange="setLang(this.options[this.selectedIndex].value);">
|
|
|
|
<option value="en"'.(($lang=="en")?' selected':'').'>English</option>
|
|
|
|
<option value="pl"'.(($lang=="pl")?' selected':'').'>Polski</option>
|
|
|
|
<option value="de"'.(($lang=="de")?' selected':'').'>Deutsch</option>
|
2017-01-30 21:36:44 +01:00
|
|
|
<option value="hu"'.(($lang=="hu")?' selected':'').'>Magyar</option>
|
2017-04-03 21:45:07 +02:00
|
|
|
<option value="fr"'.(($lang=="fr")?' selected':'').'>Français</option>
|
2017-04-05 15:40:49 +02:00
|
|
|
<option value="it"'.(($lang=="it")?' selected':'').'>Italiano</option>
|
2013-06-23 23:43:09 +02:00
|
|
|
</select>
|
|
|
|
</form>
|
|
|
|
';
|
|
|
|
// units select form
|
|
|
|
$units_form = '
|
|
|
|
<u>'.$lang_units.'</u><br />
|
|
|
|
<form>
|
|
|
|
<select name="units" onchange="setUnits(this.options[this.selectedIndex].value);">
|
|
|
|
<option value="metric"'.(($units=="metric")?' selected':'').'>'.$lang_metric.'</option>
|
|
|
|
<option value="imperial"'.(($units=="imperial")?' selected':'').'>'.$lang_imperial.'</option>
|
|
|
|
</select>
|
|
|
|
</form>
|
|
|
|
';
|
2017-02-17 16:41:39 +01:00
|
|
|
// admin menu
|
|
|
|
$admin_menu = '';
|
|
|
|
$admin_script = '';
|
|
|
|
if ($admin) {
|
|
|
|
$admin_menu = '
|
|
|
|
<div id="admin_menu">
|
|
|
|
<u>'.$lang_adminmenu.'</u><br />
|
|
|
|
<a href="javascript:void(0);" onclick="addUser()">'.$lang_adduser.'</a><br />
|
|
|
|
</div>
|
|
|
|
';
|
|
|
|
$admin_script = '<script type="text/javascript" src="admin.js"></script>';
|
|
|
|
}
|
2013-06-23 23:43:09 +02:00
|
|
|
|
2016-10-29 14:05:13 +02:00
|
|
|
print
|
2013-06-19 13:27:14 +02:00
|
|
|
'<!DOCTYPE html>
|
|
|
|
<html>
|
|
|
|
<head>
|
|
|
|
<title>'.$lang_title.'</title>
|
|
|
|
<meta http-equiv="Content-type" content="text/html;charset=UTF-8" />
|
|
|
|
<meta name="viewport" content="initial-scale=1.0, user-scalable=no" />
|
2013-06-21 11:15:09 +02:00
|
|
|
<link rel="stylesheet" type="text/css" href="main.css" />
|
2013-06-19 13:27:14 +02:00
|
|
|
<script>
|
|
|
|
var interval = '.$interval.';
|
2014-09-07 21:19:43 +02:00
|
|
|
var userid = '.(($userid)?$userid:-1).';
|
2013-06-19 13:27:14 +02:00
|
|
|
var trackid = '.(($trackid)?$trackid:-1).';
|
|
|
|
var lang_user = "'.$lang_user.'";
|
|
|
|
var lang_time = "'.$lang_time.'";
|
|
|
|
var lang_speed = "'.$lang_speed.'";
|
2017-01-30 21:36:44 +01:00
|
|
|
var lang_accuracy = "'.$lang_accuracy.'";
|
2013-06-19 13:27:14 +02:00
|
|
|
var lang_altitude = "'.$lang_altitude.'";
|
|
|
|
var lang_ttime = "'.$lang_ttime.'";
|
|
|
|
var lang_aspeed = "'.$lang_aspeed.'";
|
|
|
|
var lang_tdistance = "'.$lang_tdistance.'";
|
|
|
|
var lang_point = "'.$lang_point.'";
|
|
|
|
var lang_of = "'.$lang_of.'";
|
|
|
|
var lang_summary = "'.$lang_summary.'";
|
|
|
|
var lang_latest = "'.$lang_latest.'";
|
|
|
|
var lang_track = "'.$lang_track.'";
|
|
|
|
var lang_newinterval = "'.$lang_newinterval.'";
|
2017-03-16 12:37:17 +01:00
|
|
|
var lang_username = "'.$lang_username.'";
|
|
|
|
var lang_password = "'.$lang_password.'";
|
|
|
|
var lang_passwordrepeat = "'.$lang_passwordrepeat.'";
|
|
|
|
var lang_passwordenter = "'.$lang_passwordenter.'";
|
|
|
|
var lang_usernameenter = "'.$lang_usernameenter.'";
|
|
|
|
var lang_cancel = "'.$lang_cancel.'";
|
|
|
|
var lang_submit = "'.$lang_submit.'";
|
2013-06-19 13:27:14 +02:00
|
|
|
var units = "'.$units.'";
|
2013-06-21 11:15:09 +02:00
|
|
|
var mapapi = "'.$mapapi.'";
|
2013-06-21 12:44:57 +02:00
|
|
|
var gkey = '.(isset($gkey)?'"'.$gkey.'"':'null').';
|
2013-06-23 00:17:28 +02:00
|
|
|
var layer_ocm = "'.$layer_ocm.'";
|
|
|
|
var layer_mq = "'.$layer_mq.'";
|
|
|
|
var layer_osmapa = "'.$layer_osmapa.'";
|
2013-06-23 23:43:09 +02:00
|
|
|
var layer_ump = "'.$layer_ump.'";
|
2014-09-07 12:34:41 +02:00
|
|
|
var init_latitude = "'.$init_latitude.'";
|
|
|
|
var init_longitude = "'.$init_longitude.'";
|
2013-06-19 13:27:14 +02:00
|
|
|
</script>
|
2014-09-07 12:34:41 +02:00
|
|
|
<script type="text/javascript" src="main.js"></script>
|
2013-06-19 13:27:14 +02:00
|
|
|
';
|
|
|
|
if ($mapapi == "gmaps") {
|
2016-10-29 14:05:13 +02:00
|
|
|
print
|
|
|
|
' <script type="text/javascript" src="//maps.googleapis.com/maps/api/js'.(isset($gkey)?'?key='.$gkey:'').'"></script>
|
|
|
|
<script type="text/javascript" src="api_gmaps.js"></script>
|
2013-06-19 13:27:14 +02:00
|
|
|
';
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
print
|
2016-10-29 14:05:13 +02:00
|
|
|
' <script type="text/javascript" src="//openlayers.org/api/OpenLayers.js"></script>
|
2013-06-21 11:15:09 +02:00
|
|
|
<script type="text/javascript" src="api_openlayers.js"></script>
|
2013-06-19 13:27:14 +02:00
|
|
|
';
|
|
|
|
}
|
|
|
|
print '
|
2017-02-17 16:41:39 +01:00
|
|
|
'.$admin_script.'
|
2013-06-23 00:17:28 +02:00
|
|
|
<script type="text/javascript" src="//www.google.com/jsapi"></script>
|
2013-06-19 13:27:14 +02:00
|
|
|
<script type="text/javascript">
|
|
|
|
google.load("visualization", "1", {packages:["corechart"]});
|
|
|
|
</script>
|
2016-10-29 14:05:13 +02:00
|
|
|
|
2013-06-19 13:27:14 +02:00
|
|
|
</head>
|
|
|
|
<body onload="init();loadTrack(userid,trackid,1);">
|
|
|
|
<div id="menu">
|
|
|
|
<div id="menu-content">
|
|
|
|
<div id="user">
|
|
|
|
'.$user_form.'
|
|
|
|
</div>
|
2017-01-30 21:36:44 +01:00
|
|
|
<div id="track">
|
2013-06-19 13:27:14 +02:00
|
|
|
'.$track_form.'
|
2016-10-29 14:05:13 +02:00
|
|
|
<input type="checkbox" onchange="autoReload();"> '.$lang_autoreload.' (<a href="javascript:void(0);" onclick="setTime()"><span id="auto">'.$interval.'</span></a> s)<br />
|
2013-06-19 13:27:14 +02:00
|
|
|
<a href="javascript:void(0);" onclick="loadTrack(userid,trackid,0)">'.$lang_reload.'</a><br />
|
|
|
|
</div>
|
|
|
|
<div id="summary"></div>
|
|
|
|
<div id="other">
|
2013-06-21 11:15:09 +02:00
|
|
|
<a href="javascript:void(0);" onclick="toggleChart();">'.$lang_chart.'</a>
|
|
|
|
</div>
|
2016-10-29 14:05:13 +02:00
|
|
|
<div id="api">
|
2013-06-21 11:15:09 +02:00
|
|
|
'.$api_form.'
|
2013-06-19 13:27:14 +02:00
|
|
|
</div>
|
2016-10-29 14:05:13 +02:00
|
|
|
<div id="lang">
|
2013-06-23 23:43:09 +02:00
|
|
|
'.$lang_form.'
|
|
|
|
</div>
|
2016-10-29 14:05:13 +02:00
|
|
|
<div id="units">
|
2013-06-23 23:43:09 +02:00
|
|
|
'.$units_form.'
|
|
|
|
</div>
|
2013-06-19 13:27:14 +02:00
|
|
|
<div id="export">
|
2013-06-23 23:43:09 +02:00
|
|
|
<u>'.$lang_download.'</u><br />
|
2013-06-19 13:27:14 +02:00
|
|
|
<a href="javascript:void(0);" onclick="load(\'kml\',userid,trackid)">kml</a><br />
|
|
|
|
<a href="javascript:void(0);" onclick="load(\'gpx\',userid,trackid)">gpx</a><br />
|
|
|
|
</div>
|
2017-02-17 16:41:39 +01:00
|
|
|
'.$admin_menu.'
|
2013-06-19 13:27:14 +02:00
|
|
|
</div>
|
2013-06-26 19:58:55 +02:00
|
|
|
<div id="menu-close" onclick="toggleMenu();">»</div>
|
2017-01-30 21:36:44 +01:00
|
|
|
<div id="footer"><a target="_blank" href="https://github.com/bfabiszewski/ulogger-server"><span class="mi">μ</span>logger</a> '.$version.'</div>
|
2013-06-19 13:27:14 +02:00
|
|
|
</div>
|
|
|
|
<div id="main">
|
|
|
|
<div id="map-canvas"></div>
|
|
|
|
<div id="bottom">
|
|
|
|
<div id="chart"></div>
|
|
|
|
<div id="close"><a href="javascript:void(0);" onclick="toggleChart(0);">'.$lang_close.'</a></div>
|
2016-10-29 14:05:13 +02:00
|
|
|
</div>
|
2013-06-19 13:27:14 +02:00
|
|
|
</div>
|
|
|
|
</body>
|
|
|
|
</html>';
|
|
|
|
$mysqli->close();
|
|
|
|
?>
|