mirror of
https://github.com/xevidos/codiad.git
synced 2025-01-08 22:11:55 +01:00
Continued work on functions needed during install process
This commit is contained in:
parent
9530cd2580
commit
74bba55567
10 changed files with 362 additions and 26 deletions
|
@ -22,9 +22,16 @@ class Data {
|
||||||
);
|
);
|
||||||
|
|
||||||
public $connection = null;
|
public $connection = null;
|
||||||
|
public $fss = null;
|
||||||
protected static $instance = null;
|
protected static $instance = null;
|
||||||
|
|
||||||
function __construct() {}
|
function __construct() {
|
||||||
|
|
||||||
|
if( DBTYPE === "filesystem" ) {
|
||||||
|
|
||||||
|
$this->fss = FileSystemStorage::get_instance();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public function close() {
|
public function close() {
|
||||||
|
|
||||||
|
@ -140,8 +147,57 @@ class Data {
|
||||||
|
|
||||||
if( is_callable( $query ) ) {
|
if( is_callable( $query ) ) {
|
||||||
|
|
||||||
|
$return = call_user_func( $query );
|
||||||
|
} else {
|
||||||
|
|
||||||
|
try {
|
||||||
|
|
||||||
|
$connection = $this->connect();
|
||||||
|
$statement = $connection->prepare( $query );
|
||||||
|
$statement->execute( $bind_variables );
|
||||||
|
|
||||||
|
switch( $action ) {
|
||||||
|
|
||||||
|
case( 'rowCount' ):
|
||||||
|
|
||||||
|
$return = $statement->rowCount();
|
||||||
|
break;
|
||||||
|
|
||||||
|
case( 'fetch' ):
|
||||||
|
|
||||||
|
$return = $statement->fetch( \PDO::FETCH_ASSOC );
|
||||||
|
break;
|
||||||
|
|
||||||
|
case( 'fetchAll' ):
|
||||||
|
|
||||||
|
$return = $statement->fetchAll( \PDO::FETCH_ASSOC );
|
||||||
|
break;
|
||||||
|
|
||||||
|
case( 'fetchColumn' ):
|
||||||
|
|
||||||
|
$return = $statement->fetchColumn();
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
|
||||||
|
$return = $statement->fetchAll( \PDO::FETCH_ASSOC );
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
} catch( Throwable $error ) {
|
||||||
|
|
||||||
|
$return = $default;
|
||||||
|
|
||||||
|
if( $errors == "message" ) {
|
||||||
|
|
||||||
|
$return = json_encode( array( $error->getMessage() ) );
|
||||||
|
} elseif( $errors == "exception" ) {
|
||||||
|
|
||||||
|
throw $error;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
$this->close();
|
||||||
}
|
}
|
||||||
|
return $return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -2,6 +2,9 @@
|
||||||
|
|
||||||
require_once( "filesystemstorage/class.data.php" );
|
require_once( "filesystemstorage/class.data.php" );
|
||||||
|
|
||||||
|
|
||||||
|
require_once( "filesystemstorage/class.user.php" );
|
||||||
|
|
||||||
class FileSystemStorage {
|
class FileSystemStorage {
|
||||||
|
|
||||||
protected static $instance = null;
|
protected static $instance = null;
|
||||||
|
@ -83,7 +86,9 @@ class FileSystemStorage {
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
$return["data"] = $i->get_data( $fields );
|
$return["status"] = "success";
|
||||||
|
$return["message"] = "";
|
||||||
|
$return["value"] = $i->get_data( $fields );
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
|
@ -339,16 +344,16 @@ class FileSystemStorage {
|
||||||
|
|
||||||
if( is_callable( $update ) ) {
|
if( is_callable( $update ) ) {
|
||||||
|
|
||||||
|
$data = file_get_contents( $path );
|
||||||
$handle = fopen( $path, "w+" );
|
$handle = fopen( $path, "w+" );
|
||||||
|
|
||||||
if( flock( $handle, LOCK_EX ) ) {
|
if( flock( $handle, LOCK_EX ) ) {
|
||||||
|
|
||||||
$data = fread( $handle, filesize( $path ) );
|
|
||||||
$c = unserialize( $data );
|
$c = unserialize( $data );
|
||||||
|
|
||||||
try {
|
try {
|
||||||
|
|
||||||
$c->set_data( $update( $c->get_data() ) );
|
$c->set_data( $update( $c->headers, $c->get_data() ) );
|
||||||
} catch( Throwable $e ) {
|
} catch( Throwable $e ) {
|
||||||
|
|
||||||
$return["status"] = "error";
|
$return["status"] = "error";
|
||||||
|
|
|
@ -40,7 +40,7 @@ class Data {
|
||||||
//Add checks to validate Data with headers
|
//Add checks to validate Data with headers
|
||||||
//$this->data = $data;
|
//$this->data = $data;
|
||||||
$return = \Common::get_default_return();
|
$return = \Common::get_default_return();
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function set_meta( $meta, $uniques = array() ) {
|
public function set_meta( $meta, $uniques = array() ) {
|
||||||
|
|
56
components/data/filesystemstorage/class.user.php
Normal file
56
components/data/filesystemstorage/class.user.php
Normal file
|
@ -0,0 +1,56 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace FileSystemStorage;
|
||||||
|
|
||||||
|
class User {
|
||||||
|
|
||||||
|
protected static $instance = null;
|
||||||
|
|
||||||
|
function __construct() {}
|
||||||
|
|
||||||
|
public static function create_user( $user ) {
|
||||||
|
|
||||||
|
global $data;
|
||||||
|
$result = $data->fss->update_data( "users", self::create_user_call );
|
||||||
|
echo var_dump( $result );
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static function create_user_callback( $headers, $d ) {
|
||||||
|
|
||||||
|
$new = array();
|
||||||
|
foreach( $headers as $h ) {
|
||||||
|
|
||||||
|
if( isset( $user[$h] ) ) {
|
||||||
|
|
||||||
|
$new[$h] = $user[$h];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
$d[] = $data;
|
||||||
|
return $d;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return an instance of this class.
|
||||||
|
*
|
||||||
|
* @since ${current_version}
|
||||||
|
* @return object A single instance of this class.
|
||||||
|
*/
|
||||||
|
public static function get_instance() {
|
||||||
|
|
||||||
|
if( null == self::$instance ) {
|
||||||
|
|
||||||
|
self::$instance = new self;
|
||||||
|
}
|
||||||
|
|
||||||
|
return self::$instance;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static function get_users() {
|
||||||
|
|
||||||
|
global $data;
|
||||||
|
return $data->fss->get_data( "users" );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
?>
|
|
@ -63,23 +63,19 @@ class Initialize {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->register_constants();
|
|
||||||
$this->register_globals();
|
|
||||||
|
|
||||||
$bases = self::BASES;
|
$bases = self::BASES;
|
||||||
|
|
||||||
|
$this->register_constants();
|
||||||
|
|
||||||
foreach( $bases as $base ) {
|
foreach( $bases as $base ) {
|
||||||
|
|
||||||
$name = strtolower( $base );
|
$name = strtolower( $base );
|
||||||
$class = ucfirst( $base );
|
$class = ucfirst( $base );
|
||||||
require_once( COMPONENTS . "/$name/class.$name.php" );
|
require_once( COMPONENTS . "/$name/class.$name.php" );
|
||||||
|
|
||||||
if( class_exists( $class ) ) {
|
|
||||||
|
|
||||||
$class::get_instance();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$this->register_globals();
|
||||||
|
|
||||||
if( ! $installing ) {
|
if( ! $installing ) {
|
||||||
|
|
||||||
$this->check_extensions();
|
$this->check_extensions();
|
||||||
|
@ -219,7 +215,7 @@ class Initialize {
|
||||||
|
|
||||||
global $data;
|
global $data;
|
||||||
|
|
||||||
$data = null;
|
$data = Data::get_instance();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -25,8 +25,9 @@ class Options {
|
||||||
|
|
||||||
public function get_option( $option ) {
|
public function get_option( $option ) {
|
||||||
|
|
||||||
|
global $data;
|
||||||
$query = array(
|
$query = array(
|
||||||
"*" => "SELECT * FROM user_options WHERE name=? AND user=?",
|
"default" => "SELECT * FROM user_options WHERE name=? AND user=?",
|
||||||
"pgsql" => 'SELECT value FROM user_options WHERE name=? AND "user"=?;',
|
"pgsql" => 'SELECT value FROM user_options WHERE name=? AND "user"=?;',
|
||||||
"filesystem" => array(
|
"filesystem" => array(
|
||||||
"options",
|
"options",
|
||||||
|
@ -34,8 +35,7 @@ class Options {
|
||||||
$option
|
$option
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
$Data = Data::get_instance();
|
return $data->query( $query );
|
||||||
return $Data->query( $query );
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public function update_option( $option, $value ) {}
|
public function update_option( $option, $value ) {}
|
||||||
|
|
24
components/permissions/class.permissions.php
Normal file
24
components/permissions/class.permissions.php
Normal file
|
@ -0,0 +1,24 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
class Permissions {
|
||||||
|
|
||||||
|
const LEVELS = array(
|
||||||
|
|
||||||
|
"none" => 0,
|
||||||
|
"read" => 1,
|
||||||
|
"write" => 2,
|
||||||
|
"create" => 4,
|
||||||
|
"delete" => 8,
|
||||||
|
"manager" => 16,
|
||||||
|
"owner" => 32,
|
||||||
|
"admin" => 64,
|
||||||
|
);
|
||||||
|
|
||||||
|
const SYSTEM_LEVELS = array(
|
||||||
|
|
||||||
|
"user" => 32,
|
||||||
|
"admin" => 64,
|
||||||
|
);
|
||||||
|
|
||||||
|
function __construct() {}
|
||||||
|
}
|
98
components/user/class.user.php
Normal file
98
components/user/class.user.php
Normal file
|
@ -0,0 +1,98 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
class User {
|
||||||
|
|
||||||
|
protected static $instance = null;
|
||||||
|
|
||||||
|
function __construct() {}
|
||||||
|
|
||||||
|
function create_user( $user ) {
|
||||||
|
|
||||||
|
global $data;
|
||||||
|
$pass = true;
|
||||||
|
$return = Common::get_default_return();
|
||||||
|
$requirements = array(
|
||||||
|
"username",
|
||||||
|
"password",
|
||||||
|
"password1",
|
||||||
|
"access",
|
||||||
|
);
|
||||||
|
|
||||||
|
foreach( $requirements as $r ) {
|
||||||
|
|
||||||
|
if( ! isset( $user[$r] ) ) {
|
||||||
|
|
||||||
|
$return["status"] = "error";
|
||||||
|
$return["message"] = "Error, $r is required but was not provided.";
|
||||||
|
$pass = false;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if( $pass && $user["password"] !== $user["password1"] ) {
|
||||||
|
|
||||||
|
$return["status"] = "error";
|
||||||
|
$return["message"] = "Error, the passwords provided do not match.";
|
||||||
|
$pass = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if( $pass ) {
|
||||||
|
|
||||||
|
$query = array(
|
||||||
|
"default" => "INSERT INTO users( username, password, access, project ) VALUES ( ?, ?, ?, ? );",
|
||||||
|
"filesystem" => array( "FileSystemStorage\\User", "create_user", $user ),
|
||||||
|
);
|
||||||
|
$bind_vars = array(
|
||||||
|
$user["username"],
|
||||||
|
$user["password"],
|
||||||
|
$user["access"],
|
||||||
|
null,
|
||||||
|
);
|
||||||
|
$return = $data->query( $query, array(), array() );
|
||||||
|
}
|
||||||
|
return $return;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return an instance of this class.
|
||||||
|
*
|
||||||
|
* @since ${current_version}
|
||||||
|
* @return object A single instance of this class.
|
||||||
|
*/
|
||||||
|
public static function get_instance() {
|
||||||
|
|
||||||
|
if( null == self::$instance ) {
|
||||||
|
|
||||||
|
self::$instance = new self;
|
||||||
|
}
|
||||||
|
|
||||||
|
return self::$instance;
|
||||||
|
}
|
||||||
|
|
||||||
|
function get_user( $identifier ) {
|
||||||
|
|
||||||
|
if( is_int( ) ) {
|
||||||
|
|
||||||
|
} else {
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function get_user_by_id( $id ) {}
|
||||||
|
|
||||||
|
function get_user_by_username( $username ) {}
|
||||||
|
|
||||||
|
function get_users() {
|
||||||
|
|
||||||
|
global $data;
|
||||||
|
|
||||||
|
$query = array(
|
||||||
|
"default" => "SELECT * FROM users",
|
||||||
|
"filesystem" => array( "FileSystemStorage\\User", "get_users" ),
|
||||||
|
);
|
||||||
|
return $data->query( $query, array(), array() );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
?>
|
|
@ -1,5 +1,5 @@
|
||||||
<?php
|
<?php
|
||||||
|
define( 'DBTYPE', "filesystem" );
|
||||||
ini_set( 'display_errors', 1 );
|
ini_set( 'display_errors', 1 );
|
||||||
ini_set( 'display_startup_errors', 1 );
|
ini_set( 'display_startup_errors', 1 );
|
||||||
error_reporting( E_ALL );
|
error_reporting( E_ALL );
|
||||||
|
@ -8,6 +8,22 @@ require_once( __DIR__ . "/../components/initialize/class.initialize.php" );
|
||||||
|
|
||||||
Initialize::get_instance();
|
Initialize::get_instance();
|
||||||
|
|
||||||
|
require_once( __DIR__ . "/../components/user/class.user.php" );
|
||||||
|
|
||||||
|
//$data->install( "filesystem" );
|
||||||
|
|
||||||
|
$u = User::get_instance();
|
||||||
|
|
||||||
|
echo var_dump( $u->create_user( array(
|
||||||
|
|
||||||
|
"username" => "test",
|
||||||
|
"password" => "test",
|
||||||
|
"password1" => "test",
|
||||||
|
"access" => 0,
|
||||||
|
) ) );
|
||||||
|
|
||||||
|
exit();
|
||||||
|
|
||||||
$checks_html = "";
|
$checks_html = "";
|
||||||
$check_paths = Initialize::PATHS;
|
$check_paths = Initialize::PATHS;
|
||||||
$extensions = Initialize::EXTENSIONS;
|
$extensions = Initialize::EXTENSIONS;
|
||||||
|
@ -110,6 +126,19 @@ if( isset( $_POST["storage"] ) ) {
|
||||||
exit( json_encode( $return ) );
|
exit( json_encode( $return ) );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if( isset( $_POST["username"] ) ) {
|
||||||
|
|
||||||
|
$pass = true;
|
||||||
|
$return = Common::get_default_return();
|
||||||
|
$User = User::get_instance();
|
||||||
|
|
||||||
|
if( $pass ) {
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
exit( json_encode( $return ) );
|
||||||
|
}
|
||||||
|
|
||||||
$components = scandir( COMPONENTS );
|
$components = scandir( COMPONENTS );
|
||||||
unset( $components["."], $components[".."] );
|
unset( $components["."], $components[".."] );
|
||||||
|
|
||||||
|
|
|
@ -38,7 +38,7 @@
|
||||||
|
|
||||||
init: function() {
|
init: function() {
|
||||||
|
|
||||||
let _this = this;
|
let _ = this;
|
||||||
|
|
||||||
this.d = {
|
this.d = {
|
||||||
|
|
||||||
|
@ -58,35 +58,107 @@
|
||||||
},
|
},
|
||||||
dbhost: {
|
dbhost: {
|
||||||
|
|
||||||
conditions: $.extend( true, {}, _this.dbconditions ),
|
conditions: $.extend( true, {}, _.dbconditions ),
|
||||||
default: "localhost",
|
default: "localhost",
|
||||||
label: "Database Host: ",
|
label: "Database Host: ",
|
||||||
type: "text",
|
type: "text",
|
||||||
},
|
},
|
||||||
dbname: {
|
dbname: {
|
||||||
|
|
||||||
conditions: $.extend( true, {}, _this.dbconditions ),
|
conditions: $.extend( true, {}, _.dbconditions ),
|
||||||
default: "",
|
default: "",
|
||||||
label: "Database Name: ",
|
label: "Database Name: ",
|
||||||
type: "text",
|
type: "text",
|
||||||
},
|
},
|
||||||
dbuser: {
|
dbuser: {
|
||||||
|
|
||||||
conditions: $.extend( true, {}, _this.dbconditions ),
|
conditions: $.extend( true, {}, _.dbconditions ),
|
||||||
default: "",
|
default: "",
|
||||||
label: "Database User: ",
|
label: "Database User: ",
|
||||||
type: "text",
|
type: "text",
|
||||||
},
|
},
|
||||||
dbpass: {
|
dbpass: {
|
||||||
|
|
||||||
conditions: $.extend( true, {}, _this.dbconditions ),
|
conditions: $.extend( true, {}, _.dbconditions ),
|
||||||
default: "",
|
default: "",
|
||||||
label: "Database Password: ",
|
label: "Database Password: ",
|
||||||
type: "text",
|
type: "text",
|
||||||
},
|
},
|
||||||
dbpass1: {
|
dbpass1: {
|
||||||
|
|
||||||
conditions: $.extend( true, {}, _this.dbconditions ),
|
conditions: $.extend( true, {}, _.dbconditions ),
|
||||||
|
default: "",
|
||||||
|
label: "Repeat Password: ",
|
||||||
|
type: "text",
|
||||||
|
},
|
||||||
|
};
|
||||||
|
this.form = new codiad.forms({
|
||||||
|
data: _.d,
|
||||||
|
container: $( "#installation" ),
|
||||||
|
submit_label: "Check Data Storage Method",
|
||||||
|
});
|
||||||
|
this.form.submit = async function() {
|
||||||
|
|
||||||
|
let _this = this;
|
||||||
|
let invalid_values;
|
||||||
|
|
||||||
|
if( _this.saving ) {
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
_this.saving = true;
|
||||||
|
let data = await _this.m.get_values();
|
||||||
|
let submit = _this.v.controls.find( `[type="submit"]` );
|
||||||
|
|
||||||
|
submit.attr( "disabled", true );
|
||||||
|
submit.text( "Submitting ..." );
|
||||||
|
|
||||||
|
let response = await codiad.common.ajax( "./index.php", "POST", data );
|
||||||
|
|
||||||
|
console.log( response );
|
||||||
|
|
||||||
|
let r = JSON.parse( response );
|
||||||
|
|
||||||
|
if( r.status == "error" ) {
|
||||||
|
|
||||||
|
codiad.message.error( r.message );
|
||||||
|
$( "#data_status" ).html( "<br><br>Data Status:<br>" + r.value );
|
||||||
|
} else {
|
||||||
|
|
||||||
|
_.user_setup();
|
||||||
|
}
|
||||||
|
|
||||||
|
submit.text( _this.submit_label );
|
||||||
|
submit.attr( "disabled", false );
|
||||||
|
_this.saving = false;
|
||||||
|
}
|
||||||
|
},
|
||||||
|
user_setup: function() {
|
||||||
|
|
||||||
|
let _this = this;
|
||||||
|
|
||||||
|
this.d = {
|
||||||
|
username: {
|
||||||
|
|
||||||
|
default: "",
|
||||||
|
label: "Username: ",
|
||||||
|
type: "text",
|
||||||
|
},
|
||||||
|
email: {
|
||||||
|
|
||||||
|
default: "",
|
||||||
|
label: "Email: ",
|
||||||
|
type: "email",
|
||||||
|
},
|
||||||
|
password: {
|
||||||
|
|
||||||
|
default: "",
|
||||||
|
label: "Password: ",
|
||||||
|
type: "text",
|
||||||
|
},
|
||||||
|
password: {
|
||||||
|
|
||||||
default: "",
|
default: "",
|
||||||
label: "Repeat Password: ",
|
label: "Repeat Password: ",
|
||||||
type: "text",
|
type: "text",
|
||||||
|
@ -95,7 +167,7 @@
|
||||||
this.form = new codiad.forms({
|
this.form = new codiad.forms({
|
||||||
data: _this.d,
|
data: _this.d,
|
||||||
container: $( "#installation" ),
|
container: $( "#installation" ),
|
||||||
submit_label: "Check Data Storage Method",
|
submit_label: "Create User",
|
||||||
});
|
});
|
||||||
this.form.submit = async function() {
|
this.form.submit = async function() {
|
||||||
|
|
||||||
|
@ -130,6 +202,6 @@
|
||||||
submit.attr( "disabled", false );
|
submit.attr( "disabled", false );
|
||||||
_this.saving = false;
|
_this.saving = false;
|
||||||
}
|
}
|
||||||
}
|
},
|
||||||
};
|
};
|
||||||
})( this, jQuery );
|
})( this, jQuery );
|
Loading…
Reference in a new issue