2016-04-23 18:01:11 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
|
|
/////////////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
// ADS-B RECEIVER PORTAL //
|
|
|
|
|
// =============================================================================== //
|
|
|
|
|
// Copyright and Licensing Information: //
|
|
|
|
|
// //
|
|
|
|
|
// The MIT License (MIT) //
|
|
|
|
|
// //
|
|
|
|
|
// Copyright (c) 2015-2016 Joseph A. Prochazka //
|
|
|
|
|
// //
|
|
|
|
|
// Permission is hereby granted, free of charge, to any person obtaining a copy //
|
|
|
|
|
// of this software and associated documentation files (the "Software"), to deal //
|
|
|
|
|
// in the Software without restriction, including without limitation the rights //
|
|
|
|
|
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell //
|
|
|
|
|
// copies of the Software, and to permit persons to whom the Software is //
|
|
|
|
|
// furnished to do so, subject to the following conditions: //
|
|
|
|
|
// //
|
|
|
|
|
// The above copyright notice and this permission notice shall be included in all //
|
|
|
|
|
// copies or substantial portions of the Software. //
|
|
|
|
|
// //
|
|
|
|
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR //
|
|
|
|
|
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, //
|
|
|
|
|
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE //
|
|
|
|
|
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER //
|
|
|
|
|
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, //
|
|
|
|
|
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE //
|
|
|
|
|
// SOFTWARE. //
|
|
|
|
|
/////////////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
|
|
require_once('../classes/common.class.php');
|
|
|
|
|
require_once('../classes/settings.class.php');
|
|
|
|
|
|
|
|
|
|
$common = new common();
|
2016-04-27 23:50:37 +00:00
|
|
|
$settings = new settings();
|
2016-04-23 18:01:11 +00:00
|
|
|
|
2016-04-27 23:50:37 +00:00
|
|
|
// The most current stable release.
|
2016-05-17 17:18:55 +00:00
|
|
|
$thisVersion = "2.1.0";
|
2016-04-27 23:50:37 +00:00
|
|
|
|
|
|
|
|
// Begin the upgrade process if this release is newer than what is installed.
|
|
|
|
|
if ($common->getSetting("version") == $thisVersion) {
|
|
|
|
|
header ("Location: /");
|
|
|
|
|
}
|
|
|
|
|
|
2016-04-28 17:40:58 +00:00
|
|
|
$error = FALSE;
|
|
|
|
|
#errorMessage = "No error message returned.";
|
|
|
|
|
|
2016-05-10 18:37:14 +00:00
|
|
|
///////////////////////
|
|
|
|
|
// UPGRADE TO V2.0.1
|
|
|
|
|
///////////////////////
|
|
|
|
|
|
|
|
|
|
if ($common->getSetting("version") == "2.0.0") {
|
|
|
|
|
try {
|
|
|
|
|
// Change tables containing datetime data to datetime.
|
|
|
|
|
if ($settings::db_driver != "xml") {
|
|
|
|
|
|
|
|
|
|
// ALter MySQL tables.
|
|
|
|
|
if ($settings::db_driver != "mysql") {
|
|
|
|
|
$dbh = $common->pdoOpen();
|
|
|
|
|
|
|
|
|
|
$sql = "ALTER TABLE ".$settings::db_prefix."aircraft MODIFY firstSeen DATETIME NOT NULL";
|
|
|
|
|
$sth = $dbh->prepare($sql);
|
|
|
|
|
$sth->execute();
|
|
|
|
|
$sth = NULL;
|
|
|
|
|
|
|
|
|
|
$sql = "ALTER TABLE adsb_aircraft MODIFY lastSeen DATETIME NOT NULL";
|
|
|
|
|
$sth = $dbh->prepare($sql);
|
|
|
|
|
$sth->execute();
|
|
|
|
|
$sth = NULL;
|
|
|
|
|
|
|
|
|
|
$sql = "ALTER TABLE adsb_blogPosts MODIFY date DATETIME NOT NULL";
|
|
|
|
|
$sth = $dbh->prepare($sql);
|
|
|
|
|
$sth->execute();
|
|
|
|
|
$sth = NULL;
|
|
|
|
|
|
|
|
|
|
$sql = "ALTER TABLE adsb_flights MODIFY firstSeen DATETIME NOT NULL";
|
|
|
|
|
$sth = $dbh->prepare($sql);
|
|
|
|
|
$sth->execute();
|
|
|
|
|
$sth = NULL;
|
|
|
|
|
|
|
|
|
|
$sql = "ALTER TABLE adsb_flights MODIFY firstSeen DATETIME NOT NULL";
|
|
|
|
|
$sth = $dbh->prepare($sql);
|
|
|
|
|
$sth->execute();
|
|
|
|
|
$sth = NULL;
|
|
|
|
|
|
|
|
|
|
$sql = "ALTER TABLE adsb_positions MODIFY time DATETIME NOT NULL";
|
|
|
|
|
$sth = $dbh->prepare($sql);
|
|
|
|
|
$sth->execute();
|
|
|
|
|
$sth = NULL;
|
|
|
|
|
|
|
|
|
|
$dbh = NULL;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Convert times to GMT.
|
|
|
|
|
|
|
|
|
|
// You may wish to uncomment this block of code in order to convert existing times
|
|
|
|
|
// stored in the database to UTC/GMT time. Before doing so it is recommended that
|
|
|
|
|
// you set the setting max_execution_time setting to a large amount of time in your
|
|
|
|
|
// php.ini file. Depending on the amount of flight data logged this may take quite
|
|
|
|
|
// some time for this upgrade script to complete so be patient and let it run it's
|
|
|
|
|
// course. Afterwards set the max_execution_time back to it previous setting.
|
|
|
|
|
|
|
|
|
|
/*
|
2016-04-28 18:08:58 +00:00
|
|
|
$dbh = $common->pdoOpen();
|
2016-05-10 18:37:14 +00:00
|
|
|
$sql = "SELECT id, firstSeen, lastSeen FROM ".$settings::db_prefix."aircraft";
|
2016-04-28 18:08:58 +00:00
|
|
|
$sth = $dbh->prepare($sql);
|
|
|
|
|
$sth->execute();
|
2016-05-10 18:37:14 +00:00
|
|
|
$aircraft = $sth->fetchAll();
|
2016-04-28 18:08:58 +00:00
|
|
|
$sth = NULL;
|
|
|
|
|
$dbh = NULL;
|
|
|
|
|
|
2016-05-10 18:37:14 +00:00
|
|
|
foreach ($aircraft as $airframe) {
|
|
|
|
|
$dbh = $common->pdoOpen();
|
|
|
|
|
$sql = "UPDATE ".$settings::db_prefix."aircraft SET firstSeen = :firstSeen, lastSeen = :lastSeen WHERE id = :id";
|
|
|
|
|
$sth = $dbh->prepare($sql);
|
|
|
|
|
$sth->bindParam(':firstSeen', gmdate("Y-m-d H:i:s", $airframe["firstSeen"]), PDO::PARAM_STR);
|
|
|
|
|
$sth->bindParam(':lastSeen', gmdate("Y-m-d H:i:s", $airframe["lastSeen"]), PDO::PARAM_STR);
|
|
|
|
|
$sth->bindParam(':id', $airframe["id"], PDO::PARAM_INT);
|
|
|
|
|
$sth->execute();
|
|
|
|
|
$sth = NULL;
|
|
|
|
|
$dbh = NULL;
|
|
|
|
|
}
|
|
|
|
|
|
2016-04-28 18:08:58 +00:00
|
|
|
$dbh = $common->pdoOpen();
|
2016-05-10 18:37:14 +00:00
|
|
|
$sql = "SELECT id, date FROM ".$settings::db_prefix."blogPosts";
|
2016-04-28 18:08:58 +00:00
|
|
|
$sth = $dbh->prepare($sql);
|
|
|
|
|
$sth->execute();
|
2016-05-10 18:37:14 +00:00
|
|
|
$blogPosts = $sth->fetchAll();
|
2016-04-28 18:08:58 +00:00
|
|
|
$sth = NULL;
|
|
|
|
|
$dbh = NULL;
|
|
|
|
|
|
2016-05-10 18:37:14 +00:00
|
|
|
foreach ($blogPosts as $post) {
|
|
|
|
|
$dbh = $common->pdoOpen();
|
|
|
|
|
$sql = "UPDATE ".$settings::db_prefix."blogPosts SET date = :date WHERE id = :id";
|
|
|
|
|
$sth = $dbh->prepare($sql);
|
|
|
|
|
$sth->bindParam(':date', gmdate("Y-m-d H:i:s", $post["date"]), PDO::PARAM_STR);
|
|
|
|
|
$sth->bindParam(':id', $post["id"], PDO::PARAM_INT);
|
|
|
|
|
$sth->execute();
|
|
|
|
|
$sth = NULL;
|
|
|
|
|
$dbh = NULL;
|
|
|
|
|
}
|
2016-04-28 18:08:58 +00:00
|
|
|
|
|
|
|
|
$dbh = $common->pdoOpen();
|
2016-05-10 18:37:14 +00:00
|
|
|
$sql = "SELECT id, firstSeen, lastSeen FROM ".$settings::db_prefix."flights";
|
2016-04-28 18:08:58 +00:00
|
|
|
$sth = $dbh->prepare($sql);
|
|
|
|
|
$sth->execute();
|
2016-05-10 18:37:14 +00:00
|
|
|
$flights = $sth->fetchAll();
|
2016-04-28 18:08:58 +00:00
|
|
|
$sth = NULL;
|
|
|
|
|
$dbh = NULL;
|
2016-04-28 17:40:58 +00:00
|
|
|
|
2016-05-10 18:37:14 +00:00
|
|
|
foreach ($flights as $flight) {
|
|
|
|
|
$dbh = $common->pdoOpen();
|
|
|
|
|
$sql = "UPDATE ".$settings::db_prefix."flights SET firstSeen = :firstSeen, lastSeen = lastSeen WHERE id = :id";
|
|
|
|
|
$sth = $dbh->prepare($sql);
|
|
|
|
|
$sth->bindParam(':firstSeen', gmdate("Y-m-d H:i:s", $flight["firstSeen"]), PDO::PARAM_STR);
|
|
|
|
|
$sth->bindParam(':lastSeen', gmdate("Y-m-d H:i:s", $flight["lastSeen"]), PDO::PARAM_STR);
|
|
|
|
|
$sth->bindParam(':id', $flight["id"], PDO::PARAM_INT);
|
|
|
|
|
$sth->execute();
|
|
|
|
|
$sth = NULL;
|
|
|
|
|
$dbh = NULL;
|
|
|
|
|
}
|
2016-04-28 18:08:58 +00:00
|
|
|
|
|
|
|
|
$dbh = $common->pdoOpen();
|
2016-05-10 18:37:14 +00:00
|
|
|
$sql = "SELECT id, time FROM ".$settings::db_prefix."positions";
|
2016-04-28 18:08:58 +00:00
|
|
|
$sth = $dbh->prepare($sql);
|
|
|
|
|
$sth->execute();
|
2016-05-10 18:37:14 +00:00
|
|
|
$positionss = $sth->fetchAll();
|
2016-04-28 18:08:58 +00:00
|
|
|
$sth = NULL;
|
|
|
|
|
$dbh = NULL;
|
2016-05-10 18:37:14 +00:00
|
|
|
|
|
|
|
|
foreach ($positions as $position) {
|
|
|
|
|
$dbh = $common->pdoOpen();
|
|
|
|
|
$sql = "UPDATE ".$settings::db_prefix."positions SET time = :time WHERE id = :id";
|
|
|
|
|
$sth = $dbh->prepare($sql);
|
|
|
|
|
$sth->bindParam(':time', gmdate("Y-m-d H:i:s", $position["time"]), PDO::PARAM_STR);
|
|
|
|
|
$sth->bindParam(':id', $position["id"], PDO::PARAM_INT);
|
|
|
|
|
$sth->execute();
|
|
|
|
|
$sth = NULL;
|
|
|
|
|
$dbh = NULL;
|
|
|
|
|
}
|
|
|
|
|
*/
|
2016-04-28 18:08:58 +00:00
|
|
|
}
|
2016-04-28 17:40:58 +00:00
|
|
|
|
2016-05-10 18:37:14 +00:00
|
|
|
// Add timezone setting.
|
|
|
|
|
$common->addSetting("timeZone", date_default_timezone_get());
|
2016-04-28 18:08:58 +00:00
|
|
|
|
2016-05-10 18:37:14 +00:00
|
|
|
// update version and patch settings.
|
|
|
|
|
$common->updateSetting("version", "2.0.1");
|
|
|
|
|
$common->updateSetting("patch", "");
|
|
|
|
|
} catch(Exception $e) {
|
|
|
|
|
$error = TRUE;
|
|
|
|
|
$errorMessage = $e->getMessage();
|
2016-04-28 17:40:58 +00:00
|
|
|
}
|
2016-05-10 18:37:14 +00:00
|
|
|
}
|
2016-04-28 17:40:58 +00:00
|
|
|
|
2016-05-10 18:37:14 +00:00
|
|
|
///////////////////////
|
2016-05-17 17:18:55 +00:00
|
|
|
// UPGRADE TO V2.0.2
|
2016-05-10 18:37:14 +00:00
|
|
|
///////////////////////
|
|
|
|
|
|
|
|
|
|
if ($common->getSetting("version") == "2.0.1") {
|
|
|
|
|
try {
|
2016-05-11 02:47:18 +00:00
|
|
|
|
|
|
|
|
// Set proper permissions on the SQLite file.
|
|
|
|
|
if ($settings::db_driver == "sqlite") {
|
|
|
|
|
chmod($_SERVER['DOCUMENT_ROOT'].DIRECTORY_SEPARATOR."data".DIRECTORY_SEPARATOR."portal.sqlite", 0666);
|
|
|
|
|
}
|
|
|
|
|
|
2016-05-18 05:58:16 +00:00
|
|
|
$common->updateSetting("version", "2.0.2");
|
|
|
|
|
$common->updateSetting("patch", "");
|
|
|
|
|
} catch(Exception $e) {
|
|
|
|
|
$error = TRUE;
|
|
|
|
|
$errorMessage = $e->getMessage();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
///////////////////////
|
|
|
|
|
// UPGRADE RO V2.0.3
|
|
|
|
|
///////////////////////
|
|
|
|
|
|
|
|
|
|
if ($common->getSetting("version") == "2.0.2") {
|
|
|
|
|
try {
|
2016-05-10 18:37:14 +00:00
|
|
|
$common->updateSetting("version", $thisVersion);
|
|
|
|
|
$common->updateSetting("patch", "");
|
|
|
|
|
} catch(Exception $e) {
|
|
|
|
|
$error = TRUE;
|
|
|
|
|
$errorMessage = $e->getMessage();
|
|
|
|
|
}
|
2016-04-23 18:01:11 +00:00
|
|
|
}
|
2016-04-27 23:50:37 +00:00
|
|
|
|
2016-05-17 17:18:55 +00:00
|
|
|
///////////////////////
|
|
|
|
|
// UPGRADE TO V2.1.0
|
|
|
|
|
///////////////////////
|
|
|
|
|
|
2016-08-19 18:53:25 +00:00
|
|
|
if ($common->getSetting("version") == "2.0.3") {
|
2016-05-17 17:18:55 +00:00
|
|
|
try {
|
|
|
|
|
|
|
|
|
|
// Add the positions.aircraft column if using "SQL" storeage.
|
|
|
|
|
if ($settings::db_driver != "xml") {
|
|
|
|
|
|
|
|
|
|
if ($settings::db_driver == "sqlite") {
|
|
|
|
|
// In SQLite aircraft.flight should have been an INTEGER not TEXT column.
|
|
|
|
|
// Since SQLite does not fully support ALTER TABEL allowing the change to be done easily this change will be skipped.
|
|
|
|
|
// This change will be addressed in the future if a problem arises with this column not being specifed as an INTEGER.
|
|
|
|
|
|
|
|
|
|
// Add the column positions.aircraft.
|
|
|
|
|
$dbh = $common->pdoOpen();
|
2016-05-19 21:02:05 +00:00
|
|
|
|
2016-05-17 17:18:55 +00:00
|
|
|
$sql = "ALTER TABLE ".$settings::db_prefix."positions ADD COLUMN aircraft INTEGER";
|
|
|
|
|
$sth = $dbh->prepare($sql);
|
|
|
|
|
$sth->execute();
|
|
|
|
|
$sth = NULL;
|
|
|
|
|
$dbh = NULL;
|
2016-05-19 21:02:05 +00:00
|
|
|
|
|
|
|
|
// Add FAA database tables.
|
|
|
|
|
$faaMasterSql = 'CREATE TABLE '.$dbPrefix.'faa_master (
|
|
|
|
|
nNumber VARCHAR(5) NOT NULL,
|
|
|
|
|
serialNumber VARCHAR(30) NULL,
|
|
|
|
|
mfrMdlCode VARCHAR(7) NULL,
|
|
|
|
|
engMfrMdl VARCHAR(5) NULL,
|
|
|
|
|
yearMfr VARCHAR(4) NULL,
|
|
|
|
|
typeRegistrant VARCHAR(50) NULL,
|
|
|
|
|
name VARCHAR(33) NULL,
|
|
|
|
|
street VARCHAR(33) NULL,
|
|
|
|
|
street2 VARCHAR(18) NULL,
|
|
|
|
|
city VARCHAR(2) NULL,
|
|
|
|
|
state VARCHAR(10) NULL,
|
|
|
|
|
zipCode VARCHAR(1) NULL,
|
|
|
|
|
region VARCHAR(3) NULL,
|
|
|
|
|
county VARCHAR(2) NULL,
|
|
|
|
|
country VARCHAR(8) NULL,
|
|
|
|
|
lastActionDate VARCHAR(8) NULL,
|
|
|
|
|
certIssueDate VARCHAR(10) NULL,
|
|
|
|
|
certification VARCHAR(1) NULL,
|
|
|
|
|
typeAircraft VARCHAR(2) NULL,
|
|
|
|
|
typeEngine VARCHAR(2) NULL,
|
|
|
|
|
statusCode VARCHAR(8) NULL,
|
|
|
|
|
modeSCode VARCHAR(1) NULL,
|
|
|
|
|
fractOwner VARCHAR(8) NULL,
|
|
|
|
|
airWorthDate VARCHAR(50) NULL,
|
|
|
|
|
otherNames1 VARCHAR(50) NULL,
|
|
|
|
|
otherNames2 VARCHAR(50) NULL,
|
|
|
|
|
otherNames3 VARCHAR(50) NULL,
|
|
|
|
|
otherNames4 VARCHAR(50) NULL,
|
|
|
|
|
otherNames5 VARCHAR(50) NULL,
|
|
|
|
|
experiationDate VARCHAR(8) NULL,
|
|
|
|
|
uniqueId VARCHAR(8) NULL,
|
|
|
|
|
kitMfr VARCHAR(30) NULL,
|
|
|
|
|
kitModel VARCHAR(20) NULL,
|
|
|
|
|
modeSCodeHex VARCHAR(10) NULL);';
|
2016-05-25 21:02:59 +00:00
|
|
|
|
|
|
|
|
$faaAcftrefSql = 'CREATE TABLE '.$dbPrefix.'faa_acftref (
|
|
|
|
|
code VARCHAR(7) NOT NULL,
|
|
|
|
|
mfr VARCHAR(30) NULL,
|
|
|
|
|
model VARCHAR(20) NULL,
|
|
|
|
|
typeAcft VARCHAR(1) NULL,
|
|
|
|
|
typeEng VARCHAR(2) NULL,
|
|
|
|
|
acCat VARCHAR(1) NULL,
|
|
|
|
|
buildCertInd VARCHAR(1) NULL,
|
|
|
|
|
noEng VARCHAR(2) NULL,
|
|
|
|
|
noSeats VARCHAR(3) NULL,
|
|
|
|
|
acWeight VARCHAR(7) NULL,
|
|
|
|
|
speed VARCHAR(4) NULL);';
|
|
|
|
|
|
|
|
|
|
$faaEngineSql = 'CREATE TABLE '.$dbPrefix.'faa_engine (
|
|
|
|
|
code VARCHAR(7) NOT NULL,
|
|
|
|
|
mfr VARCHAR(30) NULL,
|
|
|
|
|
model VARCHAR(20) NULL,
|
|
|
|
|
typeAcft VARCHAR(1) NULL,
|
|
|
|
|
typeEng VARCHAR(2) NULL,
|
|
|
|
|
acCat VARCHAR(1) NULL,
|
|
|
|
|
buildCertInd VARCHAR(1) NULL,
|
|
|
|
|
noEng VARCHAR(2) NULL,
|
|
|
|
|
noSeats VARCHAR(3) NULL,
|
|
|
|
|
acWeight VARCHAR(7) NULL,
|
|
|
|
|
speed VARCHAR(4) NULL);';
|
|
|
|
|
|
2016-05-19 21:02:05 +00:00
|
|
|
$sth = $dbh->prepare($faaMasterSql);
|
|
|
|
|
$sth->execute();
|
|
|
|
|
$sth = NULL;
|
|
|
|
|
|
|
|
|
|
$dbh = NULL;
|
2016-05-17 17:18:55 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if ($settings::db_driver == "mysql") {
|
|
|
|
|
$dbh = $common->pdoOpen();
|
|
|
|
|
$sql = "ALTER TABLE ".$settings::db_prefix."positions ADD COLUMN aircraft BIGINT";
|
|
|
|
|
$sth = $dbh->prepare($sql);
|
|
|
|
|
$sth->execute();
|
|
|
|
|
$sth = NULL;
|
|
|
|
|
$dbh = NULL;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
$common->updateSetting("version", $thisVersion);
|
|
|
|
|
$common->updateSetting("patch", "");
|
|
|
|
|
} catch(Exception $e) {
|
|
|
|
|
$error = TRUE;
|
|
|
|
|
$errorMessage = $e->getMessage();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2016-04-28 17:40:58 +00:00
|
|
|
require_once('../admin/includes/header.inc.php');
|
|
|
|
|
|
|
|
|
|
// Display the instalation wizard.
|
|
|
|
|
if (!$error) {
|
|
|
|
|
?>
|
|
|
|
|
<h1>ADS-B Receiver Portal Updated</h1>
|
|
|
|
|
<p>Your portal has been upgraded to v<?php echo $thisVersion; ?>.</p>
|
|
|
|
|
<?php
|
|
|
|
|
} else {
|
|
|
|
|
?>
|
|
|
|
|
<h1>Error Encountered Upgrading Your ADS-B Receiver Portal</h1>
|
|
|
|
|
<p>There was an error encountered when upgrading your portal to v<?php echo $thisVersion; ?>.</p>
|
|
|
|
|
<?php echo $errorMessage; ?>
|
|
|
|
|
<?php
|
|
|
|
|
}
|
|
|
|
|
require_once('../admin/includes/footer.inc.php');
|
2016-04-23 18:01:11 +00:00
|
|
|
?>
|