Commit ff8836d5 authored by panjalasanthosh's avatar panjalasanthosh
Browse files

03-03-2021

parents
No related merge requests found
Pipeline #645 failed with stages
Showing with 4720 additions and 0 deletions
+4720 -0
<?
session_start();
include ('../init.php');
include ('fn_common.php');
checkUserSession();
loadLanguage($_SESSION["language"], $_SESSION["units"]);
// check privileges
if ($_SESSION["privileges"] == 'subuser')
{
$user_id = $_SESSION["manager_id"];
}
else
{
$user_id = $_SESSION["user_id"];
}
if(@$_GET['cmd'] == 'load_rilogbook_list')
{
$imei = @$_GET['imei'];
$page = $_GET['page']; // get the requested page
$limit = $_GET['rows']; // get how many rows we want to have into the grid
$sidx = $_GET['sidx']; // get index row - i.e. user click to sort
$sord = $_GET['sord']; // get the direction
if(!$sidx) $sidx =1;
// get records number
if ($_SESSION["privileges"] == 'subuser')
{
$q = "SELECT * FROM `gs_rilogbook_data` WHERE `imei` IN (".$_SESSION["privileges_imei"].")";
}
else
{
$q = "SELECT * FROM `gs_rilogbook_data` WHERE `imei` IN (".getUserObjectIMEIs($user_id).")";
}
if (isset($imei))
{
$q .= ' AND `imei`="'.$imei.'"';
}
$group = '';
if ($_GET['drivers'] == 'true')
{
$group .= '"da",';
}
if ($_GET['passengers'] == 'true')
{
$group .= '"pa",';
}
if ($_GET['trailers'] == 'true')
{
$group .= '"ta",';
}
if ($group == '')
{
$group = '""';
}
$group = rtrim($group, ',');
$q .= ' AND `group` IN ('.$group.')';
if (isset($_GET['dtf']) && isset($_GET['dtt']))
{
$q .= " AND dt_server BETWEEN '".convUserUTCTimezone($_GET['dtf'])."' AND '".convUserUTCTimezone($_GET['dtt'])."'";
}
$r = mysqli_query($ms, $q);
if (!$r){die;}
$count = mysqli_num_rows($r);
if( $count >0 )
{
$total_pages = ceil($count/$limit);
}
else
{
$total_pages = 1;
}
if ($page > $total_pages) $page=$total_pages;
$start = $limit*$page - $limit; // do not put $limit*($page - 1)
if ($_SESSION["privileges"] == 'subuser')
{
$q = "SELECT * FROM `gs_rilogbook_data` WHERE `imei` IN (".$_SESSION["privileges_imei"].")";
}
else
{
$q = "SELECT * FROM `gs_rilogbook_data` WHERE `imei` IN (".getUserObjectIMEIs($user_id).")";
}
if (isset($imei))
{
$q .= ' AND `imei`="'.$imei.'"';
}
$group = '';
if ($_GET['drivers'] == 'true')
{
$group .= '"da",';
}
if ($_GET['passengers'] == 'true')
{
$group .= '"pa",';
}
if ($_GET['trailers'] == 'true')
{
$group .= '"ta",';
}
if ($group == '')
{
$group = '""';
}
$group = rtrim($group, ',');
$q .= ' AND `group` IN ('.$group.')';
if (isset($_GET['dtf']) && isset($_GET['dtt']))
{
$q .= " AND dt_server BETWEEN '".convUserUTCTimezone($_GET['dtf'])."' AND '".convUserUTCTimezone($_GET['dtt'])."'";
}
$q .= " ORDER BY $sidx $sord LIMIT $start, $limit";
$r = mysqli_query($ms, $q);
if (!$r){die;}
$responce = new stdClass();
$responce->page = $page;
$responce->total = $total_pages;
$responce->records = $count;
$i=0;
while($row = mysqli_fetch_array($r))
{
$rilogbook_id = $row['rilogbook_id'];
$dt_tracker = convUserTimezone($row['dt_tracker']);
$imei = $row['imei'];
$group = $row["group"];
$assign_id = strtoupper($row["assign_id"]);
$lat = $row["lat"];
$lng = $row["lng"];
$object_name = getObjectName($imei);
if ($group == 'da')
{
$q2 = "SELECT * FROM `gs_user_object_drivers` WHERE `user_id`='".$user_id."' AND `driver_assign_id`='".$assign_id."'";
$r2 = mysqli_query($ms, $q2);
$row2 = mysqli_fetch_array($r2);
if ($row2)
{
$assign_id = '<a href="#" onclick="utilsShowDriverInfo(\''.$row2["driver_id"].'\');">';
$assign_id .= $row2["driver_name"];
$assign_id .= '</a>';
}
$group = $la['DRIVER'];
}
else if ($group == 'pa')
{
$q2 = "SELECT * FROM `gs_user_object_passengers` WHERE `user_id`='".$user_id."' AND `passenger_assign_id`='".$assign_id."'";
$r2 = mysqli_query($ms, $q2);
$row2 = mysqli_fetch_array($r2);
if ($row2)
{
$assign_id = '<a href="#" onclick="utilsShowPassengerInfo(\''.$row2["passenger_id"].'\');">';
$assign_id .= $row2["passenger_name"];
$assign_id .= '</a>';
}
$group = $la['PASSENGER'];
}
else if ($group == 'ta')
{
$q2 = "SELECT * FROM `gs_user_object_trailers` WHERE `user_id`='".$user_id."' AND `trailer_assign_id`='".$assign_id."'";
$r2 = mysqli_query($ms, $q2);
$row2 = mysqli_fetch_array($r2);
if ($row2)
{
$assign_id = '<a href="#" onclick="utilsShowTrailerInfo(\''.$row2["trailer_id"].'\');">';
$assign_id .= $row2["trailer_name"];
$assign_id .= '</a>';
}
$group = $la['TRAILER'];
}
$lat = sprintf('%0.6f', $lat);
$lng = sprintf('%0.6f', $lng);
$position = '<a href="http://maps.google.com/maps?q='.$lat.','.$lng.'&t=m" target="_blank">'.$lat.' &deg;, '.$lng.' &deg;</a>';
if ($row["address"] != '')
{
$position .= ' - '.$row["address"];
}
// set modify buttons
$modify = '</a><a href="#" onclick="rilogbookDelete(\''.$rilogbook_id.'\');" title="'.$la['DELETE'].'"><img src="theme/images/remove3.svg" /></a>';
// set row
$responce->rows[$i]['id']=$rilogbook_id;
$responce->rows[$i]['cell']=array($dt_tracker,$object_name,$group,$assign_id,$position,$modify);
$i++;
}
header('Content-type: application/json');
echo json_encode($responce);
die;
}
if(@$_POST['cmd'] == 'delete_record')
{
$rilogbook_id = $_POST["rilogbook_id"];
$q = "DELETE FROM `gs_rilogbook_data` WHERE `rilogbook_id`='".$rilogbook_id."'";
$r = mysqli_query($ms, $q);
echo 'OK';
die;
}
if(@$_POST['cmd'] == 'delete_selected_records')
{
$items = $_POST["items"];
for ($i = 0; $i < count($items); ++$i)
{
$item = $items[$i];
$q = "DELETE FROM `gs_rilogbook_data` WHERE `rilogbook_id`='".$item."'";
$r = mysqli_query($ms, $q);
}
echo 'OK';
die;
}
if(@$_POST['cmd'] == 'delete_all_records')
{
if ($_SESSION["privileges"] == 'subuser')
{
$q = "DELETE FROM `gs_rilogbook_data` WHERE `imei` IN (".$_SESSION["privileges_imei"].")";
}
else
{
$q = "DELETE FROM `gs_rilogbook_data` WHERE `imei` IN (".getUserObjectIMEIs($user_id).")";
}
$r = mysqli_query($ms, $q);
echo 'OK';
die;
}
?>
\ No newline at end of file
<?
// describe route array data
// $route[0] - dt_tracker
// $route[1] - lat
// $route[2] - lng
// $route[3] - altitude
// $route[4] - angle
// $route[5] - speed
// $route[6] - params
function getRouteRaw($imei, $accuracy, $dtf, $dtt)
{
global $ms;
$route = array();
$q = "SELECT DISTINCT dt_tracker,
lat,
lng,
altitude,
angle,
speed,
params
FROM `gs_object_data_".$imei."` WHERE dt_tracker BETWEEN '".$dtf."' AND '".$dtt."' ORDER BY dt_tracker ASC";
$r = mysqli_query($ms, $q);
while($route_data=mysqli_fetch_array($r))
{
$dt_tracker = convUserTimezone($route_data['dt_tracker']);
$lat = $route_data['lat'];
$lng = $route_data['lng'];
$altitude = $route_data['altitude'];
$angle = $route_data['angle'];
$speed = $route_data['speed'];
$params = json_decode($route_data['params'],true);
$speed = convSpeedUnits($speed, 'km', $_SESSION["unit_distance"]);
$altitude = convAltitudeUnits($altitude, 'km', $_SESSION["unit_distance"]);
if (isset($params['gpslev']) && ($accuracy['use_gpslev'] == true))
{
$gpslev = $params['gpslev'];
}
else
{
$gpslev = 0;
$accuracy['min_gpslev'] = 0;
}
if (isset($params['hdop']) && ($accuracy['use_hdop'] == true))
{
$hdop = $params['hdop'];
}
else
{
$hdop = 0;
$accuracy['max_hdop'] = 0;
}
if (($gpslev >= $accuracy['min_gpslev']) && ($hdop <= $accuracy['max_hdop']))
{
if (($lat != 0) && ($lng != 0))
{
$route[] = array( $dt_tracker,
$lat,
$lng,
$altitude,
$angle,
$speed,
$params);
}
}
}
return $route;
}
function getRouteEvents($imei, $dtf, $dtt)
{
global $ms;
// check privileges
if ($_SESSION["privileges"] == 'subuser')
{
$user_id = $_SESSION["manager_id"];
}
else
{
$user_id = $_SESSION["user_id"];
}
$events = array();
$q = "SELECT * FROM `gs_user_events_data` WHERE `user_id`='".$user_id."' AND `imei`='".$imei."' AND dt_tracker BETWEEN '".$dtf."' AND '".$dtt."' ORDER BY dt_tracker ASC";
$r = mysqli_query($ms, $q);
while($event_data=mysqli_fetch_array($r))
{
$event_data['speed'] = convSpeedUnits($event_data['speed'], 'km', $_SESSION["unit_distance"]);
$event_data['altitude'] = convAltitudeUnits($event_data['altitude'], 'km', $_SESSION["unit_distance"]);
$event_data['params'] = json_decode($event_data['params'],true);
$events[] = array( $event_data['event_desc'],
convUserTimezone($event_data['dt_tracker']),
$event_data['lat'],
$event_data['lng'],
$event_data['altitude'],
$event_data['angle'],
$event_data['speed'],
$event_data['params']
);
}
return $events;
}
function getRoute($imei, $dtf, $dtt, $min_stop_duration, $filter)
{
$accuracy = getObjectAccuracy($imei);
$result = array();
$result['route'] = array();
$result['stops'] = array();
$result['drives'] = array();
$result['events'] = array();
if (checkObjectActive($imei) != true)
{
return $result;
}
$route = getRouteRaw($imei, $accuracy, $dtf, $dtt);
if (count($route) > 0)
{
// get object fuel rates
$fcr = getObjectFCR($imei);
// get ACC sensor
$sensor = getSensorFromType($imei, 'acc');
$acc = $sensor[0]['param'];
// filter jumping cordinates
if ($filter == true)
{
$route = removeRouteJunkPoints($route, $accuracy, array());
}
$result['route'] = $route;
// create stops
if ($accuracy['stops'] == 'gpsacc')
{
$result['stops'] = getRouteStopsGPSACC($route, $accuracy, $min_stop_duration, $acc);
}
else if ($accuracy['stops'] == 'acc')
{
$result['stops'] = getRouteStopsACC($route, $accuracy, $min_stop_duration, $acc);
}
else
{
$result['stops'] = getRouteStopsGPS($route, $accuracy, $min_stop_duration, $acc);
}
// create drives
$fuel_sensors = getSensorFromType($imei, 'fuel');
$fuelcons_sensors = getSensorFromType($imei, 'fuelcons');
$result['drives'] = getRouteDrives($route, $accuracy, $result['stops'], $fcr, $fuel_sensors, $fuelcons_sensors, $acc);
// load events
$result['events'] = getRouteEvents($imei, $dtf, $dtt);
// count route_length
$result['route_length'] = 0;
for ($i=0; $i<count($result['drives']); ++$i)
{
$result['route_length'] += $result['drives'][$i][7];
}
// count top speed
$result['top_speed'] = 0;
for ($i=0; $i<count($result['drives']); ++$i)
{
if ($result['top_speed'] < $result['drives'][$i][8])
{
$result['top_speed'] = $result['drives'][$i][8];
}
}
// count avg speed
$result['avg_speed'] = 0;
for ($i=0; $i<count($result['drives']); ++$i)
{
$result['avg_speed'] += $result['drives'][$i][9];
}
if (count($result['drives']) > 0)
{
$result['avg_speed'] = floor($result['avg_speed'] / count($result['drives']));
}
// count fuel consumption
$result['fuel_consumption'] = 0;
for ($i=0; $i<count($result['drives']); ++$i)
{
$result['fuel_consumption'] += $result['drives'][$i][10];
}
// count fuel cost
$result['fuel_cost'] = 0;
for ($i=0; $i<count($result['drives']); ++$i)
{
$result['fuel_cost'] += $result['drives'][$i][11];
}
// count stops duration
$result['stops_duration_time'] = 0;
for ($i=0; $i<count($result['stops']); ++$i)
{
$diff = strtotime($result['stops'][$i][7])-strtotime($result['stops'][$i][6]);
$result['stops_duration_time'] += $diff;
}
$result['stops_duration'] = getTimeDetails($result['stops_duration_time'], true);
// count drives duration and engine work
$result['drives_duration_time'] = 0;
for ($i=0; $i<count($result['drives']); ++$i)
{
$diff = strtotime($result['drives'][$i][5])-strtotime($result['drives'][$i][4]);
$result['drives_duration_time'] += $diff;
}
$result['drives_duration'] = getTimeDetails($result['drives_duration_time'], true);
// prepare full engine work and idle info
$result['engine_work_time'] = 0;
$result['engine_idle_time'] = 0;
for ($i=0; $i<count($result['drives']); ++$i)
{
$result['engine_work_time'] += $result['drives'][$i][12];
$result['drives'][$i][12] = getTimeDetails($result['drives'][$i][12], true);
}
for ($i=0; $i<count($result['stops']); ++$i)
{
$result['engine_idle_time'] += $result['stops'][$i][9];
$result['stops'][$i][9] = getTimeDetails($result['stops'][$i][9], true);
}
// set total engine work and idle
$result['engine_work_time'] += $result['engine_idle_time'];
$result['engine_work'] = getTimeDetails($result['engine_work_time'], true);
$result['engine_idle'] = getTimeDetails($result['engine_idle_time'], true);
}
return $result;
}
function getRouteOverspeeds($route, $speed_limit)
{
$overspeeds = array();
$overspeed = 0;
$top_speed = 0;
$avg_speed = 0;
$avg_speed_c = 0;
for ($i=0; $i<count($route); ++$i)
{
$speed = $route[$i][5];
if ($speed > $speed_limit)
{
if($overspeed == 0)
{
$overspeed_start = $route[$i][0];
$overspeed = 1;
}
if ($speed >= $top_speed)
{
$top_speed = $speed;
$overspeed_lat = $route[$i][1];
$overspeed_lng = $route[$i][2];
}
$avg_speed += $speed;
$avg_speed_c++;
}
else
{
if ($overspeed == 1)
{
$overspeed_end = $route[$i][0];
$overspeed_duration = getTimeDifferenceDetails($overspeed_start, $overspeed_end);
$overspeeds[] = array( $overspeed_start,
$overspeed_end,
$overspeed_duration,
$top_speed,
floor($avg_speed / $avg_speed_c),
$overspeed_lat,
$overspeed_lng
);
$top_speed = 0;
$avg_speed = 0;
$avg_speed_c = 0;
$overspeed = 0;
}
}
}
return $overspeeds;
}
function getRouteUnderspeeds($route, $speed_limit)
{
$underpeeds = array();
$underpeed = 0;
$top_speed = 0;
$avg_speed = 0;
$avg_speed_c = 0;
for ($i=0; $i<count($route); ++$i)
{
$speed = $route[$i][5];
if ($speed < $speed_limit)
{
if($underpeed == 0)
{
$underpeed_start = $route[$i][0];
$underpeed = 1;
}
if ($speed >= $top_speed)
{
$top_speed = $speed;
$underpeed_lat = $route[$i][1];
$underpeed_lng = $route[$i][2];
}
$avg_speed += $speed;
$avg_speed_c++;
}
else
{
if ($underpeed == 1)
{
$underpeed_end = $route[$i][0];
$underpeed_duration = getTimeDifferenceDetails($underpeed_start, $underpeed_end);
$underpeeds[] = array( $underpeed_start,
$underpeed_end,
$underpeed_duration,
$top_speed,
floor($avg_speed / $avg_speed_c),
$underpeed_lat,
$underpeed_lng
);
$top_speed = 0;
$avg_speed = 0;
$avg_speed_c = 0;
$underpeed = 0;
}
}
}
return $underpeeds;
}
function getRouteStopsGPSACC($route, $accuracy, $min_stop_duration, $acc)
{
$stops = array();
$stoped = 0;
$min_moving_speed = $accuracy['min_moving_speed'];
for ($i=0; $i<count($route); ++$i)
{
$params = $route[$i][6];
if (!isset($params[$acc]))
{
$params[$acc] = '';
}
$stop_speed = $route[$i][5];
if ((($stop_speed <= $min_moving_speed) && ($i < count($route)-1)) || (($params[$acc] == '0') && ($i < count($route)-1)))
{
if($stoped == 0)
{
$start_id = $i;
$stop_start = $route[$i][0];
$stop_lat = $route[$i][1];
$stop_lng = $route[$i][2];
$stop_altitude = $route[$i][3];
$stop_angle = $route[$i][4];
$stop_params = $route[$i][6];
$stoped = 1;
}
}
else
{
if ($stoped == 1)
{
$end_id = $i;
$stop_end = $route[$i][0];
$stop_duration = getTimeDifferenceDetails($stop_start, $stop_end);
$stop_engine_hours = getRouteEngineHours($route, $start_id, $end_id, $acc);
$time_diff = strtotime($stop_end)-strtotime($stop_start);
if ($time_diff > ($min_stop_duration * 60))
{
$stops[] = array( $start_id,
$end_id,
$stop_lat,
$stop_lng,
$stop_altitude,
$stop_angle,
$stop_start,
$stop_end,
$stop_duration,
$stop_engine_hours,
$stop_params,
);
}
$stoped = 0;
}
}
}
return $stops;
}
function getRouteStopsACC($route, $accuracy, $min_stop_duration, $acc)
{
$stops = array();
$stoped = 0;
for ($i=0; $i<count($route); ++$i)
{
$params = $route[$i][6];
if (!isset($params[$acc]))
{
$params[$acc] = '';
}
if (($params[$acc] == '0') && ($i < count($route)-1))
{
if($stoped == 0)
{
$start_id = $i;
$stop_start = $route[$i][0];
$stop_lat = $route[$i][1];
$stop_lng = $route[$i][2];
$stop_altitude = $route[$i][3];
$stop_angle = $route[$i][4];
$stop_params = $route[$i][6];
$stoped = 1;
}
}
else
{
if ($stoped == 1)
{
$end_id = $i;
$stop_end = $route[$i][0];
$stop_duration = getTimeDifferenceDetails($stop_start, $stop_end);
//$stop_engine_hours = getRouteEngineHours($route, $start_id, $end_id, $acc);
$stop_engine_hours = '0'; // because Stop is detected by ACC
$time_diff = strtotime($stop_end)-strtotime($stop_start);
if ($time_diff > ($min_stop_duration * 60))
{
$stops[] = array( $start_id,
$end_id,
$stop_lat,
$stop_lng,
$stop_altitude,
$stop_angle,
$stop_start,
$stop_end,
$stop_duration,
$stop_engine_hours,
$stop_params
);
}
$stoped = 0;
}
}
}
return $stops;
}
function getRouteStopsGPS($route, $accuracy, $min_stop_duration, $acc)
{
$stops = array();
$stoped = 0;
$min_moving_speed = $accuracy['min_moving_speed'];
for ($i=0; $i<count($route); ++$i)
{
$stop_speed = $route[$i][5];
if (($stop_speed <= $min_moving_speed) && ($i < count($route)-1))
{
if($stoped == 0)
{
$start_id = $i;
$stop_start = $route[$i][0];
$stop_lat = $route[$i][1];
$stop_lng = $route[$i][2];
$stop_altitude = $route[$i][3];
$stop_angle = $route[$i][4];
$params = $route[$i][6];
$stoped = 1;
}
}
else
{
if ($stoped == 1)
{
$end_id = $i;
$stop_end = $route[$i][0];
$stop_duration = getTimeDifferenceDetails($stop_start, $stop_end);
$stop_engine_hours = getRouteEngineHours($route, $start_id, $end_id, $acc);
$time_diff = strtotime($stop_end)-strtotime($stop_start);
if ($time_diff > ($min_stop_duration * 60))
{
$stops[] = array( $start_id,
$end_id,
$stop_lat,
$stop_lng,
$stop_altitude,
$stop_angle,
$stop_start,
$stop_end,
$stop_duration,
$stop_engine_hours,
$params
);
}
$stoped = 0;
}
}
}
return $stops;
}
function getRouteDrives($route, $accuracy, $stops, $fcr, $fuel_sensors, $fuelcons_sensors, $acc)
{
$drives = array();
if (count($stops) == 0)
{
// moving between start and end marker if no stops
$id_start_s = 0;
$id_start = 0;
$id_end = count($route)-1;
$dt_start_s = $route[$id_start_s][0];
$dt_start = $route[$id_start][0];
$dt_end = $route[$id_end][0];
if ($dt_start != $dt_end)
{
$moving_duration = getTimeDifferenceDetails($dt_start, $dt_end);
$route_length = getRouteLength($route, $id_start_s, $id_end);
$top_speed = getRouteTopSpeed($route, $id_start_s, $id_end);
$avg_speed = getRouteAvgSpeed($route, $id_start_s, $id_end);
$fuel_consumption = getRouteFuelConsumption($route, $id_start, $id_end, $accuracy, $fcr, $fuel_sensors, $fuelcons_sensors);
$fuel_cost = getRouteFuelCost($fuel_consumption, $fcr);
$engine_work = getRouteEngineHours($route, $id_start, $id_end, $acc);
$drives_start_end = array( $id_start_s,
$id_start,
$id_end,
$dt_start_s,
$dt_start,
$dt_end,
$moving_duration,
$route_length,
$top_speed,
$avg_speed,
$fuel_consumption,
$fuel_cost,
$engine_work);
}
}
else
{
// moving between start and first stop
$id_start_s = 0;
$id_start = 0;
$id_end = $stops[0][0];
if ($id_end != 0)
{
$dt_start_s = $route[$id_start_s][0];
$dt_start = $route[$id_start][0];
$dt_end = $route[$id_end][0];
if ($dt_start != $dt_end)
{
$moving_duration = getTimeDifferenceDetails($dt_start, $dt_end);
$route_length = getRouteLength($route, $id_start_s, $id_end);
$top_speed = getRouteTopSpeed($route, $id_start_s, $id_end);
$avg_speed = getRouteAvgSpeed($route, $id_start_s, $id_end);
$fuel_consumption = getRouteFuelConsumption($route, $id_start, $id_end, $accuracy, $fcr, $fuel_sensors, $fuelcons_sensors);
$fuel_cost = getRouteFuelCost($fuel_consumption, $fcr);
$engine_work = getRouteEngineHours($route, $id_start, $id_end, $acc);
$drives_start = array( $id_start_s,
$id_start,
$id_end,
$dt_start_s,
$dt_start,
$dt_end,
$moving_duration,
$route_length,
$top_speed,
$avg_speed,
$fuel_consumption,
$fuel_cost,
$engine_work);
}
}
// moving between end and last stop
$id_start_s = $stops[count($stops)-1][0];
$id_start = $stops[count($stops)-1][1];
$id_end = count($route)-1;
if ($id_start != $id_end)
{
$dt_start_s = $route[$id_start_s][0];
$dt_start = $route[$id_start][0];
$dt_end = $route[$id_end][0];
if ($dt_start != $dt_end)
{
$moving_duration = getTimeDifferenceDetails($dt_start, $dt_end);
$route_length = getRouteLength($route, $id_start_s, $id_end);
$top_speed = getRouteTopSpeed($route, $id_start_s, $id_end);
$avg_speed = getRouteAvgSpeed($route, $id_start_s, $id_end);
$fuel_consumption = getRouteFuelConsumption($route, $id_start, $id_end, $accuracy, $fcr, $fuel_sensors, $fuelcons_sensors);
$fuel_cost = getRouteFuelCost($fuel_consumption, $fcr);
$engine_work = getRouteEngineHours($route, $id_start, $id_end, $acc);
$drives_end = array( $id_start_s,
$id_start,
$id_end,
$dt_start_s,
$dt_start,
$dt_end,
$moving_duration,
$route_length,
$top_speed,
$avg_speed,
$fuel_consumption,
$fuel_cost,
$engine_work);
}
}
}
// moving between stops
for ($i=0; $i<count($stops)-1; ++$i)
{
$id_start_s = $stops[$i][0];
$id_start = $stops[$i][1];
$id_end = $stops[$i+1][0];
$dt_start_s = $route[$id_start_s][0];
$dt_start = $route[$id_start][0];
$dt_end = $route[$id_end][0];
if ($dt_start != $dt_end)
{
$moving_duration = getTimeDifferenceDetails($dt_start, $dt_end);
$route_length = getRouteLength($route, $id_start_s, $id_end);
$top_speed = getRouteTopSpeed($route, $id_start_s, $id_end);
$avg_speed = getRouteAvgSpeed($route, $id_start_s, $id_end);
$fuel_consumption = getRouteFuelConsumption($route, $id_start, $id_end, $accuracy, $fcr, $fuel_sensors, $fuelcons_sensors);
$fuel_cost = getRouteFuelCost($fuel_consumption, $fcr);
$engine_work = getRouteEngineHours($route, $id_start, $id_end, $acc);
$drives_stops[] = array( $id_start_s,
$id_start,
$id_end,
$dt_start_s,
$dt_start,
$dt_end,
$moving_duration,
$route_length,
$top_speed,
$avg_speed,
$fuel_consumption,
$fuel_cost,
$engine_work);
}
}
if(isset($drives_start_end))
{
$drives[] = $drives_start_end;
}
else
{
if(isset($drives_start))
{
$drives[] = $drives_start;
}
if(isset($drives_stops))
{
$drives = array_merge($drives, $drives_stops);
}
if(isset($drives_end))
{
$drives[] = $drives_end;
}
}
return $drives;
}
function getRouteFuelCost($fuel_consumption, $fcr)
{
$fuel_cost = 0;
if ($fcr == '')
{
return $fuel_cost;
}
$fuel_cost = $fuel_consumption * $fcr['cost'];
return sprintf("%01.2f", $fuel_cost);
}
function getRouteFuelConsumption($route, $start_id, $end_id, $accuracy, $fcr, $fuel_sensors, $fuelcons_sensors)
{
$fuel_consumtion = 0;
if ($fcr == '')
{
return $fuel_consumtion;
}
$source = $fcr['source'];
$measurement = $fcr['measurement'];
$cost = $fcr['cost'];
$summer = $fcr['summer'];
$winter = $fcr['winter'];
$winter_start = $fcr['winter_start'];
$winter_end= $fcr['winter_end'];
$diff_ff = $accuracy['min_ff'];
if ($source == 'rates')
{
if (($summer > 0) && ($winter > 0))
{
for ($i=$start_id; $i<$end_id-1; ++$i)
{
$lat1 = $route[$i][1];
$lng1 = $route[$i][2];
$lat2 = $route[$i+1][1];
$lng2 = $route[$i+1][2];
$length = getLengthBetweenCoordinates($lat1, $lng1, $lat2, $lng2);
if ($measurement == 'mpg')
{
$length = convDistanceUnits($length, 'km', 'mi');
}
$f_date = strtotime($route[$i][0]);
$f_date1 = strtotime(gmdate("Y").'-'.$winter_start);
$f_date2 = strtotime(gmdate("Y").'-'.$winter_end);
if ($f_date1 >= $f_date2)
{
$f_date2 = strtotime((gmdate("Y") + 1).'-'.$winter_end);
}
if (($f_date >= $f_date1) && ($f_date <= $f_date2 ))
{
$fuel_consumtion += $length / $winter;
}
else
{
$fuel_consumtion += $length / $summer;
}
}
}
}
else if (($source == 'fuel') && ($fuel_sensors != false))
{
$params1 = $route[$start_id][6];
$params2 = $route[$end_id][6];
// loop per fuel sensors
for ($j=0; $j<count($fuel_sensors); ++$j)
{
$before = getSensorValue($params1, $fuel_sensors[$j]);
$after = getSensorValue($params2, $fuel_sensors[$j]);
$diff = $after['value'] - $before['value'];
if ($diff < 0)
{
$fuel_consumtion += $diff;
}
}
$fuel_consumtion = abs($fuel_consumtion);
}
else if (($source == 'fuelcons') && ($fuelcons_sensors != false))
{
for ($i=$start_id; $i<$end_id; ++$i)
{
$params = $route[$i][6];
$cons = getSensorValue($params, $fuelcons_sensors[0]);
$fuel_consumtion += abs($cons['value']);
}
}
return sprintf("%01.2f", $fuel_consumtion);
}
function getRouteFuelFillings($route, $accuracy, $fuel_sensors)
{
$result = array();
$result['fillings'] = array();
if ($fuel_sensors == false)
{
return $result;
}
$diff_ff = $accuracy['min_ff'];
$total_filled = 0;
for ($i=0; $i<count($route)-1; ++$i)
{
$params1 = $route[$i][6];
$params2 = $route[$i+1][6];
$speed1 = $route[$i][5];
$speed2 = $route[$i+1][5];
// loop per fuel sensors
for ($j=0; $j<count($fuel_sensors); ++$j)
{
$before = getSensorValue($params1, $fuel_sensors[$j]); // fuel level
$after = getSensorValue($params2, $fuel_sensors[$j]); // fuel level in next point
$diff = $after['value'] - $before['value']; // fuel filling
if (($diff >= $diff_ff) && (($speed1 < 10) || ($speed2 < 10)))
{
//echo $before['value'].' '.$after['value'].' '.$diff.'</br>';
$dt_tracker = $route[$i+1][0];
$lat = $route[$i+1][1];
$lng = $route[$i+1][2];
$filled = $after['value'] - $before['value'];
$total_filled += $filled;
$sensor = $fuel_sensors[$j]['name'];
$params = $route[$i+1][6];
$result['fillings'][] = array( $dt_tracker,
$lat,
$lng,
$before['value_full'],
$after['value_full'],
$filled.' '.$fuel_sensors[$j]['units'],
$sensor,
$params);
}
}
}
$result['total_filled'] = $total_filled.' '.$fuel_sensors[0]['units'];
return $result;
}
function getRouteFuelThefts($route, $accuracy, $fuel_sensors)
{
$result = array();
$result['thefts'] = array();
if ($fuel_sensors == false)
{
return $result;
}
$diff_ft = $accuracy['min_ft'];
$total_stolen = 0;
for ($i=0; $i<count($route)-1; ++$i)
{
$params1 = $route[$i][6];
$params2 = $route[$i+1][6];
$speed1 = $route[$i][5];
$speed2 = $route[$i+1][5];
// loop per fuel sensors
for ($j=0; $j<count($fuel_sensors); ++$j)
{
$before = getSensorValue($params1, $fuel_sensors[$j]); // fuel level
$after = getSensorValue($params2, $fuel_sensors[$j]); // fuel level in next point
$diff = $before['value'] - $after['value']; // fuel filling
if (($diff >= $diff_ft) && (($speed1 < 10) || ($speed2 < 10)))
{
$dt_tracker = $route[$i+1][0];
$lat = $route[$i+1][1];
$lng = $route[$i+1][2];
$stolen = $before['value'] - $after['value'];
$total_stolen += $stolen;
$sensor = $fuel_sensors[$j]['name'];
$params = $route[$i+1][6];
$result['thefts'][] = array( $dt_tracker,
$lat,
$lng,
$before['value_full'],
$after['value_full'],
$stolen.' '.$fuel_sensors[$j]['units'],
$sensor,
$params);
}
}
}
$result['total_stolen'] = $total_stolen.' '.$fuel_sensors[0]['units'];
return $result;
}
function getRouteLogicSensorInfo($route, $accuracy, $sensors)
{
$result = array();
if ($sensors == false)
{
return $result;
}
for ($i=0; $i<count($sensors); ++$i)
{
$status = false;
$activation_time = '';
$deactivation_time = '';
$activation_lat = '';
$activation_lng = '';
$deactivation_lat = '';
$deactivation_lng = '';
$sensor = $sensors[$i];
$sensor_name = $sensor['name'];
$sensor_param = $sensor['param'];
for ($j=0; $j<count($route); ++$j)
{
$dt_tracker = $route[$j][0];
$lat = $route[$j][1];
$lng = $route[$j][2];
$params = $route[$j][6];
$param_value = getParamValue($params, $sensor_param);
if ($status == false)
{
if ($param_value == 1)
{
$activation_time = $dt_tracker;
$activation_lat = $lat;
$activation_lng = $lng;
$status = true;
}
}
else
{
if ($param_value == 0)
{
$deactivation_time = $dt_tracker;
$deactivation_lat = $lat;
$deactivation_lng = $lng;
$duration = getTimeDifferenceDetails($activation_time, $deactivation_time);
$result[] = array($sensor_name,
$activation_time,
$deactivation_time,
$duration,
$activation_lat,
$activation_lng,
$deactivation_lat,
$deactivation_lng);
$status = false;
$activation_time = '';
$deactivation_time = '';
$activation_lat = '';
$activation_lng = '';
$deactivation_lat = '';
$deactivation_lng = '';
}
}
}
}
return $result;
}
function getRouteLength($route, $start_id, $end_id)
{
// check if not last point
if (count($route) == $end_id)
{
$end_id -= 1;
}
$length = 0;
for ($i=$start_id; $i<$end_id; ++$i)
{
$lat1 = $route[$i][1];
$lng1 = $route[$i][2];
$lat2 = $route[$i+1][1];
$lng2 = $route[$i+1][2];
$length += getLengthBetweenCoordinates($lat1, $lng1, $lat2, $lng2);
}
$length = convDistanceUnits($length, 'km', $_SESSION["unit_distance"]);
return sprintf("%01.2f", $length);
}
function getRouteTopSpeed($route, $start_id, $end_id)
{
$top_speed = 0;
for ($i=$start_id; $i<$end_id; ++$i)
{
if ($top_speed < $route[$i][5])
{
$top_speed = $route[$i][5];
}
}
return $top_speed;
}
function getRouteAvgSpeed($route, $start_id, $end_id)
{
$avg_speed = 0;
for ($i=$start_id; $i<$end_id; ++$i)
{
$avg_speed += $route[$i][5];
}
$num = $end_id - $start_id;
return floor($avg_speed/$num);
}
function getRouteEngineHours($route, $start_id, $end_id, $acc)
{
// check if not last point
if (count($route) == $end_id)
{
$end_id -= 1;
}
$engine_hours = 0;
for ($i=$start_id; $i<$end_id; ++$i)
{
$dt_tracker1 = $route[$i][0];
$params1 = $route[$i][6];
$dt_tracker2 = $route[$i+1][0];
$params2 = $route[$i+1][6];
if (isset($params1[$acc]) && isset($params2[$acc]))
{
if (($params1[$acc] == '1') && ($params2[$acc] == '1'))
{
$engine_hours += strtotime($dt_tracker2)-strtotime($dt_tracker1);
}
}
}
return $engine_hours;
}
function removeRouteJunkPoints($route, $accuracy)
{
$temp = array();
$min_moving_speed = $accuracy['min_moving_speed'];
$min_diff_points = $accuracy['min_diff_points'];
// filter drifting
for ($i=0; $i<count($route)-1; ++$i)
{
$dt_tracker = $route[$i][0];
$lat1 = $route[$i][1];
$lng1 = $route[$i][2];
$lat2 = $route[$i+1][1];
$lng2 = $route[$i+1][2];
$speed = $route[$i][5];
$lat_diff = abs($lat1 - $lat2);
$lng_diff = abs($lng1 - $lng2);
if (($i == 0) || ($speed > $min_moving_speed) || ($lat_diff > $min_diff_points) && ($lng_diff > $min_diff_points))
{
$lat_temp = $lat2;
$lng_temp = $lng2;
$temp[] = $route[$i];
}
else
{
if (isset($lat_temp))
{
$route[$i][1] = $lat_temp;
$route[$i][2] = $lng_temp;
}
$temp[] = $route[$i];
}
}
$temp[] = $route[count($route)-1]; // add last point
return $temp;
}
?>
\ No newline at end of file
<?
if(empty($_POST['filename']) || empty($_POST['content'])){
die;
}
if(@$_GET['format'] == 'html')
{
$filename = preg_replace('/[^a-z0-9\_\.]/i','_',$_POST['filename'].'.html');
//$filename = $_POST['filename'];
header('Content-type: text/html');
header('Content-Disposition: attachment; filename="'.$filename.'"');
header("Pragma: no-cache");
header("Expires: 0");
echo base64_decode(stripslashes($_POST['content']));
}
if(@$_GET['format'] == 'pdf')
{
$filename = preg_replace('/[^a-z0-9\_\.]/i','_',$_POST['filename'].'.pdf');
//$filename = $_POST['filename'];
header('Content-type: application/pdf');
header('Content-Disposition: attachment; filename="'.$filename.'"');
header("Pragma: no-cache");
header("Expires: 0");
echo base64_decode(stripslashes($_POST['content']));
}
if(@$_GET['format'] == 'xls')
{
$filename = preg_replace('/[^a-z0-9\_\.]/i','_',$_POST['filename'].'.xls');
//$filename = $_POST['filename'];
header("Content-type: application/x-msdownload");
header('Content-Disposition: attachment; filename="'.$filename.'"');
header("Pragma: no-cache");
header("Expires: 0");
echo base64_decode(stripslashes($_POST['content']));
}
?>
\ No newline at end of file
<?
session_start();
include ('../init.php');
include ('fn_common.php');
checkUserSession();
loadLanguage($_SESSION["language"], $_SESSION["units"]);
// check privileges
if ($_SESSION["privileges"] == 'subuser')
{
$user_id = $_SESSION["manager_id"];
}
else
{
$user_id = $_SESSION["user_id"];
}
if(@$_POST['cmd'] == 'delete_object_custom_field')
{
$field_id = $_POST["field_id"];
$imei = $_POST["imei"];
$q = "DELETE FROM `gs_object_custom_fields` WHERE `field_id`='".$field_id."' AND `imei`='".$imei."'";
$r = mysqli_query($ms, $q);
echo 'OK';
die;
}
if(@$_POST['cmd'] == 'delete_selected_object_custom_fields')
{
$items = $_POST["items"];
$imei = $_POST["imei"];
for ($i = 0; $i < count($items); ++$i)
{
$item = $items[$i];
$q = "DELETE FROM `gs_object_custom_fields` WHERE `field_id`='".$item."' AND `imei`='".$imei."'";
$r = mysqli_query($ms, $q);
}
echo 'OK';
die;
}
if(@$_POST['cmd'] == 'save_object_custom_field')
{
$field_id = $_POST["field_id"];
$imei = $_POST["imei"];
$name = $_POST["name"];
$value = $_POST["value"];
$data_list = $_POST["data_list"];
$popup = $_POST["popup"];
if ($field_id == 'false')
{
$q = "INSERT INTO `gs_object_custom_fields` (`imei`, `name`, `value`, `data_list`, `popup`) VALUES ('".$imei."', '".$name."', '".$value."', '".$data_list."', '".$popup."')";
}
else
{
$q = "UPDATE `gs_object_custom_fields` SET `imei`='".$imei."', `name`='".$name."', `value`='".$value."', `data_list`='".$data_list."', `popup`='".$popup."' WHERE `field_id`='".$field_id."'";
}
$r = mysqli_query($ms, $q);
echo 'OK';
}
if(@$_GET['cmd'] == 'load_object_custom_field_list')
{
$page = $_GET['page']; // get the requested page
$limit = $_GET['rows']; // get how many rows we want to have into the grid
$sidx = $_GET['sidx']; // get index row - i.e. user click to sort
$sord = $_GET['sord']; // get the direction
$imei = $_GET['imei'];
if(!$sidx) $sidx =1;
// get records number
$q = "SELECT * FROM `gs_object_custom_fields` WHERE `imei`='".$imei."'";
$r = mysqli_query($ms, $q);
$count = mysqli_num_rows($r);
$q = "SELECT * FROM `gs_object_custom_fields` WHERE `imei`='".$imei."' ORDER BY $sidx $sord";
$result = mysqli_query($ms, $q);
$responce = new stdClass();
$i=0;
while($row = mysqli_fetch_array($result)) {
$field_id = $row["field_id"];
$name = $row['name'];
$value = $row['value'];
$data_list = $row['data_list'];
$popup = $row['popup'];
if ($data_list == 'true')
{
$data_list = '<img src="theme/images/tick-green.svg" />';
}
else
{
$data_list = '<img src="theme/images/remove-red.svg" style="width:12px;" />';
}
if ($popup == 'true')
{
$popup = '<img src="theme/images/tick-green.svg" />';
}
else
{
$popup = '<img src="theme/images/remove-red.svg" style="width:12px;" />';
}
// set modify buttons
$modify = '<a href="#" onclick="settingsObjectCustomFieldProperties(\''.$field_id.'\');" title="'.$la['EDIT'].'"><img src="theme/images/edit.svg" />';
$modify .= '</a><a href="#" onclick="settingsObjectCustomFieldDelete(\''.$field_id.'\');" title="'.$la['DELETE'].'"><img src="theme/images/remove3.svg" /></a>';
// set row
$responce->rows[$i]['id']=$field_id;
$responce->rows[$i]['cell']=array($name,$value,$data_list,$popup,$modify);
$i++;
}
$responce->page = 1;
//$responce->total = $count;
$responce->records = $count;
header('Content-type: application/json');
echo json_encode($responce);
die;
}
?>
\ No newline at end of file
<?
session_start();
include ('../init.php');
include ('fn_common.php');
checkUserSession();
loadLanguage($_SESSION["language"], $_SESSION["units"]);
// check privileges
if ($_SESSION["privileges"] == 'subuser')
{
$user_id = $_SESSION["manager_id"];
}
else
{
$user_id = $_SESSION["user_id"];
}
if(@$_POST['cmd'] == 'delete_object_driver')
{
$driver_id = $_POST["driver_id"];
$q = "SELECT * FROM `gs_user_object_drivers` WHERE `driver_id`='".$driver_id."'";
$r = mysqli_query($ms, $q);
$row = mysqli_fetch_array($r);
$img_file = $gsValues['PATH_ROOT'].'data/user/drivers/'.$row['driver_img_file'];
if(is_file($img_file))
{
@unlink($img_file);
}
$q = "DELETE FROM `gs_user_object_drivers` WHERE `driver_id`='".$driver_id."'";
$r = mysqli_query($ms, $q);
// reset driver_id in objects
$q = "UPDATE `gs_user_objects` SET `driver_id`='0' WHERE `driver_id`='".$driver_id."'";
$r = mysqli_query($ms, $q);
echo 'OK';
die;
}
if(@$_POST['cmd'] == 'delete_selected_object_drivers')
{
$items = $_POST["items"];
for ($i = 0; $i < count($items); ++$i)
{
$item = $items[$i];
$q = "SELECT * FROM `gs_user_object_drivers` WHERE `driver_id`='".$item."' AND `user_id`='".$user_id."'";
$r = mysqli_query($ms, $q);
$row = mysqli_fetch_array($r);
$img_file = $gsValues['PATH_ROOT'].'data/user/drivers/'.$row['driver_img_file'];
if(is_file($img_file))
{
@unlink($img_file);
}
$q = "DELETE FROM `gs_user_object_drivers` WHERE `driver_id`='".$item."' AND `user_id`='".$user_id."'";
$r = mysqli_query($ms, $q);
// reset driver_id in objects
$q = "UPDATE `gs_user_objects` SET `driver_id`='0' WHERE `driver_id`='".$item."'";
$r = mysqli_query($ms, $q);
}
echo 'OK';
die;
}
if(@$_POST['cmd'] == 'save_object_driver')
{
$driver_id = $_POST["driver_id"];
$driver_name = $_POST["driver_name"];
$driver_assign_id = strtoupper($_POST["driver_assign_id"]);
$driver_idn = $_POST["driver_idn"];
$driver_address = $_POST["driver_address"];
$driver_phone = $_POST["driver_phone"];
$driver_email = $_POST["driver_email"];
$driver_desc = $_POST["driver_desc"];
$driver_img_file = $_POST["driver_img_file"];
if ($driver_img_file == 'false')
{
$driver_img_file = '';
}
if ($driver_img_file == 'delete')
{
$driver_img_file = '';
if ($driver_id != 'false')
{
$q = "SELECT * FROM `gs_user_object_drivers` WHERE `driver_id`='".$driver_id."'";
$r = mysqli_query($ms, $q);
$row = mysqli_fetch_array($r);
$img_file = $gsValues['PATH_ROOT'].'data/user/drivers/'.$row['driver_img_file'];
if(is_file($img_file))
{
@unlink($img_file);
}
$q = "UPDATE `gs_user_object_drivers` SET `driver_img_file`='' WHERE `driver_id`='".$driver_id."'";
$r = mysqli_query($ms, $q);
}
}
if ($driver_img_file == 'true')
{
$driver_img_file = $user_id.'_'.md5(gmdate("Y-m-d H:i:s")).'.png';
$file_temp = $gsValues['PATH_ROOT'].'data/user/drivers/'.$user_id.'_temp.png';
$file_new = $gsValues['PATH_ROOT'].'data/user/drivers/'.$driver_img_file;
if(is_file($file_temp))
{
rename($file_temp, $file_new);
}
if ($driver_id != 'false')
{
$q = "SELECT * FROM `gs_user_object_drivers` WHERE `driver_id`='".$driver_id."'";
$r = mysqli_query($ms, $q);
$row = mysqli_fetch_array($r);
$img_file = $gsValues['PATH_ROOT'].'data/user/drivers/'.$row['driver_img_file'];
if(is_file($img_file))
{
@unlink($img_file);
}
$q = "UPDATE `gs_user_object_drivers` SET `driver_img_file`='".$driver_img_file."' WHERE `driver_id`='".$driver_id."'";
$r = mysqli_query($ms, $q);
}
}
if ($driver_id == 'false')
{
$q = "INSERT INTO `gs_user_object_drivers`( `user_id`,
`driver_name`,
`driver_assign_id`,
`driver_idn`,
`driver_address`,
`driver_phone`,
`driver_email`,
`driver_desc`,
`driver_img_file`)
VALUES
('".$user_id."',
'".$driver_name."',
'".$driver_assign_id."',
'".$driver_idn."',
'".$driver_address."',
'".$driver_phone."',
'".$driver_email."',
'".$driver_desc."',
'".$driver_img_file."')";
}
else
{
$q = "UPDATE `gs_user_object_drivers` SET `driver_name`='".$driver_name."',
`driver_assign_id`='".$driver_assign_id."',
`driver_idn`='".$driver_idn."',
`driver_address`='".$driver_address."',
`driver_phone`='".$driver_phone."',
`driver_email`='".$driver_email."',
`driver_desc`='".$driver_desc."'
WHERE `driver_id`='".$driver_id."'";
}
$r = mysqli_query($ms, $q);
echo 'OK';
die;
}
if(@$_GET['cmd'] == 'load_object_driver_list')
{
$page = $_GET['page']; // get the requested page
$limit = $_GET['rows']; // get how many rows we want to have into the grid
$sidx = $_GET['sidx']; // get index row - i.e. user click to sort
$sord = $_GET['sord']; // get the direction
if(!$sidx) $sidx =1;
$q = "SELECT * FROM `gs_user_object_drivers` WHERE `user_id`='".$user_id."'";
$r = mysqli_query($ms, $q);
$count = mysqli_num_rows($r);
if( $count >0 )
{
$total_pages = ceil($count/$limit);
}
else
{
$total_pages = 1;
}
if ($page > $total_pages) $page=$total_pages;
$start = $limit*$page - $limit; // do not put $limit*($page - 1)
$q = "SELECT * FROM `gs_user_object_drivers` WHERE `user_id`='".$user_id."' ORDER BY $sidx $sord LIMIT $start, $limit";
$r = mysqli_query($ms, $q);
$responce = new stdClass();
$responce->page = $page;
$responce->total = $total_pages;
$responce->records = $count;
$i=0;
while($row = mysqli_fetch_array($r))
{
$driver_id = $row['driver_id'];
$driver_name = $row['driver_name'];
$driver_idn = $row["driver_idn"];
$driver_desc = $row['driver_desc'];
// set modify buttons
$modify = '<a href="#" onclick="settingsObjectDriverProperties(\''.$driver_id.'\');" title="'.$la['EDIT'].'"><img src="theme/images/edit.svg" /></a>';
$modify .= '<a href="#" onclick="settingsObjectDriverDelete(\''.$driver_id.'\');" title="'.$la['DELETE'].'"><img src="theme/images/remove3.svg" /></a>';
// set row
$responce->rows[$i]['id']=$driver_id;
$responce->rows[$i]['cell']=array($driver_name,$driver_idn,$driver_desc,$modify);
$i++;
}
header('Content-type: application/json');
echo json_encode($responce);
die;
}
if(@$_POST['cmd'] == 'load_object_driver_values')
{
$q = "SELECT * FROM `gs_user_object_drivers` WHERE `user_id`='".$user_id."' ORDER BY `driver_name` ASC";
$r = mysqli_query($ms, $q);
$result = array();
while($row=mysqli_fetch_array($r))
{
$driver_id = $row['driver_id'];
$result[$driver_id] = array( 'name' => $row['driver_name'],
'assign_id' => $row['driver_assign_id'],
'idn' => $row['driver_idn'],
'address' => $row['driver_address'],
'phone' => $row['driver_phone'],
'email' => $row['driver_email'],
'desc' => $row['driver_desc'],
'img' => $row['driver_img_file']
);
}
echo json_encode($result);
die;
}
?>
\ No newline at end of file
<?
session_start();
include ('../init.php');
include ('fn_common.php');
checkUserSession();
loadLanguage($_SESSION["language"], $_SESSION["units"]);
if(@$_POST['cmd'] == 'load_event_values')
{
$user_id = $_SESSION["user_id"];
$q = "SELECT * FROM `gs_user_events` WHERE `user_id`='".$user_id."' ORDER BY `name` ASC";
$r = mysqli_query($ms, $q);
$result = array();
while($row = mysqli_fetch_array($r))
{
$event_id = $row['event_id'];
$day_time = json_decode($row['day_time'], true);
if (($row['type'] == 'param') || ($row['type'] == 'sensor'))
{
$row['checked_value'] = json_decode($row['checked_value'], true);
if ($row['checked_value'] == null)
{
$row['checked_value'] = array();
}
}
$result[$event_id] = array( 'type' => $row['type'],
'name' => $row['name'],
'active' => $row['active'],
'duration_from_last_event' => $row['duration_from_last_event'],
'duration_from_last_event_minutes' => $row['duration_from_last_event_minutes'],
'week_days' => $row['week_days'],
'day_time' => $day_time,
'imei' => $row['imei'],
'checked_value' => $row['checked_value'],
'route_trigger' => $row['route_trigger'],
'zone_trigger' => $row['zone_trigger'],
'routes' => $row['routes'],
'zones' => $row['zones'],
'notify_system' => $row['notify_system'],
'notify_email' => $row['notify_email'],
'notify_email_address' => $row['notify_email_address'],
'notify_sms' => $row['notify_sms'],
'notify_sms_number' => $row['notify_sms_number'],
'email_template_id' => $row['email_template_id'],
'sms_template_id' => $row['sms_template_id'],
'notify_arrow' => $row['notify_arrow'],
'notify_arrow_color' => $row['notify_arrow_color'],
'notify_ohc' => $row['notify_ohc'],
'notify_ohc_color' => $row['notify_ohc_color'],
'cmd_send' => $row['cmd_send'],
'cmd_gateway' => $row['cmd_gateway'],
'cmd_type' => $row['cmd_type'],
'cmd_string' => $row['cmd_string']
);
}
echo json_encode($result);
die;
}
if(@$_GET['cmd'] == 'load_event_list')
{
$page = $_GET['page']; // get the requested page
$limit = $_GET['rows']; // get how many rows we want to have into the grid
$sidx = $_GET['sidx']; // get index row - i.e. user click to sort
$sord = $_GET['sord']; // get the direction
$user_id = $_SESSION["user_id"];
if(!$sidx) $sidx =1;
// get records number
$q = "SELECT * FROM `gs_user_events` WHERE `user_id`='".$user_id."'";
$r = mysqli_query($ms, $q);
$count = mysqli_num_rows($r);
if( $count >0 )
{
$total_pages = ceil($count/$limit);
}
else
{
$total_pages = 1;
}
if ($page > $total_pages) $page=$total_pages;
$start = $limit*$page - $limit; // do not put $limit*($page - 1)
$q = "SELECT * FROM `gs_user_events` WHERE `user_id`='".$user_id."' ORDER BY $sidx $sord LIMIT $start, $limit";
$r = mysqli_query($ms, $q);
$responce = new stdClass();
$responce->page = $page;
$responce->total = $total_pages;
$responce->records = $count;
$i=0;
while($row = mysqli_fetch_array($r))
{
$event_id = $row['event_id'];
$name = $row['name'];
if ($row['active'] == 'true')
{
$active = '<img src="theme/images/tick-green.svg" />';
}
else
{
$active = '<img src="theme/images/remove-red.svg" style="width:12px;" />';
}
$notify_system = explode(",", $row['notify_system']);
if (@$notify_system[0] == 'true')
{
$notify_system = '<img src="theme/images/tick-green.svg" />';
}
else
{
$notify_system = '<img src="theme/images/remove-red.svg" style="width:12px;" />';
}
if ($row['notify_email'] == 'true')
{
$notify_email = '<img src="theme/images/tick-green.svg" />';
}
else
{
$notify_email = '<img src="theme/images/remove-red.svg" style="width:12px;" />';
}
if ($row['notify_sms'] == 'true')
{
$notify_sms = '<img src="theme/images/tick-green.svg" />';
}
else
{
$notify_sms = '<img src="theme/images/remove-red.svg" style="width:12px;" />';
}
// set modify buttons
$modify = '<a href="#" onclick="settingsEventProperties(\''.$event_id.'\');" title="'.$la['EDIT'].'"><img src="theme/images/edit.svg" />';
$modify .= '</a><a href="#" onclick="settingsEventDelete(\''.$event_id.'\');" title="'.$la['DELETE'].'"><img src="theme/images/remove3.svg" /></a>';
// set row
$responce->rows[$i]['id']=$event_id;
$responce->rows[$i]['cell']=array($name,$active,$notify_system,$notify_email,$notify_sms,$modify);
$i++;
}
header('Content-type: application/json');
echo json_encode($responce);
die;
}
if(@$_POST['cmd'] == 'delete_event')
{
$event_id = $_POST["event_id"];
$user_id = $_SESSION["user_id"];
$q = "DELETE FROM `gs_user_events` WHERE `event_id`='".$event_id."' AND `user_id`='".$user_id."'";
$r = mysqli_query($ms, $q);
$q = "DELETE FROM `gs_user_events_status` WHERE `event_id`='".$event_id."'";
$r = mysqli_query($ms, $q);
echo 'OK';
die;
}
if(@$_POST['cmd'] == 'delete_selected_events')
{
$items = $_POST["items"];
$user_id = $_SESSION["user_id"];
for ($i = 0; $i < count($items); ++$i)
{
$item = $items[$i];
$q = "DELETE FROM `gs_user_events` WHERE `event_id`='".$item."' AND `user_id`='".$user_id."'";
$r = mysqli_query($ms, $q);
$q = "DELETE FROM `gs_user_events_status` WHERE `event_id`='".$item."'";
$r = mysqli_query($ms, $q);
}
echo 'OK';
die;
}
if(@$_POST['cmd'] == 'save_event')
{
$event_id = $_POST["event_id"];
$user_id = $_SESSION["user_id"];
$type = $_POST["type"];
$name = $_POST["name"];
$active = $_POST["active"];
$duration_from_last_event = $_POST["duration_from_last_event"];
$duration_from_last_event_minutes = $_POST["duration_from_last_event_minutes"];
$week_days = $_POST["week_days"];
$day_time = $_POST["day_time"];
$imei = $_POST["imei"];
$checked_value = $_POST["checked_value"];
$route_trigger = $_POST["route_trigger"];
$zone_trigger = $_POST["zone_trigger"];
$routes = $_POST["routes"];
$zones = $_POST["zones"];
$notify_system = $_POST["notify_system"];
$notify_email = $_POST["notify_email"];
$notify_email_address = $_POST["notify_email_address"];
$notify_sms = $_POST["notify_sms"];
$notify_sms_number = $_POST["notify_sms_number"];
$email_template_id = $_POST["email_template_id"];
$sms_template_id = $_POST["sms_template_id"];
$notify_arrow = $_POST["notify_arrow"];
$notify_arrow_color = $_POST["notify_arrow_color"];
$notify_ohc = $_POST["notify_ohc"];
$notify_ohc_color = $_POST["notify_ohc_color"];
$cmd_send = $_POST["cmd_send"];
$cmd_gateway = $_POST["cmd_gateway"];
$cmd_type = $_POST["cmd_type"];
$cmd_string = $_POST["cmd_string"];
if ($event_id == 'false')
{
$q = "INSERT INTO `gs_user_events` (`user_id`,
`type`,
`name`,
`active`,
`duration_from_last_event`,
`duration_from_last_event_minutes`,
`week_days`,
`day_time`,
`imei`,
`checked_value`,
`route_trigger`,
`zone_trigger`,
`routes`,
`zones`,
`notify_system`,
`notify_email`,
`notify_email_address`,
`notify_sms`,
`notify_sms_number`,
`email_template_id`,
`sms_template_id`,
`notify_arrow`,
`notify_arrow_color`,
`notify_ohc`,
`notify_ohc_color`,
`cmd_send`,
`cmd_gateway`,
`cmd_type`,
`cmd_string`
) VALUES (
'".$user_id."',
'".$type."',
'".$name."',
'".$active."',
'".$duration_from_last_event."',
'".$duration_from_last_event_minutes."',
'".$week_days."',
'".$day_time."',
'".$imei."',
'".$checked_value."',
'".$route_trigger."',
'".$zone_trigger."',
'".$routes."',
'".$zones."',
'".$notify_system."',
'".$notify_email."',
'".$notify_email_address."',
'".$notify_sms."',
'".$notify_sms_number."',
'".$email_template_id."',
'".$sms_template_id."',
'".$notify_arrow."',
'".$notify_arrow_color."',
'".$notify_ohc."',
'".$notify_ohc_color."',
'".$cmd_send."',
'".$cmd_gateway."',
'".$cmd_type."',
'".$cmd_string."')";
}
else
{
$q = "UPDATE `gs_user_events` SET `type`='".$type."',
`name`='".$name."',
`active`='".$active."',
`duration_from_last_event`='".$duration_from_last_event."',
`duration_from_last_event_minutes`='".$duration_from_last_event_minutes."',
`week_days`='".$week_days."',
`day_time`='".$day_time."',
`imei`='".$imei."',
`checked_value`='".$checked_value."',
`route_trigger`='".$route_trigger."',
`zone_trigger`='".$zone_trigger."',
`routes`='".$routes."',
`zones`='".$zones."',
`notify_system`='".$notify_system."',
`notify_email`='".$notify_email."',
`notify_email_address`='".$notify_email_address."',
`notify_sms`='".$notify_sms."',
`notify_sms_number`='".$notify_sms_number."',
`email_template_id`='".$email_template_id."',
`sms_template_id`='".$sms_template_id."',
`notify_arrow`='".$notify_arrow."',
`notify_arrow_color`='".$notify_arrow_color."',
`notify_ohc`='".$notify_ohc."',
`notify_ohc_color`='".$notify_ohc_color."',
`cmd_send`='".$cmd_send."',
`cmd_gateway`='".$cmd_gateway."',
`cmd_type`='".$cmd_type."',
`cmd_string`='".$cmd_string."'
WHERE `event_id`='".$event_id."'";
}
$r = mysqli_query($ms, $q);
echo 'OK';
}
?>
\ No newline at end of file
<?
session_start();
include ('../init.php');
include ('fn_common.php');
checkUserSession();
loadLanguage($_SESSION["language"], $_SESSION["units"]);
// check privileges
if ($_SESSION["privileges"] == 'subuser')
{
$user_id = $_SESSION["manager_id"];
}
else
{
$user_id = $_SESSION["user_id"];
}
if(@$_POST['cmd'] == 'delete_object_group')
{
$group_id = $_POST["group_id"];
$q = "DELETE FROM `gs_user_object_groups` WHERE `group_id`='".$group_id."' AND `user_id`='".$user_id."'";
$r = mysqli_query($ms, $q);
// reset group_id in objects
$q = "UPDATE `gs_user_objects` SET `group_id`='0' WHERE `group_id`='".$group_id."'";
$r = mysqli_query($ms, $q);
echo 'OK';
die;
}
if(@$_POST['cmd'] == 'delete_selected_object_groups')
{
$items = $_POST["items"];
for ($i = 0; $i < count($items); ++$i)
{
$item = $items[$i];
$q = "DELETE FROM `gs_user_object_groups` WHERE `group_id`='".$item."' AND `user_id`='".$user_id."'";
$r = mysqli_query($ms, $q);
// reset group_id in objects
$q = "UPDATE `gs_user_objects` SET `group_id`='0' WHERE `group_id`='".$item."'";
$r = mysqli_query($ms, $q);
}
echo 'OK';
die;
}
if(@$_POST['cmd'] == 'save_object_group')
{
$group_id = $_POST["group_id"];
$group_name = $_POST["group_name"];
$group_desc = $_POST["group_desc"];
if ($group_id == 'false')
{
$q = "INSERT INTO `gs_user_object_groups` (`user_id`, `group_name`, `group_desc`) VALUES ('".$user_id."', '".$group_name."', '".$group_desc."')";
}
else
{
$q = "UPDATE `gs_user_object_groups` SET `group_name`='".$group_name."', `group_desc`='".$group_desc."' WHERE `group_id`='".$group_id."'";
}
$r = mysqli_query($ms, $q);
echo 'OK';
}
if(@$_GET['cmd'] == 'load_object_group_list')
{
$page = $_GET['page']; // get the requested page
$limit = $_GET['rows']; // get how many rows we want to have into the grid
$sidx = $_GET['sidx']; // get index row - i.e. user click to sort
$sord = $_GET['sord']; // get the direction
if(!$sidx) $sidx =1;
$q = "SELECT * FROM `gs_user_object_groups` WHERE `user_id`='".$user_id."'";
$r = mysqli_query($ms, $q);
$count = mysqli_num_rows($r);
if( $count >0 )
{
$total_pages = ceil($count/$limit);
}
else
{
$total_pages = 1;
}
if ($page > $total_pages) $page=$total_pages;
$start = $limit*$page - $limit; // do not put $limit*($page - 1)
$q = "SELECT * FROM `gs_user_object_groups` WHERE `user_id`='".$user_id."' ORDER BY $sidx $sord LIMIT $start, $limit";
$r = mysqli_query($ms, $q);
$responce = new stdClass();
$responce->page = $page;
$responce->total = $total_pages;
$responce->records = $count;
$i=0;
while($row = mysqli_fetch_array($r))
{
$group_id = $row['group_id'];
$group_name = $row['group_name'];
$group_desc = $row['group_desc'];
// get object number in group
$q2 = "SELECT * FROM `gs_user_objects` WHERE `group_id`='".$group_id."'";
$r2 = mysqli_query($ms, $q2);
$object_number = mysqli_num_rows($r2);
// set modify buttons
$modify = '<a href="#" onclick="settingsObjectGroupProperties(\''.$group_id.'\');" title="'.$la['EDIT'].'"><img src="theme/images/edit.svg" />';
$modify .= '</a><a href="#" onclick="settingsObjectGroupDelete(\''.$group_id.'\');" title="'.$la['DELETE'].'"><img src="theme/images/remove3.svg" /></a>';
// set row
$responce->rows[$i]['id']=$group_id;
$responce->rows[$i]['cell']=array($group_name,$object_number,$group_desc,$modify);
$i++;
}
header('Content-type: application/json');
echo json_encode($responce);
die;
}
if(@$_POST['cmd'] == 'load_object_group_values')
{
$q = "SELECT * FROM `gs_user_object_groups` WHERE `user_id`='".$user_id."' ORDER BY `group_name` ASC";
$r = mysqli_query($ms, $q);
$result = array();
// add ungrouped group
$result[] = array( 'name' => $la['UNGROUPED'],
'desc' => '',
'visible' => true,
'follow' => false
);
while($row=mysqli_fetch_array($r))
{
$group_id = $row['group_id'];
$result[$group_id] = array( 'name' => $row['group_name'],
'desc' => $row['group_desc'],
'visible' => true,
'follow' => false
);
}
echo json_encode($result);
die;
}
?>
\ No newline at end of file
<?
session_start();
include ('../init.php');
include ('fn_common.php');
checkUserSession();
loadLanguage($_SESSION["language"], $_SESSION["units"]);
// check privileges
if ($_SESSION["privileges"] == 'subuser')
{
$user_id = $_SESSION["manager_id"];
}
else
{
$user_id = $_SESSION["user_id"];
}
if(@$_POST['cmd'] == 'add_object')
{
if (($_SESSION["manager_id"] == 0) && ($_SESSION["obj_add"] != 'false'))
{
$name = $_POST["name"];
$imei = strtoupper($_POST["imei"]);
if (checkObjectLimitSystem())
{
echo 'LIMIT';
die;
}
if(checkObjectExistsUser($imei))
{
echo 'EXISTS';
die;
}
if($_SESSION["obj_add"] == 'true')
{
if(checkObjectLimitUser($user_id))
{
echo 'LIMIT';
die;
}
if ($_SESSION["obj_days"] == 'true')
{
$object_expire = 'true';
$object_expire_dt = $_SESSION["obj_days_dt"];
}
else
{
$object_expire = 'false';
$object_expire_dt = '';
}
}
else if ($_SESSION["obj_add"] == "trial")
{
$object_expire = 'true';
$object_expire_dt = gmdate("Y-m-d", strtotime(gmdate("Y-m-d").' + '.$gsValues['OBJ_DAYS_TRIAL'].' days'));
}
addObjectSystem($name, $imei, 'true', $object_expire, $object_expire_dt, $_SESSION["manager_id"]);
addObjectUser($user_id, $imei, 0, 0, 0);
createObjectDataTable($imei);
echo 'OK';
}
die;
}
if(@$_POST['cmd'] == 'duplicate_object')
{
if (($_SESSION["manager_id"] == 0) && ($_SESSION["obj_add"] != 'false'))
{
$duplicate_imei = strtoupper($_POST["duplicate_imei"]);
$name = $_POST["name"];
$imei = strtoupper($_POST["imei"]);
if (checkObjectLimitSystem())
{
echo 'LIMIT';
die;
}
if(checkObjectExistsUser($imei))
{
echo 'EXISTS';
die;
}
if($_SESSION["obj_add"] == 'true')
{
if(checkObjectLimitUser($user_id))
{
echo 'LIMIT';
die;
}
if ($_SESSION["obj_days"] == 'true')
{
$object_expire = 'true';
$object_expire_dt = $_SESSION["obj_days_dt"];
}
else
{
$object_expire = 'false';
$object_expire_dt = '';
}
}
else if ($_SESSION["obj_add"] == "trial")
{
$object_expire = 'true';
$object_expire_dt = gmdate("Y-m-d", strtotime(gmdate("Y-m-d").' + '.$gsValues['OBJ_DAYS_TRIAL'].' days'));
}
duplicateObjectSystem($duplicate_imei, $imei, $object_expire, $object_expire_dt, $_SESSION["manager_id"], $name);
$q = "SELECT * FROM `gs_user_objects` WHERE `imei`='".$duplicate_imei."' AND `user_id`='".$user_id."'";
$r = mysqli_query($ms, $q);
$row = mysqli_fetch_array($r);
addObjectUser($user_id, $imei, $row['group_id'], $row['driver_id'], $row['trailer_id']);
createObjectDataTable($imei);
//write log
writeLog('object_op', 'Add object: successful. IMEI: '.$imei);
echo 'OK';
}
die;
}
if(@$_POST['cmd'] == 'edit_object')
{
$group_id = $_POST["group_id"];
$driver_id = $_POST["driver_id"];
$trailer_id = $_POST["trailer_id"];
$name = $_POST["name"];
$imei = $_POST["imei"];
$device = $_POST["device"];
$sim_number = $_POST["sim_number"];
$model = $_POST["model"];
$vin = $_POST["vin"];
$plate_number = $_POST["plate_number"];
$icon = $_POST["icon"];
$map_arrows = $_POST["map_arrows"];
$map_icon = $_POST["map_icon"];
$tail_color = $_POST["tail_color"];
$tail_points = $_POST["tail_points"];
$fcr = $_POST["fcr"];
$time_adj = $_POST["time_adj"];
$accuracy = $_POST["accuracy"];
$q = "UPDATE `gs_user_objects` SET `group_id`='".$group_id."',
`driver_id`='".$driver_id."',
`trailer_id`='".$trailer_id."'
WHERE `user_id`='".$user_id."' AND `imei`='".$imei."'";
$r = mysqli_query($ms, $q);
$q = "UPDATE `gs_objects` SET `name`='".$name."',
`icon`='".$icon."',
`map_icon`='".$map_icon."',
`map_arrows`='".$map_arrows."',
`tail_color`='".$tail_color."',
`tail_points`='".$tail_points."',
`device`='".$device."',
`sim_number`='".$sim_number."',
`model`='".$model."',
`vin`='".$vin."',
`plate_number`='".$plate_number."',
`fcr`='".$fcr."',
`accuracy`='".$accuracy."'
WHERE `imei`='".$imei."'";
$r = mysqli_query($ms, $q);
// set time adjustment
$q = "SELECT * FROM `gs_objects` WHERE `imei`='".$imei."'";
$r = mysqli_query($ms, $q);
$row = mysqli_fetch_array($r);
if($time_adj != $row["time_adj"])
{
$q = "UPDATE `gs_objects` SET `dt_server`='0000-00-00 00:00:00',
`dt_tracker`='0000-00-00 00:00:00',
`lat`='0',
`lng`='0',
`altitude`='0',
`angle`='0',
`speed`='0',
`loc_valid`='0',
`params`='',
`time_adj`='".$time_adj."'
WHERE `imei`='".$imei."'";
$r = mysqli_query($ms, $q);
}
// set odometer and engine hours type
$odometer_type = $_POST["odometer_type"];
$engine_hours_type = $_POST["engine_hours_type"];
$q = "UPDATE `gs_objects` SET `odometer_type`='".$odometer_type."', `engine_hours_type`='".$engine_hours_type."' WHERE `imei`='".$imei."'";
$r = mysqli_query($ms, $q);
// get odometer and engine_hours and check if saving is needed
$odometer = $_POST["odometer"];
if ($odometer != 'false')
{
// save in km
$odometer = floor(convDistanceUnits($odometer, $_SESSION["unit_distance"], 'km'));
$q = "UPDATE `gs_objects` SET `odometer`='".$odometer."' WHERE `imei`='".$imei."'";
$r = mysqli_query($ms, $q);
}
$engine_hours = $_POST["engine_hours"];
if ($engine_hours != 'false')
{
$engine_hours = $engine_hours * 60 * 60;
$q = "UPDATE `gs_objects` SET `engine_hours`='".$engine_hours."' WHERE `imei`='".$imei."'";
$r = mysqli_query($ms, $q);
}
echo 'OK';
die;
}
if(@$_POST['cmd'] == 'clear_history_object')
{
if($_SESSION["obj_history_clear"] == 'true')
{
$imei = $_POST['imei'];
$q = "SELECT * FROM `gs_user_objects` WHERE `imei`='".$imei."' AND `user_id`='".$user_id."'";
$r = mysqli_query($ms, $q);
$row = mysqli_fetch_array($r);
if($row)
{
clearObjectHistory($imei);
}
echo 'OK';
}
die;
}
if(@$_POST['cmd'] == 'delete_object')
{
$imei = $_POST["imei"];
delObjectUser($user_id, $imei);
echo 'OK';
die;
}
if(@$_POST['cmd'] == 'clear_history_selected_objects')
{
if($_SESSION["obj_history_clear"] == 'true')
{
$items = $_POST["items"];
for ($i = 0; $i < count($items); ++$i)
{
$item = $items[$i];
clearObjectHistory($item);
}
echo 'OK';
die;
}
}
if(@$_POST['cmd'] == 'delete_selected_objects')
{
$items = $_POST["items"];
for ($i = 0; $i < count($items); ++$i)
{
$item = $items[$i];
delObjectUser($user_id, $item);
}
echo 'OK';
die;
}
if(@$_POST['cmd'] == 'load_object_values')
{
// check privileges
if ($_SESSION["privileges"] == 'subuser')
{
$q = "SELECT gs_objects.*, gs_user_objects.*
FROM gs_objects
INNER JOIN gs_user_objects ON gs_objects.imei = gs_user_objects.imei
WHERE gs_user_objects.user_id='".$user_id."'
AND gs_objects.imei IN (".$_SESSION["privileges_imei"].")";
}
else
{
$q = "SELECT gs_objects.*, gs_user_objects.*
FROM gs_objects
INNER JOIN gs_user_objects ON gs_objects.imei = gs_user_objects.imei
WHERE gs_user_objects.user_id='".$user_id."'";
}
$r = mysqli_query($ms, $q);
$result = array();
while($row = mysqli_fetch_array($r))
{
$imei = $row['imei'];
// get object accuracy
$accuracy = getObjectAccuracy($imei);
// get object sensor list
$sensors = getObjectSensors($imei);
// get object service list
$service = getObjectService($imei);
// get object custom fields list
$custom_fields = getObjectCustomFields($imei);
// set default fcr if not set in DB
$fcr = getObjectFCR($imei);
// set default odometer and engine hours type if not set in DB
if ($row['odometer_type'] == '')
{
$row['odometer_type'] = 'gps';
}
if ($row['engine_hours_type'] == '')
{
$row['engine_hours_type'] = 'acc';
}
// odometer and engine hours
$row['odometer'] = floor(convDistanceUnits($row['odometer'], 'km', $_SESSION["unit_distance"]));
$row['engine_hours'] = floor($row['engine_hours'] / 60 / 60);
// map arrows
$default = array( 'arrow_no_connection' => 'arrow_red',
'arrow_stopped' => 'arrow_red',
'arrow_moving' => 'arrow_green',
'arrow_engine_idle' => 'off'
);
if (($row['map_arrows'] == '') || (json_decode($row['map_arrows'],true) == null))
{
$map_arrows = $default;
}
else
{
$map_arrows = json_decode($row['map_arrows'],true);
if (!isset($map_arrows["arrow_no_connection"])) { $map_arrows["arrow_no_connection"] = $default["arrow_no_connection"]; }
if (!isset($map_arrows["arrow_stopped"])) { $map_arrows["arrow_stopped"] = $default["arrow_stopped"]; }
if (!isset($map_arrows["arrow_moving"])) { $map_arrows["arrow_moving"] = $default["arrow_moving"]; }
if (!isset($map_arrows["arrow_engine_idle"])) { $map_arrows["arrow_engine_idle"] = $default["arrow_engine_idle"]; }
}
$result[$imei] = array( 'protocol' => $row['protocol'],
'group_id' => $row['group_id'],
'driver_id' => $row['driver_id'],
'trailer_id' => $row['trailer_id'],
'name' => $row['name'],
'icon' => $row['icon'],
'map_arrows' => $map_arrows,
'map_icon' => $row['map_icon'],
'tail_color' => $row['tail_color'],
'tail_points' => $row['tail_points'],
'device' => $row['device'],
'sim_number' => $row['sim_number'],
'model' => $row['model'],
'vin' => $row['vin'],
'plate_number' => $row['plate_number'],
'odometer_type' => $row['odometer_type'],
'engine_hours_type' => $row['engine_hours_type'],
'odometer' => $row['odometer'],
'engine_hours' => $row['engine_hours'],
'fcr' => $fcr,
'time_adj' => $row['time_adj'],
'accuracy' => $accuracy,
'sensors' => $sensors,
'service' => $service,
'custom_fields' => $custom_fields,
'params' => getParamsArray($row['params']),
'active' => $row['active'],
'object_expire' => $row['object_expire'],
'object_expire_dt' => $row['object_expire_dt']
);
}
echo json_encode($result);
die;
}
if(@$_GET['cmd'] == 'load_object_info_list')
{
$page = $_GET['page']; // get the requested page
$limit = $_GET['rows']; // get how many rows we want to have into the grid
$sidx = $_GET['sidx']; // get index row - i.e. user click to sort
$sord = $_GET['sord']; // get the direction
$imei = $_GET['imei'];
if(!$sidx) $sidx =1;
// get records number
$q = "SELECT * FROM `gs_objects` WHERE `imei`='".$imei."'";
$r = mysqli_query($ms, $q);
$count = mysqli_num_rows($r);
$row = mysqli_fetch_array($r);
$row['dt_server'] = convUserTimezone($row['dt_server']);
$row['dt_tracker'] = convUserTimezone($row['dt_tracker']);
$row['lat'] = sprintf('%0.6f', $row['lat']);
$row['lng'] = sprintf('%0.6f', $row['lng']);
$row['altitude'] = convAltitudeUnits($row['altitude'], 'km', $_SESSION["unit_distance"]).' '.$la["UNIT_HEIGHT"];
$row['speed'] = convSpeedUnits($row['speed'], 'km', $_SESSION["unit_distance"]).' '.$la["UNIT_SPEED"];
if ($row['params'] == '')
{
$row['params'] = '';
}
else
{
$row['params'] = json_decode($row['params'],true);
$arr_params = array();
foreach ($row['params'] as $key => $value)
{
array_push($arr_params, $key.'='.$value);
}
$row['params'] = implode(', ', $arr_params);
}
$list_array = array( $la['ALTITUDE'] => $row['altitude'],
$la['ANGLE'] => $row['angle'].' &deg;',
$la['LATITUDE'] => $row['lat'].' &deg;',
$la['LONGITUDE'] => $row['lng'].' &deg;',
$la['PARAMETERS'] => $row['params'],
$la['PROTOCOL'] => $row['protocol'],
$la['SPEED'] => $row['speed'],
$la['TIME_POSITION'] => $row['dt_tracker'],
$la['TIME_SERVER'] => $row['dt_server']
);
ksort($list_array);
$responce = new stdClass();
$i=0;
foreach ($list_array as $key => $value)
{
$responce->rows[$i]['cell']=array($key, $value);
$i++;
}
$responce->page = 1;
//$responce->total = $count;
$responce->records = $count;
header('Content-type: application/json');
echo json_encode($responce);
die;
}
if(@$_GET['cmd'] == 'load_object_list')
{
$page = $_GET['page']; // get the requested page
$limit = $_GET['rows']; // get how many rows we want to have into the grid
$sidx = $_GET['sidx']; // get index row - i.e. user click to sort
$sord = $_GET['sord']; // get the direction
//$search = strtoupper(@$_GET['s']); // get search
if(!$sidx) $sidx =1;
$q = "SELECT * FROM `gs_user_objects` WHERE `user_id`='".$user_id."'";
$r = mysqli_query($ms, $q);
$count = mysqli_num_rows($r);
if( $count >0 )
{
$total_pages = ceil($count/$limit);
}
else
{
$total_pages = 1;
}
if ($page > $total_pages) $page=$total_pages;
$start = $limit*$page - $limit; // do not put $limit*($page - 1)
$q = "SELECT * FROM `gs_objects` WHERE `imei` IN (".getUserObjectIMEIs($user_id).") ORDER BY $sidx $sord LIMIT $start, $limit";
$r = mysqli_query($ms, $q);
$responce = new stdClass();
$responce->page = $page;
$responce->total = $total_pages;
$responce->records = $count;
if ($r)
{
$i=0;
while($row = mysqli_fetch_array($r))
{
$imei = $row['imei'];
$object_expire_dt = '';
if ($row['active'] == 'true')
{
$active = '<img src="theme/images/tick-green.svg" />';
if ($row['object_expire'] == 'true')
{
$object_expire_dt = $row['object_expire_dt'];
}
}
else
{
$active = '<img src="theme/images/remove-red.svg" style="width:12px;" />';
if ($row['object_expire'] == 'true')
{
if ($_SESSION["billing"] == true)
{
$object_expire_dt = '<a href="#" onclick="billingOpen();">'.$la['ACTIVATE'].'</a>';
}
else
{
$object_expire_dt = $row['object_expire_dt'];
}
}
}
// set modify buttons
$modify = '<a href="#" onclick="settingsObjectEdit(\''.$imei.'\');" title="'.$la['EDIT'].'"><img src="theme/images/edit.svg" /></a>';
$modify .= '<a href="#" onclick="settingsObjectDuplicate(\''.$imei.'\');" title="'.$la['DUPLICATE'].'"><img src="theme/images/copy.svg" /></a>';
$modify .= '<a href="#" onclick="settingsObjectClearHistory(\''.$imei.'\');" title="'.$la['CLEAR_HISTORY'].'"><img src="theme/images/erase.svg" /></a>';
$modify .= '<a href="#" onclick="settingsObjectDelete(\''.$imei.'\');" title="'.$la['DELETE'].'"><img src="theme/images/remove3.svg" /></a>';
// set row
$responce->rows[$i]['id']=$imei;
$responce->rows[$i]['cell']=array($row['name'],$imei,$active,$object_expire_dt,$modify);
$i++;
}
}
header('Content-type: application/json');
echo json_encode($responce);
die;
}
if(@$_POST['cmd'] == 'delete_custom_icon')
{
$file = $_POST['file'];
$path = $gsValues['PATH_ROOT'];
$icon_file = $path.'/'.$file;
if(is_file($icon_file))
{
@unlink($icon_file);
}
echo 'OK';
die;
}
if(@$_POST['cmd'] == 'delete_all_custom_icons')
{
$filter = $_SESSION['user_id'].'_';
$path = $gsValues['PATH_ROOT'].'data/user/objects';
$dh = opendir($path);
$result = array();
while (($file = readdir($dh)) !== false)
{
if ($file != '.' && $file != '..' && $file != 'Thumbs.db')
{
if (0 === strpos($file, $filter))
{
$icon_file = $path.'/'.$file;
if(is_file($icon_file))
{
@unlink($icon_file);
}
}
}
}
closedir($dh);
echo 'OK';
die;
}
?>
\ No newline at end of file
<?
session_start();
include ('../init.php');
include ('fn_common.php');
checkUserSession();
loadLanguage($_SESSION["language"], $_SESSION["units"]);
// check privileges
if ($_SESSION["privileges"] == 'subuser')
{
$user_id = $_SESSION["manager_id"];
}
else
{
$user_id = $_SESSION["user_id"];
}
if(@$_POST['cmd'] == 'delete_object_passenger')
{
$passenger_id = $_POST["passenger_id"];
$q = "DELETE FROM `gs_user_object_passengers` WHERE `passenger_id`='".$passenger_id."' AND `user_id`='".$user_id."'";
$r = mysqli_query($ms, $q);
echo 'OK';
die;
}
if(@$_POST['cmd'] == 'delete_selected_object_passengers')
{
$items = $_POST["items"];
for ($i = 0; $i < count($items); ++$i)
{
$item = $items[$i];
$q = "DELETE FROM `gs_user_object_passengers` WHERE `passenger_id`='".$item."' AND `user_id`='".$user_id."'";
$r = mysqli_query($ms, $q);
}
echo 'OK';
die;
}
if(@$_POST['cmd'] == 'save_object_passenger')
{
$passenger_id = $_POST["passenger_id"];
$passenger_name = $_POST["passenger_name"];
$passenger_assign_id = strtoupper($_POST["passenger_assign_id"]);
$passenger_idn = $_POST["passenger_idn"];
$passenger_address = $_POST["passenger_address"];
$passenger_phone = $_POST["passenger_phone"];
$passenger_email = $_POST["passenger_email"];
$passenger_desc = $_POST["passenger_desc"];
if ($passenger_id == 'false')
{
$q = "INSERT INTO `gs_user_object_passengers`( `user_id`,
`passenger_name`,
`passenger_assign_id`,
`passenger_idn`,
`passenger_address`,
`passenger_phone`,
`passenger_email`,
`passenger_desc`)
VALUES
('".$user_id."',
'".$passenger_name."',
'".$passenger_assign_id."',
'".$passenger_idn."',
'".$passenger_address."',
'".$passenger_phone."',
'".$passenger_email."',
'".$passenger_desc."')";
}
else
{
$q = "UPDATE `gs_user_object_passengers` SET `passenger_name`='".$passenger_name."',
`passenger_assign_id`='".$passenger_assign_id."',
`passenger_idn`='".$passenger_idn."',
`passenger_address`='".$passenger_address."',
`passenger_phone`='".$passenger_phone."',
`passenger_email`='".$passenger_email."',
`passenger_desc`='".$passenger_desc."'
WHERE `passenger_id`='".$passenger_id."'";
}
$r = mysqli_query($ms, $q);
echo 'OK';
die;
}
if(@$_GET['cmd'] == 'load_object_passenger_list')
{
$page = $_GET['page']; // get the requested page
$limit = $_GET['rows']; // get how many rows we want to have into the grid
$sidx = $_GET['sidx']; // get index row - i.e. user click to sort
$sord = $_GET['sord']; // get the direction
if(!$sidx) $sidx =1;
$q = "SELECT * FROM `gs_user_object_passengers` WHERE `user_id`='".$user_id."'";
$r = mysqli_query($ms, $q);
$count = mysqli_num_rows($r);
if( $count >0 )
{
$total_pages = ceil($count/$limit);
}
else
{
$total_pages = 1;
}
if ($page > $total_pages) $page=$total_pages;
$start = $limit*$page - $limit; // do not put $limit*($page - 1)
$q = "SELECT * FROM `gs_user_object_passengers` WHERE `user_id`='".$user_id."' ORDER BY $sidx $sord LIMIT $start, $limit";
$r = mysqli_query($ms, $q);
$responce = new stdClass();
$responce->page = $page;
$responce->total = $total_pages;
$responce->records = $count;
$i=0;
while($row = mysqli_fetch_array($r))
{
$passenger_id = $row['passenger_id'];
$passenger_name = $row['passenger_name'];
$passenger_idn = $row["passenger_idn"];
$passenger_desc = $row['passenger_desc'];
// set modify buttons
$modify = '<a href="#" onclick="settingsObjectPassengerProperties(\''.$passenger_id.'\');" title="'.$la['EDIT'].'"><img src="theme/images/edit.svg" /></a>';
$modify .= '<a href="#" onclick="settingsObjectPassengerDelete(\''.$passenger_id.'\');" title="'.$la['DELETE'].'"><img src="theme/images/remove3.svg" /></a>';
// set row
$responce->rows[$i]['id']=$passenger_id;
$responce->rows[$i]['cell']=array($passenger_name,$passenger_idn,$passenger_desc,$modify);
$i++;
}
header('Content-type: application/json');
echo json_encode($responce);
die;
}
if(@$_POST['cmd'] == 'load_object_passenger_values')
{
$passenger_id = $_POST["passenger_id"];
$q = "SELECT * FROM `gs_user_object_passengers` WHERE `passenger_id`='".$passenger_id."' AND `user_id`='".$user_id."'";
$r = mysqli_query($ms, $q);
$row = mysqli_fetch_array($r);
$result = array('name' => $row['passenger_name'],
'assign_id' => $row['passenger_assign_id'],
'idn' => $row['passenger_idn'],
'address' => $row['passenger_address'],
'phone' => $row['passenger_phone'],
'email' => $row['passenger_email'],
'desc' => $row['passenger_desc']
);
echo json_encode($result);
die;
}
?>
\ No newline at end of file
<?
session_start();
include ('../init.php');
include ('fn_common.php');
include ('../tools/sms.php');
checkUserSession();
loadLanguage($_SESSION["language"], $_SESSION["units"]);
if(@$_POST['cmd'] == 'clear_sms_queue')
{
clearSMSAPPQueue($_SESSION['sms_gateway_identifier']);
echo 'OK';
die;
}
if(@$_POST['cmd'] == 'load_server_values')
{
$custom_maps = array();
$q = "SELECT * FROM `gs_maps` ORDER BY `name` ASC";
$r = mysqli_query($ms, $q);
while($row=mysqli_fetch_array($r))
{
$map_id = $row['map_id'];
$name = $row['name'];
$active = $row['active'];
$type = $row['type'];
$url = $row['url'];
$layers = $row['layers'];
$layer_id = 'map_'.strtolower($name).'_'.$map_id;
if ($active == 'true')
{
$custom_maps[] = array('layer_id' => $layer_id,'name' => $name, 'active' => $active, 'type' => $type, 'url' => $url, 'layers' => $layers);
}
}
$result = array('url_root' => $gsValues['URL_ROOT'],
'map_custom' => $custom_maps,
'map_osm' => $gsValues['MAP_OSM'],
'map_bing' => $gsValues['MAP_BING'],
'map_google' => $gsValues['MAP_GOOGLE'],
'map_google_traffic' => $gsValues['MAP_GOOGLE_TRAFFIC'],
'map_mapbox' => $gsValues['MAP_MAPBOX'],
'map_yandex' => $gsValues['MAP_YANDEX'],
'map_bing_key' => $gsValues['MAP_BING_KEY'],
'map_mapbox_key' => $gsValues['MAP_MAPBOX_KEY'],
'map_layer' => $gsValues['MAP_LAYER'],
'map_zoom' => $gsValues['MAP_ZOOM'],
'map_lat' => $gsValues['MAP_LAT'],
'map_lng' => $gsValues['MAP_LNG'],
'notify_obj_expire' => $gsValues['NOTIFY_OBJ_EXPIRE'],
'notify_obj_expire_period' => $gsValues['NOTIFY_OBJ_EXPIRE_PERIOD'],
'notify_account_expire' => $gsValues['NOTIFY_ACCOUNT_EXPIRE'],
'notify_account_expire_period' => $gsValues['NOTIFY_ACCOUNT_EXPIRE_PERIOD']
);
echo json_encode($result);
die;
}
if(@$_POST['cmd'] == 'load_user_settings')
{
// groups_collapsed
$default = array( 'objects' => false,
'markers' => false,
'routes' => false,
'zones' => false
);
if (($_SESSION['groups_collapsed'] == '') || (json_decode($_SESSION['groups_collapsed'],true) == null))
{
$groups_collapsed = $default;
}
else
{
$groups_collapsed = json_decode($_SESSION['groups_collapsed'],true);
if (!isset($groups_collapsed["objects"])) { $groups_collapsed["objects"] = $default["objects"]; }
if (!isset($groups_collapsed["markers"])) { $groups_collapsed["markers"] = $default["markers"]; }
if (!isset($groups_collapsed["routes"])) { $groups_collapsed["routes"] = $default["routes"]; }
if (!isset($groups_collapsed["zones"])) { $groups_collapsed["objects"] = $default["zones"]; }
}
// ohc
$default = array( 'no_connection' => false,
'no_connection_color' => '#FFAEAE',
'stopped' => false,
'stopped_color' => '#FFAEAE',
'moving' => false,
'moving_color' => '#B0E57C',
'engine_idle' => false,
'engine_idle_color' => '#FFF0AA',
'event_sos' => false,
'event_sos_color' => '#B4D8E7'
);
if (($_SESSION['ohc'] == '') || (json_decode($_SESSION['ohc'],true) == null))
{
$ohc = $default;
}
else
{
$ohc = json_decode($_SESSION['ohc'],true);
if (!isset($ohc["no_connection"])) { $ohc["no_connection"] = $default["no_connection"]; }
if (!isset($ohc["no_connection_color"])) { $ohc["no_connection_color"] = $default["no_connection_color"]; }
if (!isset($ohc["stopped"])) { $ohc["stopped"] = $default["stopped"]; }
if (!isset($ohc["stopped_color"])) { $ohc["stopped_color"] = $default["stopped_color"]; }
if (!isset($ohc["moving"])) { $ohc["moving"] = $default["moving"]; }
if (!isset($ohc["moving_color"])) { $ohc["moving_color"] = $default["moving_color"]; }
if (!isset($ohc["engine_idle"])) { $ohc["engine_idle"] = $default["engine_idle"]; }
if (!isset($ohc["engine_idle_color"])) { $ohc["engine_idle_color"] = $default["engine_idle_color"]; }
if (!isset($ohc["event_sos"])) { $ohc["event_sos"] = $default["event_sos"]; }
if (!isset($ohc["event_sos_color"])) { $ohc["event_sos_color"] = $default["event_sos_color"]; }
}
if (($_SESSION['info'] == '') || (json_decode($_SESSION['info'],true) == null))
{
$info = array('name' => '',
'company' => '',
'address' => '',
'post_code' => '',
'city' => '',
'country' => '',
'phone1' => '',
'phone2' => '',
'email' => ''
);
}
else
{
$info = json_decode($_SESSION['info'], true);
}
if ($_SESSION['sms_gateway_identifier'] == '')
{
$_SESSION['sms_gateway_identifier'] = genSMSGatewayIdn($_SESSION["email"]);
}
$result = array('username' => $_SESSION["username"],
'email' => $_SESSION["email"],
'manager_id' => $_SESSION["manager_id"],
'cpanel_privileges' => $_SESSION["cpanel_privileges"],
'privileges' => $_SESSION["privileges"],
'privileges_imei' => $_SESSION["privileges_imei"],
'privileges_marker' => $_SESSION["privileges_marker"],
'privileges_route' => $_SESSION["privileges_route"],
'privileges_zone' => $_SESSION["privileges_zone"],
'privileges_history' => $_SESSION["privileges_history"],
'privileges_reports' => $_SESSION["privileges_reports"],
'privileges_rilogbook' => $_SESSION["privileges_rilogbook"],
'privileges_dtc' => $_SESSION["privileges_dtc"],
'privileges_object_control' => $_SESSION["privileges_object_control"],
'privileges_image_gallery' => $_SESSION["privileges_image_gallery"],
'privileges_chat' => $_SESSION["privileges_chat"],
'obj_add' => $_SESSION["obj_add"],
'obj_limit' => $_SESSION["obj_limit"],
'obj_limit_num' => $_SESSION["obj_limit_num"],
'obj_days' => $_SESSION["obj_days"],
'obj_days_dt' => $_SESSION["obj_days_dt"],
'obj_edit' => $_SESSION["obj_edit"],
'obj_history_clear' => $_SESSION["obj_history_clear"],
'chat_notify' => $_SESSION['chat_notify'],
'map_sp' => $_SESSION['map_sp'],
'map_is' => $_SESSION['map_is'],
'map_rc' => $_SESSION['map_rc'],
'map_rhc' => $_SESSION['map_rhc'],
'groups_collapsed' => $groups_collapsed,
'od' => $_SESSION['od'],
'ohc' => $ohc,
'sms_gateway' => $_SESSION['sms_gateway'],
'sms_gateway_type' => $_SESSION['sms_gateway_type'],
'sms_gateway_url' => $_SESSION['sms_gateway_url'],
'sms_gateway_identifier' => $_SESSION['sms_gateway_identifier'],
'sms_gateway_total_in_queue' => getSMSAPPTotalInQueue($_SESSION['sms_gateway_identifier']),
'language' => $_SESSION["language"],
'unit_distance' => $_SESSION["unit_distance"],
'unit_capacity' => $_SESSION["unit_capacity"],
'unit_temperature' => $_SESSION["unit_temperature"],
'currency' => $_SESSION["currency"],
'timezone' => $_SESSION["timezone"],
'dst' => $_SESSION["dst"],
'dst_start' => $_SESSION["dst_start"],
'dst_end' => $_SESSION["dst_end"],
'info' => $info
);
echo json_encode($result);
die;
}
if(@$_POST['cmd'] == 'save_user_settings')
{
$sms_gateway = $_POST["sms_gateway"];
$sms_gateway_type = $_POST["sms_gateway_type"];
$sms_gateway_url = $_POST["sms_gateway_url"];
$sms_gateway_identifier = $_POST["sms_gateway_identifier"];
$chat_notify = $_POST["chat_notify"];
$map_sp = $_POST["map_sp"];
$map_is = $_POST["map_is"];
$map_rc = $_POST["map_rc"];
$map_rhc = $_POST["map_rhc"];
$groups_collapsed = $_POST["groups_collapsed"];
$od = $_POST["od"];
$ohc = $_POST["ohc"];
$language = $_POST["language"];
$units = $_POST["units"];
$currency = $_POST["currency"];
$timezone = $_POST["timezone"];
$dst = $_POST["dst"];
$dst_start = $_POST["dst_start"];
$dst_end = $_POST["dst_end"];
$info = $_POST["info"];
$old_password = $_POST["old_password"];
$new_password = $_POST["new_password"];
$q = "UPDATE `gs_users` SET ";
if ($sms_gateway != 'na')
{
$q .= "`sms_gateway`='".$sms_gateway."',";
}
if ($sms_gateway_type != 'na')
{
$q .= "`sms_gateway_type`='".$sms_gateway_type."',";
}
if ($sms_gateway_url != 'na')
{
$q .= "`sms_gateway_url`='".$sms_gateway_url."',";
}
if ($sms_gateway_identifier != 'na')
{
$q .= "`sms_gateway_identifier`='".$sms_gateway_identifier."',";
}
if ($chat_notify != 'na')
{
$q .= "`chat_notify`='".$chat_notify."',";
}
$q .= "`map_sp`='".$map_sp."',";
$q .= "`map_is`='".$map_is."',";
if ($map_rc != 'na')
{
$q .= "`map_rc`='".$map_rc."',";
}
if ($map_rhc != 'na')
{
$q .= "`map_rhc`='".$map_rhc."',";
}
if ($groups_collapsed != 'na')
{
$q .= "`groups_collapsed`='".$groups_collapsed."',";
}
if ($od != 'na')
{
$q .= "`od`='".$od."',";
}
if ($ohc != 'na')
{
$q .= "`ohc`='".$ohc."',";
}
if ($info != 'na')
{
$q .= "`info`='".$info."',";
}
if ($currency != 'na')
{
$q .= "`currency`='".$currency."',";
}
$q .= "`language`='".$language."',
`units`='".$units."',
`timezone`='".$timezone."'";
$q .= "WHERE `id`='".$_SESSION["user_id"]."'";
$r = mysqli_query($ms, $q);
if (!$r)
{
echo 'error';
die;
}
// dst
if ($dst != 'na')
{
$q = "UPDATE `gs_users` SET dst='".$dst."', dst_start='".$dst_start."', dst_end='".$dst_end."' WHERE `id`='".$_SESSION["user_id"]."'";
$r = mysqli_query($ms, $q);
}
// password
if ($new_password != '')
{
$q = "SELECT * FROM `gs_users` WHERE `id`='".$_SESSION["user_id"]."' AND `password`='".md5($old_password)."' LIMIT 1";
$r = mysqli_query($ms, $q);
$row = mysqli_fetch_array($r);
if ($row)
{
$q = "UPDATE `gs_users` SET password='".md5($new_password)."' WHERE `id`='".$_SESSION["user_id"]."'";
$r = mysqli_query($ms, $q);
}
else
{
echo 'error_pass';
die;
}
}
echo 'OK';
die;
}
if(@$_POST['cmd'] == 'save_user_language')
{
$language = $_POST["language"];
$q = "UPDATE `gs_users` SET `language`='".$language."' WHERE `id`='".$_SESSION["user_id"]."'";
$r = mysqli_query($ms, $q);
if (!$r)
{
echo 'error';
die;
}
echo 'OK';
die;
}
?>
\ No newline at end of file
<?
session_start();
include ('../init.php');
include ('fn_common.php');
checkUserSession();
loadLanguage($_SESSION["language"], $_SESSION["units"]);
if(@$_POST['cmd'] == 'clear_detected_sensor_cache')
{
$imei = $_POST["imei"];
$q = "UPDATE `gs_objects` SET `params`='' WHERE `imei`='".$imei."'";
$r = mysqli_query($ms, $q);
echo 'OK';
die;
}
if(@$_POST['cmd'] == 'delete_object_sensor')
{
$sensor_id = $_POST["sensor_id"];
$imei = $_POST["imei"];
$q = "DELETE FROM `gs_object_sensors` WHERE `sensor_id`='".$sensor_id."' AND `imei`='".$imei."'";
$r = mysqli_query($ms, $q);
echo 'OK';
die;
}
if(@$_POST['cmd'] == 'delete_selected_object_sensors')
{
$items = $_POST["items"];
$imei = $_POST["imei"];
for ($i = 0; $i < count($items); ++$i)
{
$item = $items[$i];
$q = "DELETE FROM `gs_object_sensors` WHERE `sensor_id`='".$item."' AND `imei`='".$imei."'";
$r = mysqli_query($ms, $q);
}
echo 'OK';
die;
}
if(@$_POST['cmd'] == 'save_object_sensor')
{
$sensor_id = $_POST["sensor_id"];
$imei = $_POST["imei"];
$name = $_POST["name"];
$type = $_POST["type"];
$param = $_POST["param"];
$data_list = $_POST["data_list"];
$popup = $_POST["popup"];
$result_type = $_POST["result_type"];
$text_1 = $_POST["text_1"];
$text_0 = $_POST["text_0"];
$units = $_POST["units"];
$lv = $_POST["lv"];
$hv = $_POST["hv"];
$formula = $_POST["formula"];
$calibration = $_POST["calibration"];
if ($sensor_id == 'false')
{
$q = "INSERT INTO `gs_object_sensors` (`imei`,
`name`,
`type`,
`param`,
`data_list`,
`popup`,
`result_type`,
`text_1`,
`text_0`,
`units`,
`lv`,
`hv`,
`formula`,
`calibration`)
VALUES
('".$imei."',
'".$name."',
'".$type."',
'".$param."',
'".$data_list."',
'".$popup."',
'".$result_type."',
'".$text_1."',
'".$text_0."',
'".$units."',
'".$lv."',
'".$hv."',
'".$formula."',
'".$calibration."')";
}
else
{
$q = "UPDATE `gs_object_sensors` SET `name`='".$name."',
`type`='".$type."',
`param`='".$param."',
`data_list`='".$data_list."',
`popup`='".$popup."',
`result_type`='".$result_type."',
`text_1`='".$text_1."',
`text_0`='".$text_0."',
`units`='".$units."',
`lv`='".$lv."',
`hv`='".$hv."',
`formula`='".$formula."',
`calibration`='".$calibration."'
WHERE `sensor_id`='".$sensor_id."'";
}
$r = mysqli_query($ms, $q);
echo 'OK';
die;
}
if(@$_GET['cmd'] == 'load_object_sensor_list')
{
$page = $_GET['page']; // get the requested page
$limit = $_GET['rows']; // get how many rows we want to have into the grid
$sidx = $_GET['sidx']; // get index row - i.e. user click to sort
$sord = $_GET['sord']; // get the direction
$imei = $_GET['imei'];
if(!$sidx) $sidx =1;
// get records number
$q = "SELECT * FROM `gs_object_sensors` WHERE `imei`='".$imei."'";
$r = mysqli_query($ms, $q);
$count = mysqli_num_rows($r);
$q = "SELECT * FROM `gs_object_sensors` WHERE `imei`='".$imei."' ORDER BY $sidx $sord";
$result = mysqli_query($ms, $q);
$responce = new stdClass();
$i=0;
while($row = mysqli_fetch_array($result)) {
$sensor_id = $row["sensor_id"];
$name = $row['name'];
$type = $row['type'];
$param = $row['param'];
// change type
if ($type == "di") $type = $la['DIGITAL_INPUT'];
if ($type == "do") $type = $la['DIGITAL_OUTPUT'];
if ($type == "da") $type = $la['DRIVER_ASSIGN'];
if ($type == "engh") $type = $la['ENGINE_HOURS'];
if ($type == "fuel") $type = $la['FUEL_LEVEL'];
if ($type == "fuelcons") $type = $la['FUEL_CONSUMPTION'];
if ($type == "acc") $type = $la['IGNITION_ACC'];
if ($type == "odo") $type = $la['ODOMETER'];
if ($type == "pa") $type = $la['PASSENGER_ASSIGN'];
if ($type == "temp") $type = $la['TEMPERATURE'];
if ($type == "ta") $type = $la['TRAILER_ASSIGN'];
if ($type == "cust") $type = $la['CUSTOM'];
// set modify buttons
$modify = '<a href="#" onclick="settingsObjectSensorProperties(\''.$sensor_id.'\');" title="'.$la['EDIT'].'"><img src="theme/images/edit.svg" />';
$modify .= '</a><a href="#" onclick="settingsObjectSensorDelete(\''.$sensor_id.'\');" title="'.$la['DELETE'].'"><img src="theme/images/remove3.svg" /></a>';
// set row
$responce->rows[$i]['id']=$sensor_id;
$responce->rows[$i]['cell']=array($name,$type,$param,$modify);
$i++;
}
$responce->page = 1;
//$responce->total = $count;
$responce->records = $count;
header('Content-type: application/json');
echo json_encode($responce);
die;
}
?>
\ No newline at end of file
<?
session_start();
include ('../init.php');
include ('fn_common.php');
checkUserSession();
loadLanguage($_SESSION["language"], $_SESSION["units"]);
if(@$_POST['cmd'] == 'delete_object_service')
{
$service_id = $_POST["service_id"];
$imei = $_POST["imei"];
$q = "DELETE FROM `gs_object_services` WHERE `service_id`='".$service_id."' AND `imei`='".$imei."'";
$r = mysqli_query($ms, $q);
echo 'OK';
die;
}
if(@$_POST['cmd'] == 'delete_selected_object_services')
{
$items = $_POST["items"];
$imei = $_POST["imei"];
for ($i = 0; $i < count($items); ++$i)
{
$item = $items[$i];
$q = "DELETE FROM `gs_object_services` WHERE `service_id`='".$item."' AND `imei`='".$imei."'";
$r = mysqli_query($ms, $q);
}
echo 'OK';
die;
}
if(@$_POST['cmd'] == 'save_object_service')
{
$service_id = $_POST["service_id"];
$imei = $_POST["imei"];
$name = $_POST["name"];
$data_list = $_POST["data_list"];
$popup = $_POST["popup"];
$odo = $_POST["odo"];
$odo_interval = $_POST["odo_interval"];
$odo_last = $_POST["odo_last"];
$engh = $_POST["engh"];
$engh_interval = $_POST["engh_interval"];
$engh_last = $_POST["engh_last"];
$days = $_POST["days"];
$days_interval = $_POST["days_interval"];
$days_last = $_POST["days_last"];
$odo_left = $_POST["odo_left"];
$odo_left_num = $_POST["odo_left_num"];
$engh_left = $_POST["engh_left"];
$engh_left_num = $_POST["engh_left_num"];
$days_left = $_POST["days_left"];
$days_left_num = $_POST["days_left_num"];
$update_last = $_POST["update_last"];
// save in km
$odo_interval = convDistanceUnits($odo_interval, $_SESSION["unit_distance"], 'km');
$odo_last = convDistanceUnits($odo_last, $_SESSION["unit_distance"], 'km');
$odo_left_num = convDistanceUnits($odo_left_num, $_SESSION["unit_distance"], 'km');
if ($service_id == 'false')
{
$q = "INSERT INTO `gs_object_services` (`imei`,
`name`,
`data_list`,
`popup`,
`odo`,
`odo_interval`,
`odo_last`,
`engh`,
`engh_interval`,
`engh_last`,
`days`,
`days_interval`,
`days_last`,
`odo_left`,
`odo_left_num`,
`engh_left`,
`engh_left_num`,
`days_left`,
`days_left_num`,
`update_last`)
VALUES
('".$imei."',
'".$name."',
'".$data_list."',
'".$popup."',
'".$odo."',
'".$odo_interval."',
'".$odo_last."',
'".$engh."',
'".$engh_interval."',
'".$engh_last."',
'".$days."',
'".$days_interval."',
'".$days_last."',
'".$odo_left."',
'".$odo_left_num."',
'".$engh_left."',
'".$engh_left_num."',
'".$days_left."',
'".$days_left_num."',
'".$update_last."')";
}
else
{
$q = "UPDATE `gs_object_services` SET `name`='".$name."',
`data_list`='".$data_list."',
`popup`='".$popup."',
`odo`='".$odo."',
`odo_interval`='".$odo_interval."',
`odo_last`='".$odo_last."',
`engh`='".$engh."',
`engh_interval`='".$engh_interval."',
`engh_last`='".$engh_last."',
`days`='".$days."',
`days_interval`='".$days_interval."',
`days_last`='".$days_last."',
`odo_left`='".$odo_left."',
`odo_left_num`='".$odo_left_num."',
`engh_left`='".$engh_left."',
`engh_left_num`='".$engh_left_num."',
`days_left`='".$days_left."',
`days_left_num`='".$days_left_num."',
`update_last`='".$update_last."'
WHERE `service_id`='".$service_id."'";
}
$r = mysqli_query($ms, $q);
echo 'OK';
die;
}
if(@$_GET['cmd'] == 'load_object_service_list')
{
$page = $_GET['page']; // get the requested page
$limit = $_GET['rows']; // get how many rows we want to have into the grid
$sidx = $_GET['sidx']; // get index row - i.e. user click to sort
$sord = $_GET['sord']; // get the direction
$imei = $_GET['imei'];
if(!$sidx) $sidx =1;
// get records number
$q = "SELECT * FROM `gs_object_services` WHERE `imei`='".$imei."'";
$r = mysqli_query($ms, $q);
$count = mysqli_num_rows($r);
$q = "SELECT * FROM `gs_object_services` WHERE `imei`='".$imei."' ORDER BY $sidx $sord";
$result = mysqli_query($ms, $q);
$responce = new stdClass();
// get real odometer and engine hours
$odometer = getObjectOdometer($imei);
$odometer = floor(convDistanceUnits($odometer, 'km', $_SESSION["unit_distance"]));
$engine_hours = getObjectEngineHours($imei, false);
$i=0;
while($row = mysqli_fetch_array($result)) {
$service_id = $row["service_id"];
$name = $row['name'];
$status_arr = array();
if ($row['odo'] == 'true')
{
$row['odo_interval'] = floor(convDistanceUnits($row['odo_interval'], 'km', $_SESSION["unit_distance"]));
$row['odo_last'] = floor(convDistanceUnits($row['odo_last'], 'km', $_SESSION["unit_distance"]));
$odo_diff = $odometer - $row['odo_last'];
$odo_diff = $row['odo_interval'] - $odo_diff;
if ($odo_diff <= 0)
{
$odo_diff = abs($odo_diff);
$status_arr[] = '<font color="red">'.$la['ODOMETER_EXPIRED'].' ('.$odo_diff.' '.$la["UNIT_DISTANCE"].')</font>';
}
else
{
$status_arr[] = $la['ODOMETER_LEFT'].' ('.$odo_diff.' '.$la["UNIT_DISTANCE"].')';
}
}
if ($row['engh'] == 'true')
{
$engh_diff = $engine_hours - $row['engh_last'];
$engh_diff = $row['engh_interval'] - $engh_diff;
if ($engh_diff <= 0)
{
$engh_diff = abs($engh_diff);
$status_arr[] = '<font color="red">'.$la['ENGINE_HOURS_EXPIRED'].' ('.$engh_diff.' '.$la["UNIT_H"].')</font>';
}
else
{
$status_arr[] = $la['ENGINE_HOURS_LEFT'].' ('.$engh_diff.' '.$la["UNIT_H"].')';
}
}
if ($row['days'] == 'true')
{
$days_diff = strtotime(gmdate("Y-m-d")) - (strtotime($row['days_last']));
$days_diff = floor($days_diff/3600/24);
$days_diff = $row['days_interval'] - $days_diff;
if ($days_diff <= 0)
{
$days_diff = abs($days_diff);
$status_arr[] = '<font color="red">'.$la['DAYS_EXPIRED'].' ('.$days_diff.')</font>';
}
else
{
$status_arr[] = $la['DAYS_LEFT'].' ('.$days_diff.')';
}
}
$status = strtolower(implode(", ", $status_arr));
// set modify buttons
$modify = '<a href="#" onclick="settingsObjectServiceProperties(\''.$service_id.'\');" title="'.$la['EDIT'].'"><img src="theme/images/edit.svg" />';
$modify .= '</a><a href="#" onclick="settingsObjectServiceDelete(\''.$service_id.'\');" title="'.$la['DELETE'].'"><img src="theme/images/remove3.svg" /></a>';
// set row
$responce->rows[$i]['id']=$service_id;
$responce->rows[$i]['cell']=array($name,$status,$modify);
$i++;
}
$responce->page = 1;
//$responce->total = $count;
$responce->records = $count;
header('Content-type: application/json');
echo json_encode($responce);
die;
}
?>
\ No newline at end of file
<?
session_start();
include ('../init.php');
include ('fn_common.php');
checkUserSession();
include ('../tools/email.php');
loadLanguage($_SESSION["language"], $_SESSION["units"]);
if(@$_POST['cmd'] == 'load_subaccount_values')
{
$manager_id = $_SESSION["user_id"];
$q = "SELECT * FROM `gs_users` WHERE `privileges` LIKE '%subuser%' AND `manager_id`='".$manager_id."' ORDER BY `email` ASC";
$r = mysqli_query($ms, $q);
$result = array();
while($row=mysqli_fetch_array($r))
{
$privileges = json_decode($row['privileges'],true);
$privileges = checkUserPrivilegesArray($privileges);
$imei = $privileges['imei'];
$marker = $privileges['marker'];
$route = $privileges['route'];
$zone = $privileges['zone'];
$history = $privileges['history'];
$reports = $privileges['reports'];
$rilogbook = $privileges['rilogbook'];
$dtc = $privileges['dtc'];
$object_control = $privileges['object_control'];
$image_gallery = $privileges['image_gallery'];
$chat = $privileges['chat'];
if (!isset($privileges['au_active'])) { $privileges['au_active'] = false; }
$au_active = $privileges['au_active'];
if (!isset($privileges['au'])) { $privileges['au'] = ''; }
$au = $privileges['au'];
$subaccount_id = $row['id'];
$result[$subaccount_id] = array('email' => $row['email'],
'active' => $row['active'],
'account_expire' => $row['account_expire'],
'account_expire_dt' => $row['account_expire_dt'],
'imei' => $imei,
'marker' => $marker,
'route' => $route,
'zone' => $zone,
'history' => $history,
'reports' => $reports,
'rilogbook' => $rilogbook,
'dtc' => $dtc,
'object_control' => $object_control,
'image_gallery' => $image_gallery,
'chat' => $chat,
'au_active' => $au_active,
'au' => $au
);
}
echo json_encode($result);
die;
}
if(@$_POST['cmd'] == 'delete_subaccount')
{
$subaccount_id= $_POST["subaccount_id"];
$manager_id = $_SESSION["user_id"];
$q = "DELETE FROM `gs_users` WHERE `id`='".$subaccount_id."' AND `manager_id`='".$manager_id."'";
$r = mysqli_query($ms, $q);
echo 'OK';
die;
}
if(@$_POST['cmd'] == 'delete_selected_subaccounts')
{
$items = $_POST["items"];
$manager_id = $_SESSION["user_id"];
for ($i = 0; $i < count($items); ++$i)
{
$item = $items[$i];
$q = "DELETE FROM `gs_users` WHERE `id`='".$item."' AND `manager_id`='".$manager_id."'";
$r = mysqli_query($ms, $q);
}
echo 'OK';
die;
}
if(@$_POST['cmd'] == 'save_subaccount')
{
$result = '';
$subaccount_id = $_POST["subaccount_id"];
$email = strtolower($_POST["email"]);
$password = $_POST["password"];
$active = $_POST["active"];
$account_expire = $_POST["account_expire"];
$account_expire_dt = $_POST["account_expire_dt"];
$privileges = $_POST["privileges"];
$manager_id = $_SESSION["user_id"];
if ($subaccount_id == 'false')
{
$manager_id = $_SESSION["user_id"];
$result = addUser('true', $active, $account_expire, $account_expire_dt, $privileges, $manager_id, $email, $password, 'false', 'false', '', 'false', '', 'false', 'false');
}
else
{
$q = "UPDATE `gs_users` SET `active`='".$active."',
`account_expire`='".$account_expire."',
`account_expire_dt`='".$account_expire_dt."',
`username`='".$email."',
`email`='".$email."',
`privileges`='".$privileges."'
WHERE `id`='".$subaccount_id."' AND `manager_id`='".$manager_id."'";
$r = mysqli_query($ms, $q);
if ($password != '')
{
$q = "UPDATE `gs_users` SET `password`='".md5($password)."' WHERE `id`='".$subaccount_id."' AND `manager_id`='".$manager_id."'";
$r = mysqli_query($ms, $q);
}
$result = 'OK';
}
echo $result;
}
if(@$_GET['cmd'] == 'load_subaccount_list')
{
$manager_id = $_SESSION["user_id"];
$page = $_GET['page']; // get the requested page
$limit = $_GET['rows']; // get how many rows we want to have into the grid
$sidx = $_GET['sidx']; // get index row - i.e. user click to sort
$sord = $_GET['sord']; // get the direction
if(!$sidx) $sidx = 1;
// get records number
$q = "SELECT * FROM `gs_users` WHERE `privileges` LIKE '%subuser%' AND `manager_id`='".$manager_id."'";
$r = mysqli_query($ms, $q);
$count = mysqli_num_rows($r);
if( $count >0 )
{
$total_pages = ceil($count/$limit);
}
else
{
$total_pages = 1;
}
if ($page > $total_pages) $page=$total_pages;
$start = $limit*$page - $limit; // do not put $limit*($page - 1)
$q = "SELECT * FROM `gs_users` WHERE `privileges` LIKE '%subuser%' AND `manager_id`='".$manager_id."' ORDER BY $sidx $sord LIMIT $start, $limit";
$r = mysqli_query($ms, $q);
$responce = new stdClass();
$responce->page = $page;
$responce->total = $total_pages;
$responce->records = $count;
$i=0;
while($row = mysqli_fetch_array($r))
{
$subaccount_id = $row["id"];
$email = $row['email'];
if ($row['active'] == 'true')
{
$active = '<img src="theme/images/tick-green.svg" />';
}
else
{
$active = '<img src="theme/images/remove-red.svg" style="width:12px;" />';
}
$privileges = json_decode($row['privileges'],true);
$imeis = count(explode(",", $privileges['imei']));
$markers = explode(",", $privileges['marker']);
if ($markers[0] == '')
{
$markers = 0;
}
else
{
$markers = count($markers);
}
$routes = explode(",", $privileges['route']);
if ($routes[0] == '')
{
$routes = 0;
}
else
{
$routes = count($routes);
}
$zones = explode(",", $privileges['zone']);
if ($zones[0] == '')
{
$zones = 0;
}
else
{
$zones = count($zones);
}
$places = $markers.'/'.$routes.'/'.$zones;
// set modify buttons
$modify = '<a href="#" onclick="settingsSubaccountProperties(\''.$subaccount_id.'\');"><img src="theme/images/edit.svg" title="'.$la['EDIT'].'"/></a>';
$modify .= '<a href="#" onclick="settingsSubaccountDelete(\''.$subaccount_id.'\');"><img src="theme/images/remove3.svg" title="'.$la['DELETE'].'"/></a>';
// set row
$responce->rows[$i]['id']=$subaccount_id;
$responce->rows[$i]['cell']=array($email,$active,$imeis,$places,$modify);
$i++;
}
header('Content-type: application/json');
echo json_encode($responce);
die;
}
?>
\ No newline at end of file
<?
session_start();
include ('../init.php');
include ('fn_common.php');
checkUserSession();
loadLanguage($_SESSION["language"], $_SESSION["units"]);
if(@$_POST['cmd'] == 'load_template_values')
{
$user_id = $_SESSION["user_id"];
$q = "SELECT * FROM `gs_user_templates` WHERE `user_id`='".$user_id."' ORDER BY `name` ASC";
$r = mysqli_query($ms, $q);
$result = array();
while($row=mysqli_fetch_array($r))
{
$template_id = $row['template_id'];
$result[$template_id] = array( 'name' => $row['name'],
'desc' => $row['desc'],
'subject' => $row['subject'],
'message' => $row['message']
);
}
echo json_encode($result);
die;
}
if(@$_GET['cmd'] == 'load_template_list')
{
$page = $_GET['page']; // get the requested page
$limit = $_GET['rows']; // get how many rows we want to have into the grid
$sidx = $_GET['sidx']; // get index row - i.e. user click to sort
$sord = $_GET['sord']; // get the direction
$user_id = $_SESSION["user_id"];
if(!$sidx) $sidx =1;
// get records number
$q = "SELECT * FROM `gs_user_templates` WHERE `user_id`='".$user_id."'";
$r = mysqli_query($ms, $q);
$count = mysqli_num_rows($r);
if( $count >0 )
{
$total_pages = ceil($count/$limit);
}
else
{
$total_pages = 1;
}
if ($page > $total_pages) $page=$total_pages;
$start = $limit*$page - $limit; // do not put $limit*($page - 1)
$q = "SELECT * FROM `gs_user_templates` WHERE `user_id`='".$user_id."' ORDER BY $sidx $sord LIMIT $start, $limit";
$r = mysqli_query($ms, $q);
$responce = new stdClass();
$responce->page = $page;
$responce->total = $total_pages;
$responce->records = $count;
$i=0;
while($row = mysqli_fetch_array($r)) {
$template_id = $row['template_id'];
$name = $row['name'];
$desc = $row['desc'];
// set modify buttons
$modify = '<a href="#" onclick="settingsTemplateProperties(\''.$template_id.'\');" title="'.$la['EDIT'].'"><img src="theme/images/edit.svg" />';
$modify .= '</a><a href="#" onclick="settingsTemplateDelete(\''.$template_id.'\');" title="'.$la['DELETE'].'"><img src="theme/images/remove3.svg" /></a>';
// set row
$responce->rows[$i]['id']=$template_id;
$responce->rows[$i]['cell']=array($name,$desc,$modify);
$i++;
}
header('Content-type: application/json');
echo json_encode($responce);
die;
}
if(@$_POST['cmd'] == 'delete_template')
{
$template_id = $_POST["template_id"];
$user_id = $_SESSION["user_id"];
$q = "DELETE FROM `gs_user_templates` WHERE `template_id`='".$template_id."' AND `user_id`='".$user_id."'";
$r = mysqli_query($ms, $q);
echo 'OK';
die;
}
if(@$_POST['cmd'] == 'delete_selected_templates')
{
$items = $_POST["items"];
$user_id = $_SESSION["user_id"];
for ($i = 0; $i < count($items); ++$i)
{
$item = $items[$i];
$q = "DELETE FROM `gs_user_templates` WHERE `template_id`='".$item."' AND `user_id`='".$user_id."'";
$r = mysqli_query($ms, $q);
}
echo 'OK';
die;
}
if(@$_POST['cmd'] == 'save_template')
{
$template_id = $_POST["template_id"];
$user_id = $_SESSION["user_id"];
$name = $_POST["name"];
$desc = $_POST["desc"];
$subject = $_POST["subject"];
$message = $_POST["message"];
if ($template_id == 'false')
{
$q = "INSERT INTO `gs_user_templates` (`user_id`,
`name`,
`desc`,
`subject`,
`message`
) VALUES (
'".$user_id."',
'".$name."',
'".$desc."',
'".$subject."',
'".$message."')";
}
else
{
$q = "UPDATE `gs_user_templates` SET `name`='".$name."',
`desc`='".$desc."',
`subject`='".$subject."',
`message`='".$message."'
WHERE `template_id`='".$template_id."'";
}
$r = mysqli_query($ms, $q);
echo 'OK';
}
?>
\ No newline at end of file
<?
session_start();
include ('../init.php');
include ('fn_common.php');
checkUserSession();
loadLanguage($_SESSION["language"], $_SESSION["units"]);
// check privileges
if ($_SESSION["privileges"] == 'subuser')
{
$user_id = $_SESSION["manager_id"];
}
else
{
$user_id = $_SESSION["user_id"];
}
if(@$_POST['cmd'] == 'delete_object_trailer')
{
$trailer_id = $_POST["trailer_id"];
$q = "DELETE FROM `gs_user_object_trailers` WHERE `trailer_id`='".$trailer_id."' AND `user_id`='".$user_id."'";
$r = mysqli_query($ms, $q);
// reset trailer_id in objects
$q = "UPDATE `gs_user_objects` SET `trailer_id`='0' WHERE `trailer_id`='".$trailer_id."'";
$r = mysqli_query($ms, $q);
echo 'OK';
die;
}
if(@$_POST['cmd'] == 'delete_selected_object_trailers')
{
$items = $_POST["items"];
for ($i = 0; $i < count($items); ++$i)
{
$item = $items[$i];
$q = "DELETE FROM `gs_user_object_trailers` WHERE `trailer_id`='".$item."' AND `user_id`='".$user_id."'";
$r = mysqli_query($ms, $q);
// reset trailer_id in objects
$q = "UPDATE `gs_user_objects` SET `trailer_id`='0' WHERE `trailer_id`='".$item."'";
$r = mysqli_query($ms, $q);
}
echo 'OK';
die;
}
if(@$_POST['cmd'] == 'save_object_trailer')
{
$trailer_id = $_POST["trailer_id"];
$trailer_name = $_POST["trailer_name"];
$trailer_assign_id = strtoupper($_POST["trailer_assign_id"]);
$trailer_model = $_POST["trailer_model"];
$trailer_vin = $_POST["trailer_vin"];
$trailer_plate_number = $_POST["trailer_plate_number"];
$trailer_desc = $_POST["trailer_desc"];
if ($trailer_id == 'false')
{
$q = "INSERT INTO `gs_user_object_trailers`( `user_id`,
`trailer_name`,
`trailer_assign_id`,
`trailer_model`,
`trailer_vin`,
`trailer_plate_number`,
`trailer_desc`)
VALUES
('".$user_id."',
'".$trailer_name."',
'".$trailer_assign_id."',
'".$trailer_model."',
'".$trailer_vin."',
'".$trailer_plate_number."',
'".$trailer_desc."')";
}
else
{
$q = "UPDATE `gs_user_object_trailers` SET `trailer_name`='".$trailer_name."',
`trailer_assign_id`='".$trailer_assign_id."',
`trailer_model`='".$trailer_model."',
`trailer_vin`='".$trailer_vin."',
`trailer_plate_number`='".$trailer_plate_number."',
`trailer_desc`='".$trailer_desc."'
WHERE `trailer_id`='".$trailer_id."'";
}
$r = mysqli_query($ms, $q);
echo 'OK';
die;
}
if(@$_GET['cmd'] == 'load_object_trailer_list')
{
$page = $_GET['page']; // get the requested page
$limit = $_GET['rows']; // get how many rows we want to have into the grid
$sidx = $_GET['sidx']; // get index row - i.e. user click to sort
$sord = $_GET['sord']; // get the direction
if(!$sidx) $sidx =1;
$q = "SELECT * FROM `gs_user_object_trailers` WHERE `user_id`='".$user_id."'";
$r = mysqli_query($ms, $q);
$count = mysqli_num_rows($r);
if( $count >0 )
{
$total_pages = ceil($count/$limit);
}
else
{
$total_pages = 1;
}
if ($page > $total_pages) $page=$total_pages;
$start = $limit*$page - $limit; // do not put $limit*($page - 1)
$q = "SELECT * FROM `gs_user_object_trailers` WHERE `user_id`='".$user_id."' ORDER BY $sidx $sord LIMIT $start, $limit";
$r = mysqli_query($ms, $q);
$responce = new stdClass();
$responce->page = $page;
$responce->total = $total_pages;
$responce->records = $count;
$i=0;
while($row = mysqli_fetch_array($r))
{
$trailer_id = $row["trailer_id"];
$trailer_name = $row["trailer_name"];
$trailer_desc = $row["trailer_desc"];
// set modify buttons
$modify = '<a href="#" onclick="settingsObjectTrailerProperties(\''.$trailer_id.'\');" title="'.$la['EDIT'].'"><img src="theme/images/edit.svg" /></a>';
$modify .= '<a href="#" onclick="settingsObjectTrailerDelete(\''.$trailer_id.'\');" title="'.$la['DELETE'].'"><img src="theme/images/remove3.svg" /></a>';
// set row
$responce->rows[$i]['id']=$trailer_id;
$responce->rows[$i]['cell']=array($trailer_name,$trailer_desc,$modify);
$i++;
}
header('Content-type: application/json');
echo json_encode($responce);
die;
}
if(@$_POST['cmd'] == 'load_object_trailer_values')
{
$q = "SELECT * FROM `gs_user_object_trailers` WHERE `user_id`='".$user_id."' ORDER BY `trailer_name` ASC";
$r = mysqli_query($ms, $q);
$result = array();
while($row=mysqli_fetch_array($r))
{
$trailer_id = $row['trailer_id'];
$result[$trailer_id] = array( 'name' => $row['trailer_name'],
'assign_id' => $row['trailer_assign_id'],
'model' => $row['trailer_model'],
'vin' => $row['trailer_vin'],
'plate_number' => $row['trailer_plate_number'],
'desc' => $row['trailer_desc']
);
}
echo json_encode($result);
die;
}
?>
\ No newline at end of file
<?
session_start();
include ('../init.php');
include ('fn_common.php');
checkUserSession();
if(@$_GET['file'] == 'logo_png')
{
if ($_SESSION["cpanel_privileges"] != 'super_admin')
{
die;
}
$postdata = file_get_contents("php://input");
if (isset($postdata))
{
$imageData = $postdata;
$filteredData = substr($imageData, strpos($imageData, ",")+1);
$unencodedData=base64_decode($filteredData);
$file_path = $gsValues['PATH_ROOT'].'img/logo.png';
$fp = fopen( $file_path, 'wb' );
fwrite( $fp, $unencodedData);
fclose( $fp );
$file_url = $gsValues['URL_ROOT'].'/img/logo.png';
echo $file_url;
}
}
if(@$_GET['file'] == 'logo_svg')
{
if ($_SESSION["cpanel_privileges"] != 'super_admin')
{
die;
}
$postdata = file_get_contents("php://input");
if (isset($postdata))
{
$imageData = $postdata;
$filteredData = substr($imageData, strpos($imageData, ",")+1);
$unencodedData=base64_decode($filteredData);
$file_path = $gsValues['PATH_ROOT'].'img/logo.svg';
$fp = fopen( $file_path, 'wb' );
fwrite( $fp, $unencodedData);
fclose( $fp );
$file_url = $gsValues['URL_ROOT'].'/img/logo.svg';
echo $file_url;
}
}
if(@$_GET['file'] == 'driver_photo')
{
$postdata = file_get_contents("php://input");
if (isset($postdata))
{
$imageData = $postdata;
$filteredData = substr($imageData, strpos($imageData, ",")+1);
$unencodedData=base64_decode($filteredData);
$file_path = $gsValues['PATH_ROOT'].'data/user/drivers/'.$_SESSION["user_id"].'_temp.png';
$file_url = $gsValues['URL_ROOT'].'/data/user/drivers/'.$_SESSION["user_id"].'_temp.png';
$fp = fopen( $file_path, 'wb' );
fwrite( $fp, $unencodedData);
fclose( $fp );
echo $file_url;
}
}
if(@$_GET['file'] == 'object_icon_png')
{
$postdata = file_get_contents("php://input");
if (isset($postdata))
{
$imageData = $postdata;
$filteredData = substr($imageData, strpos($imageData, ",")+1);
$unencodedData=base64_decode($filteredData);
$file_path = $gsValues['PATH_ROOT'].'data/user/objects/'.$_SESSION["user_id"].'_'.md5(gmdate("Y-m-d H:i:s")).'.png';
$fp = fopen( $file_path, 'wb' );
fwrite( $fp, $unencodedData);
fclose( $fp );
}
}
if(@$_GET['file'] == 'object_icon_svg')
{
$postdata = file_get_contents("php://input");
if (isset($postdata))
{
$imageData = $postdata;
$filteredData = substr($imageData, strpos($imageData, ",")+1);
$unencodedData=base64_decode($filteredData);
$file_path = $gsValues['PATH_ROOT'].'data/user/objects/'.$_SESSION["user_id"].'_'.md5(gmdate("Y-m-d H:i:s")).'.svg';
$fp = fopen( $file_path, 'wb' );
fwrite( $fp, $unencodedData);
fclose( $fp );
}
}
if(@$_GET['file'] == 'places_icon_png')
{
$postdata = file_get_contents("php://input");
if (isset($postdata))
{
$imageData = $postdata;
$filteredData = substr($imageData, strpos($imageData, ",")+1);
$unencodedData=base64_decode($filteredData);
$file_path = $gsValues['PATH_ROOT'].'data/user/places/'.$_SESSION["user_id"].'_'.md5(gmdate("Y-m-d H:i:s")).'.png';
$fp = fopen( $file_path, 'wb' );
fwrite( $fp, $unencodedData);
fclose( $fp );
}
}
if(@$_GET['file'] == 'places_icon_svg')
{
$postdata = file_get_contents("php://input");
if (isset($postdata))
{
$imageData = $postdata;
$filteredData = substr($imageData, strpos($imageData, ",")+1);
$unencodedData=base64_decode($filteredData);
$file_path = $gsValues['PATH_ROOT'].'data/user/places/'.$_SESSION["user_id"].'_'.md5(gmdate("Y-m-d H:i:s")).'.svg';
$fp = fopen( $file_path, 'wb' );
fwrite( $fp, $unencodedData);
fclose( $fp );
}
}
?>
\ No newline at end of file
67421D253B3B5395081D034877E4B397
\ No newline at end of file
img/Group 21.png

