2017-12-16 18:17:57 +01:00
< ? php
namespace TclUpdates ;
class SQLiteReader
{
const OTA_ONLY = 0 ;
const FULL_ONLY = 1 ;
const BOTH = 2 ;
private $dbFile ;
private $pdo ;
public function __construct ()
{
2017-12-18 15:02:24 +01:00
$this -> dbFile = __DIR__ . '/../../otadb.db3' ;
2017-12-16 18:17:57 +01:00
$this -> pdo = new \PDO ( 'sqlite:' . $this -> dbFile );
if ( $this -> pdo === false ) {
return false ;
}
$this -> pdo -> exec ( 'PRAGMA foreign_keys=on;' );
}
2017-12-16 19:42:24 +01:00
public function getAllRefs ()
2017-12-16 18:17:57 +01:00
{
$sql = 'SELECT DISTINCT curef FROM updates ORDER BY curef;' ;
$sqlresult = $this -> pdo -> query ( $sql );
$result = array ();
foreach ( $sqlresult as $row ) {
$result [] = $row [ 0 ];
}
return $result ;
}
2017-12-16 19:42:24 +01:00
public function getAllKnownRefs ()
2017-12-16 18:17:57 +01:00
{
2017-12-19 22:36:42 +01:00
$sql = 'SELECT DISTINCT curef FROM devices ORDER BY curef;' ;
2017-12-16 18:17:57 +01:00
$sqlresult = $this -> pdo -> query ( $sql );
$result = array ();
foreach ( $sqlresult as $row ) {
$result [] = $row [ 0 ];
}
return $result ;
}
2017-12-16 19:42:24 +01:00
public function getUnknownRefs ()
2017-12-16 18:17:57 +01:00
{
2017-12-16 19:42:24 +01:00
$knownPrds = $this -> getAllKnownRefs ();
$allPrds = $this -> getAllRefs ();
2017-12-16 18:17:57 +01:00
$unknownPrds = array_diff ( $allPrds , $knownPrds );
return $unknownPrds ;
}
public function getAllVariants ()
{
2017-12-19 22:36:42 +01:00
$sql = 'SELECT f.name, m.name, d.curef, d.name FROM families f LEFT JOIN models m ON f.familyId=m.familyId LEFT JOIN devices d ON m.modelId=d.modelId;' ;
2017-12-16 18:17:57 +01:00
$sqlresult = $this -> pdo -> query ( $sql );
$result = array ();
foreach ( $sqlresult as $row ) {
$family = $row [ 0 ];
$model = $row [ 1 ];
2017-12-19 22:36:42 +01:00
$curef = $row [ 2 ];
2017-12-16 18:17:57 +01:00
$variant = $row [ 3 ];
if ( ! isset ( $result [ $family ])) {
$result [ $family ] = array ();
}
if ( ! isset ( $result [ $family ][ $model ])) {
$result [ $family ][ $model ] = array ();
}
2017-12-19 22:36:42 +01:00
$result [ $family ][ $model ][ $curef ] = $variant ;
2017-12-16 18:17:57 +01:00
}
return $result ;
}
2017-12-17 02:15:59 +01:00
public function getAllVariantsFlat ()
{
2017-12-19 22:36:42 +01:00
$sql = 'SELECT f.name AS family, m.name AS model, d.curef, d.name AS variant FROM families f LEFT JOIN models m ON f.familyId=m.familyId LEFT JOIN devices d ON m.modelId=d.modelId;' ;
2017-12-17 02:15:59 +01:00
$sqlresult = $this -> pdo -> query ( $sql );
$result = array ();
foreach ( $sqlresult -> fetchAll ( \PDO :: FETCH_ASSOC ) as $row ) {
2017-12-19 22:36:42 +01:00
$result [ $row [ 'curef' ]] = $row [ 'family' ] . ' ' . $row [ 'model' ];
2017-12-17 02:15:59 +01:00
if ( strlen ( $row [ 'variant' ]) > 0 ) {
2017-12-19 22:36:42 +01:00
$result [ $row [ 'curef' ]] .= ' (' . $row [ 'variant' ] . ')' ;
2017-12-17 02:15:59 +01:00
}
}
return $result ;
}
2017-12-19 22:36:42 +01:00
public function getAllUpdates ( $curef , $which = self :: BOTH )
2017-12-16 18:17:57 +01:00
{
$sql = 'SELECT * FROM updates u LEFT JOIN files f ON u.file_sha1=f.sha1 WHERE curef=?' ;
if ( $which == self :: OTA_ONLY ) {
$sql .= ' AND fv IS NOT null' ;
} elseif ( $which == self :: FULL_ONLY ) {
$sql .= ' AND fv IS null' ;
}
$stmt = $this -> pdo -> prepare ( $sql );
2017-12-19 22:36:42 +01:00
$ok = $stmt -> execute ( array ( $curef ));
2017-12-16 18:17:57 +01:00
$result = $stmt -> fetchAll ( \PDO :: FETCH_ASSOC );
return $result ;
}
2017-12-19 22:36:42 +01:00
public function getLatestUpdate ( $curef , $which = self :: BOTH )
2017-12-16 18:17:57 +01:00
{
$sql = 'SELECT * FROM updates u LEFT JOIN files f ON u.file_sha1=f.sha1 WHERE curef=?' ;
if ( $which == self :: OTA_ONLY ) {
$sql .= ' AND fv IS NOT null' ;
} elseif ( $which == self :: FULL_ONLY ) {
$sql .= ' AND fv IS null' ;
}
$sql .= ' ORDER BY tv DESC, fv DESC LIMIT 1' ;
$stmt = $this -> pdo -> prepare ( $sql );
2017-12-19 22:36:42 +01:00
$ok = $stmt -> execute ( array ( $curef ));
2017-12-16 18:17:57 +01:00
$result = $stmt -> fetchAll ( \PDO :: FETCH_ASSOC );
2017-12-17 02:15:59 +01:00
if ( count ( $result ) == 1 ) {
$result = reset ( $result );
}
2017-12-16 18:17:57 +01:00
return $result ;
}
2017-12-16 19:42:24 +01:00
2017-12-19 22:36:42 +01:00
public function getAllVersionsForRef ( $curef = null , $which = self :: BOTH )
2017-12-16 19:42:24 +01:00
{
$sql = 'SELECT fv, tv FROM updates u LEFT JOIN files f ON u.file_sha1=f.sha1' ;
2017-12-17 19:33:33 +01:00
$where_arr = array ();
2017-12-16 19:42:24 +01:00
$params_arr = array ();
2017-12-19 22:36:42 +01:00
if ( ! is_null ( $curef )) {
2017-12-17 19:33:33 +01:00
$where_arr [] = 'curef=?' ;
2017-12-19 22:36:42 +01:00
$params_arr [] = $curef ;
2017-12-16 19:42:24 +01:00
}
2017-12-17 19:33:33 +01:00
if ( $which == self :: OTA_ONLY ) {
$where_arr [] = 'fv IS NOT null' ;
} elseif ( $which == self :: FULL_ONLY ) {
$where_arr [] = 'fv IS null' ;
}
if ( count ( $where_arr ) > 0 ) {
$sql .= ' WHERE ' . implode ( ' AND ' , $where_arr );
}
2017-12-16 19:42:24 +01:00
$stmt = $this -> pdo -> prepare ( $sql );
$ok = $stmt -> execute ( $params_arr );
$result = $stmt -> fetchAll ( \PDO :: FETCH_ASSOC );
$version = array ();
foreach ( $result as $row ) {
if ( ! is_null ( $row [ 'fv' ])) {
$version [] = $row [ 'fv' ];
}
$version [] = $row [ 'tv' ];
}
$version = array_unique ( $version );
sort ( $version );
return $version ;
}
public function getAllVersionsForModel ( $model )
{
2017-12-19 22:36:42 +01:00
$sql = 'SELECT fv, tv FROM models m LEFT JOIN devices d ON m.modelId=d.modelId LEFT JOIN updates u ON d.curef=u.curef LEFT JOIN files f ON u.file_sha1=f.sha1 WHERE m.name=?' ;
2017-12-16 19:42:24 +01:00
$stmt = $this -> pdo -> prepare ( $sql );
$ok = $stmt -> execute ( array ( $model ));
$result = $stmt -> fetchAll ( \PDO :: FETCH_ASSOC );
$version = array ();
foreach ( $result as $row ) {
if ( ! is_null ( $row [ 'fv' ])) {
$version [] = $row [ 'fv' ];
}
if ( ! is_null ( $row [ 'tv' ])) {
$version [] = $row [ 'tv' ];
}
}
$version = array_unique ( $version );
sort ( $version );
return $version ;
}
2017-12-16 18:17:57 +01:00
}