2018-10-09 21:30:00 +02:00
|
|
|
<?php
|
|
|
|
|
2019-02-04 22:42:12 +01:00
|
|
|
|
2018-10-09 21:30:00 +02:00
|
|
|
class sql {
|
|
|
|
|
|
|
|
public $connection = null;
|
2019-02-04 22:42:12 +01:00
|
|
|
public $identifier_character = null;
|
|
|
|
protected static $instance = null;
|
2018-10-09 21:30:00 +02:00
|
|
|
|
|
|
|
public function __construct() {
|
|
|
|
|
2019-02-04 22:42:12 +01:00
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
public function close() {
|
|
|
|
|
|
|
|
$this->connection = null;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function connect() {
|
|
|
|
|
|
|
|
if( $this->connection == null ) {
|
|
|
|
|
|
|
|
$host = DBHOST;
|
|
|
|
$dbname = DBNAME;
|
|
|
|
$dbtype = DBTYPE;
|
|
|
|
$username = DBUSER;
|
|
|
|
$password = DBPASS;
|
|
|
|
|
|
|
|
$this->connection = new PDO( "{$dbtype}:host={$host};dbname={$dbname}", $username, $password );
|
|
|
|
}
|
|
|
|
|
|
|
|
return( $this->connection );
|
|
|
|
}
|
|
|
|
|
|
|
|
public static function escape_identifier( $i ) {
|
|
|
|
|
|
|
|
$i = preg_replace('/[^A-Za-z0-9_]+/', '', $i );
|
|
|
|
$i = $i;
|
2018-10-09 21:30:00 +02:00
|
|
|
}
|
|
|
|
|
2019-02-04 22:42:12 +01:00
|
|
|
public static function is_not_error( $i ) {
|
2018-11-10 06:41:28 +01:00
|
|
|
|
|
|
|
$return = false;
|
2019-02-04 22:42:12 +01:00
|
|
|
$result = json_decode( $i );
|
2018-11-10 06:41:28 +01:00
|
|
|
|
2019-02-04 22:42:12 +01:00
|
|
|
if ( json_last_error() !== JSON_ERROR_NONE || ( ! $i == NULL && ! $i["status"] == "error" ) ) {
|
2018-11-10 06:41:28 +01:00
|
|
|
|
|
|
|
$return = true;
|
|
|
|
}
|
|
|
|
return( $return );
|
|
|
|
}
|
|
|
|
|
2019-02-04 22:42:12 +01:00
|
|
|
public static function get_instance() {
|
2018-10-09 21:30:00 +02:00
|
|
|
|
2019-02-04 22:42:12 +01:00
|
|
|
// If the single instance hasn't been set, set it now.
|
|
|
|
if ( null == self::$instance ) {
|
|
|
|
|
|
|
|
self::$instance = new self;
|
|
|
|
}
|
2018-10-09 21:30:00 +02:00
|
|
|
|
2019-02-04 22:42:12 +01:00
|
|
|
return self::$instance;
|
2018-10-09 21:30:00 +02:00
|
|
|
}
|
|
|
|
|
2019-02-04 22:42:12 +01:00
|
|
|
public function query( $query, $bind_variables, $default, $action='fetchAll' ) {
|
2018-10-09 21:30:00 +02:00
|
|
|
|
2019-02-04 22:42:12 +01:00
|
|
|
$connection = $this->connect();
|
|
|
|
$statement = $connection->prepare( $query );
|
|
|
|
$statement->execute( $bind_variables );
|
|
|
|
|
|
|
|
switch( $action ) {
|
|
|
|
|
|
|
|
case( 'rowCount' ):
|
|
|
|
|
|
|
|
$return = $statement->rowCount();
|
|
|
|
break;
|
|
|
|
|
|
|
|
case( 'fetchAll' ):
|
|
|
|
|
|
|
|
$return = $statement->fetchAll( \PDO::FETCH_ASSOC );
|
|
|
|
break;
|
|
|
|
|
|
|
|
case( 'fetchColumn' ):
|
|
|
|
|
|
|
|
$return = $statement->fetchColumn();
|
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
|
|
|
|
|
|
|
$return = $statement->fetchAll( \PDO::FETCH_ASSOC );
|
|
|
|
break;
|
|
|
|
}
|
2018-10-09 21:30:00 +02:00
|
|
|
|
2019-02-04 22:42:12 +01:00
|
|
|
$error = $statement->errorInfo();
|
|
|
|
if( ! $error[0] == "00000" ) {
|
2018-10-09 21:30:00 +02:00
|
|
|
|
Changed $path to __DIR__ for config location, Updated auto reload variables, Removed unload listener for auto reload, Changed project default to array so that if no projects exist the program does not crash, Updated autosave to use let instead of vars, Fixed capitalization for sideExpanded variable, Added try catch to pdo initialization on install, Added more error checks on install, Removed password function on install query, Changed default settings array, Added loading div to user delete, Updated queries that threw errors when a default value was zero, Added blank username and password check,
2019-02-09 22:14:27 +01:00
|
|
|
echo var_export( $error );
|
|
|
|
echo var_export( $return );
|
2019-02-04 22:42:12 +01:00
|
|
|
$return = $default;
|
2018-10-09 21:30:00 +02:00
|
|
|
}
|
|
|
|
|
2019-02-04 22:42:12 +01:00
|
|
|
$this->close();
|
2018-10-09 21:30:00 +02:00
|
|
|
return( $return );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
?>
|