kopia lustrzana https://github.com/jprochazka/adsb-receiver
				
				
				
			
		
			
				
	
	
		
			209 wiersze
		
	
	
		
			10 KiB
		
	
	
	
		
			PHP
		
	
	
			
		
		
	
	
			209 wiersze
		
	
	
		
			10 KiB
		
	
	
	
		
			PHP
		
	
	
| <?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.                                                                       //
 | |
|     /////////////////////////////////////////////////////////////////////////////////////
 | |
| 
 | |
|     class links {
 | |
| 
 | |
|         function getAllLinks() {
 | |
|             require_once($_SERVER['DOCUMENT_ROOT'].DIRECTORY_SEPARATOR."classes".DIRECTORY_SEPARATOR."settings.class.php");
 | |
|             $settings = new settings();
 | |
| 
 | |
|             if ($settings::db_driver == "xml") {
 | |
|                 // XML
 | |
|                 $links = array();
 | |
|                 $xmlLinks = simplexml_load_file($_SERVER['DOCUMENT_ROOT'].DIRECTORY_SEPARATOR."data".DIRECTORY_SEPARATOR."links.xml");
 | |
|                 foreach ($xmlLinks as $xmlLink) {
 | |
|                     $links[] = array("name"=>$xmlLink->name, "address"=>$xmlLink->address);
 | |
|                 }
 | |
|             } else {
 | |
|                 // PDO
 | |
|                 require_once($_SERVER['DOCUMENT_ROOT'].DIRECTORY_SEPARATOR."classes".DIRECTORY_SEPARATOR."common.class.php");
 | |
|                 $common = new common();
 | |
| 
 | |
|                 $dbh = $common->pdoOpen();
 | |
|                 $sql = "SELECT name, address FROM ".$settings::db_prefix."links ORDER BY name";
 | |
|                 $sth = $dbh->prepare($sql);
 | |
|                 $sth->execute();
 | |
|                 $links = $sth->fetchAll(PDO::FETCH_ASSOC);
 | |
|                 $sth = NULL;
 | |
|                 $dbh = NULL;
 | |
|             }
 | |
|             return $links;
 | |
|         }
 | |
| 
 | |
|         function getLinkByName($name) {
 | |
|             require_once($_SERVER['DOCUMENT_ROOT'].DIRECTORY_SEPARATOR."classes".DIRECTORY_SEPARATOR."settings.class.php");
 | |
|             $settings = new settings();
 | |
| 
 | |
|             if ($settings::db_driver == "xml") {
 | |
|                 // XML
 | |
|                 $links = simplexml_load_file($_SERVER['DOCUMENT_ROOT'].DIRECTORY_SEPARATOR."data".DIRECTORY_SEPARATOR."links.xml");
 | |
|                 foreach ($links as $link) {
 | |
|                     if (strtolower($link->name) == strtolower($name)) {
 | |
|                         return (array)$link;
 | |
|                     }
 | |
|                 }
 | |
|             } else {
 | |
|                 // PDO
 | |
|                 require_once($_SERVER['DOCUMENT_ROOT'].DIRECTORY_SEPARATOR."classes".DIRECTORY_SEPARATOR."common.class.php");
 | |
|                 $common = new common();
 | |
| 
 | |
|                 $dbh = $common->pdoOpen();
 | |
|                 $sql = "SELECT * FROM ".$settings::db_prefix."links WHERE name = :name";
 | |
|                 $sth = $dbh->prepare($sql);
 | |
|                 $sth->bindParam(':name', $name, PDO::PARAM_STR, 100);
 | |
|                 $sth->execute();
 | |
|                 $link = $sth->fetch(PDO::FETCH_ASSOC);
 | |
|                 $sth = NULL;
 | |
|                 $dbh = NULL;
 | |
|                 return $link;
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         function nameExists($newName) {
 | |
|             require_once($_SERVER['DOCUMENT_ROOT'].DIRECTORY_SEPARATOR."classes".DIRECTORY_SEPARATOR."settings.class.php");
 | |
|             $settings = new settings();
 | |
| 
 | |
|             if ($settings::db_driver == "xml") {
 | |
|                 // XML
 | |
|                 $links = simplexml_load_file($_SERVER['DOCUMENT_ROOT'].DIRECTORY_SEPARATOR."data".DIRECTORY_SEPARATOR."links.xml");
 | |
|                 foreach ($links as $link) {
 | |
|                     if ($link->name == $name) {
 | |
|                         return TRUE;
 | |
|                     }
 | |
|                 }
 | |
|                 return FALSE;
 | |
|             } else {
 | |
|                 // PDO
 | |
|                 require_once($_SERVER['DOCUMENT_ROOT'].DIRECTORY_SEPARATOR."classes".DIRECTORY_SEPARATOR."common.class.php");
 | |
|                 $common = new common();
 | |
| 
 | |
|                 $dbh = $common->pdoOpen();
 | |
|                 $sql = "SELECT COUNT(*) FROM ".$settings::db_prefix."links WHERE name = :name";
 | |
|                 $sth = $dbh->prepare($sql);
 | |
|                 $sth->bindParam(':name', $name, PDO::PARAM_STR, 100);
 | |
|                 $sth->execute();
 | |
|                 $count = $sth->fetchColumn();
 | |
|                 $sth = NULL;
 | |
|                 $dbh = NULL;
 | |
| 
 | |
|                 if ($count > 0)
 | |
|                     return TRUE;
 | |
|                 return FALSE;
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         function addLink($name, $address) {
 | |
|             require_once($_SERVER['DOCUMENT_ROOT'].DIRECTORY_SEPARATOR."classes".DIRECTORY_SEPARATOR."settings.class.php");
 | |
|             $settings = new settings();
 | |
| 
 | |
|             if ($settings::db_driver == "xml") {
 | |
|                 // XML
 | |
|                 $links = simplexml_load_file($_SERVER['DOCUMENT_ROOT'].DIRECTORY_SEPARATOR."data".DIRECTORY_SEPARATOR."links.xml");
 | |
|                 $link = $links->addChild('link', '');
 | |
|                 $link->addChild('name', $name);
 | |
|                 $link->addChild('address', $address);
 | |
|                 $dom = dom_import_simplexml($links)->ownerDocument;
 | |
|                 $dom->formatOutput = TRUE;
 | |
|                 file_put_contents($_SERVER['DOCUMENT_ROOT'].DIRECTORY_SEPARATOR."data".DIRECTORY_SEPARATOR."links.xml", $dom->saveXML());
 | |
|             } else {
 | |
|                 // PDO
 | |
|                 require_once($_SERVER['DOCUMENT_ROOT'].DIRECTORY_SEPARATOR."classes".DIRECTORY_SEPARATOR."common.class.php");
 | |
|                 $common = new common();
 | |
| 
 | |
|                 $dbh = $common->pdoOpen();
 | |
|                 $sql = "INSERT INTO ".$settings::db_prefix."links (name, address) VALUES (:name, :address)";
 | |
|                 $sth = $dbh->prepare($sql);
 | |
|                 $sth->bindParam(':name', $name, PDO::PARAM_STR, 100);
 | |
|                 $sth->bindParam(':address', $address, PDO::PARAM_STR, 250);
 | |
|                 $sth->execute();
 | |
|                 $sth = NULL;
 | |
|                 $dbh = NULL;
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         function editLinkByName($originalName, $name, $address) {
 | |
|             require_once($_SERVER['DOCUMENT_ROOT'].DIRECTORY_SEPARATOR."classes".DIRECTORY_SEPARATOR."settings.class.php");
 | |
|             $settings = new settings();
 | |
| 
 | |
|             if ($settings::db_driver == "xml") {
 | |
|                 // XML
 | |
|                 $links = simplexml_load_file($_SERVER['DOCUMENT_ROOT'].DIRECTORY_SEPARATOR."data".DIRECTORY_SEPARATOR."links.xml");
 | |
|                 foreach ($links->xpath("link[name='".$originalName."']") as $link) {
 | |
|                     $link->name = $name;
 | |
|                     $link->address = $address;
 | |
|                 }
 | |
|                 file_put_contents($_SERVER['DOCUMENT_ROOT'].DIRECTORY_SEPARATOR."data".DIRECTORY_SEPARATOR."links.xml", $links->asXML());
 | |
|             } else {
 | |
|                 // PDO
 | |
|                 require_once($_SERVER['DOCUMENT_ROOT'].DIRECTORY_SEPARATOR."classes".DIRECTORY_SEPARATOR."common.class.php");
 | |
|                 $common = new common();
 | |
| 
 | |
|                 $dbh = $common->pdoOpen();
 | |
|                 $sql = "UPDATE ".$settings::db_prefix."links SET name = :name, address = :address WHERE name = :originalName";
 | |
|                 $sth = $dbh->prepare($sql);
 | |
|                 $sth->bindParam(':originalName', $originalName, PDO::PARAM_STR, 100);
 | |
|                 $sth->bindParam(':name', $name, PDO::PARAM_STR, 100);
 | |
|                 $sth->bindParam(':address', $address, PDO::PARAM_STR, 250);
 | |
|                 $sth->execute();
 | |
|                 $sth = NULL;
 | |
|                 $dbh = NULL;
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         function deleteLinkByName($name) {
 | |
|             require_once($_SERVER['DOCUMENT_ROOT'].DIRECTORY_SEPARATOR."classes".DIRECTORY_SEPARATOR."settings.class.php");
 | |
|             $settings = new settings();
 | |
| 
 | |
|             if ($settings::db_driver == "xml") {
 | |
|                 $links = simplexml_load_file($_SERVER['DOCUMENT_ROOT'].DIRECTORY_SEPARATOR."data".DIRECTORY_SEPARATOR."links.xml");
 | |
|                 foreach($links as $link) {
 | |
|                     if($link->name == $name) {
 | |
|                         $dom = dom_import_simplexml($link);
 | |
|                         $dom->parentNode->removeChild($dom);
 | |
|                     }
 | |
|                 }
 | |
|                 file_put_contents($_SERVER['DOCUMENT_ROOT'].DIRECTORY_SEPARATOR."data".DIRECTORY_SEPARATOR."links.xml", $links->asXml());
 | |
|             } else {
 | |
|                 // PDO
 | |
|                 require_once($_SERVER['DOCUMENT_ROOT'].DIRECTORY_SEPARATOR."classes".DIRECTORY_SEPARATOR."common.class.php");
 | |
|                 $common = new common();
 | |
| 
 | |
|                 $dbh = $common->pdoOpen();
 | |
|                 $sql = "DELETE FROM ".$settings::db_prefix."links WHERE name = :name";
 | |
|                 $sth = $dbh->prepare($sql);
 | |
|                 $sth->bindParam(':name', $name, PDO::PARAM_STR, 100);
 | |
|                 $sth->execute();
 | |
|                 $sth = NULL;
 | |
|                 $dbh = NULL;
 | |
|             }
 | |
|         }
 | |
|     }
 | |
| ?>
 |