Continued work on functions needed during install process

This commit is contained in:
xevidos 2020-07-27 13:20:12 -04:00
parent 9530cd2580
commit 74bba55567
10 changed files with 362 additions and 26 deletions

View file

@ -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;
} }
} }

View file

@ -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";

View file

@ -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() ) {

View 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" );
}
}
?>

View file

@ -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();
} }
} }

View file

@ -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 ) {}

View 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() {}
}

View 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() );
}
}
?>

View file

@ -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[".."] );

View file

@ -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 );