2016-10-02 21:07:17 +00:00
< ? php
2016-10-06 02:08:43 +00:00
declare ( strict_types = 1 );
2016-10-02 21:07:17 +00:00
namespace JKingWeb\NewsSync ;
class Database {
2016-10-15 13:45:23 +00:00
const SCHEMA_VERSION = 1 ;
2016-10-17 20:49:39 +00:00
const FORMAT_TS = " Y-m-d h:i:s " ;
const FORMAT_DATE = " Y-m-d " ;
const FORMAT_TIME = " h:i:s " ;
2016-10-15 13:45:23 +00:00
2016-10-17 20:49:39 +00:00
protected $data ;
2016-10-15 13:45:23 +00:00
protected $db ;
2016-10-17 20:49:39 +00:00
protected function cleanName ( string $name ) : string {
2016-10-15 13:45:23 +00:00
return ( string ) preg_filter ( " [^0-9a-zA-Z_ \ .] " , " " , $name );
}
2016-10-02 21:07:17 +00:00
2016-10-17 20:49:39 +00:00
public function __construct ( RuntimeData $data ) {
$this -> data = $data ;
$driver = $data -> conf -> dbClass ;
$this -> db = $driver :: create ( $data , INSTALL );
2016-10-15 13:45:23 +00:00
$ver = $this -> db -> schemaVersion ();
2016-10-17 20:49:39 +00:00
if ( ! INSTALL && $ver < self :: SCHEMA_VERSION ) {
$this -> db -> update ( self :: SCHEMA_VERSION );
2016-10-15 13:45:23 +00:00
}
2016-10-02 21:07:17 +00:00
}
2016-10-06 02:08:43 +00:00
static public function listDrivers () : array {
$sep = \DIRECTORY_SEPARATOR ;
$path = __DIR__ . $sep . " Db " . $sep ;
$classes = [];
foreach ( glob ( $path . " Driver?*.php " ) as $file ) {
$name = basename ( $file , " .php " );
if ( substr ( $name , - 3 ) != " PDO " ) {
$name = NS_BASE . " Db \\ $name " ;
if ( class_exists ( $name )) {
$classes [ $name ] = $name :: driverName ();
}
}
}
return $classes ;
}
public function schemaVersion () : int {
2016-10-15 13:45:23 +00:00
return $this -> db -> schemaVersion ();
}
2016-10-18 15:42:21 +00:00
public function dbUpdate () : bool {
if ( $this -> db -> schemaVersion () < self :: SCHEMA_VERSION ) return $this -> db -> update ( self :: SCHEMA_VERSION );
return false ;
}
public function settingGet ( string $key ) {
2016-10-17 20:49:39 +00:00
$row = $this -> db -> prepare ( " SELECT value, type from newssync_settings where key = ? " , " str " ) -> run ( $key ) -> get ();
if ( ! $row ) return null ;
switch ( $row [ 'type' ]) {
case " int " : return ( int ) $row [ 'value' ];
case " numeric " : return ( float ) $row [ 'value' ];
case " text " : return $row [ 'value' ];
case " json " : return json_decode ( $row [ 'value' ]);
case " timestamp " : return date_create_from_format ( " ! " . self :: FORMAT_TS , $row [ 'value' ], new DateTimeZone ( " UTC " ));
case " date " : return date_create_from_format ( " ! " . self :: FORMAT_DATE , $row [ 'value' ], new DateTimeZone ( " UTC " ));
case " time " : return date_create_from_format ( " ! " . self :: FORMAT_TIME , $row [ 'value' ], new DateTimeZone ( " UTC " ));
case " bool " : return ( bool ) $row [ 'value' ];
case " null " : return null ;
default : return $row [ 'value' ];
}
}
2016-10-18 15:42:21 +00:00
public function settingSet ( string $key , $in , string $type = null ) : bool {
2016-10-17 20:49:39 +00:00
if ( ! $type ) {
switch ( gettype ( $in )) {
case " boolean " : $type = " bool " ; break ;
case " integer " : $type = " int " ; break ;
case " double " : $type = " numeric " ; break ;
case " string " :
case " array " : $type = " json " ; break ;
case " resource " :
case " unknown type " :
case " NULL " : $type = " null " ; break ;
case " object " :
if ( $in instanceof DateTimeInterface ) {
$type = " timestamp " ;
} else {
$type = " text " ;
}
break ;
default : $type = 'null' ; break ;
}
}
$type = strtolower ( $type );
switch ( $type ) {
case " integer " :
$type = " int " ;
case " int " :
$value =& $in ;
break ;
case " float " :
case " double " :
case " real " :
$type = " numeric " ;
case " numeric " :
$value =& $in ;
break ;
case " str " :
case " string " :
$type = " text " ;
case " text " :
$value =& $in ;
break ;
case " json " :
if ( is_array ( $in ) || is_object ( $in )) {
$value = json_encode ( $in );
} else {
$value =& $in ;
}
break ;
case " datetime " :
$type = " timestamp " ;
case " timestamp " :
if ( $in instanceof DateTimeInterface ) {
$value = gmdate ( self :: FORMAT_TS , $in -> format ( " U " ));
} else if ( is_numeric ( $in )) {
$value = gmdate ( self :: FORMAT_TS , $in );
} else {
$value = gmdate ( self :: FORMAT_TS , gmstrftime ( $in ));
}
break ;
case " date " :
if ( $in instanceof DateTimeInterface ) {
$value = gmdate ( self :: FORMAT_DATE , $in -> format ( " U " ));
} else if ( is_numeric ( $in )) {
$value = gmdate ( self :: FORMAT_DATE , $in );
} else {
$value = gmdate ( self :: FORMAT_DATE , gmstrftime ( $in ));
}
break ;
case " time " :
if ( $in instanceof DateTimeInterface ) {
$value = gmdate ( self :: FORMAT_TIME , $in -> format ( " U " ));
} else if ( is_numeric ( $in )) {
$value = gmdate ( self :: FORMAT_TIME , $in );
} else {
$value = gmdate ( self :: FORMAT_TIME , gmstrftime ( $in ));
}
break ;
case " boolean " :
case " bit " :
$type = " bool " ;
case " bool " :
$value = ( int ) $in ;
break ;
case " null " :
$value = null ;
break ;
default :
$type = " text " ;
$value =& $in ;
break ;
}
$this -> db -> prepare ( " REPLACE INTO newssync_settings(key,value,type) values(?,?,?) " , " str " , (( $type == " null " ) ? " null " : " str " ), " str " ) -> run ( $key , $value , " text " );
}
2016-10-18 15:42:21 +00:00
public function settingClear ( string $key ) : bool {
2016-10-17 20:49:39 +00:00
$this -> db -> prepare ( " DELETE from newssync_settings where key = ? " , " str " ) -> run ( $key );
return true ;
}
2016-10-15 13:45:23 +00:00
public function userAdd ( string $username , string $password = null , bool $admin = false ) : string {
$this -> db -> prepare ( " INSERT INTO newssync_users(id,password,admin) values(?,?,?) " , " str " , " str " , " bool " ) -> run ( $username , $password , $admin );
return $username ;
}
2016-10-18 15:42:21 +00:00
2016-10-15 13:45:23 +00:00
public function subscriptionAdd ( string $user , string $url , string $fetchUser = null , string $fetchPassword = null ) : int {
$this -> db -> begin ();
2016-10-18 15:42:21 +00:00
$qFeed = $this -> db -> prepare ( " SELECT id from newssync_feeds where url is ? and username is ? and password is ? " , " str " , " str " , " str " );
2016-10-15 13:45:23 +00:00
if ( is_null ( $id = $qFeed -> run ( $url , $fetchUser , $fetchPassword ) -> getSingle ())) {
$this -> db -> prepare ( " INSERT INTO newssync_feeds(url,username,password) values(?,?,?) " , " str " , " str " , " str " ) -> run ( $url , $fetchUser , $fetchPassword );
$id = $qFeed -> run ( $url , $fetchUser , $fetchPassword ) -> getSingle ();
2016-10-18 15:42:21 +00:00
var_export ( $id );
2016-10-15 13:45:23 +00:00
}
$this -> db -> prepare ( " INSERT INTO newssync_subscriptions(owner,feed) values(?,?) " , " str " , " int " ) -> run ( $user , $id );
$this -> db -> commit ();
return 0 ;
2016-10-02 21:07:17 +00:00
}
2016-10-15 13:45:23 +00:00
2016-10-02 21:07:17 +00:00
}