mirror of
https://github.com/xevidos/codiad.git
synced 2025-01-03 11:42:12 +01:00
5583db5528
* Added PostgreSQL * Added SQL library * Added show password * Performance Improvements * Updated active files module * Updated cursor tracking * Updated settings module
281 lines
No EOL
5.9 KiB
PHP
Executable file
281 lines
No EOL
5.9 KiB
PHP
Executable file
<?php
|
|
|
|
require_once( __DIR__ . "/class.sql.conversions.php" );
|
|
|
|
class sql {
|
|
|
|
const DB_TYPES = array(
|
|
|
|
"MySQL" => "mysql",
|
|
"PostgresSQL" => "pgsql",
|
|
"SQLite" => "sqlite",
|
|
);
|
|
|
|
public $connection = null;
|
|
public $conversions = null;
|
|
public $identifier_character = null;
|
|
protected static $instance = null;
|
|
|
|
public function __construct() {
|
|
|
|
$this->conversions = new sql_conversions();
|
|
}
|
|
|
|
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 function create_table( $table_name, $fields=array(), $attributes=array() ) {
|
|
|
|
$query = $this->conversions->table( $table_name, $fields, $attributes );
|
|
//$this->query( $query, array(), array(), null, "rowCount" );
|
|
}
|
|
|
|
public function create_default_tables() {
|
|
|
|
$result = $this->create_tables(
|
|
array(
|
|
"active" => array(
|
|
"fields" => array(
|
|
"username" => "string",
|
|
"path" => "text",
|
|
"position" => "string",
|
|
"focused" => "string"
|
|
),
|
|
"attributes" => array(
|
|
"username" => array( "not null", "unique" ),
|
|
"path" => array( "not null", "unique" ),
|
|
"focused" => array( "not null" ),
|
|
)
|
|
),
|
|
"options" => array(
|
|
"fields" => array(
|
|
"id" => "int",
|
|
"name" => "string",
|
|
"value" => "text",
|
|
),
|
|
"attributes" => array(
|
|
"id" => array( "id" ),
|
|
"name" => array( "not null", "unique" ),
|
|
"value" => array( "not null" ),
|
|
)
|
|
),
|
|
"projects" => array(
|
|
"fields" => array(
|
|
"id" => "int",
|
|
"name" => "string",
|
|
"path" => "text",
|
|
"owner" => "string",
|
|
"access" => "string",
|
|
),
|
|
"attributes" => array(
|
|
|
|
"id" => array( "id" ),
|
|
"name" => array( "not null" ),
|
|
"path" => array( "not null", "unique" ),
|
|
"owner" => array( "not null", "unique" ),
|
|
"access" => array(),
|
|
)
|
|
),
|
|
"users" => array(
|
|
"fields" => array(
|
|
"id" => "int",
|
|
"first_name" => "string",
|
|
"last_name" => "string",
|
|
"username" => "string",
|
|
"password" => "text",
|
|
"email" => "string",
|
|
"project" => "string",
|
|
"access" => "string",
|
|
"groups" => "string",
|
|
"token" => "string",
|
|
),
|
|
"attributes" => array(
|
|
"id" => array( "id" ),
|
|
"username" => array( "not null", "unique" ),
|
|
"password" => array( "not null" ),
|
|
"access" => array( "not null" ),
|
|
)
|
|
),
|
|
"user_options" => array(
|
|
"fields" => array(
|
|
"id" => "int",
|
|
"name" => "string",
|
|
"username" => "string",
|
|
"value" => "text",
|
|
),
|
|
"attributes" => array(
|
|
"id" => array( "id" ),
|
|
"name" => array( "not null", "unique" ),
|
|
"username" => array( "not null", "unique" ),
|
|
"value" => array( "not null" ),
|
|
)
|
|
),
|
|
)
|
|
);
|
|
|
|
return $result;
|
|
}
|
|
|
|
public function create_tables( $table ) {
|
|
|
|
/**
|
|
Tables layout
|
|
array(
|
|
|
|
"table_name" => array(
|
|
|
|
"fields" => array(
|
|
|
|
"id" => "int",
|
|
"test_field" => "string"
|
|
),
|
|
"attributes" => array(
|
|
|
|
"id" => array( "id" ),
|
|
"test_field" => array( "not null" ),
|
|
)
|
|
),
|
|
"table2_name" => array(
|
|
|
|
"fields" => array(
|
|
|
|
"id" => "int",
|
|
"test_field" => "string"
|
|
),
|
|
"attributes" => array(
|
|
|
|
"id" => array( "id" ),
|
|
"test_field" => array( "not null" ),
|
|
)
|
|
)
|
|
);
|
|
*/
|
|
|
|
$query = $this->conversions->tables( $table );
|
|
$connection = $this->connect();
|
|
$result = $connection->exec( $query );
|
|
$error = $connection->errorInfo();
|
|
//echo var_dump( $query, $result, $connection->errorInfo() ) . "<br>";
|
|
|
|
if ( $result === false || ! $error[0] == "00000" ) {
|
|
|
|
return $error;
|
|
} else {
|
|
|
|
return true;
|
|
}
|
|
}
|
|
|
|
public static function escape_identifier( $i ) {
|
|
|
|
$i = preg_replace('/[^A-Za-z0-9_]+/', '', $i );
|
|
return $i;
|
|
}
|
|
|
|
public static function is_not_error( $i ) {
|
|
|
|
$return = false;
|
|
$result = json_decode( $i );
|
|
|
|
if ( json_last_error() !== JSON_ERROR_NONE || ( ! $i == NULL && ! $i["status"] == "error" ) ) {
|
|
|
|
$return = true;
|
|
}
|
|
return( $return );
|
|
}
|
|
|
|
public static function get_instance() {
|
|
|
|
// If the single instance hasn't been set, set it now.
|
|
if ( null == self::$instance ) {
|
|
|
|
self::$instance = new self;
|
|
}
|
|
|
|
return self::$instance;
|
|
}
|
|
|
|
public function select( $table, $fields=array(), $where=array() ) {
|
|
|
|
$array = $this->conversions->select( $table, $fields, $where );
|
|
$query = $array[0];
|
|
$bind_vars = $array[1];
|
|
$result = $this->query( $query, $bind_vars, array() );
|
|
//echo var_dump( $query, $bind_vars ) . "<br>";
|
|
return $result;
|
|
}
|
|
|
|
public function update( $table, $fields=array(), $where=array() ) {
|
|
|
|
$query = $this->conversions->update( $table, $fields, $where );
|
|
//echo var_dump( $query ) . "<br>";
|
|
}
|
|
|
|
public function query( $query, $bind_variables, $default, $action='fetchAll', $show_errors=false ) {
|
|
|
|
$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;
|
|
}
|
|
|
|
$error = $statement->errorInfo();
|
|
|
|
if( ! $error[0] == "00000" ) {
|
|
|
|
echo var_export( $error );
|
|
echo var_export( $return );
|
|
$return = $default;
|
|
}
|
|
|
|
if( $show_errors ) {
|
|
|
|
$return = json_encode( $error );
|
|
}
|
|
|
|
//echo var_dump( $error, $return );
|
|
|
|
$this->close();
|
|
return( $return );
|
|
}
|
|
}
|
|
?>
|