38.6 KB

<svg width="417" height="91" viewBox="0 0 417 91" fill="none" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
<rect width="223" height="91" transform="matrix(-1 0 0 1 326 0)" fill="url(#pattern0)" fill-opacity="0.7"/>
<rect width="77" height="32" transform="matrix(-1 0 0 1 77 54)" fill="url(#pattern1)" fill-opacity="0.7"/>
<rect width="78" height="32" transform="matrix(-1 0 0 1 417 54)" fill="url(#pattern2)" fill-opacity="0.7"/>
<defs>
<pattern id="pattern0" patternContentUnits="objectBoundingBox" width="1" height="1">
<use xlink:href="#image0" transform="translate(0 -0.0894665) scale(0.00151286 0.00370734)"/>
</pattern>
<pattern id="pattern1" patternContentUnits="objectBoundingBox" width="1" height="1">
<use xlink:href="#image0" transform="translate(0 -0.0788105) scale(0.00151286 0.00364032)"/>
</pattern>
<pattern id="pattern2" patternContentUnits="objectBoundingBox" width="1" height="1">
<use xlink:href="#image0" transform="translate(0 -0.0863275) scale(0.00151286 0.00368759)"/>
</pattern>
<image id="image0" width="661" height="318" xlink:href=""/>
</defs>
</svg>
<svg width="402" height="95" viewBox="0 0 402 95" fill="none" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
<rect x="88" width="214" height="95" fill="url(#pattern0)" fill-opacity="0.7"/>
<rect x="327" y="57" width="75" height="33" fill="url(#pattern1)" fill-opacity="0.7"/>
<rect y="57" width="75" height="33" fill="url(#pattern2)" fill-opacity="0.7"/>
<defs>
<pattern id="pattern0" patternContentUnits="objectBoundingBox" width="1" height="1">
<use xlink:href="#image0" transform="translate(0 -0.0418584) scale(0.00151286 0.00340791)"/>
</pattern>
<pattern id="pattern1" patternContentUnits="objectBoundingBox" width="1" height="1">
<use xlink:href="#image0" transform="translate(0 -0.0466923) scale(0.00151286 0.00343832)"/>
</pattern>
<pattern id="pattern2" patternContentUnits="objectBoundingBox" width="1" height="1">
<use xlink:href="#image0" transform="translate(0 -0.0466923) scale(0.00151286 0.00343832)"/>
</pattern>
<image id="image0" width="661" height="318" xlink:href=""/>
</defs>
</svg>
Markdown is supported
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment